123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275127612771278127912801281128212831284128512861287128812891290129112921293129412951296129712981299130013011302130313041305130613071308130913101311131213131314131513161317131813191320132113221323132413251326132713281329133013311332133313341335133613371338133913401341134213431344134513461347134813491350135113521353135413551356135713581359136013611362136313641365136613671368136913701371137213731374137513761377137813791380138113821383138413851386138713881389139013911392139313941395139613971398139914001401 |
- <template>
- <div class="app-container">
- <el-form
- :rules="queryRules"
- :model="queryParams"
- ref="queryForm"
- :inline="true"
- v-show="showSearch"
- label-width="68px"
- >
- <el-row>
- <el-col :span="24">
- <el-form-item label-width="auto" prop="accessory">
- <template slot="label"> <div class="label">机组搜索:</div> </template>
- </el-form-item>
- <el-form-item
- label-width="auto"
- label="机组功率(kw)区间"
- prop="unitPowerKwMin"
- >
- <el-input
- v-model.number="queryParams.unitPowerKwMin"
- placeholder="请选择机组功率(kw)"
- clearable
- size="small"
- @keyup.enter.native="handleQuery"
- >
- </el-input>
- </el-form-item>
- <el-form-item label-width="auto" label="到" prop="unitPowerKwMax">
- <el-input
- v-model.number="queryParams.unitPowerKwMax"
- placeholder="请选择机组功率(kw)"
- clearable
- size="small"
- @keyup.enter.native="handleQuery"
- >
- </el-input>
- </el-form-item>
- <el-form-item
- label-width="auto"
- label="机组功率(kva)区间"
- prop="unitPowerKvaMin"
- >
- <el-input
- v-model.number="queryParams.unitPowerKvaMin"
- placeholder="请选择机组功率(kva)"
- clearable
- size="small"
- @keyup.enter.native="handleQuery"
- >
- </el-input>
- </el-form-item>
- <el-form-item label-width="auto" label="到" prop="unitPowerKvaMax">
- <el-input
- v-model.number="queryParams.unitPowerKvaMax"
- placeholder="请选择机组功率(kva)"
- clearable
- size="small"
- @keyup.enter.native="handleQuery"
- >
- </el-input>
- </el-form-item>
- <el-form-item label="品牌" prop="brand">
- <el-select
- v-model="queryParams.brand"
- placeholder="请选择品牌"
- clearable
- size="small"
- @keyup.enter.native="handleQuery"
- >
- <el-option
- v-for="(item, index) in searchOption[0]"
- :key="index"
- :value="item"
- :label="item"
- ></el-option>
- </el-select>
- </el-form-item>
- <el-form-item>
- <el-button
- type="cyan"
- icon="el-icon-search"
- size="mini"
- @click="handleQuery"
- >搜索</el-button
- >
- <el-button icon="el-icon-refresh" size="mini" @click="resetQuery"
- >重置</el-button
- >
- </el-form-item>
- </el-col>
- <el-col :span="24">
- <el-form-item label-width="auto" prop="accessory">
- <template slot="label"> <div class="label">零件搭配:</div> </template>
- </el-form-item>
- <el-form-item label-width="auto" label="静音/开架" prop="accessory">
- <el-select v-model="computedQuery.accessory">
- <el-option key="1" value="mutePrice" label="静音机壳"></el-option>
- <el-option key="2" value="openPrice" label="开架"></el-option>
- </el-select>
- </el-form-item>
- <el-form-item label-width="auto" label="ATS" prop="unitPowerKvaMax">
- <el-select v-model="computedQuery.isHaveAst">
- <el-option key="1" :value="true" label="有"></el-option>
- <el-option key="2" :value="false" label="无"></el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="控制器" prop="controllerPrice">
- <el-select
- v-model="computedQuery.controllerPrice"
- placeholder="请选择控制器"
- clearable
- size="small"
- >
- <el-option
- @click.native="
- () => {
- computedQuery.controllerModel = item.controllerModel;
- }
- "
- v-for="(item, index) in controllerList"
- :label="item.controllerModel"
- :value="item.controllerPrice"
- :key="index"
- ></el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="发电机品牌" prop="fadianji" label-width="120">
- <el-select v-model="computedQuery.fadianji" placeholder="请选择发电机品牌" clearable size="small">
- <el-option
- v-for="item in fadianjiOptions"
- :key="item.value"
- :label="item.label"
- :value="item.value">
- </el-option>
- </el-select>
- </el-form-item>
- </el-col>
- </el-row>
- </el-form>
- <el-row :gutter="10" class="mb8">
- <el-col :span="1.5">
- <el-button
- type="primary"
- icon="el-icon-plus"
- size="mini"
- @click="handleAdd"
- v-hasPermi="['price:info:add']"
- >新增</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-button
- type="success"
- icon="el-icon-edit"
- size="mini"
- :disabled="single"
- @click="handleUpdate"
- v-hasPermi="['price:info:edit']"
- >修改</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-button
- type="danger"
- icon="el-icon-delete"
- size="mini"
- :disabled="multiple"
- @click="handleDelete"
- v-hasPermi="['price:info:remove']"
- >删除</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-button
- type="warning"
- icon="el-icon-top"
- size="mini"
- @click="handleExport"
- v-hasPermi="['price:info:export']"
- >导出</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-upload
- v-hasPermi="['price:info:import']"
- :show-file-list="false"
- class="upload-demo"
- with-credentials
- :headers="{
- Authorization: 'Bearer ' + token,
- }"
- :action="uploadUrl+'/price/info/import'"
- :on-success="handleSuccess"
- multiple
- accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet,application/vnd.ms-excel"
- :file-list="fileList"
- >
- <el-button
- type="warning"
- icon="el-icon-bottom"
- size="mini"
- v-hasPermi="['price:info:import']"
- >导入</el-button
- >
- </el-upload>
- </el-col>
- <el-col :span="1.5">
- <el-button
- type="primary"
- icon="el-icon-right"
- :disabled="multiple"
- size="mini"
- @click="handleAddItems"
- >添加到订单</el-button>
- </el-col>
- <right-toolbar
- :showSearch.sync="showSearch"
- @queryTable="getList"
- ></right-toolbar>
- </el-row>
- <el-table
- fit
- size="mini"
- :row-style="{ height: '25px' }"
- v-loading="loading"
- :data="infoList"
- @selection-change="handleSelectionChange"
- >
- <el-table-column type="selection" width="40" align="center" />
- <el-table-column
- :key="0"
- fixed
- :width="tableColumnWidthSmall"
- label="机组型号"
- align="center"
- prop="unitModel"
- />
- <el-table-column
- :key="1"
- fixed
- :width="tableColumnWidthMini"
- label="机组功率(kw)"
- align="center"
- prop="unitPowerKw"
- />
- <el-table-column
- :key="2"
- fixed
- :width="tableColumnWidthMini"
- label="机组功率备用(kw)"
- align="center"
- prop="unitPowerKwSpare"
- />
- <el-table-column
- :key="3"
- fixed
- :width="tableColumnWidthMini"
- label="机组功率(kva)"
- align="center"
- prop="unitPowerKva"
- />
- <el-table-column
- :key="4"
- fixed
- :width="tableColumnWidthMini"
- label="机组功率备用(kva)"
- align="center"
- prop="unitPowerKvaSpare"
- />
- <el-table-column
- :key="5"
- :width="tableColumnWidthMini"
- label="频率(Hz)"
- align="center"
- prop="rate"
- />
- <el-table-column
- :key="6"
- :width="tableColumnWidthSmall"
- label="柴油机型号"
- align="center"
- prop="dieselEngineModel"
- />
- <el-table-column
- :key="7"
- :width="'100px'"
- label="品牌"
- align="center"
- prop="brand"
- />
- <el-table-column
- :key="8"
- :width="tableColumnWidthMini"
- label="转速"
- align="center"
- prop="speed"
- />
- <el-table-column
- :key="9"
- :width="tableColumnWidthMini"
- v-hasPermi="['price:info:list:powerPrice']"
- v-if="checkPermissions(['price:info:list:powerPrice'])"
- label="动力价格"
- align="center"
- prop="powerPrice"
- />
- <el-table-column
- :key="10"
- :width="tableColumnWidthSmall"
- label="发电机型号(仿斯坦福)"
- align="center"
- v-if="computedQuery.fadianji==0"
- prop="generatorModelFstf"
- />
- <el-table-column
- :key="11"
- :width="tableColumnWidthMini"
- label="发电机价格(仿斯坦福)"
- v-if="checkPermissions(['price:info:list:generatorPrice'])&&computedQuery.fadianji==0"
- v-hasPermi="['price:info:list:generatorPrice']"
- align="center"
- prop="generatorPriceFstf"
- />
- <el-table-column
- :key="12"
- :width="tableColumnWidthSmall"
- v-if="computedQuery.fadianji==1"
- label="发电机型号(利来森马)"
- align="center"
- prop="generatorModelLlsm"
- />
- <el-table-column
- :key="13"
- :width="tableColumnWidthMini"
- label="发电机价格(利来森马)"
- v-if="checkPermissions(['price:info:list:generatorPrice'])&&computedQuery.fadianji==1"
- v-hasPermi="['price:info:list:generatorPrice']"
- align="center"
- prop="generatorPriceLlsm"
- />
- <el-table-column
- :key="14"
- :width="tableColumnWidthSmall"
- v-if="computedQuery.fadianji==2"
- label="发电机型号(美迪奥)"
- align="center"
- prop="generatorModelMda"
- />
- <el-table-column
- :key="15"
- :width="tableColumnWidthMini"
- label="发电机价格(美迪奥)"
- v-if="checkPermissions(['price:info:list:generatorPrice'])&&computedQuery.fadianji==2"
- v-hasPermi="['price:info:list:generatorPrice']"
- align="center"
- prop="generatorPriceMda"
- />
- <el-table-column
- :key="16"
- :width="tableColumnWidthSmall"
- v-if="computedQuery.fadianji==3"
- label="发电机型号(马拉松)"
- align="center"
- prop="generatorModelMls"
- />
- <el-table-column
- :key="17"
- :width="tableColumnWidthMini"
- label="发电机价格(马拉松)"
- v-if="checkPermissions(['price:info:list:generatorPrice'])&&computedQuery.fadianji==3"
- v-hasPermi="['price:info:list:generatorPrice']"
- align="center"
- prop="generatorPriceMls"
- />
- <el-table-column
- :key="18"
- :width="tableColumnWidthSmall"
- v-if="computedQuery.fadianji==4"
- label="发电机型号(斯坦福)"
- align="center"
- prop="generatorModelStf"
- />
- <el-table-column
- :key="19"
- :width="tableColumnWidthMini"
- label="发电机价格(斯坦福)"
- v-if="checkPermissions(['price:info:list:generatorPrice'])&&computedQuery.fadianji==4"
- v-hasPermi="['price:info:list:generatorPrice']"
- align="center"
- prop="generatorPriceStf"
- />
- <el-table-column
- :key="21"
- :width="tableColumnWidthMini"
- label="静音/开架"
- align="center"
- v-hasPermi="['price:info:list:mutePrice']"
- prop="mutePrice"
- ><template slot-scope="scope">
- <span>{{ computedQuery.accessory =="mutePrice"? "静音机壳":"开架" }}</span>
- </template>
- </el-table-column>
- <el-table-column
- :key="22"
- :width="tableColumnWidthMini"
- v-if="
- computedQuery.accessory == 'mutePrice' &&
- checkPermissions(['price:info:list:mutePrice'])
- "
- label="静音机壳价格"
- align="center"
- v-hasPermi="['price:info:list:mutePrice']"
- prop="mutePrice"
- />
- <el-table-column
- :key="23"
- :width="tableColumnWidthMini"
- v-if="
- computedQuery.accessory == 'openPrice' &&
- checkPermissions(['price:info:list:openPrice'])
- "
- label="开架价格"
- align="center"
- v-hasPermi="['price:info:list:openPrice']"
- prop="openPrice"
- />
- <el-table-column
- :key="24"
- :width="tableColumnWidthMini"
- v-if="computedQuery.isHaveAst"
- label="ATS型号"
- align="center"
- prop="atsModel"
- />
- <el-table-column
- :key="25"
- :width="tableColumnWidthMini"
- v-if="
- computedQuery.isHaveAst &&
- checkPermissions(['price:info:list:astPrice'])
- "
- v-hasPermi="['price:info:list:astPrice']"
- label="ATS价格"
- align="center"
- prop="atsPrice"
- />
- <el-table-column
- :key="26"
- :width="tableColumnWidthMini"
- label="电瓶型号"
- align="center"
- prop="batteryModel"
- />
- <el-table-column
- :key="27"
- :width="tableColumnWidthMini"
- label="电瓶价格"
- v-hasPermi="['price:info:list:batteryPrice']"
- v-if="checkPermissions(['price:info:list:batteryPrice'])"
- align="center"
- prop="batteryPrice"
- />
- <el-table-column
- :key="28"
- :width="tableColumnWidthMini"
- label="控制器型号"
- align="center"
- prop="controllerModel"
- >
- <template>
- {{ computedQuery.controllerModel }}
- </template>
- </el-table-column>
- <el-table-column
- :key="29"
- :width="tableColumnWidthMini"
- v-hasPermi="['price:info:list:controllerPrice']"
- v-if="checkPermissions(['price:info:list:controllerPrice'])"
- label="控制器价格"
- align="center"
- prop="controllerPrice"
- >
- <template>
- {{ computedQuery.controllerPrice }}
- </template>
- </el-table-column>
- <el-table-column
- :key="30"
- v-if="computedQuery.fadianji==0"
- class-name="bg-lightpink"
- :width="tableColumnWidthMini"
- label="合计含税成本(仿斯坦福)"
- align="center"
- prop="totalCostMuteFstf"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.generatorPriceFstf">
- {{ computedTotalPrice(scope.row, scope.row.generatorPriceFstf) }}
- </span>
- </template>
- </el-table-column>
- <el-table-column
- :key="31"
- v-if="computedQuery.fadianji==1"
- class-name="bg-lightblue"
- :width="tableColumnWidthMini"
- label="合计含税成本(利来森马)"
- align="center"
- prop="totalCostMuteLlsm"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.generatorPriceLlsm"> {{ computedTotalPrice(scope.row, scope.row.generatorPriceLlsm) }}</span>
- </template>
- </el-table-column>
- <el-table-column
- :key="32"
- v-if="computedQuery.fadianji==2"
- class-name="bg-lightcyan"
- :width="tableColumnWidthMini"
- label="合计含税成本(美迪奥)"
- align="center"
- prop="totalCostMuteMda"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.generatorPriceMda"> {{ computedTotalPrice(scope.row, scope.row.generatorPriceMda) }}</span>
- </template>
- </el-table-column>
- <el-table-column
- :key="33"
- v-if="computedQuery.fadianji==3"
- class-name="bg-lightskyblue"
- :width="tableColumnWidthMini"
- label="合计含税成本(马拉松)"
- align="center"
- prop="totalCostMuteMls"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.generatorPriceMls">{{ computedTotalPrice(scope.row, scope.row.generatorPriceMls) }}</span>
- </template>
- </el-table-column>
- <el-table-column
- :key="34"
- v-if="computedQuery.fadianji==4"
- class-name="bg-lightgoldenrodyellow"
- :width="tableColumnWidthMini"
- label="合计含税成本(斯坦福)"
- align="center"
- prop="totalCostMuteStf"
- >
- <template slot-scope="scope">
- <span v-if="scope.row.generatorPriceStf">{{ computedTotalPrice(scope.row, scope.row.generatorPriceStf) }}</span>
- </template>
- </el-table-column>
- <el-table-column
- :key="35"
- width="100px"
- v-if="computedQuery.accessory == 'openPrice'"
- label="开架尺寸(长/宽/高/重量)"
- align="center"
- prop="openParms"
- />
- <el-table-column
- :key="36"
- :width="'100px'"
- v-if="computedQuery.accessory == 'mutePrice'"
- label="静音尺寸(长/宽/高/重量)"
- align="center"
- prop="muteParms"
- />
- <el-table-column
- :key="37"
- :width="tableColumnWidthMini"
- width="180px"
- label="操作"
- align="center"
- class-name="small-padding fixed-width"
- >
- <template slot-scope="scope">
- <div style="display: inline-flex">
- <el-button
- size="mini"
- type="text"
- icon="el-icon-edit"
- @click="handleUpdate(scope.row)"
- v-hasPermi="['price:info:edit']"
- >修改</el-button
- >
- <el-button
- @click="
- () => {
- $router.push('/gallery?id=' + scope.row.id + '&type=1');
- }
- "
- size="mini"
- type="text"
- icon="el-icon-picture-outline"
- >图片</el-button
- >
- <el-button
- size="mini"
- type="text"
- icon="el-icon-delete"
- @click="handleDelete(scope.row)"
- v-hasPermi="['price:info:remove']"
- >删除</el-button
- >
- </div>
- </template>
- </el-table-column>
- </el-table>
- <pagination
- v-show="total > 0"
- :total="total"
- :page.sync="queryParams.pageNum"
- :limit.sync="queryParams.pageSize"
- @pagination="getList"
- />
- <div v-if="itemList.length>0">
- <p align="center">订单详情</p>
- <el-row :gutter="10" class="mb8">
- <el-col :span="1.5">
- <el-button
- type="danger"
- icon="el-icon-delete"
- size="mini"
- :disabled="itemMultiple"
- @click="handleItemDelete"
- >删除</el-button
- >
- </el-col>
- <el-col :span="1.5">
- <el-button
- type="primary"
- icon="el-icon-right"
- :disabled="multiple"
- size="mini"
- @click="createOrder"
- >生成订单</el-button>
- </el-col>
- </el-row>
- <el-table
- fit
- size="mini"
- :row-style="{ height: '25px' }"
- v-loading="loading"
- :data="itemList"
- @selection-change="handleItemSelectionChange"
- >
- <!--<el-table-column type="selection" width="55" align="center" />-->
- <!--<el-table-column label="生产单号" align="center" prop="orderNo" />-->
- <el-table-column type="selection" width="40" align="center" />
- <el-table-column label="机组型号" align="center" prop="unitModel" />
- <el-table-column label="频率(Hz)" align="center" prop="rate" />
- <el-table-column label="电压(V)" align="center" prop="voltage" />
- <el-table-column label="机组功率(kw)" align="center" prop="unitPowerKw" />
- <el-table-column label="机组功率(kva)" align="center" prop="unitPowerKva" />
- <el-table-column label="机组备用功率(kw)" align="center" prop="unitPowerKwSpare" />
- <el-table-column label="机组备用功率(kva)" align="center" prop="unitPowerKvaSpare" />
- <el-table-column label="柴油机型号" align="center" prop="dieselEngineModel" />
- <el-table-column label="发电机型号" align="center" prop="fjd" />
- <el-table-column label="控制器型号" align="center" prop="controllerModel" />
- <el-table-column label="水套加热器" align="center" prop="heater" />
- <el-table-column label="ATS" align="center" prop="ats" />
- <el-table-column label="断路器" align="center" prop="breaker" />
- <el-table-column label="电瓶" align="center" prop="battery" />
- <el-table-column label="静音/开架" align="center" prop="muteOrOpen" />
- <el-table-column label="机壳颜色" align="center" prop="color" />
- <el-table-column label="数量" align="center" prop="number" />
- <el-table-column label="零售价" align="center" prop="priceRetail" />
- <!--<el-table-column label="采购价" align="center" prop="pricePurchase" />-->
- </el-table>
- </div>
- <!-- 添加或修改报价对话框 -->
- <el-dialog :title="title" :visible.sync="open" width="500px" append-to-body>
- <el-form ref="form" :model="form" :rules="rules" label-width="80px">
- <el-form-item label="品牌" prop="brand">
- <el-select
- v-model="form.brand"
- placeholder="请选择品牌"
- clearable
- size="small"
- @keyup.enter.native="handleQuery"
- >
- <el-option
- v-for="(item, index) in searchOption[0]"
- :value="item"
- :key="index"
- :label="item"
- ></el-option>
- </el-select>
- </el-form-item>
- <el-form-item label="机组功率(kw)" prop="unitPowerKw">
- <el-input
- v-model="form.unitPowerKw"
- placeholder="请输入机组功率(kw)"
- />
- </el-form-item>
- <el-form-item label="机组功率(kva)" prop="unitPowerKva">
- <el-input
- v-model="form.unitPowerKva"
- placeholder="请输入机组功率(kva)"
- />
- </el-form-item>
- <el-form-item label="频率(Hz)" prop="rate">
- <el-input v-model="form.rate" placeholder="请输入频率(Hz)" />
- </el-form-item>
- <el-form-item label="动力品牌" prop="brand">
- <el-input v-model="form.brand" placeholder="请输入动力品牌" />
- </el-form-item>
- <el-form-item label="柴油机型号" prop="dieselEngineModel">
- <el-input
- v-model="form.dieselEngineModel"
- placeholder="请输入柴油机型号"
- />
- </el-form-item>
- <el-form-item label="转速" prop="speed">
- <el-input v-model="form.speed" placeholder="请输入转速" />
- </el-form-item>
- <el-form-item label="动力价格" prop="powerPrice">
- <el-input v-model="form.powerPrice" placeholder="请输入动力价格" />
- </el-form-item>
- <el-form-item label="发电机型号(仿斯坦福)" prop="generatorModelFstf">
- <el-input
- v-model="form.generatorModelFstf"
- placeholder="请输入发电机型号(仿斯坦福)"
- />
- </el-form-item>
- <el-form-item label="发电机价格(仿斯坦福)" prop="generatorPriceFstf">
- <el-input
- v-model="form.generatorPriceFstf"
- placeholder="请输入发电机价格(仿斯坦福)"
- />
- </el-form-item>
- <el-form-item label="发电机型号(斯坦福)" prop="generatorModelStf">
- <el-input
- v-model="form.generatorModelStf"
- placeholder="请输入发电机型号(斯坦福)"
- />
- </el-form-item>
- <el-form-item label="发电机价格(斯坦福)" prop="generatorPriceStf">
- <el-input
- v-model="form.generatorPriceStf"
- placeholder="请输入发电机价格(斯坦福)"
- />
- </el-form-item>
- <el-form-item label="发电机型号(利来森马)" prop="generatorModelLlsm">
- <el-input
- v-model="form.generatorModelLlsm"
- placeholder="请输入发电机型号(利来森马)"
- />
- </el-form-item>
- <el-form-item label="发电机价格(利来森马)" prop="generatorPriceLlsm">
- <el-input
- v-model="form.generatorPriceLlsm"
- placeholder="请输入发电机价格(利来森马)"
- />
- </el-form-item>
- <el-form-item label="发电机型号(马拉松)" prop="generatorModelMls">
- <el-input
- v-model="form.generatorModelMls"
- placeholder="请输入发电机型号(马拉松)"
- />
- </el-form-item>
- <el-form-item label="发电机价格(马拉松)" prop="generatorPriceMls">
- <el-input
- v-model="form.generatorPriceMls"
- placeholder="请输入发电机价格(马拉松)"
- />
- </el-form-item>
- <el-form-item label="发电机型号(美迪奥)" prop="generatorModelMda">
- <el-input
- v-model="form.generatorModelMda"
- placeholder="请输入发电机型号(美迪奥)"
- />
- </el-form-item>
- <el-form-item label="发电机价格(美迪奥)" prop="generatorPriceMda">
- <el-input
- v-model="form.generatorPriceMda"
- placeholder="请输入发电机价格(美迪奥)"
- />
- </el-form-item>
- <el-form-item label="静音机壳价格" prop="mutePrice">
- <el-input v-model="form.mutePrice" placeholder="请输入静音机壳价格" />
- </el-form-item>
- <el-form-item label="开架价格" prop="openPrice">
- <el-input v-model="form.openPrice" placeholder="请输入开架价格" />
- </el-form-item>
- <el-form-item label="ATS型号" prop="atsModel">
- <el-input v-model="form.atsModel" placeholder="请输入ATS型号" />
- </el-form-item>
- <el-form-item label="ATS价格" prop="atsPrice">
- <el-input v-model="form.atsPrice" placeholder="请输入ATS价格" />
- </el-form-item>
- <el-form-item label="电瓶型号" prop="batteryModel">
- <el-input v-model="form.batteryModel" placeholder="请输入电瓶型号" />
- </el-form-item>
- <el-form-item label="电瓶价格" prop="batteryPrice">
- <el-input v-model="form.batteryPrice" placeholder="请输入电瓶价格" />
- </el-form-item>
- <el-form-item
- label="合计含税成本(静音配仿斯坦福)"
- prop="totalCostMuteFstf"
- >
- <el-input
- v-model="form.totalCostMuteFstf"
- placeholder="请输入合计含税成本(静音配仿斯坦福)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(开架配仿斯坦福)"
- prop="totalCostOpenFstf"
- >
- <el-input
- v-model="form.totalCostOpenFstf"
- placeholder="请输入合计含税成本(开架配仿斯坦福)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(静音配斯坦福)"
- prop="totalCostMuteStf"
- >
- <el-input
- v-model="form.totalCostMuteStf"
- placeholder="请输入合计含税成本(静音配斯坦福)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(开架配斯坦福)"
- prop="totalCostOpenStf"
- >
- <el-input
- v-model="form.totalCostOpenStf"
- placeholder="请输入合计含税成本(开架配斯坦福)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(静音配利来森马)"
- prop="totalCostMuteLlsm"
- >
- <el-input
- v-model="form.totalCostMuteLlsm"
- placeholder="请输入合计含税成本(静音配利来森马)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(开架配利来森马)"
- prop="totalCostOpenLlsm"
- >
- <el-input
- v-model="form.totalCostOpenLlsm"
- placeholder="请输入合计含税成本(开架配利来森马)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(静音配马拉松)"
- prop="totalCostMuteMls"
- >
- <el-input
- v-model="form.totalCostMuteMls"
- placeholder="请输入合计含税成本(静音配马拉松)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(开架配马拉松)"
- prop="totalCostOpenMls"
- >
- <el-input
- v-model="form.totalCostOpenMls"
- placeholder="请输入合计含税成本(开架配马拉松)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(静音配美迪奥)"
- prop="totalCostMuteMda"
- >
- <el-input
- v-model="form.totalCostMuteMda"
- placeholder="请输入合计含税成本(静音配美迪奥)"
- />
- </el-form-item>
- <el-form-item
- label="合计含税成本(开架配美迪奥)"
- prop="totalCostOpenMda"
- >
- <el-input
- v-model="form.totalCostOpenMda"
- placeholder="请输入合计含税成本(开架配美迪奥)"
- />
- </el-form-item>
- <el-form-item label="静音尺寸" prop="muteParms">
- <el-input v-model="form.muteParms" placeholder="请输入静音尺寸" />
- </el-form-item>
- <el-form-item label="静音尺寸" prop="openParms">
- <el-input v-model="form.openParms" placeholder="请输入静音尺寸" />
- </el-form-item>
- </el-form>
- <div slot="footer" class="dialog-footer">
- <el-button type="primary" @click="submitForm">确 定</el-button>
- <el-button @click="cancel">取 消</el-button>
- </div>
- </el-dialog>
- </div>
- </template>
- <script>
- import {
- listInfo,
- getInfo,
- delInfo,
- addInfo,
- updateInfo,
- exportInfo,
- getFieldName,
- } from "@/api/price/managehz50";
- import { listInfo as controllerListInfo } from "@/api/price/controller";
- import { addInfo as addOrderInfo} from "@/api/order/info";
- import { getToken } from "@/utils/auth";
- import { mapGetters } from "vuex";
- let computedQuery = {
- accessory: "mutePrice",
- isHaveAst: true,
- controllerPrice: null,
- controllerModel: null,
- fadianji:0
- };
- const controllerPriceValidator = (rule, value, callBack) => {
- console.log(computedQuery.controllerPrice && computedQuery.controllerModel);
- if (computedQuery.controllerPrice && computedQuery.controllerModel) {
- callBack();
- } else {
- callBack(new Error("必须选择一个控制器"));
- }
- };
- export default {
- name: "Info",
- data() {
- return {
- jishuqi:0,
- fadianjiOptions:[{
- value: 0,
- label: '仿斯坦福'
- }, {
- value: 1,
- label: '利来森马'
- }, {
- value: 2,
- label: '美迪奥'
- }, {
- value: 3,
- label: '马拉松'
- }, {
- value: 4,
- label: '斯坦福'
- }],
- controllerModel: "",
- controllerPrice: 0,
- token: getToken(), uploadUrl:process.env.VUE_APP_BASE_API,
- fileList: [],
- //搜索下拉选项
- searchOption: [[], [], [], []],
- // 遮罩层
- loading: false,
- // 选中数组
- ids: [],
- // 选中数组
- itemids: [],
- // 非单个禁用
- single: true,
- // 非多个禁用
- multiple: true,
- itemMultiple: true,
- // 显示搜索条件
- showSearch: true,
- // 总条数
- total: 0,
- // 报价表格数据
- infoList: [],
- // 订单详情数据
- itemList: [],
- // 控制器列表
- controllerList: [],
- // 弹出层标题
- title: "",
- // 是否显示弹出层
- open: false,
- //查询参数规则
- queryRules: {
- controllerPrice: [
- {
- validator: controllerPriceValidator,
- trigger: "change",
- type: "number",
- },
- ],
- unitPowerKwMin: [
- {
- required: false,
- message: "请输入数字",
- trigger: "change",
- type: "number",
- },
- ],
- unitPowerKwMax: [
- {
- required: false,
- message: "请输入数字",
- trigger: "change",
- type: "number",
- },
- ],
- unitPowerKvaMax: [
- {
- required: false,
- message: "请输入数字",
- trigger: "change",
- type: "number",
- },
- ],
- unitPowerKvaMin: [
- {
- required: false,
- message: "请输入数字",
- trigger: "change",
- type: "number",
- },
- ],
- },
- //计算参数
- computedQuery: computedQuery,
- // 查询参数
- queryParams: {
- pageNum: 1,
- pageSize: 10,
- brand: null,
- unitModel: null,
- unitPowerKwMax: null,
- unitPowerKwMin: null,
- controllerPrice: 0,
- controllerModel: "",
- unitPowerKvaMax: null,
- unitPowerKvaMin: null,
- rate: null,
- dieselEngineModel: null,
- speed: null,
- powerPrice: null,
- generatorModel: null,
- generatorPrice: null,
- mutePrice: null,
- openPrice: null,
- atsModel: null,
- atsPrice: null,
- batteryModel: null,
- batteryPrice: null,
- controllerMinbei: null,
- controllerPrice: null,
- totalCostMute: null,
- totalCostOpen: null,
- muteLong: null,
- muteWidth: null,
- muteHigh: null,
- openLong: null,
- openWidth: null,
- openHigh: null,
- ckdLong: null,
- ckdWidth: null,
- ckdHigh: null,
- },
- // 表单参数
- form: {},
- // 表单校验
- rules: {},
- };
- },
- computed: {
- ...mapGetters([
- "permissions",
- "roles",
- "tableColumnWidth",
- "tableColumnWidthSamll",
- "tableColumnWidthMini",
- ]),
- },
- created() {
- this.getControllerList();
- this.getList();
- this.getSearchOption();
- },
- methods: {
- //检查用户是否可以看
- checkPermissions(permissions) {
- let res = false;
- //管理员权限完整
- if (this.roles.includes("admin")) {
- return true;
- } else {
- if (Array.isArray(permissions)) {
- res = permissions.every((item) => {
- return this.permissions.includes(item);
- });
- } else {
- res = this.permissions.includes(permissions);
- }
- return res;
- }
- },
- computedTotalPrice(row, alternatorPrice) {
- let totalPrice =
- row.powerPrice +
- alternatorPrice +
- row[computedQuery.accessory] +
- computedQuery.controllerPrice +
- (computedQuery.isHaveAst ? row.atsPrice : 0) +
- row.batteryPrice;
- totalPrice = Math.round(totalPrice);
- return totalPrice;
- },
- getControllerList() {
- controllerListInfo().then((response) => {
- this.controllerList = response.rows;
- this.computedQuery.controllerModel = response.rows[0].controllerModel;
- this.computedQuery.controllerPrice = response.rows[0].controllerPrice;
- });
- },
- handleSuccess() {
- this.msgSuccess("上传成功");
- this.getSearchOption();
- this.getList()
- },
- push(url) {
- this.router.push(url);
- },
- getSearchOption() {
- getFieldName("brand").then((response) => {
- this.$set(this.searchOption, 0, response.data);
- });
- getFieldName("unit_power_kw").then((response) => {
- this.$set(this.searchOption, 1, response.data);
- });
- getFieldName("unit_power_kva").then((response) => {
- this.$set(this.searchOption, 2, response.data);
- });
- // getFieldName('rate').then(response => {
- // this.$set(this.searchOption, 3, response.data);
- // })
- },
- /** 查询报价列表 */
- getList() {
- this.loading = true;
- listInfo(this.queryParams).then((response) => {
- this.infoList = response.rows;
- this.total = response.total;
- this.loading = false;
- });
- },
- // 取消按钮
- cancel() {
- this.open = false;
- this.reset();
- },
- // 表单重置
- reset() {
- this.form = {
- id: null,
- brand: null,
- unitModel: null,
- unitPowerKw: null,
- unitPowerKva: null,
- rate: null,
- dieselEngineModel: null,
- speed: null,
- powerPrice: null,
- generatorModel: null,
- generatorPrice: null,
- mutePrice: null,
- openPrice: null,
- atsModel: null,
- atsPrice: null,
- batteryModel: null,
- batteryPrice: null,
- controllerMinbei: null,
- controllerPrice: null,
- totalCostMute: null,
- totalCostOpen: null,
- muteLong: null,
- muteWidth: null,
- muteHigh: null,
- openLong: null,
- openWidth: null,
- openHigh: null,
- ckdLong: null,
- ckdWidth: null,
- ckdHigh: null,
- createTime: null,
- updateTime: null,
- };
- this.resetForm("form");
- },
- createOrder(){
- addOrderInfo(this.itemList).then((response) => {
- this.msgSuccess("订单创建成功,请到订单管理查看");
- this.itemList=[];
- });
- },
- /** 搜索按钮操作 */
- handleQuery() {
- this.$refs["queryForm"].validate((valid) => {
- if (valid) {
- this.controllerModel = this.queryParams.controllerModel || "";
- this.controllerPrice = this.queryParams.controllerPrice || 0;
- this.queryParams.pageNum = 1;
- this.getList();
- } else {
- return false;
- }
- });
- },
- /** 重置按钮操作 */
- resetQuery() {
- this.controllerPrice = 0;
- this.controllerModel = "";
- this.resetForm("queryForm");
- this.handleQuery();
- },
- // 多选框选中数据
- handleSelectionChange(selection) {
- this.ids = selection.map((item) => item.id);
- this.single = selection.length !== 1;
- this.multiple = !selection.length;
- },
- handleItemSelectionChange(selection) {
- this.itemids = selection.map((item) => item.itemId);
- this.itemMultiple = !selection.length;
- },
- /** 新增按钮操作 */
- handleAdd() {
- this.reset();
- this.open = true;
- this.title = "添加报价";
- },
- /** 修改按钮操作 */
- handleUpdate(row) {
- this.reset();
- const id = row.id || this.ids;
- getInfo(id).then((response) => {
- this.form = response.data;
- this.open = true;
- this.title = "修改报价";
- });
- },
- /** 提交按钮 */
- submitForm() {
- this.$refs["form"].validate((valid) => {
- if (valid) {
- if (this.form.id != null) {
- updateInfo(this.form).then((response) => {
- this.msgSuccess("修改成功");
- this.open = false;
- this.getList();
- });
- } else {
- addInfo(this.form).then((response) => {
- this.msgSuccess("新增成功");
- this.open = false;
- this.getList();
- });
- }
- }
- });
- },
- handleAddItems(){
- const ids = this.ids;
- for(var i = 0 ; i< ids.length;i++){
- var itemid = ids[i];
- var infoList = this.infoList;
- // console.log(infoList);
- for(var j =0;j <infoList.length;j++){
- var info = infoList[j];
- if (itemid == info.id){
- this.addItem(info,this.itemList);
- }
- }
- }
- },
- addItem(info,list){
- var item ={};
- console.log(info.unitModel);
- item.unitModel= info.unitModel;
- item.rate= info.rate;
- item.unitPowerKw= info.unitPowerKw;
- item.unitPowerKva= info.unitPowerKva;
- item.unitPowerKwSpare= info.unitPowerKwSpare;
- item.unitPowerKvaSpare= info.unitPowerKvaSpare;
- item.dieselEngineModel= info.dieselEngineModel;
- item.number= 1;
- item.ats= computedQuery.isHaveAst?info.atsModel:"无";
- item.muteOrOpen= computedQuery.accessory=='mutePrice'?"静音机壳":"开架";
- item.controllerModel= computedQuery.controllerModel;
- if (computedQuery.fadianji ==0){
- item.fjd= info.generatorModelFstf;
- }else if (computedQuery.fadianji ==1){
- item.fjd= info.generatorModelLlsm;
- }else if(computedQuery.fadianji ==2){
- item.fjd= info.generatorModelMda;
- }else if(computedQuery.fadianji ==3){
- item.fjd= info.generatorModelMls;
- }else if(computedQuery.fadianji ==4){
- item.fjd= info.generatorModelStf;
- }
- item.unitModel= info.unitModel;
- item.itemId = this.jishuqi++;
- list.push(item);
- },
- handleItemDelete(row){
- },
- /** 删除按钮操作 */
- handleDelete() {
- },
- /** 导出按钮操作 */
- handleExport() {
- const queryParams = this.queryParams;
- this.$confirm("是否确认导出所有报价数据项?", "警告", {
- confirmButtonText: "确定",
- cancelButtonText: "取消",
- type: "warning",
- })
- .then(function () {
- return exportInfo(queryParams);
- })
- .then((response) => {
- this.download(response.data);
- });
- },
- },
- };
- </script>
- <style lang="scss">
- .bg-lightpink {
- background: lightpink;
- }
- .bg-lightblue {
- background: lightblue;
- }
- .bg-lightcyan {
- background: lightcyan;
- }
- .bg-lightskyblue {
- background: lightskyblue;
- }
- .bg-lightgoldenrodyellow {
- background: lightgoldenrodyellow;
- }
- .label{
- color: red
- }
- </style>
|