Merge branch 'dev' of http://114.132.189.42:9002/r/lims-ruoyi-before into dev
| | |
| | | // åæææ¥æ£é¡µé¢ç¸å
³æ¥å£ |
| | | import request from '@/utils/request' |
| | | |
| | | // æ¥è¯¢IFS订å-å¾
æ¥æ£ |
¶Ô±ÈÐÂÎļþ |
| | |
| | | // åææä¸å页é¢ç¸å
³æ¥å£ |
| | | import request from '@/utils/request' |
| | | |
| | | // æ¥è¯¢åææä¸å-å¾
ä¸å |
| | | export function getPurchaseOrder(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/getPurchaseOrder', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ¥è¯¢IFS订å-å¾
æ£éª |
| | | export function getIfsByStateOne(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/getIfsByStateOne', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ¥è¯¢åææä¸å-å·²æ£éª |
| | | export function getIfsByOver(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/getIfsByOver', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ¥è¯¢åææä¸å-å
¨é¨ |
| | | export function getIfsByAll(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/getIfsByAll', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ¥è¯¢å£åº¦æ£éª |
| | | export function getIfsByQuarter(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/getIfsByQuarter', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // è·åå½åç»å½ç客æ·ä¿¡æ¯ |
| | | export function getUserNow(query) { |
| | | return request({ |
| | | url: '/user/getUserNow', |
| | | method: 'get', |
| | | }) |
| | | } |
| | | // è·åæ åæ ä¸æ åæ¹æ³æä¸¾ |
| | | export function selectStandardMethodEnum(query) { |
| | | return request({ |
| | | url: '/standardTree/selectStandardMethodEnum', |
| | | method: 'get', |
| | | }) |
| | | } |
| | | // æ¥è¯¢æ£éªä¸åå
容详æ
|
| | | export function getInsOrder(query) { |
| | | return request({ |
| | | url: '/insOrder/getInsOrder', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // åææä¸åç´æ¥å
æ£å
æ£æ¥å£ |
| | | export function notificationRawOrder(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/notificationRawOrder', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ¥è¯¢ |
| | | export function selectStandardTreeListByPartNo(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/selectStandardTreeListByPartNo', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // å é¤åæææ¨¡æ¿ |
| | | export function delRawMaterOrderTemplate(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/delRawMaterOrderTemplate', |
| | | method: 'delete', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ ¹æ®idæ¥è¯¢æ¨¡æ¿å
容 |
| | | export function selectRawMaterOrderTemplateById(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/selectRawMaterOrderTemplateById', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // åæææ°å¢æ¨¡æ¿ |
| | | export function addRawMaterOrderTemplate(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/addRawMaterOrderTemplate', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | // å
æ£ |
| | | export function addExemptionOrder(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/addExemptionOrder', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | // éè¿æ åæ æ¥è¯¢å¯¹åºçæ£éªé¡¹ç® |
| | | export function selectStandardProductList(query) { |
| | | return request({ |
| | | url: '/standardTree/selectStandardProductList', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | // æ ¹æ®æ åæ è¿è¡æ åæ¥è¯¢ |
| | | export function selectsStandardMethodByFLSSM(query) { |
| | | return request({ |
| | | url: '/standardTree/selectsStandardMethodByFLSSM', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | | // æ·»å æ£éªä¸åæ°æ® |
| | | export function addInsOrder(query) { |
| | | return request({ |
| | | url: '/insOrder/addInsOrder', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | // éåä¸ä¸å |
| | | export function addRawCopperOrder(query) { |
| | | return request({ |
| | | url: '/insOrder/addRawCopperOrder', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | // éåä¸ä¸åè¿åæ£éªå
æ£æ¥å£ |
| | | export function addRawCopperOrderExemptionOrder(query) { |
| | | return request({ |
| | | url: '/rawMaterialOrder/addRawCopperOrderExemptionOrder', |
| | | method: 'post', |
| | | data: query |
| | | }) |
| | | } |
| | | // éåä¸ä¸åè¿åæ£éªå
æ£æ¥å£ |
| | | export function selectStandardTreeList2() { |
| | | return request({ |
| | | url: '/standardTree/selectStandardTreeList2', |
| | | method: 'get' |
| | | }) |
| | | } |
| | | // éåä¸ä¸åè¿åæ£éªå
æ£æ¥å£ |
| | | export function selectInsOrderTemplate(query) { |
| | | return request({ |
| | | url: '/insOrder/selectInsOrderTemplate', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | |
| | | export function delItemParameter(query) { |
| | | return request({ |
| | | url: '/capacityScope/delItemParameter', |
| | | method: 'post', |
| | | method: 'get', |
| | | params: query |
| | | }) |
| | | } |
| | |
| | | export function delTestObject(query) { |
| | | return request({ |
| | | url: '/capacityScope/delTestObject', |
| | | method: 'post', |
| | | method: 'delete', |
| | | params: query |
| | | }) |
| | | } |
| | |
| | | export function delProduct(query) { |
| | | return request({ |
| | | url: '/capacityScope/delProduct', |
| | | method: 'post', |
| | | method: 'delete', |
| | | params: query |
| | | }) |
| | | } |
| | |
| | | data: query |
| | | }) |
| | | } |
| | | // ä¿®æ¹äº§ååå®¶å¯åº¦ç»å® |
| | | // å é¤äº§ååå®¶å¯åº¦ç»å® |
| | | export function deleteProductSupplierDensity(query) { |
| | | return request({ |
| | | url: '/productSupplierDensity/deleteProductSupplierDensity', |
| | | method: 'post', |
| | | method: 'delete', |
| | | params: query |
| | | }) |
| | | } |
¶Ô±ÈÐÂÎļþ |
| | |
| | | <!--éåä¸ä¸å--> |
| | | <template> |
| | | <div class="app-container"> |
| | | <div class="header"> |
| | | <div> |
| | | <span>éåä¸ä¸å</span> |
| | | </div> |
| | | <div> |
| | | <el-button v-show="active==1 && addObj.orderType === 'è¿åæ£éª'" :loading="noNeedCheckLoad" size="small" type="primary" @click="noNeedCheck">å
æ£</el-button> |
| | | <el-button v-show="active==1" :loading="saveLoad" size="small" type="primary" @click="save">æäº¤</el-button> |
| | | <el-button size="small" @click="goBack"> |
| | | <span style="color: #3A7BFA;">è¿å</span> |
| | | </el-button> |
| | | </div> |
| | | </div> |
| | | <div class="container"> |
| | | <div class="search"> |
| | | <el-form ref="addObj" :inline="true" :model="addObj" :rules="addObjRules" label-width="90px"> |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="æ ·ååç§°:" prop="sample"> |
| | | <el-input v-model="addObj.sample" readonly size="small" style="width: 208px"> |
| | | <template slot="append"><el-button slot="append" :disabled="active>1" icon="el-icon-search" |
| | | @click="selectStandardTree = true"></el-button></template> |
| | | </el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="å°è´§æ°é:" prop="qtyArrived" required> |
| | | <el-input v-model="addObj.qtyArrived" :disabled="active > 1" class="addObj-info" |
| | | clearable placeholder="" size="small"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="åä½:" prop="buyUnitMeas"> |
| | | <el-input v-model="addObj.buyUnitMeas" :disabled="active > 1" clearable class="addObj-info" size="small"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="æ¹æ¬¡å·:" prop="updateBatchNo"> |
| | | <el-input v-model="addObj.updateBatchNo" :disabled="active > 1" class="addObj-info" clearable size="small"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="æ£éªç±»å:"> |
| | | <el-select v-model="addObj.orderType" clearable disabled size="small" style="width: 100%"> |
| | | <el-option v-for="(a, ai) in dict.type.check_type" :key="ai" :label="a.label" :value="a.value"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="çº¦å®æ¶é´:" prop="appointed"> |
| | | <el-date-picker |
| | | v-model="addObj.appointed" |
| | | :disabled="active > 1" |
| | | format="yyyy-MM-dd" |
| | | placeholder="éæ©æ¥æ" |
| | | size="small" |
| | | style="width: 100%" |
| | | type="date" |
| | | value-format="yyyy-MM-dd"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="ææåå®¶:" prop="supplierName"> |
| | | <el-input v-model="addObj.supplierName" :disabled="active > 1" class="addObj-info" clearable placeholder="" size="small"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="æ½æ£æ°é:" prop="testQuantity"> |
| | | <el-input v-model="addObj.testQuantity" :disabled="active > 1" class="addObj-info" clearable placeholder="" size="small"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="è§æ ¼åå·:" placeholder="请填å" prop="partDetail"> |
| | | <el-tooltip :content="addObj.partDetail" :disabled="!addObj.partDetail"> |
| | | <el-input v-model="addObj.partDetail" :disabled="active > 1" clearable class="addObj-info" size="small"></el-input> |
| | | </el-tooltip> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="å°è´§æ¶é´:" prop="declareDate"> |
| | | <el-date-picker |
| | | v-model="addObj.declareDate" |
| | | :disabled="active > 1" |
| | | format="yyyy-MM-dd" |
| | | placeholder="éæ©æ¥æ" |
| | | size="small" |
| | | style="width: 100%" |
| | | type="date" |
| | | value-format="yyyy-MM-dd HH:mm:ss"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="夿³¨:"> |
| | | <el-input v-model="addObj.remark" :autosize="{ minRows: 2, maxRows: 2}" :placeholder="active>1 ? '' : '请è¾å
¥'" :readonly="active>1" clearable |
| | | size="small" type="textarea"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | </el-row> |
| | | </el-form> |
| | | </div> |
| | | <div style="display: flex;justify-content: space-between;"> |
| | | <div v-if="active==1"> |
| | | <el-form :inline="true" :model="addObj1" label-width="90px"> |
| | | <el-form-item label="æ ·ååå·:" style="margin-bottom: 6px"> |
| | | <el-select v-model="model" :placeholder="active>1 ? '' : '请è¾å
¥'" |
| | | allow-create clearable default-first-option filterable |
| | | size="small" |
| | | @change="changeModel"> |
| | | <el-option v-for="item in models" :key="item.value" :label="item.label" :value="item.value"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="æ£éªæ å:"> |
| | | <el-select v-model="standardMethodListId" :loading="methodLoad" |
| | | :placeholder="active>1 ? '' : '请è¾å
¥'" clearable size="small" |
| | | @change="changeStandardMethodListId" @focus="methodFocus"> |
| | | <el-option v-for="item in methods" :key="item.id" :label="item.code" :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-form> |
| | | </div> |
| | | <div style="margin-top: 3px"> |
| | | <el-button v-show="active==1" :disabled="sampleList.length === 2" size="small" type="primary" @click="handleSplitCountNum">æå</el-button> |
| | | </div> |
| | | </div> |
| | | <div style="height: auto;"> |
| | | <el-table ref="sampleTable" :data="sampleList" class="el-table sampleTable" highlight-current-row |
| | | max-height="400px" tooltip-effect="dark" @selection-change="selectSample" @row-click="rowClick"> |
| | | <el-table-column v-if="active==1" :selectable="selectable" type="selection" width="60"></el-table-column> |
| | | <el-table-column align="center" label="åºå·" type="index" width="65"></el-table-column> |
| | | <el-table-column align="center" label="æ ·ååç§°" min-width="100" prop="sample"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-model="scope.row.sample" :readonly="active>1" clearable size="small"></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="æ ·åç¼å·" min-width="140" prop="sampleCode"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-model="scope.row.sampleCode" :readonly="active>1" clearable placeholder="ä¸å¡«ååç³»ç»èªå¨çæ" |
| | | size="small"></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="æ ·ååå·" min-width="100" prop="model"> |
| | | <template slot-scope="scope"> |
| | | <el-select v-model="scope.row.model" :disabled="active>1" allow-create default-first-option filterable |
| | | placeholder="æ ·ååå·" size="small" style="width: 100%;" @change="handleChangeModel"> |
| | | <el-option v-for="item in models" :key="item.value" :label="item.label" :value="item.value"> |
| | | </el-option> |
| | | </el-select> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column v-if="!(active>1)" align="center" label="åå·åæ°" prop="modelNum" width="130"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-model="scope.row.modelNum" :disabled="active>1|| scope.$index !== 0" clearable placeholder="éå¿
å¡«" |
| | | size="small" |
| | | @input="methodChange(scope.row.standardMethodListId, scope.row)"></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="æ£éªæ å" min-width="100" prop="standardMethodListId"> |
| | | <template slot-scope="scope"> |
| | | <el-select v-model="scope.row.standardMethodListId" :disabled="scope.row.model==null||active>1 || scope.$index !== 0" |
| | | :loading="methodLoad" :readonly="active>1" clearable placeholder="æ£éªæ å" |
| | | size="small" style="width: 100%;" @change="(value)=>methodChange(value, scope.row)" @clear="productList = []" @focus="methodFocus"> |
| | | <el-option v-for="item in methods" :key="item.id" :label="item.code" :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column v-if="addObj.mating==1" align="center" label="é
奿 ·ååç§°" prop="joinName" width="140"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-model="scope.row.joinName" :autosize="{ minRows: 1, maxRows: 1}" size="small" |
| | | type="textarea"></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column v-if="addObj.mating==1" align="center" label="é
奿 ·ååå·" prop="joinModel" width="140"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-model="scope.row.joinModel" :autosize="{ minRows: 1, maxRows: 1}" size="small" |
| | | type="textarea"></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column v-if="addObj.mating==1" align="center" label="é
奿 ·åæ°é" prop="joinNum" width="140"> |
| | | <template slot-scope="scope"> |
| | | <el-input-number v-model="scope.row.joinNum" :controls="false" :max="100" :min="1" :precision="0" |
| | | size="small" style="width: 80%;"></el-input-number> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="å¾
æ£é¡¹æ°é" prop="proNum" width="105"></el-table-column> |
| | | </el-table> |
| | | <el-table ref="productTable" v-loading="getProductLoad" :data="productList" :row-class-name="tableRowClassName" class="el-table" |
| | | max-height="400px" style="margin-bottom: 10px;" tooltip-effect="dark" |
| | | @select="selectOne" @selection-change="selectProduct" @select-all="handleAll"> |
| | | <el-table-column v-if="active==1" :selectable="selectable" type="selection" width="65"></el-table-column> |
| | | <el-table-column label="æ£éªé¡¹åç±»" min-width="140" prop="inspectionItemClass" show-overflow-tooltip></el-table-column> |
| | | <el-table-column label="æ£éªé¡¹" min-width="140" prop="inspectionItem" show-overflow-tooltip> |
| | | <template slot="header" slot-scope="scope"> |
| | | <div style="display: flex;align-items: center;flex-direction: column;font-size: 14px"> |
| | | <span>æ£éªé¡¹</span> |
| | | <el-input |
| | | v-if="active==1" |
| | | v-model="inspectionItem" |
| | | placeholder="请è¾å
¥" |
| | | size="mini" |
| | | @input="searchFilterList"/> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="æ£éªé¡¹å项" min-width="140" prop="inspectionItemSubclass" |
| | | show-overflow-tooltip> |
| | | <template slot="header" slot-scope="scope"> |
| | | <div style="display: flex;align-items: center;flex-direction: column;font-size: 14px"> |
| | | <span>æ£éªé¡¹å项</span> |
| | | <el-input |
| | | v-if="active==1" |
| | | v-model="inspectionItemSubclass" |
| | | placeholder="请è¾å
¥" |
| | | size="mini" |
| | | @input="searchFilterList"/> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="è¦æ±å¼" min-width="220px" prop="ask"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-if="active==1&&isAskOnlyRead&&scope.row.inspectionValueType!='5'" v-model="scope.row.ask" :autosize="{ minRows: 1, maxRows: 3}" clearable placeholder="è¦æ±å¼" |
| | | size="small" type="textarea" |
| | | @change="e=>requestChange(e,scope.row,'ask')"></el-input> |
| | | <span v-else> |
| | | <!-- <template v-if="(scope.row.ask.indexOf('D')>-1 |
| | | ||scope.row.ask.indexOf('W')>-1 |
| | | ||scope.row.ask.indexOf('X')>-1 |
| | | ||scope.row.ask.indexOf('RTS')>-1 |
| | | ||scope.row.ask.indexOf('H')>-1 |
| | | ||scope.row.ask.indexOf('L')>-1)&&active==1"> |
| | | <input class="askRts" v-model="scope.row.rts" /><br />{{ scope.row.ask }} |
| | | </template> |
| | | <template v-else>{{ scope.row.ask }}</template> --> |
| | | <template >{{ scope.row.ask }}</template> |
| | | </span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="è¦æ±æè¿°" min-width="220px" prop="tell"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-if="active==1&&isAskOnlyRead" v-model="scope.row.tell" :autosize="{ minRows: 1, maxRows: 3}" clearable placeholder="è¦æ±æè¿°" |
| | | size="small" type="textarea" |
| | | @change="e=>requestChange(e,scope.row,'tell')"></el-input> |
| | | <span v-else> |
| | | <template >{{ scope.row.tell }}</template> |
| | | </span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="æ¡ä»¶" min-width="140" prop="radius" show-overflow-tooltip></el-table-column> |
| | | <el-table-column label="è¯éªæ¹æ³" min-width="120" prop="methodS" show-overflow-tooltip> |
| | | <template slot="header" slot-scope="scope"> |
| | | <div style="display: flex;align-items: center;flex-direction: column;font-size: 14px"> |
| | | <span>è¯éªæ¹æ³</span> |
| | | <el-input |
| | | v-if="active==1" |
| | | v-model="methodS" |
| | | placeholder="请è¾å
¥" |
| | | size="mini" |
| | | @input="searchFilterList"/> |
| | | </div> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="计éåä½" prop="unit" show-overflow-tooltip width="100"></el-table-column> |
| | | <el-table-column label="åä»·" prop="price" show-overflow-tooltip width="100"></el-table-column> |
| | | <!-- <el-table-column prop="manDay" label="é¢è®¡æ¶é´(天)" width="120" show-overflow-tooltip></el-table-column> |
| | | <el-table-column prop="manHour" label="å·¥æ¶ç³»æ°" width="100" show-overflow-tooltip></el-table-column> --> |
| | | <!-- <el-table-column prop="deviceGroup" label="设å¤ç»" width="120" show-overflow-tooltip></el-table-column> --> |
| | | <el-table-column label="åºé´" min-width="120" prop="section" show-overflow-tooltip></el-table-column> |
| | | <el-table-column :filter-method="filterHandler" :filters="filters" label="åå®éªå®¤" min-width="130" prop="sonLaboratory" |
| | | show-overflow-tooltip></el-table-column> |
| | | </el-table> |
| | | </div> |
| | | </div> |
| | | <el-dialog :visible.sync="selectStandardTree" title="éæ©æ ·å" width="500px"> |
| | | <div v-if="selectStandardTree" v-loading="selectStandardTreeLoading" class="body" style="height: 60vh;overflow-y: auto;user-select: none;"> |
| | | <el-row> |
| | | <el-col :span="24"> |
| | | <el-input v-model="search" clearable placeholder="è¾å
¥å
³é®åè¿è¡æç´¢" size="small" |
| | | style="margin-bottom: 5px;" suffix-icon="el-icon-search" @blur="searchFilter" @clear="searchFilter" |
| | | @keyup.enter.native="searchFilter"></el-input> |
| | | </el-col> |
| | | </el-row> |
| | | <el-tree ref="tree" :data="list" :default-expanded-keys="expandedKeys" :filter-node-method="filterNode" |
| | | :props="{ children: 'children', label: 'label' }" highlight-current node-key="label" @node-click="handleNodeClick" |
| | | @node-expand="nodeOpen" @node-collapse="nodeClose" @dblclick.native="activeStandardTree"> |
| | | <div slot-scope="{ node, data }" class="custom-tree-node"> |
| | | <el-row> |
| | | <el-col :span="24"> |
| | | <span><i |
| | | :class="`node_i ${data.children != undefined ? (data.code==='[1]'?'el-icon-folder-opened':'el-icon-folder') : 'el-icon-tickets'}`"></i> |
| | | {{ data.code }} {{ data.label }}</span> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </el-tree> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="selectStandardTree = false">å æ¶</el-button> |
| | | <el-button type="primary" @click="activeStandardTree">ç¡® å®</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | <!--ç¹æ®å¼å¤çæ¡--> |
| | | <el-dialog :before-close="beforeClose" :close-on-click-modal="false" :close-on-press-escape="false" :show-close="false" |
| | | :visible.sync="bsm1DiaAll" |
| | | min-width="400px" |
| | | title="æ£æµå°ç¹æ®é¡¹ï¼è¯·ä½åºä»¥ä¸éæ©"> |
| | | <div v-for="(item, index) in bsm1DiaList" :key="item.id" class="body" style="max-height: 60vh;"> |
| | | <span>{{item.inspectionItem}}</span> |
| | | <el-row v-if="item.bsm1"> |
| | | <el-col :span="24" class="search_thing" style="height: initial;margin: 5px 0;"> |
| | | <div class="search_label" style="width: 80px;"><span class="required-span">* </span>é项ï¼</div> |
| | | <div class="search_input"> |
| | | <el-radio-group v-model="item.bsm1Val" v-removeAriaHidden @input="upBsmAll(item)"> |
| | | <el-radio v-for="(a, ai) in JSON.parse(item.bsmRow.sectionCopy)" :key="ai" :label="a" style="margin-bottom: 2px;margin-top: 2px;"></el-radio> |
| | | </el-radio-group> |
| | | </div> |
| | | </el-col> |
| | | <el-col :span="24" class="search_thing" style="height: initial;margin: 5px 0;"> |
| | | <div class="search_label" style="width: 80px;">è¦æ±å¼ï¼</div> |
| | | <div class="search_input"> |
| | | <el-radio-group v-model="item.bsm1Val" v-removeAriaHidden @input="upBsmAll(item)"> |
| | | <el-radio v-for="(a, ai) in JSON.parse(item.bsmRow.sectionCopy)" :key="ai" |
| | | :label="a">{{JSON.parse(item.bsmRow.askCopy)[ai]}}</el-radio> |
| | | </el-radio-group> |
| | | </div> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-row> |
| | | <el-button :loading="saveLoad" type="primary" @click="save1">ç¡® å®</el-button> |
| | | </el-row> |
| | | </span> |
| | | </el-dialog> |
| | | <el-dialog :close-on-click-modal="false" :close-on-press-escape="false" |
| | | :show-close="false" :visible.sync="bsm3Dia" |
| | | title="åºé´å¼å¡«å" width="800px"> |
| | | <el-table |
| | | :data="editTable" |
| | | height="80vh" style="width: 100%"> |
| | | <!-- inspectionItemList --> |
| | | <el-table-column |
| | | label="æ£éªé¡¹" |
| | | prop="inspectionItemList" |
| | | width="180"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="æ ·åç¼å·" |
| | | prop="sampleCode" |
| | | width="180"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="æ ·ååå·" |
| | | prop="model" |
| | | width="180"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="è¯å«ç¬¦å·" |
| | | prop="symbolItem"> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="è¯å«ç¬¦å¼" |
| | | prop="value"> |
| | | <template slot-scope="scope"> |
| | | <el-input v-model="scope.row.value" placeholder="请è¾å
¥" size="small" @input="inputValueHandler(scope.row,scope.$index)"></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-row> |
| | | <el-button @click="bsm3Dia=false">å æ¶</el-button> |
| | | <el-button :loading="saveLoad" type="primary" @click="save0">ç¡® å®</el-button> |
| | | </el-row> |
| | | </span> |
| | | </el-dialog> |
| | | <el-dialog |
| | | :visible.sync="noNeedCheckDia" |
| | | title="å
æ£æç¤º" |
| | | width="32%"> |
| | | <span>确认å
æ£å½åæ£éªåï¼</span> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button :loading="noNeedCheckLoad" @click="noNeedCheckDia = false">å æ¶</el-button> |
| | | <el-button :loading="noNeedCheckLoad" type="primary" @click="handleNoNeedCheck">ç¡® å®</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | // import ValueTable from '../../tool/value-table.vue' |
| | | import Vue from 'vue' |
| | | import { |
| | | addRawCopperOrder, |
| | | getInsOrder, |
| | | getUserNow, |
| | | addRawCopperOrderExemptionOrder, |
| | | selectStandardTreeList2, |
| | | selectsStandardMethodByFLSSM, |
| | | selectInsOrderTemplate, |
| | | selectStandardProductList, |
| | | selectStandardMethodEnum |
| | | } from "@/api/business/rawMaterialOrder"; |
| | | |
| | | var validateSixDecimalPositives = (rule, value, callback) => { |
| | | if (value == 0 || value == null) { |
| | | callback(new Error('请è¾å
¥æ£ç¡®çæ°åæå°æ°')) |
| | | } else if (!/^[0-9]+.?[0-9]*$/.test(value)) { |
| | | callback(new Error('请è¾å
¥æ°åæå°æ°')) |
| | | } else { |
| | | callback() |
| | | } |
| | | } |
| | | |
| | | export default { |
| | | components: {}, |
| | | dicts: ['check_type', 'urgency_level'], |
| | | props: { |
| | | currentId: { |
| | | type: Number, |
| | | default: () => 0 |
| | | } |
| | | }, |
| | | data() { |
| | | return { |
| | | active: '', |
| | | sampleSelectionList: [],//æ ·åè¡¨æ ¼é䏿°æ® |
| | | editTable:[], |
| | | noNeedCheckLoad: false, // å
æ£æé®loading |
| | | template: null, |
| | | templates: [], |
| | | addObj: { |
| | | testQuantity: null, // æ½æ£æ°é |
| | | custom: null, |
| | | company: null, |
| | | userId: null, |
| | | type: '0', // ç´§æ¥ç¨åº¦ |
| | | code: null, |
| | | remark: null, // 夿³¨ |
| | | mating: 0, |
| | | sample: null, // æ ·ååç§° |
| | | appointed: '', // çº¦å®æ¶é´ |
| | | buyUnitMeas: '', // åä½ |
| | | updateBatchNo: '', // æ¹æ¬¡å· |
| | | partDetail: '', // è§æ ¼åå· |
| | | declareDate: '', // å°è´§æ¶é´ |
| | | factory: null, |
| | | laboratory: null, |
| | | sampleType: null, |
| | | sampleNum: 1, |
| | | unit: null, |
| | | model: null, |
| | | method: null, |
| | | phone: null, |
| | | processing: 1, |
| | | isLeave: 0, |
| | | orderType: 'è¿åæ£éª', // æ£éªç±»å |
| | | supplierName: '', // ææåå®¶ |
| | | qtyArrived: '', // å°è´§æ°é |
| | | }, |
| | | sample: { |
| | | sampleCode: null, |
| | | laboratory: null, |
| | | factory: null, |
| | | sampleType: null, |
| | | sample: null, |
| | | model: null, |
| | | modelNum: null, |
| | | sampleNum: 1, |
| | | isLeave: 0, |
| | | unit: null |
| | | }, |
| | | selectStandardTree: false, |
| | | search: null, |
| | | list: [], |
| | | selectStandardTreeLoading: false, |
| | | selectTree: null, |
| | | expandedKeys: [], |
| | | sampleList: [], |
| | | sampleIds: [], |
| | | methodList: [], |
| | | addSampleDia: false, |
| | | count: 1, |
| | | productList: [], |
| | | productList0: [], |
| | | bsm1DiaList: [], |
| | | productIds: [], |
| | | productListSelected: [], |
| | | getProductLoad: false, |
| | | saveLoad: false, |
| | | templateDia: false, |
| | | templateLoading: false, |
| | | templateName: '', |
| | | upLoad: false, |
| | | units: [], |
| | | models: [], |
| | | methods: [], |
| | | methodLoad: false, |
| | | filters: [], |
| | | currentMethod: null, |
| | | isAskOnlyRead: false, |
| | | sampleId: null, |
| | | bsmRow: null, |
| | | bsm1: false, |
| | | bsm1Val: null, |
| | | bsm1DiaAll: false, |
| | | bsm2: false, |
| | | bsm2Val: null, |
| | | bsm2Dia: false, |
| | | bsm2Val2: [], |
| | | bsm2Val3: [], |
| | | bsmRow3: null, |
| | | bsm3Val: null, |
| | | bsm3Dia: false, |
| | | // total: 0, |
| | | RTS: '', |
| | | totalArr: [], |
| | | addObj1: {}, |
| | | model: null, |
| | | standardMethodListId: null, |
| | | symbolList:['RTS'], |
| | | inspectionItem:null, |
| | | inspectionItemSubclass:null, |
| | | methodS:null, |
| | | isBsm2Val2:false, |
| | | isShowInput: false, |
| | | temId: '', |
| | | selectiveEcho: [], // æ£éªä¸åçæ¶åå¾éæ£éªé¡¹ç®,å¦æä½¿ç¨çéæäº¤æ¾ç¤ºæ£éªé¡¹ç®ä¸ºç©º åæ¾å表 |
| | | addObjRules: { // è¡¨åæ ¡éªè§å |
| | | sample: [ |
| | | { required: true, message: 'è¯·éæ©æ ·å', trigger: 'change' } |
| | | ], |
| | | qtyArrived: [ |
| | | { validator: validateSixDecimalPositives, trigger: 'blur' } |
| | | ], |
| | | testQuantity: [ |
| | | { required: true, message: 'è¯·å¡«åæ½æ£æ°é', trigger: 'blur' } |
| | | ], |
| | | supplierName: [ |
| | | { required: true, message: 'è¯·å¡«åææåå®¶', trigger: 'blur' } |
| | | ], |
| | | appointed: [ |
| | | { required: true, message: 'è¯·éæ©çº¦å®æ¶é´', trigger: 'change' } |
| | | ], |
| | | buyUnitMeas: [ |
| | | { required: true, message: '请填ååä½', trigger: 'blur' } |
| | | ], |
| | | updateBatchNo: [ |
| | | { required: true, message: 'è¯·å¡«åæ¹æ¬¡å·', trigger: 'blur' } |
| | | ], |
| | | partDetail: [ |
| | | { required: true, message: '请填åè§æ ¼åå·', trigger: 'blur' } |
| | | ], |
| | | declareDate: [ |
| | | { required: true, message: '请填åå°è´§æ¶é´', trigger: 'blur' } |
| | | ] |
| | | }, |
| | | noNeedCheckDia: false, |
| | | } |
| | | }, |
| | | watch: { |
| | | sampleList() { |
| | | this.addObj.method = null |
| | | this.productList = [] |
| | | }, |
| | | productList: { |
| | | deep: true, |
| | | handler(val) { |
| | | if (val && val.length > 0) { |
| | | let arr = []; |
| | | val.forEach(item => { |
| | | if (item.sonLaboratory && !arr.find(a => a.value == item.sonLaboratory)) { |
| | | arr.push({ |
| | | text: item.sonLaboratory, |
| | | value: item.sonLaboratory |
| | | }) |
| | | } |
| | | }) |
| | | this.filters = arr |
| | | } |
| | | } |
| | | }, |
| | | productListSelected: { |
| | | deep: true, |
| | | handler(val) { |
| | | if(val.length>0){ |
| | | for(let i =0 ; i< val.length; i++){ |
| | | if(val[i].inspectionItem.includes('æ¾å¥ç®¡')){ |
| | | this.inspectionItemST = 1 |
| | | break; |
| | | }else{ |
| | | this.inspectionItemST = 0 |
| | | } |
| | | } |
| | | }else{ |
| | | this.inspectionItemST = 0 |
| | | } |
| | | } |
| | | }, |
| | | sampleList: { |
| | | deep: true, |
| | | handler(val) { |
| | | this.getTotal() |
| | | } |
| | | }, |
| | | 'addObj.sample'(val) { |
| | | this.model = null |
| | | this.standardMethodListId = null |
| | | }, |
| | | 'addObj.sampleNum'(val) { |
| | | this.model = null |
| | | this.standardMethodListId = null |
| | | } |
| | | }, |
| | | mounted() { |
| | | this.active = this.$route.query.active |
| | | this.getUserNowInfo() |
| | | this.selectStandardTreeList() |
| | | this.selectStandardMethods() |
| | | this.getInfo() // è·åæ°æ® |
| | | }, |
| | | methods: { |
| | | // æå |
| | | handleSplitCountNum () { |
| | | this.sample.joinName = null |
| | | this.sample.joinModel = null |
| | | this.sample.joinNum = 1 |
| | | // ä¸¤æ¡æ°æ®ä¿æä¸è´ |
| | | this.sample.sample = this.sampleList[0].sample |
| | | this.sample.model = this.sampleList[0].model |
| | | this.sample.unit = this.sampleList[0].unit |
| | | this.sample.modelNum = this.sampleList[0].modelNum |
| | | this.sample.standardMethodListId = this.sampleList[0].standardMethodListId |
| | | this.sample.insProduct = [] |
| | | this.sample.id = this.count |
| | | this.sample.childSampleList = [] |
| | | this.sample.insulating = null |
| | | this.sample.sheath = null |
| | | this.sampleList.push(this.HaveJson(this.sample)) |
| | | this.sampleList.forEach(item => { |
| | | item.quantity = 1 |
| | | }) |
| | | this.count++ |
| | | this.computationalPairing(this.sampleList.length) |
| | | }, |
| | | noNeedCheck () { |
| | | this.$refs['addObj'].validate((valid) => { |
| | | if (valid) { |
| | | if (!this.sampleList.every(m => m.standardMethodListId)) { |
| | | this.$message.error('è¯·éæ©æ£éªæ å') |
| | | return |
| | | } |
| | | // æ£éªç±»å为è¿åæ£éªæ¶å¯éæ©å
æ£ï¼ä½ä¸è½éæ©æ£éªé¡¹ |
| | | const sampleList = this.HaveJson(this.sampleList) |
| | | sampleList.forEach(item => { |
| | | item.insProduct = this.productList |
| | | }) |
| | | this.getTotal(sampleList) |
| | | let projectNum = this.totalArr.filter(a => a.state == 1).length |
| | | if (projectNum!=0){ |
| | | this.$message.error('å
æ£ä¸å¯éæ©æ£éªé¡¹') |
| | | return |
| | | } |
| | | this.noNeedCheckDia = true |
| | | } else { |
| | | console.log('error submit!!'); |
| | | return false; |
| | | } |
| | | }); |
| | | }, |
| | | handleNoNeedCheck () { |
| | | const sampleList = this.HaveJson(this.sampleList) |
| | | sampleList.forEach(item => { |
| | | item.insProduct = this.productList |
| | | }) |
| | | this.getTotal(sampleList) |
| | | let projectNum = this.totalArr.filter(a => a.state == 1).length |
| | | if (projectNum!=0){ |
| | | this.$message.error('å
æ£ä¸å¯éæ©æ£éªé¡¹') |
| | | } else { |
| | | const pairing = [] |
| | | let trees = this.selectTree.split(" - ") |
| | | if (trees.length < 3) { |
| | | this.$message.error('æªéæ©å¯¹è±¡') |
| | | return |
| | | } |
| | | this.addObj.factory = trees[0] |
| | | this.addObj.laboratory = trees[1] |
| | | this.addObj.sampleType = trees[2] |
| | | if (trees[3] === undefined || trees[3] === '') { |
| | | this.addObj.sample = trees[2] |
| | | } else { |
| | | this.addObj.sample = trees[3] |
| | | } |
| | | this.addObj.model = (trees[4] == undefined ? null : trees[4]) |
| | | this.noNeedCheckLoad = true |
| | | addRawCopperOrderExemptionOrder({ |
| | | str: JSON.stringify({ |
| | | insOrder: this.addObj, |
| | | list: JSON.stringify(sampleList.map(a => { |
| | | if (a.modelNum) { |
| | | // æ ¹æ®xå·å¤æåå·åæ°ä¸æ ·ååå·çæ¼æ¥ä½ç½® |
| | | // ä¾å¦Ã4ï¼å°±ä¸º500MLÃ4ï¼4Ãï¼å°±ä¸º4Ã500ML |
| | | const index = a.modelNum.indexOf('Ã') |
| | | if (index === 0) { |
| | | a.model = a.model + a.modelNum |
| | | } else if (index === -1) { |
| | | a.model = a.model + '-' + a.modelNum |
| | | } else { |
| | | a.model = a.modelNum + a.model |
| | | } |
| | | } else { |
| | | a.model = a.model + ((a.modelNum == null || a.modelNum == '' || a.modelNum == 'null') ? '' : ('-' + a.modelNum)) |
| | | } |
| | | a.insProduct = a.insProduct.filter(b=>b.state === 1) |
| | | return a |
| | | })), |
| | | pairing: JSON.stringify(pairing) |
| | | }) |
| | | }).then(res => { |
| | | this.noNeedCheckLoad = false |
| | | if (res.code == 201) return |
| | | this.$message.success('å·²æäº¤') |
| | | this.goBack() |
| | | }).catch(e=>{ |
| | | this.noNeedCheckLoad = false |
| | | }) |
| | | } |
| | | }, |
| | | // è·åæ°æ® |
| | | getInfo () { |
| | | if (this.active != 1) { |
| | | // æ¥çæµç¨ |
| | | // è¯·æ±æ¥å£ï¼åæ¾æ°æ® |
| | | getInsOrder({orderId: this.currentId}).then(res => { |
| | | this.addObj = { |
| | | ...res.data.insOrder |
| | | } |
| | | this.addObj.qtyArrived = res.data.insOrderTemplate.qtyArrived |
| | | this.addObj.buyUnitMeas = res.data.insOrderTemplate.buyUnitMeas |
| | | this.addObj.updateBatchNo = res.data.insOrderTemplate.updateBatchNo |
| | | this.addObj.supplierName = res.data.insOrderTemplate.supplierName |
| | | this.addObj.type = String(this.addObj.type) |
| | | this.sampleList = this.HaveJson(res.data.sampleProduct); |
| | | this.getProNum() |
| | | this.addObj.sampleNum = this.sampleList.length |
| | | this.$nextTick(() => { |
| | | this.$refs.sampleTable.doLayout() |
| | | if (this.sampleList.length > 0) { // æ¥çæ¶å¦æææ ·åé»è®¤éä¸ç¬¬ä¸æ¡ |
| | | this.productList = this.sampleList[0].insProduct |
| | | this.$refs.sampleTable.setCurrentRow(this.sampleList[0], true) |
| | | this.rowClick(this.sampleList[0]) |
| | | } |
| | | }) |
| | | }) |
| | | } |
| | | }, |
| | | //ç¹æ®å¼å¡«åå¤ç |
| | | inputValueHandler(row,index){ |
| | | if(row){ |
| | | const nextIndex = index+1 |
| | | for (let i = nextIndex; i < this.editTable.length; i++) { |
| | | const element = this.editTable[i]; |
| | | if(element.model==row.model&&row.symbolItem==element.symbolItem){ |
| | | this.editTable[i].value = row.value |
| | | } |
| | | } |
| | | } |
| | | }, |
| | | changeProductList0(){ |
| | | this.productList0.forEach(a=>{ |
| | | let obj = this.productList.find(m => m.id == a.id) |
| | | if(obj){ |
| | | a.state = obj.state |
| | | a.section = obj.section |
| | | a.ask = obj.ask |
| | | a.manHour = obj.manHour |
| | | a.price = obj.price |
| | | a.tell = obj.tell |
| | | } |
| | | if(a.state == 0&&a.bsmRow){ |
| | | a = this.HaveJson(a.bsmRow) |
| | | } |
| | | }) |
| | | }, |
| | | searchFilterList () { |
| | | const vtw = { |
| | | inspectionItem: this.inspectionItem, // æ£éªé¡¹ |
| | | inspectionItemSubclass: this.inspectionItemSubclass, // æ£éªé¡¹å项 |
| | | methodS: this.methodS, // è¯éªæ¹æ³ |
| | | } |
| | | const isHaveValue = Object.values(vtw).some(item => { |
| | | return item |
| | | }) |
| | | this.changeProductList0() |
| | | if (isHaveValue) { |
| | | for(let i in vtw) { |
| | | if (vtw[i]) { |
| | | this.productList = this.productList0.filter((item) => { |
| | | return item[i] && item[i].includes(vtw[i]) |
| | | }) |
| | | } |
| | | } |
| | | this.$nextTick(()=>{ |
| | | this.productList.forEach(a => { |
| | | if (a.state == 1) this.toggleSelection(a) |
| | | }) |
| | | }) |
| | | } else { |
| | | // æ²¡ææ¥è¯¢æ¡ä»¶æ¶æ¸²ææææ°æ® |
| | | this.productList = this.productList0 |
| | | this.$nextTick(()=>{ |
| | | this.productList.forEach(a => { |
| | | if (a.state == 1) this.toggleSelection(a) |
| | | }) |
| | | }) |
| | | } |
| | | }, |
| | | containsValue(str) { |
| | | if(str){ |
| | | let symbolItem = '' |
| | | this.symbolList.some(value =>{ |
| | | if(str.includes(value)){ |
| | | symbolItem = value |
| | | return true |
| | | } |
| | | }) |
| | | return symbolItem |
| | | } |
| | | }, |
| | | handleAsk(ask,symbolItem, value) { |
| | | try{ |
| | | let code = [">", "<", "=", "ï¼", "ï¼", "â¥", "â¤", "±"]; |
| | | let code2 = ['+', '*', '/', '-'] |
| | | if (ask.includes('&')) { |
| | | // å¤ä¸ªæ¡ä»¶ |
| | | let arr0 = ask.split('&') |
| | | let arr1 = [] |
| | | arr0.forEach(m => { |
| | | let index = code.findIndex(b => m.includes(b)) |
| | | if (index > -1) { |
| | | let arr = m.split(code[index]).filter(b => !!b) |
| | | let num = eval(this.replaceAll(arr[0], symbolItem, value)) |
| | | m = code[index] + '' + num |
| | | arr1.push(m) |
| | | } |
| | | }) |
| | | return arr1.join('&') |
| | | } else if (ask.includes('ï½') || ask.includes('~')) { |
| | | let arr0 = [] |
| | | if (ask.includes('ï½')) { |
| | | arr0 = ask.split('ï½') |
| | | } else { |
| | | arr0 = ask.split('~') |
| | | } |
| | | // å¤ä¸ªæ¡ä»¶ |
| | | let arr1 = [] |
| | | arr0.forEach(m => { |
| | | m = m.replace(symbolItem, value) |
| | | const index = code2.findIndex(b => m.includes(b)) |
| | | if (index > -1) { |
| | | m = eval(m) |
| | | } |
| | | arr1.push(m) |
| | | }) |
| | | return arr1.join('ï½') |
| | | } else { |
| | | // å个æ¡ä»¶ |
| | | let index = code.findIndex(b => ask.includes(b)) |
| | | if (index > -1) { |
| | | let arr = ask.split(code[index]).filter(b => !!b) |
| | | let num = eval(this.replaceAll(arr[0], symbolItem, value)) |
| | | return code[index] + '' + num |
| | | } |
| | | } |
| | | }catch(e){} |
| | | }, |
| | | handleTell(tell,symbolItem, value){ |
| | | try{ |
| | | let num = this.replaceAll(tell, symbolItem, value) |
| | | return num |
| | | }catch(e){} |
| | | }, |
| | | replaceAll(str,find,value) { |
| | | if (str === undefined) { |
| | | return str |
| | | } |
| | | return str.replaceAll(find, value); |
| | | }, |
| | | save() { |
| | | this.$refs['addObj'].validate((valid) => { |
| | | if (valid) { |
| | | if (!this.sampleList.every(m => m.standardMethodListId)) { |
| | | this.$message.error('è¯·éæ©æ£éªæ å') |
| | | return |
| | | } |
| | | // if (!this.sampleList.every(m => m.quantity)) { |
| | | // this.$message.error('è¯·éæ©å¾
æ£é¡¹æ°é') |
| | | // return |
| | | // } |
| | | const sampleList = this.HaveJson(this.sampleList) |
| | | sampleList.forEach(item => { |
| | | item.quantity = 1 |
| | | item.insProduct = this.productList |
| | | }) |
| | | this.getTotal(sampleList) |
| | | let projectNum = this.totalArr.filter(a => a.state == 1).length |
| | | if(projectNum==0){ |
| | | this.$confirm('æ£éªé¡¹ç®ä¸ºç©ºï¼æ¯å¦ç¡®è®¤æäº¤?', "æç¤º", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning" |
| | | }).then(() => { |
| | | this.saveMethod(sampleList) |
| | | }).catch(() => {}) |
| | | }else{ |
| | | let isRTS = this.totalArr.find(a => a.ask != null && this.symbolList.find(b=>a.ask.includes(b)) && a.state == 1) |
| | | if (isRTS) { |
| | | this.editTable = this.handleData(sampleList,this.containsValue, 0) |
| | | this.editTable.forEach(item => { |
| | | item.value = item.modelNum |
| | | }) |
| | | this.bsm3Dia = true; |
| | | return |
| | | } |
| | | this.saveMethod(sampleList) |
| | | } |
| | | } else { |
| | | console.log('error submit!!'); |
| | | return false; |
| | | } |
| | | }); |
| | | }, |
| | | save0(){ |
| | | if(this.editTable.every(m=>m.value)){ |
| | | this.sampleList.forEach(item => { |
| | | item.quantity = 1 |
| | | item.insProduct = this.productList |
| | | }) |
| | | let sampleList = this.handleData(this.HaveJson(this.sampleList),this.handleAsk,1) |
| | | sampleList.forEach(a => { |
| | | a.insProduct = a.insProduct.filter(b=>b.state === 1) |
| | | }) |
| | | this.saveMethod(sampleList) |
| | | }else{ |
| | | this.$message.error('请填åè¯å«ç¬¦å¼') |
| | | } |
| | | }, |
| | | handleData(sampleList,calBack,type){ |
| | | let editTable = [] |
| | | sampleList.forEach(item => { |
| | | let obj = { |
| | | sampleCode:item.sampleCode, |
| | | model:item.model, |
| | | symbolList:[], |
| | | sampleId:item.id, |
| | | modelNum:item.modelNum, |
| | | } |
| | | if (item.insProduct && item.insProduct.length > 0) { |
| | | item.insProduct.forEach(a => { |
| | | if (a.state == 1) { |
| | | if(type==0){ |
| | | let str = calBack(a.ask) |
| | | str&&obj.symbolList.push({ |
| | | symbolItem:str, |
| | | inspectionItem:a.inspectionItem, |
| | | }) |
| | | }else if(type==1){ |
| | | let arr = this.editTable.filter(b => b.sampleId == item.id) |
| | | for (var i=0;i<arr.length;i++){ |
| | | if(a.ask){ |
| | | if(a.ask.includes(arr[i].symbolItem)){ |
| | | let ask = calBack(a.ask, arr[i].symbolItem,arr[i].value) |
| | | if (ask) { |
| | | a.ask = ask |
| | | } |
| | | let tell = this.handleAsk(a.tell, arr[i].symbolItem,arr[i].value) |
| | | if (tell) { |
| | | a.tell = tell |
| | | } |
| | | } |
| | | }else{ |
| | | this.$message.error('è¦æ±å¼ä¸ºç©ºï¼éè¦å»æ ååºç»´æ¤ï¼') |
| | | } |
| | | } |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | // å
çº¤å¸¦é¡¹ç® |
| | | if (item.bushing && item.bushing.length > 0) { |
| | | item.bushing.forEach(a => { |
| | | if (a.fiber && a.fiber.length > 0) { |
| | | a.fiber.forEach(b => { |
| | | if (b.productList && b.productList.length > 0) { |
| | | b.productList.forEach(c => { |
| | | if (c.state == 1) { |
| | | if(type==0){ |
| | | let str = calBack(c.ask) |
| | | str&&obj.symbolList.push({ |
| | | symbolItem:str, |
| | | inspectionItem:c.inspectionItem, |
| | | }) |
| | | }else if(type==1){ |
| | | let arr = this.editTable.filter(b => b.sampleId == item.id) |
| | | arr.forEach(f => { |
| | | if(c.ask.includes(f.symbolItem)){ |
| | | let ask = calBack(c.ask, f.symbolItem,f.value) |
| | | if (ask) { |
| | | c.ask = ask |
| | | } |
| | | let tell = this.handleTell(c.tell, f.symbolItem,f.value) |
| | | if (tell) { |
| | | c.tell = tell |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | if (a.fibers && a.fibers.length > 0) { |
| | | a.fibers.forEach(b => { |
| | | if (b.productList && b.productList.length > 0) { |
| | | b.productList.forEach(c => { |
| | | if (c.state == 1) { |
| | | if(type==0){ |
| | | let str = calBack(c.ask) |
| | | str&&obj.symbolList.push({ |
| | | symbolItem:str, |
| | | inspectionItem:c.inspectionItem, |
| | | }) |
| | | }else if(type==1){ |
| | | // let ask = calBack(c.ask, c.rts) |
| | | // if (ask && c.state == 1) { |
| | | // c.ask = csk |
| | | // } |
| | | let arr = this.editTable.filter(b => b.sampleId == item.id) |
| | | arr.forEach(f => { |
| | | if(c.ask.includes(f.symbolItem)){ |
| | | let ask = calBack(c.ask, f.symbolItem,f.value) |
| | | if (ask) { |
| | | c.ask = ask |
| | | } |
| | | let tell = this.handleTell(c.tell, f.symbolItem,f.value) |
| | | if (tell) { |
| | | c.tell = tell |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | if (b.fiber && b.fiber.length > 0) { |
| | | b.fiber.forEach(c => { |
| | | if (c.productList && c.productList.length > 0) { |
| | | c.productList.forEach(d => { |
| | | if (d.state == 1) { |
| | | if(type==0){ |
| | | let str = calBack(d.ask) |
| | | str&&obj.symbolList.push({ |
| | | symbolItem:str, |
| | | inspectionItem:d.inspectionItem, |
| | | }) |
| | | }else if(type==1){ |
| | | // let ask = calBack(d.ask, d.rts) |
| | | // if (ask && d.state == 1) { |
| | | // d.ask = ask |
| | | // } |
| | | let arr = this.editTable.filter(b => b.sampleId == item.id) |
| | | arr.forEach(f => { |
| | | if(d.ask.includes(f.symbolItem)){ |
| | | let ask = calBack(d.ask, f.symbolItem,f.value) |
| | | if (ask) { |
| | | d.ask = ask |
| | | } |
| | | let tell = this.handleTell(d.tell, f.symbolItem,f.value) |
| | | if (tell) { |
| | | d.tell = tell |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | if(type==0){ |
| | | editTable.push(obj) |
| | | } |
| | | }) |
| | | if(type==0){ |
| | | editTable.forEach(a => { |
| | | a.symbolList.forEach(b => { |
| | | let arr = a.symbolList.filter(c => c.symbolItem == b.symbolItem); |
| | | b.inspectionItemList = arr.map(c => c.inspectionItem).join(',') |
| | | }) |
| | | }) |
| | | editTable.forEach(a => { |
| | | let mySet = new Set(); |
| | | a.symbolList = a.symbolList.filter(b =>{ |
| | | let num0 = mySet.size; |
| | | mySet.add(b.symbolItem); |
| | | let num1 = mySet.size; |
| | | if(num0!=num1){ |
| | | return true; |
| | | }else{ |
| | | return false |
| | | } |
| | | }) |
| | | }) |
| | | let editTableNew = [] |
| | | editTable.forEach(a => { |
| | | a.symbolList.forEach(b => { |
| | | let obj = { |
| | | sampleCode:a.sampleCode, |
| | | model:a.model, |
| | | symbolItem:b.symbolItem, |
| | | sampleId:a.sampleId, |
| | | value:null, |
| | | inspectionItemList:b.inspectionItemList, |
| | | modelNum:a.modelNum, |
| | | } |
| | | editTableNew.push(obj) |
| | | }) |
| | | }) |
| | | return editTableNew |
| | | }else{ |
| | | return sampleList |
| | | } |
| | | }, |
| | | saveMethod(sampleList){ |
| | | this.saveLoad = true |
| | | addRawCopperOrder({ |
| | | str: JSON.stringify({ |
| | | insOrder: this.addObj, |
| | | list: JSON.stringify(sampleList.map(a => { |
| | | if (a.modelNum) { |
| | | const index = a.modelNum.indexOf('Ã') |
| | | if (index === 0) { |
| | | a.model = a.model + a.modelNum |
| | | } else if (index === -1) { |
| | | a.model = a.model + '-' + a.modelNum |
| | | } else { |
| | | a.model = a.modelNum + a.model |
| | | } |
| | | } else { |
| | | a.model = a.model + ((a.modelNum == null || a.modelNum == '' || a.modelNum == 'null') ? '' : ('-' + a.modelNum)) |
| | | } |
| | | a.insProduct = a.insProduct.filter(b=>b.state === 1) |
| | | return a |
| | | })), |
| | | pairing: JSON.stringify(this.bsm2Val2) |
| | | }) |
| | | }).then(res => { |
| | | this.saveLoad = false |
| | | if (res.code == 201) return |
| | | this.$message.success('å·²æäº¤') |
| | | this.bsm3Dia = false; |
| | | this.goBack() |
| | | }).catch(e=>{ |
| | | this.saveLoad = false |
| | | }) |
| | | }, |
| | | getUserNowInfo() { |
| | | getUserNow().then(res => { |
| | | let selects = res.data |
| | | if (selects == null) return |
| | | this.addObj.userId = selects.id |
| | | this.addObj.company = selects.company |
| | | this.addObj.custom = selects.name |
| | | this.addObj.code = selects.code |
| | | this.addObj.phone = selects.phone |
| | | this.addObj.companyId = selects.departId |
| | | if(this.active==1){ |
| | | this.selectInsOrderTemplateInfo() |
| | | } |
| | | }) |
| | | }, |
| | | getProNum() { |
| | | this.sampleSelectionList.forEach((m, i) => { |
| | | Vue.set(this.sampleSelectionList[i], 'proNum', m.insProduct.filter(a => a.state == 1).length) |
| | | }) |
| | | this.$refs.sampleTable.doLayout() |
| | | }, |
| | | searchFilter() { |
| | | this.$refs.tree.filter(this.search) |
| | | }, |
| | | nodeOpen(data, node, el) { |
| | | $($(el.$el).find('.node_i')[0]).attr('class', 'node_i el-icon-folder-opened') |
| | | }, |
| | | nodeClose(data, node, el) { |
| | | $($(el.$el).find('.node_i')[0]).attr('class', 'node_i el-icon-folder') |
| | | }, |
| | | handleNodeClick(val, node, el) { |
| | | this.selectTree = '' |
| | | this.models = val.children |
| | | this.getNodeParent(node) |
| | | let flag = false |
| | | if (node.level == 3) { |
| | | if(node.data.children.length>0){ |
| | | node.data.children.forEach(a => { |
| | | let key = Object.keys(a) |
| | | if(!key.includes('level')) { |
| | | flag = true |
| | | } |
| | | }) |
| | | |
| | | } |
| | | } |
| | | this.selectTree = this.selectTree.replace(' - ', '') |
| | | if(flag) { |
| | | this.selectTree = ' - - ' + this.selectTree |
| | | } |
| | | let data = this.selectTree.split(' - ') |
| | | let data2 = '' |
| | | for (let index = data.length - 1; index >= 0; index--) { |
| | | data2 += " - " + data[index] |
| | | } |
| | | this.selectTree = data2.replace(' - ', '') |
| | | }, |
| | | getNodeParent(val) { |
| | | if (val.parent != null) { |
| | | if (val.data.children === null) { |
| | | this.selectTree += ' - ' + val.label + ' - ' + '' |
| | | } else { |
| | | this.selectTree += ' - ' + val.label |
| | | } |
| | | this.getNodeParent(val.parent) |
| | | } |
| | | }, |
| | | selectStandardTreeList() { |
| | | this.selectStandardTreeLoading = true |
| | | selectStandardTreeList2().then(res => { |
| | | this.list = res.data |
| | | this.list.forEach(a => { |
| | | this.expandedKeys.push(a.label) |
| | | }) |
| | | this.selectStandardTreeLoading=false |
| | | }) |
| | | }, |
| | | filterNode(value, data) { |
| | | if (!value) return true; |
| | | return data.label.indexOf(value) !== -1; |
| | | }, |
| | | activeStandardTree() { |
| | | let trees = this.selectTree.split(" - ") |
| | | if (trees.length < 3) { |
| | | this.$message.error('æªéæ©å¯¹è±¡') |
| | | return |
| | | } |
| | | this.addObj.factory = trees[0] |
| | | this.addObj.laboratory = trees[1] |
| | | this.addObj.sampleType = trees[2] |
| | | if (trees[3] === undefined || trees[3] === '' || trees[3] === '- ') { |
| | | this.addObj.sample = trees[2] |
| | | } else { |
| | | this.addObj.sample = trees[3] |
| | | } |
| | | this.addObj.model = (trees[4] == undefined ? null : trees[4]) |
| | | this.selectStandardTree = false |
| | | this.sampleList = [] |
| | | for (var i = 0; i < this.addObj.sampleNum; i++) { |
| | | this.sample.joinName = null |
| | | this.sample.joinModel = null |
| | | this.sample.joinNum = 1 |
| | | this.sample.sample = this.addObj.sample |
| | | this.sample.model = this.addObj.model |
| | | this.sample.unit = this.addObj.unit |
| | | this.sample.standardMethodListId = null |
| | | this.sample.insProduct = [] |
| | | this.sample.id = this.count |
| | | this.sample.childSampleList = [] |
| | | this.sample.insulating = null |
| | | this.sample.sheath = null |
| | | this.sampleList.push(this.HaveJson(this.sample)) |
| | | this.count++ |
| | | } |
| | | this.$refs.sampleTable.doLayout() |
| | | // this.selectsStandardMethodByFLSSM() |
| | | }, |
| | | selectsStandardMethodByFLSSM() { |
| | | this.methodLoad = true |
| | | selectsStandardMethodByFLSSM({tree: this.selectTree}).then(res => { |
| | | this.methodLoad = false |
| | | try { |
| | | if (res.data.standardMethodList.length == 0 && this.selectTree.split('-').length == 5) { |
| | | let arr = this.selectTree.split('-') |
| | | let arr0 = arr.slice(0, arr.length - 1) |
| | | let selectTree = arr0.join('-').substring(0, arr0.join('-').length - 1) |
| | | selectsStandardMethodByFLSSM({tree: selectTree}).then(ress => { |
| | | this.methods = ress.data.standardMethodList |
| | | }) |
| | | } else { |
| | | this.methods = res.data.standardMethodList |
| | | } |
| | | } catch (e) {} |
| | | }) |
| | | }, |
| | | addStandardTree() { |
| | | if (this.selectTree == null) return |
| | | this.sampleList = [] |
| | | this.productList = [] |
| | | for (var i = 0; i < this.addObj.sampleNum; i++) { |
| | | this.sample.joinName = null |
| | | this.sample.joinModel = null |
| | | this.sample.joinNum = 1 |
| | | this.sample.sample = this.addObj.sample |
| | | this.sample.model = this.addObj.model |
| | | this.sample.unit = this.addObj.unit |
| | | this.sample.standardMethodListId = null |
| | | this.sample.insProduct = [] |
| | | this.sample.id = parseInt(i+1) |
| | | this.sample.childSampleList = [] |
| | | this.sample.insulating = null |
| | | this.sample.sheath = null |
| | | this.sampleList.push(this.HaveJson(this.sample)) |
| | | // this.count++ |
| | | } |
| | | this.computationalPairing(this.sampleList.length) |
| | | this.bsm2Val2 = this.HaveJson(this.bsm2Val3) |
| | | }, |
| | | selectSample(val) { |
| | | this.sampleIds = [] |
| | | val.forEach(a => { |
| | | this.sampleIds.push(a.id) |
| | | }) |
| | | this.sampleSelectionList = val |
| | | }, |
| | | selectProduct(val) { |
| | | this.productListSelected = val |
| | | this.productIds = [] |
| | | val.forEach(a => { |
| | | this.productIds.push(a.id) |
| | | }) |
| | | }, |
| | | rowClick(row, column, event) { |
| | | this.currentMethod = row |
| | | let obj = this.methods.find(a => a.id == this.currentMethod.standardMethodListId) |
| | | if (obj && obj.code == 'ææ¯è¦æ±') { |
| | | this.isAskOnlyRead = true |
| | | } else { |
| | | this.isAskOnlyRead = false |
| | | } |
| | | this.sampleId = row.id |
| | | if (this.active !== 1) { |
| | | this.sampleIds = [] |
| | | this.sampleSelectionList.forEach(ele=>{ |
| | | if(ele.id == row.id){ |
| | | this.sampleIds.push(row.id) |
| | | } |
| | | }) |
| | | } |
| | | // this.productList = row.insProduct |
| | | if (this.productList !== null) { |
| | | setTimeout(() => { |
| | | this.productList.forEach(a => { |
| | | if (a.state == 1) this.toggleSelection(a) |
| | | }) |
| | | }, 200) |
| | | } |
| | | }, |
| | | toggleSelection(row) { |
| | | this.$refs.productTable.toggleRowSelection(row, true); |
| | | }, |
| | | selectOne(selection, row) { |
| | | this.bsm1DiaList = [] |
| | | row.state = row.state == 1 ? 0 : 1 |
| | | if(row.section === null) { |
| | | row.section = "" |
| | | } |
| | | if (row.sectionCopy === undefined && row.section) { |
| | | if (row.section.indexOf('[') > -1) { |
| | | this.$set(row, 'sectionCopy', row.section) |
| | | } |
| | | } |
| | | if (row.ask.includes('[')) { |
| | | this.$set(row, 'askCopy', row.ask) |
| | | } |
| | | if (row.tell.includes('[')) { |
| | | this.$set(row, 'tellCopy', row.tell) |
| | | } |
| | | // if (row.manHour.includes('[')) { |
| | | // this.$set(row, 'manHourCopy', row.manHour) |
| | | // } |
| | | // if (row.price.includes('[')) { |
| | | // this.$set(row, 'priceCopy', row.price) |
| | | // } |
| | | let arr = this.productList.filter(m=>m.state==1&&row.sectionCopy&&row.sectionCopy.includes(m.sectionCopy)&&m.ask&&m.sectionCopy.indexOf('[')==-1) |
| | | if (row.bsm === '1' && row.sectionCopy !== '' && row.sectionCopy !== null && row.sectionCopy !== undefined && row.state === 1&&arr.length==0) { |
| | | if (row.sectionCopy.indexOf('[') > -1) { |
| | | row.bsmRow = this.HaveJson(row) |
| | | } |
| | | row.bsm1 = true |
| | | this.bsm1DiaList.push(row) |
| | | this.bsm1DiaAll = true |
| | | } else if (row.bsm === '1' && row.sectionCopy !== '' && row.sectionCopy !== null && row.state === 0&&arr.length==0) { |
| | | row.bsm1 = false |
| | | }else if(arr.length>0){ |
| | | try{ |
| | | row.bsmRow = this.HaveJson(row) |
| | | let sectionCopy = arr[0].sectionCopy |
| | | let arr0 = JSON.parse(row.sectionCopy) |
| | | let arr1 = JSON.parse(row.ask) |
| | | // let arr2 = JSON.parse(row.manHour) |
| | | // let arr3 = JSON.parse(row.price) |
| | | let arr4 = JSON.parse(row.tell) |
| | | let index = arr0.indexOf(sectionCopy) |
| | | row.sectionCopy = sectionCopy |
| | | row.ask = arr1[index] |
| | | // row.manHour = arr2[index] |
| | | // row.price = arr3[index] |
| | | row.tell = arr4[index] |
| | | } catch(e) {} |
| | | } |
| | | this.sampleList.map(item => { |
| | | if (this.sampleIds.indexOf(item.id) > -1) { |
| | | item.insProduct.map(m => { |
| | | if (m.id == row.id) { |
| | | m.state = row.state; |
| | | } |
| | | return m; |
| | | }) |
| | | } |
| | | return item |
| | | }) |
| | | this.changeProductList0() |
| | | this.currentMethod.insProduct = this.productList0 |
| | | this.getProNum() |
| | | }, |
| | | permute(nums) { |
| | | const result = []; |
| | | |
| | | function backtrack(temp, nums) { |
| | | if (temp.length === 2) { |
| | | result.push([...temp]); |
| | | return; |
| | | } |
| | | for (let i = 0; i < nums.length; i++) { |
| | | if (temp.includes(nums[i])) continue; |
| | | // é¿å
é夿°å |
| | | if (temp.length > 0 && nums[i] < temp[temp.length - 1]) continue; // è§å®é¡ºåºï¼é¿å
éå¤ç»å |
| | | temp.push(nums[i]); |
| | | backtrack(temp, nums); |
| | | temp.pop(); |
| | | } |
| | | } |
| | | backtrack([], nums); |
| | | return result; |
| | | }, |
| | | computationalPairing(n) { |
| | | const nums = []; |
| | | for (let i = 1; i <= n; i++) { |
| | | nums.push(i); |
| | | } |
| | | this.bsm2Val3 = this.HaveJson(this.permute(nums)) |
| | | }, |
| | | tableRowClassName({row, rowIndex}) { |
| | | if (row.state === 0) { |
| | | return ''; |
| | | } |
| | | return 'warning-row'; |
| | | }, |
| | | selectInsOrderTemplateInfo() { |
| | | selectInsOrderTemplate({company: this.addObj.company}).then(res => { |
| | | this.templates = res.data |
| | | }) |
| | | }, |
| | | methodChange(val, row) { |
| | | if (val === null || val === '') return |
| | | if (this.sampleList.length > 1) { |
| | | // æä¸¤æ¡æ ·åæ¶ï¼ç¬¬äºæ¡æ ·åä¿¡æ¯åç¬¬ä¸æ¡ä¿æä¸è´ |
| | | this.sampleList.forEach(item => { |
| | | item.standardMethodListId = val |
| | | item.modelNum = row.modelNum |
| | | }) |
| | | } |
| | | this.currentMethod = row |
| | | let obj = this.methods.find(a => a.id == this.currentMethod.standardMethodListId) |
| | | if (obj && obj.code == 'ææ¯è¦æ±') { |
| | | this.isAskOnlyRead = true |
| | | } else { |
| | | this.isAskOnlyRead = false |
| | | } |
| | | this.getProductLoad = true |
| | | let selectTreeList = this.selectTree.split(" - ") |
| | | this.addObj.model&&(selectTreeList[selectTreeList.length - 1] = this.addObj.model) |
| | | selectStandardProductList({ |
| | | model: this.addObj.model?this.addObj.model:row.model, |
| | | modelNum: row.modelNum, |
| | | standardMethodListId: val, |
| | | factory: selectTreeList.join(" - "), |
| | | }).then(res => { |
| | | res.data.forEach(a => { |
| | | a.state = 0 |
| | | }) |
| | | row.insProduct = this.HaveJson(res.data) |
| | | this.getProductLoad = false |
| | | this.productList = row.insProduct |
| | | this.productList0 = JSON.parse(JSON.stringify(this.productList)) |
| | | this.$refs.sampleTable.setCurrentRow(row) |
| | | setTimeout(() => { |
| | | this.productList.forEach(a => { |
| | | if (a.state == 1) this.toggleSelection(a) |
| | | }) |
| | | }, 200) |
| | | }) |
| | | // this.searchTemList() |
| | | }, |
| | | // searchTemList () { |
| | | // this.temperatureList = [] |
| | | // this.$axios.post(this.$api.enums.selectEnumByCategory, { |
| | | // category: "çµåæ¸©åº¦å¾ªç¯æ£éª" |
| | | // }).then(res => { |
| | | // if (res.data.length > 0) { |
| | | // this.temperatureEngList = res.data |
| | | // res.data.forEach(item => { |
| | | // this.temperatureList.push(item.label) |
| | | // }) |
| | | // } |
| | | // }) |
| | | // }, |
| | | changeModel() { |
| | | this.sampleList.forEach(a => { |
| | | let obj = this.sampleIds.find(b => b == a.id) |
| | | if (obj) { |
| | | a.model = this.model |
| | | } |
| | | }) |
| | | }, |
| | | changeStandardMethodListId() { |
| | | this.sampleList.forEach(a => { |
| | | let obj = this.sampleIds.find(b => b == a.id) |
| | | if (obj) { |
| | | a.standardMethodListId = this.standardMethodListId |
| | | this.methodChange(this.standardMethodListId, a) |
| | | } |
| | | }) |
| | | }, |
| | | methodFocus() { |
| | | this.selectsStandardMethodByFLSSM() |
| | | }, |
| | | handleChangeModel(e) { |
| | | this.productList = [] |
| | | let num = this.selectTree.split('-').length; |
| | | if (num != 5) { |
| | | this.selectTree = this.selectTree + ' - ' + e |
| | | } else { |
| | | let arr = this.selectTree.split('-') |
| | | let arr0 = arr.slice(0, arr.length - 1) |
| | | this.selectTree = arr0.join('-') + '- ' + e |
| | | } |
| | | }, |
| | | // è¦æ±å¼ååæ¶ |
| | | requestChange(e, row,type) { |
| | | //this.currentMethod å½åæ ·åid |
| | | this.sampleList.forEach(item=>{ |
| | | if(item.id == this.currentMethod.id){ |
| | | item.insProduct.forEach(i=>{ |
| | | if(i.id == row.id){ |
| | | i[type] = e |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | }, |
| | | selectStandardMethods() { |
| | | selectStandardMethodEnum().then(res => { |
| | | this.methods = res.data |
| | | }) |
| | | }, |
| | | selectable() { |
| | | if (this.active > 1) { |
| | | return false |
| | | } else { |
| | | return true |
| | | } |
| | | }, |
| | | handleAll(e) { |
| | | if (e.length > 0) { |
| | | this.productList.map(m => { |
| | | if(e.find(a=>a.id == m.id)){ |
| | | m.state = 1 |
| | | } |
| | | return m |
| | | }) |
| | | } else { |
| | | this.productList.map(m => { |
| | | m.state = 0 |
| | | return m |
| | | }) |
| | | } |
| | | this.bsmRow3 = []; |
| | | this.bsm1DiaList = [] |
| | | this.productList.forEach(p => { |
| | | if (p.sectionCopy === undefined && p.section) { |
| | | if (p.section.indexOf('[') > -1) { |
| | | this.$set(p, 'sectionCopy', p.section) |
| | | } |
| | | } |
| | | if (p.ask.includes('[')) { |
| | | this.$set(p, 'askCopy', p.ask) |
| | | } |
| | | if (p.tell.includes('[')) { |
| | | this.$set(p, 'tellCopy', p.tell) |
| | | } |
| | | // if (p.manHour.includes('[')) { |
| | | // this.$set(p, 'manHourCopy', p.manHour) |
| | | // } |
| | | // if (p.price.includes('[')) { |
| | | // this.$set(p, 'priceCopy', p.price) |
| | | // } |
| | | if (p.bsm === '1' && p.sectionCopy !== '' && p.sectionCopy !== null && p.sectionCopy !== undefined && p.state === 1) { |
| | | if (p.sectionCopy.indexOf('[') > -1) { |
| | | p.bsmRow = this.HaveJson(p) |
| | | } |
| | | p.bsm1 = true |
| | | this.bsm1DiaList.push(p) |
| | | this.bsm1DiaAll = true |
| | | } else if (p.bsm === '1' && p.sectionCopy !== '' && p.sectionCopy !== null && p.state === 0) { |
| | | p.bsm1 = false |
| | | } |
| | | }) |
| | | if (e.length > 0) { |
| | | this.sampleList.map(item => { |
| | | if (this.sampleIds.indexOf(item.id) > -1) { |
| | | item.insProduct.map(m => { |
| | | m.state = 1 |
| | | return m; |
| | | }) |
| | | } |
| | | return item |
| | | }) |
| | | } else { |
| | | this.sampleList.map(item => { |
| | | if (this.sampleIds.indexOf(item.id) > -1) { |
| | | item.insProduct.map(m => { |
| | | m.state = 0 |
| | | return m; |
| | | }) |
| | | } |
| | | return item |
| | | }) |
| | | } |
| | | this.changeProductList0() |
| | | this.currentMethod.insProduct = this.productList0 |
| | | this.getProNum() |
| | | this.$nextTick(() => { |
| | | this.$refs.productTable.doLayout() |
| | | }) |
| | | }, |
| | | filterHandler(value, row, column) { |
| | | const property = column['property']; |
| | | return row[property] === value; |
| | | }, |
| | | // å
¨éç¹æ®å¼å¤çæ¡éæ©è¦æ±å¼çåè° |
| | | upBsmAll (item) { |
| | | const i = this.bsm1DiaList.findIndex(obj => obj.id === item.id) |
| | | if (i > -1) { |
| | | // æ¾å°ç¸åºçæ£éªé¡¹èµå¼ |
| | | this.bsm1DiaList[i].bsm1Val = item.bsm1Val |
| | | let sections = this.bsm1DiaList[i].bsmRow.sectionCopy && JSON.parse(this.bsm1DiaList[i].bsmRow.sectionCopy); |
| | | let asks = this.bsm1DiaList[i].bsmRow.askCopy && JSON.parse(this.bsm1DiaList[i].bsmRow.askCopy); |
| | | let tells = this.bsm1DiaList[i].bsmRow.tellCopy && JSON.parse(this.bsm1DiaList[i].bsmRow.tellCopy); |
| | | // let manHours = this.bsm1DiaList[i].bsmRow.manHourCopy && JSON.parse(this.bsm1DiaList[i].bsmRow.manHourCopy); |
| | | // let prices = this.bsm1DiaList[i].bsmRow.priceCopy && JSON.parse(this.bsm1DiaList[i].bsmRow.priceCopy); |
| | | for (var a in sections) { |
| | | if (this.bsm1DiaList[i].bsm1Val === sections[a]) { |
| | | this.productList.forEach(p => { |
| | | // å°éæ©å¥½çè¦æ±å¼èµå¼å°å表é |
| | | if (p.id === this.bsm1DiaList[i].bsmRow.id) { |
| | | p.section = sections[a] |
| | | p.ask = asks[a] |
| | | p.tell = tells[a] |
| | | // p.manHour = manHours[a] |
| | | // p.price = prices[a] |
| | | } |
| | | }) |
| | | break |
| | | } |
| | | } |
| | | } |
| | | this.changeProductList0() |
| | | this.currentMethod.insProduct = this.productList0 |
| | | }, |
| | | save1 () { |
| | | if (this.bsm1DiaList.length > 0) { |
| | | this.bsm1DiaList.forEach(item => { |
| | | if (!item.bsm1Val) { |
| | | throw this.$message.error('ç¹æ®é¡¹ç®å¿
é¡»å¤ç') |
| | | } |
| | | }) |
| | | } |
| | | this.bsm1DiaAll = false |
| | | }, |
| | | beforeClose(done) { |
| | | if (this.bsm1DiaList.length > 0) { |
| | | this.bsm1DiaList.forEach(item => { |
| | | if (!item.bsm1Val) { |
| | | throw this.$message.error('ç¹æ®é¡¹ç®å¿
é¡»å¤ç') |
| | | } |
| | | }) |
| | | } |
| | | done() |
| | | }, |
| | | beforeClose0(done) { |
| | | if (!this.bsm3Val) { |
| | | this.$message.error('RSTå¿
须填å') |
| | | return |
| | | } else { |
| | | if (Array.isArray(this.bsmRow3)) { |
| | | this.bsmRow3.forEach(item => { |
| | | item.rts = this.bsm3Val |
| | | }) |
| | | } else { |
| | | this.bsmRow3.rts = this.bsm3Val |
| | | } |
| | | } |
| | | done() |
| | | }, |
| | | getTotal() { |
| | | this.totalArr = [] |
| | | // this.total = 0; |
| | | this.sampleList.forEach(item => { |
| | | if (item.insProduct && item.insProduct.length > 0) { |
| | | item.insProduct.forEach(a => { |
| | | this.totalArr.push(a) |
| | | }) |
| | | } |
| | | if (item.bushing && item.bushing.length > 0) { |
| | | item.bushing.forEach(a => { |
| | | if (a.fiber && a.fiber.length > 0) { |
| | | a.fiber.forEach(b => { |
| | | if (b.productList && b.productList.length > 0) { |
| | | b.productList.forEach(c => { |
| | | this.totalArr.push(c) |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | if (a.fibers && a.fibers.length > 0) { |
| | | a.fibers.forEach(b => { |
| | | if (b.productList && b.productList.length > 0) { |
| | | b.productList.forEach(c => { |
| | | this.totalArr.push(c) |
| | | }) |
| | | } |
| | | if (b.fiber && b.fiber.length > 0) { |
| | | b.fiber.forEach(c => { |
| | | if (c.productList && c.productList.length > 0) { |
| | | c.productList.forEach(d => { |
| | | this.totalArr.push(d) |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | } |
| | | }) |
| | | let mySet = new Set(); |
| | | let arr0 = this.totalArr.filter(item => { |
| | | if (item.state == 1) { |
| | | let num1 = mySet.size |
| | | if (item.manHourGroup === '' || !item.manHourGroup) { |
| | | return true |
| | | } else { |
| | | mySet.add(item.manHourGroup) |
| | | let num2 = mySet.size |
| | | if (num2 > num1) { |
| | | return true |
| | | } else { |
| | | return false |
| | | } |
| | | } |
| | | } |
| | | }) |
| | | // arr0.forEach(item => { |
| | | // this.total += Number(item.price) |
| | | // }) |
| | | |
| | | }, |
| | | goBack () { |
| | | const obj = { path: "/business/materialOrder" }; |
| | | this.$tab.closeOpenPage(obj); |
| | | } |
| | | } |
| | | } |
| | | </script> |
| | | <style scoped> |
| | | .header { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | margin-bottom: 10px; |
| | | } |
| | | </style> |
| | |
| | | <template> |
| | | <div class="ins_order_add"> |
| | | <div class="app-container"> |
| | | <div> |
| | | <el-row class="title"> |
| | | <el-col :span="active > 1 && isShowTab ? 5 : 6" style="padding-left: 20px;text-align: left;">éè´è®¢åä¿¡æ¯</el-col> |
| | | <el-col v-if="active > 1 && isShowTab" :span="4" style="text-align: left;margin-top: 12px"> |
| | | <ul class="tab"> |
| | | <div class="header"> |
| | | <div> |
| | | <span>éè´è®¢åä¿¡æ¯</span> |
| | | <ul class="tab" v-if="active > 1 && isShowTab"> |
| | | <li v-for="(m,i) in dataTitle" :key="i" :class="{active:i===dataIndex}" @click="handleDataTab(m,i)">{{m.label}}</li> |
| | | </ul> |
| | | </el-col> |
| | | <el-col :span="active > 1 && isShowTab ? 15 : 18" style="text-align: right;"> |
| | | <el-select v-show="active==1" v-model="template" placeholder="ä¸å模æ¿" size="medium" style="margin-right: 10px;" |
| | | @change="selectInsOrderTemplateById"> |
| | | </div> |
| | | <div> |
| | | <el-select v-show="active==1" v-model="template" placeholder="ä¸å模æ¿" size="small" style="margin-right: 10px;" |
| | | @change="selectInsOrderTemplateByIdList"> |
| | | <el-option v-for="(a, ai) in templates" :key="ai" :label="a.name" :value="a.id"> |
| | | <span style="float: left">{{ a.name }}</span> |
| | | <i class="el-icon-delete" style="float: right; color: #66b1ff; font-size: 16px" |
| | | @click.stop="handleDelete(a)"></i> |
| | | </el-option> |
| | | </el-select> |
| | | <el-button v-show="active==1" size="medium" @click="templateDia=true"> |
| | | <el-button v-show="active==1" size="small" @click="templateDia=true"> |
| | | <span style="color: #3A7BFA;">ä¿å模æ¿</span> |
| | | </el-button> |
| | | <el-button v-show="active==1 && addObj.orderType === 'è¿åæ£éª'" :loading="noNeedCheckLoad" size="medium" type="primary" @click="noNeedCheck">å
æ£</el-button> |
| | | <el-button v-show="active==1" :loading="saveLoad" size="medium" type="primary" @click="save">æäº¤</el-button> |
| | | <el-button size="medium" @click="goBack"> |
| | | <el-button v-show="active==1 && addObj.orderType === 'è¿åæ£éª'" :loading="noNeedCheckLoad" size="small" type="primary" @click="noNeedCheck">å
æ£</el-button> |
| | | <el-button v-show="active==1" :loading="saveLoad" size="small" type="primary" @click="save">æäº¤</el-button> |
| | | <el-button size="small" @click="goBack"> |
| | | <span style="color: #3A7BFA;">è¿å</span> |
| | | </el-button> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <div class="search"> |
| | | <el-form ref="addObj" :inline="true" :model="addObj" :rules="addObjRules" label-width="120px"> |
| | | <el-form ref="addObj" :inline="true" :model="addObj" :rules="addObjRules" label-width="90px"> |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="éè´è®¢åå·:"> |
| | |
| | | <el-row> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="åä½:" prop="buyUnitMeas"> |
| | | <el-input v-model="addObj.buyUnitMeas" class="addObj-info" disabled size="small"></el-input> |
| | | <el-input v-model="addObj.buyUnitMeas" class="addObj-info" clearable disabled size="small"></el-input> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="æ£éªç±»å«:" prop="orderType"> |
| | | <el-select v-model="addObj.orderType" :disabled="active>1 || orderType===1" clearable size="small" style="width: 100%"> |
| | | <el-option v-for="(a, ai) in checkType" :key="ai" :label="a.label" :value="a.value"></el-option> |
| | | <el-option v-for="(a, ai) in dict.type.check_type" :key="ai" :label="a.label" :value="a.value"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="è§æ ¼åå·:" placeholder="请填å" prop="partDetail"> |
| | | <el-tooltip :content="addObj.partDetail" :disabled="!addObj.partDetail"> |
| | | <el-input v-model="addObj.partDetail" :disabled="active > 1" class="addObj-info" size="small"></el-input> |
| | | <el-input v-model="addObj.partDetail" :disabled="active > 1" clearable class="addObj-info" size="small"></el-input> |
| | | </el-tooltip> |
| | | </el-form-item> |
| | | </el-col> |
| | |
| | | <el-col :span="6"> |
| | | <el-form-item class="addObj-form-item" label="ç´§æ¥ç¨åº¦:" placeholder="è¯·éæ©" prop="type"> |
| | | <el-select v-model="addObj.type" :disabled="active>1" class="addObj-info" clearable size="small" style="width: 100%"> |
| | | <el-option v-for="(a, ai) in types" :key="ai" :label="a.label" :value="a.value"></el-option> |
| | | <el-option v-for="(a, ai) in dict.type.urgency_level" :key="ai" :label="a.label" :value="a.value"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | </el-col> |
| | |
| | | </el-form> |
| | | </div> |
| | | <div> |
| | | <div style="display: flex;flex-direction: row;justify-content: space-between;padding: 5px 0;"> |
| | | <div v-if="active==1" style="display: flex;background: transparent;"> |
| | | <div class="search_thing"> |
| | | <div class="search_label">æ ·ååå·ï¼</div> |
| | | <div class="search_input"> |
| | | <div style="display: flex;justify-content: space-between;"> |
| | | <div v-if="active==1"> |
| | | <el-form :inline="true" :model="addObj1" label-width="90px"> |
| | | <el-form-item label="æ ·ååå·:" style="margin-bottom: 6px"> |
| | | <el-select v-model="model" :placeholder="active>1 ? '' : '请è¾å
¥'" |
| | | allow-create clearable default-first-option filterable |
| | | size="small" |
| | |
| | | <el-option v-for="item in models" :key="item.value" :label="item.label" :value="item.value"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | </div> |
| | | <div class="search_thing"> |
| | | <div class="search_label">æ£éªæ åï¼</div> |
| | | <div class="search_input"> |
| | | </el-form-item> |
| | | <el-form-item label="æ£éªæ å:"> |
| | | <el-select v-model="standardMethodListId" :loading="methodLoad" |
| | | :placeholder="active>1 ? '' : '请è¾å
¥'" clearable size="small" |
| | | @change="changeStandardMethodListId" @focus="methodFocus"> |
| | | <el-option v-for="item in methods" :key="item.id" :label="item.code" :value="item.id"> |
| | | </el-option> |
| | | </el-select> |
| | | </div> |
| | | </div> |
| | | </el-form-item> |
| | | </el-form> |
| | | </div> |
| | | <div class="search_thing"> |
| | | <el-button v-show="active==1" :disabled="sampleList.length === 2" size="medium" type="primary" @click="handleSplitCountNum">æå</el-button> |
| | | <div style="margin-top: 3px"> |
| | | <el-button v-show="active==1" :disabled="sampleList.length === 2" size="small" type="primary" @click="handleSplitCountNum">æå</el-button> |
| | | </div> |
| | | </div> |
| | | |
| | | <el-table ref="sampleTable" :data="sampleList" |
| | | border class="el-table sampleTable" |
| | | class="el-table sampleTable" |
| | | highlight-current-row |
| | | max-height="400px" style="margin-top: 10px;" |
| | | max-height="400px" |
| | | tooltip-effect="dark" |
| | | @selection-change="selectSample" @row-click="rowClick"> |
| | | <el-table-column v-if="active==1" :selectable="selectable" type="selection" width="65"></el-table-column> |
| | |
| | | </el-table-column> |
| | | </el-table> |
| | | <el-table ref="productTable" v-loading="getProductLoad" :data="productList" |
| | | :row-class-name="tableRowClassName" border |
| | | :row-class-name="tableRowClassName" |
| | | class="el-table" |
| | | max-height="400px" |
| | | style="margin-bottom: 10px;" |
| | |
| | | width="32%"> |
| | | <span>{{ dialogMessage }}</span> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button type="primary" @click="$parent.playOrder(0)">ç¡® å®</el-button> |
| | | <el-button type="primary" @click="goBack()">ç¡® å®</el-button> |
| | | </span> |
| | | </el-dialog> |
| | | <el-dialog |
| | |
| | | |
| | | <script> |
| | | import ValueTable from "@/components/Table/value-table.vue"; |
| | | import { |
| | | addInsOrder, |
| | | addRawMaterOrderTemplate, delRawMaterOrderTemplate, |
| | | getInsOrder, |
| | | getUserNow, |
| | | notificationRawOrder, selectRawMaterOrderTemplateById, selectStandardMethodEnum, selectStandardProductList, |
| | | selectStandardTreeListByPartNo |
| | | } from "@/api/business/rawMaterialOrder"; |
| | | |
| | | export default { |
| | | name: "CustomsInspection", |
| | | dicts: ['check_type', 'urgency_level'], |
| | | components: { |
| | | ValueTable, |
| | | }, |
| | | props: { |
| | | active: { |
| | | type: Number, |
| | | default: () => 0 |
| | | }, |
| | | customsInspection: { |
| | | type: Object, |
| | | default: () => {} |
| | | }, |
| | | currentId: { |
| | | type: Number, |
| | | default: () => 0 |
| | | }, |
| | | orderType: { |
| | | type: Number, |
| | | default: () => 0 |
| | | }, |
| | |
| | | }, |
| | | data() { |
| | | return { |
| | | customsInspection: {}, |
| | | orderType: '', |
| | | active: 0, |
| | | editTable:[], // åºé´ç¹æ®å¼å¡«å |
| | | template: null, |
| | | saveLoad: false, // ä¿åæé®loading |
| | |
| | | { required: true, message: 'è¯·å¡«åæ½æ£æ°é', trigger: 'blur' } |
| | | ], |
| | | partDetail: [ |
| | | { required: true, message: '请填åé¶ä»¶æè¿°', trigger: 'blur' } |
| | | { required: true, message: '请填åè§æ ¼åå·', trigger: 'blur' } |
| | | ], |
| | | orderType: [ |
| | | { required: true, message: 'è¯·éæ©æ£éªç±»å«', trigger: 'change' } |
| | |
| | | sampleId: null, |
| | | // total: 0, |
| | | totalArr: [], |
| | | addObj1: {}, |
| | | model: null, |
| | | standardMethodListId: null, |
| | | inspectionItem:null, |
| | |
| | | watch: { |
| | | sampleList() { |
| | | this.addObj.method = null |
| | | // this.productList = [] |
| | | }, |
| | | productList: { |
| | | deep: true, |
| | |
| | | } |
| | | }, |
| | | mounted() { |
| | | this.getUserNow() // è·åå½åç¨æ·ä¿¡æ¯ |
| | | this.selectCheckType() // æ¥è¯¢æ£éªç±»å |
| | | this.active = this.$route.query.active |
| | | this.orderType = this.$route.query.orderType |
| | | this.customsInspection = this.$route.query.customsInspection |
| | | // this.getUserNowList() // è·åå½åç¨æ·ä¿¡æ¯ |
| | | this.selectStandardMethods() // è·åæ£éªæ åä¸ææ¡æ°æ® |
| | | this.selectEnumByCategoryForType() // è·åç´§æ¥ç¨åº¦ä¸ææ¡ |
| | | this.getInfo() // è·åæ°æ® |
| | | |
| | | }, |
| | | methods: { |
| | | save1 () { |
| | |
| | | } |
| | | // æ¥ç |
| | | // è¯·æ±æ¥å£ï¼åæ¾æ°æ® |
| | | this.$axios.post(this.$api.insOrder.getInsOrder, { |
| | | getInsOrder({ |
| | | orderId: orderId |
| | | }).then(res => { |
| | | if (res.code === 200) { |
| | |
| | | } |
| | | }) |
| | | } else { |
| | | this.$axios.get(this.$api.rawMaterialOrder.notificationRawOrder+'?ifsInventoryId='+this.customsInspection.id).then(res => { |
| | | notificationRawOrder({ifsInventoryId:this.customsInspection.id}).then(res => { |
| | | if (res.code === 200) { |
| | | if (res.data === 1) { |
| | | this.dialogVisible2 = true |
| | |
| | | } |
| | | }) |
| | | // æ¥æ£æµç¨ |
| | | this.$axios.get(this.$api.materialInspection.selectStandardTreeListByPartNo+'?partNo='+this.customsInspection.partNo).then(res => { |
| | | selectStandardTreeListByPartNo({partNo:this.customsInspection.partNo}).then(res => { |
| | | if (res.code === 200) { |
| | | this.addObj.sample = res.data.label |
| | | this.codeLevel = res.data.code |
| | |
| | | this.selectTree = str.join(' - ') |
| | | this.addListInfo(this.codeLevel, res.data) // åæææ ·åæ¯åºå®çï¼å°±é»è®¤èµå¼ä¸æ¡æ°æ®ï¼å¯æå |
| | | this.selectInsOrderTemplate() // åæææ¨¡æ¿å表æ¥è¯¢ |
| | | } else { |
| | | this.dialogVisible = true |
| | | this.dialogMessage = res.message |
| | | } |
| | | }).catch(err => { |
| | | console.log('err---', err) |
| | | this.dialogVisible = true |
| | | this.dialogMessage = err.message |
| | | }) |
| | | } |
| | | }, |
| | | // æ¥è¯¢æ¨¡æ¿-åæ¾æ¨¡æ¿ |
| | | selectInsOrderTemplateById(e) { |
| | | this.$axios.get(this.$api.materialInspection.selectRawMaterOrderTemplateById + '?id=' + e).then(res => { |
| | | if (res.code == 201) return |
| | | selectInsOrderTemplateByIdList(e) { |
| | | selectRawMaterOrderTemplateById({id: e}).then(res => { |
| | | let obj = JSON.parse(res.data) |
| | | this.sampleList = obj.sampleList; |
| | | this.productList = obj.sampleList[0].insProduct |
| | |
| | | item.insProduct = this.productList |
| | | }) |
| | | this.templateLoading = true; |
| | | this.$axios.post(this.$api.materialInspection.addRawMaterOrderTemplate, { |
| | | addRawMaterOrderTemplate({ |
| | | partNo: this.addObj.partNo, |
| | | name: this.templateName, |
| | | thing: JSON.stringify({ |
| | |
| | | sampleList: sampleList, |
| | | selectTree:this.selectTree |
| | | }) |
| | | }, { |
| | | headers: { |
| | | 'Content-Type': 'application/json' |
| | | } |
| | | }).then(res => { |
| | | if (res.code == 201) return |
| | | this.templateLoading = false; |
| | | this.templateDia = false; |
| | | this.$message.success('ä¿åæå') |
| | |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning" |
| | | }).then(() => { |
| | | this.$axios.post(this.$api.materialInspection.delRawMaterOrderTemplate, { |
| | | id: row.id |
| | | }).then(res => { |
| | | if (res.code === 201) { |
| | | return |
| | | } |
| | | delRawMaterOrderTemplate({id: row.id}).then(res => { |
| | | this.$message.success('å 餿å') |
| | | this.selectInsOrderTemplate() |
| | | }).catch(e => { |
| | |
| | | }, |
| | | // æ¥è¯¢æ¨¡æ¿å表 |
| | | selectInsOrderTemplate() { |
| | | this.$axios.get(this.$api.materialInspection.selectRawMaterOrderTemplate+'?partNo='+this.addObj.partNo).then(res => { |
| | | if (res.code == 201) return |
| | | selectStandardTreeListByPartNo({partNo:this.addObj.partNo}).then(res => { |
| | | this.templates = res.data |
| | | }) |
| | | }, |
| | |
| | | this.addObj.model = (trees[4] == undefined ? null : trees[4]) |
| | | this.addObj.ifsInventoryId = this.customsInspection.id |
| | | this.noNeedCheckLoad = true |
| | | this.$axios.post(this.$api.rawMaterialOrder.addExemptionOrder, { |
| | | addExemptionOrder({ |
| | | str: JSON.stringify({ |
| | | insOrder: this.addObj, |
| | | list: JSON.stringify(sampleList.map(a => { |
| | |
| | | if (res.code == 201) return |
| | | this.noNeedCheckDia = false |
| | | this.$message.success('å·²æäº¤') |
| | | this.$parent.playOrder(0) |
| | | this.goBack() |
| | | }).catch(e=>{ |
| | | this.noNeedCheckLoad = false |
| | | }) |
| | |
| | | this.addObj.model = (trees[4] == undefined ? null : trees[4]) |
| | | this.addObj.ifsInventoryId = this.customsInspection.id |
| | | this.saveLoad = true |
| | | this.$axios.post(this.$api.insOrder.addInsOrder, { |
| | | addInsOrder({ |
| | | str: JSON.stringify({ |
| | | insOrder: this.addObj, |
| | | list: JSON.stringify(sampleList.map(a => { |
| | |
| | | if (res.code == 201) return |
| | | this.$message.success('å·²æäº¤') |
| | | this.bsm3Dia = false; |
| | | this.$parent.playOrder(0) |
| | | this.goBack() |
| | | }).catch(e=>{ |
| | | this.saveLoad = false |
| | | }) |
| | |
| | | } |
| | | }) |
| | | }, |
| | | selectCheckType() { |
| | | this.$axios.post(this.$api.enums.selectEnumByCategory, { |
| | | category: "æ£éªç±»å" |
| | | }).then(res => { |
| | | this.checkType = res.data |
| | | }) |
| | | }, |
| | | // è·åå½åç¨æ·ä¿¡æ¯ |
| | | getUserNow() { |
| | | this.$axios.get(this.$api.user.getUserNow).then(res => { |
| | | getUserNowList() { |
| | | getUserNow().then(res => { |
| | | let selects = res.data |
| | | if (selects == null) return |
| | | this.addObj.userId = selects.id |
| | |
| | | }, |
| | | // è·åæ£éªæ åä¸ææ¡æ°æ® |
| | | selectStandardMethods() { |
| | | this.$axios.get(this.$api.standardTree.selectStandardMethodEnum).then(res => { |
| | | selectStandardMethodEnum().then(res => { |
| | | this.methods = res.data |
| | | }) |
| | | }, |
| | |
| | | }, |
| | | selectsStandardMethodByFLSSM() { |
| | | this.methodLoad = true |
| | | this.$axios.post(this.$api.standardTree.selectsStandardMethodByFLSSM, { |
| | | selectsStandardMethodByFLSSM({ |
| | | tree: this.selectTree |
| | | }).then(res => { |
| | | this.methodLoad = false |
| | |
| | | let arr = this.selectTree.split('-') |
| | | let arr0 = arr.slice(0, arr.length - 1) |
| | | let selectTree = arr0.join('-').substring(0, arr0.join('-').length - 1) |
| | | this.$axios.post(this.$api.standardTree.selectsStandardMethodByFLSSM, { |
| | | selectsStandardMethodByFLSSM({ |
| | | tree: selectTree |
| | | }).then(ress => { |
| | | this.methods = ress.data.standardMethodList |
| | |
| | | this.getProductLoad = true |
| | | let selectTreeList = this.selectTree.split(" - ") |
| | | this.addObj.model&&(selectTreeList[selectTreeList.length - 1] = this.addObj.model) |
| | | this.$axios.post(this.$api.standardTree.selectStandardProductList, { |
| | | selectStandardProductList({ |
| | | model: this.addObj.model?this.addObj.model:row.model, |
| | | modelNum: row.modelNum, |
| | | standardMethodListId: val, |
| | | factory: selectTreeList.join(" - "), |
| | | partNo: this.addObj.partNo, |
| | | ifsInventoryId: this.customsInspection.id |
| | | }, { |
| | | headers: { |
| | | 'Content-Type': 'application/json' |
| | | } |
| | | }).then(res => { |
| | | this.getProductLoad = false |
| | | if (res.code === 200) { |
| | |
| | | this.selectTree = arr0.join(' - ') + '- ' + e |
| | | } |
| | | }, |
| | | selectEnumByCategoryForType() { |
| | | this.$axios.post(this.$api.enums.selectEnumByCategory, { |
| | | category: "ç´§æ¥ç¨åº¦" |
| | | }).then(res => { |
| | | this.types = res.data |
| | | }) |
| | | }, |
| | | // è¦æ±å¼ååæ¶ |
| | | requestChange(e, row) { |
| | | this.sampleList.map(item => { |
| | |
| | | p.section = sections[a] |
| | | p.ask = asks[a] |
| | | p.tell = tells[a] |
| | | // p.manHour = manHours[a] |
| | | // p.price = prices[a] |
| | | } |
| | | }) |
| | | break |
| | |
| | | if (row.tell.includes('[')) { |
| | | this.$set(row, 'tellCopy', row.tell) |
| | | } |
| | | // if (row.manHour.includes('[')) { |
| | | // this.$set(row, 'manHourCopy', row.manHour) |
| | | // } |
| | | // if (row.price.includes('[')) { |
| | | // this.$set(row, 'priceCopy', row.price) |
| | | // } |
| | | let arr = this.productList.filter(m=>m.state==1&&row.sectionCopy&&row.sectionCopy.includes(m.sectionCopy)&&m.ask&&m.sectionCopy.indexOf('[')==-1) |
| | | if (row.bsm === '1' && row.sectionCopy !== '' && row.sectionCopy !== null && row.sectionCopy !== undefined && row.state === 1&&arr.length==0) { |
| | | if (row.sectionCopy.indexOf('[') > -1) { |
| | |
| | | let section = arr[0].section |
| | | let arr0 = JSON.parse(row.section) |
| | | let arr1 = JSON.parse(row.ask) |
| | | // let arr2 = JSON.parse(row.manHour) |
| | | // let arr3 = JSON.parse(row.price) |
| | | let arr4 = JSON.parse(row.tell) |
| | | let index = arr0.indexOf(section) |
| | | row.section = section |
| | | row.ask = arr1[index] |
| | | // row.manHour = arr2[index] |
| | | // row.price = arr3[index] |
| | | row.tell = arr4[index] |
| | | } catch(e) {} |
| | | } |
| | |
| | | if (p.tell.includes('[')) { |
| | | this.$set(p, 'tellCopy', p.tell) |
| | | } |
| | | // if (p.manHour.includes('[')) { |
| | | // this.$set(p, 'manHourCopy', p.manHour) |
| | | // } |
| | | // if (p.price.includes('[')) { |
| | | // this.$set(p, 'priceCopy', p.price) |
| | | // } |
| | | if (p.bsm === '1' && p.sectionCopy !== '' && p.sectionCopy !== null && p.sectionCopy !== undefined && p.state === 1) { |
| | | if (p.sectionCopy.indexOf('[') > -1) { |
| | | p.bsmRow = this.HaveJson(p) |
| | |
| | | </script> |
| | | |
| | | <style scoped> |
| | | .addObj-form-item { |
| | | width: 100%; |
| | | } |
| | | .ins_order_add { |
| | | width: 100%; |
| | | height: 100%; |
| | | overflow-y: auto; |
| | | overflow-x: hidden; |
| | | } |
| | | |
| | | .ins_order_add::-webkit-scrollbar { |
| | | width: 0; |
| | | } |
| | | |
| | | .title { |
| | | height: 60px; |
| | | line-height: 60px; |
| | | } |
| | | |
| | | .search { |
| | | width: calc(100% - 40px); |
| | | background-color: #fff; |
| | | padding: 5px 40px 5px 0; |
| | | } |
| | | |
| | | .search_thing { |
| | | .header { |
| | | display: flex; |
| | | align-items: center; |
| | | height: 50px; |
| | | } |
| | | |
| | | .search_label { |
| | | width: 120px; |
| | | font-size: 14px; |
| | | text-align: right; |
| | | } |
| | | |
| | | .search_input { |
| | | width: calc(100% - 120px); |
| | | } |
| | | |
| | | .node_i { |
| | | color: orange; |
| | | font-size: 18px; |
| | | } |
| | | |
| | | .el-select-dropdown__item { |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: space-between; |
| | | } |
| | | |
| | | .pairing { |
| | | text-align: center; |
| | | line-height: 36px; |
| | | margin: 3px 0; |
| | | border: 1px solid rgba(0, 0, 0, 0.1); |
| | | border-radius: 4px; |
| | | } |
| | | |
| | | .askRts { |
| | | width: 100px; |
| | | font-size: 12px; |
| | | border-top: 0; |
| | | border-left: 0; |
| | | border-right: 0; |
| | | border-bottom: 2px solid rgba(0, 0, 0, 0.3); |
| | | text-align: center; |
| | | background-color: rgba(0, 0, 0, 0.1); |
| | | outline: none; |
| | | border-radius: 2px; |
| | | line-height: 24px; |
| | | margin-top: 5px; |
| | | } |
| | | .circulateTable { |
| | | display: flex; |
| | | flex-direction: row; |
| | | justify-content: space-between; |
| | | } |
| | | .opticalProject { |
| | | width: 38%; |
| | | } |
| | | .temperatureList { |
| | | width: 60%; |
| | | } |
| | | .temperatureListTitle { |
| | | display: flex; |
| | | flex-direction: row; |
| | | justify-content: space-between; |
| | | line-height: 30px; |
| | | } |
| | | >>> .el-form-item__content { |
| | | text-align: left; |
| | | width: 65%; |
| | | } |
| | | .ins_order_add .el-input-group__append, |
| | | .el-input-group__prepend { |
| | | padding: 0 10px; |
| | | } |
| | | |
| | | .ins_order_add .el-tree-node__content { |
| | | height: 32px; |
| | | font-size: 14px; |
| | | border-radius: 2px; |
| | | } |
| | | |
| | | .ins_order_add .el-tree--highlight-current .el-tree-node.is-current>.el-tree-node__content { |
| | | color: #3A7BFA; |
| | | } |
| | | |
| | | .ins_order_add .has-gutter .el-table__cell .cell { |
| | | line-height: 30px; |
| | | background-color: #fafafa; |
| | | } |
| | | |
| | | .ins_order_add .has-gutter .el-table__cell { |
| | | background-color: #fafafa !important; |
| | | } |
| | | |
| | | .ins_order_add .el-table__row .cell { |
| | | font-size: 12px; |
| | | } |
| | | |
| | | .ins_order_add .el-table .warning-row .cell { |
| | | color: #3A7BFA; |
| | | margin-bottom: 10px; |
| | | } |
| | | .tab { |
| | | list-style-type: none; |
| | |
| | | <template> |
| | | <div class="app-container"> |
| | | <div style="width: 100%;height: 100%;"> |
| | | <div> |
| | | <el-row class="title"> |
| | | <el-col :span="12" style="text-align: left;">åæææ£éªä¸å</el-col> |
| | | <el-col :span="12" style="text-align: right;"> |
| | | <el-button v-show="tabIndex === 3 || tabIndex === 2" :loading="outLoading" size="small" type="primary" @click="handleOut">导åº</el-button> |
| | | <el-button v-if="tabIndex === 0" size="small" type="primary" @click="copper">éææä¸å</el-button> |
| | | <el-button v-if="tabIndex !== 0" size="small" type="primary" @click="openPrint">æ ç¾æå°</el-button> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | <div> |
| | | <div class="search"> |
| | | <el-form :model="entity" ref="entity" size="small" :inline="true"> |
| | | <el-row> |
| | | <el-form-item label="æ¹å·" prop="menuName"> |
| | | <el-input v-model="entity.updateBatchNo" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="å§æç¼å·" prop="menuName"> |
| | | <el-input v-model="entity.entrustCode" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="é¶ä»¶å·" prop="menuName"> |
| | | <el-input v-model="entity.partNo" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="é¶ä»¶æè¿°" prop="menuName"> |
| | | <el-input v-model="entity.partDesc" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form :model="entity" ref="entity" size="small" :inline="true"><el-form-item label="æ¹å·" prop="updateBatchNo"> |
| | | <el-input v-model="entity.updateBatchNo" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item><el-form-item label="å§æç¼å·" prop="entrustCode"> |
| | | <el-input v-model="entity.entrustCode" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item><el-form-item label="é¶ä»¶å·" prop="partNo"> |
| | | <el-input v-model="entity.partNo" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item><el-form-item label="é¶ä»¶æè¿°" prop="partDesc"> |
| | | <el-input v-model="entity.partDesc" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item> |
| | | <el-button v-if="tabIndex === 2 || tabIndex === 3 || tabIndex === 4" :icon="!more?'el-icon-arrow-down':'el-icon-arrow-up'" style="color: #3A7BFA;" type="text" @click="more=!more">{{!more?'æ´å¤':'æ¶èµ·'}}</el-button> |
| | | <el-button icon="el-icon-search" size="small" type="primary" @click="refreshTable()">æ¥ è¯¢</el-button> |
| | | <el-button icon="el-icon-refresh" size="small" @click="refresh()">é ç½®</el-button> |
| | | </el-row> |
| | | <el-row> |
| | | <el-form-item label="ä¾åºååç§°" prop="menuName" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-input v-model="entity.supplierName" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="æ ·ååå·" prop="menuName" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-input v-model="entity.sampleModel" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="æ£éªç¶æ" prop="menuName" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-select v-model="entity.inspectStatus" clearable |
| | | size="small" style="width: 100%;" @change="refreshTable()"> |
| | | <el-option v-for="(a, i) in inspectStatusList" :key="i" :label="a.label" :value="a.value"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="ä¸åæ¶é´" prop="menuName" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-date-picker |
| | | v-model="entity.date" |
| | | end-placeholder="ç»ææ¥æ" |
| | | format="yyyy-MM-dd" |
| | | placeholder="éæ©æ¥æ" |
| | | range-separator="è³" |
| | | size="small" |
| | | start-placeholder="å¼å§æ¥æ" |
| | | style="width: 100%;" |
| | | type="daterange" |
| | | value-format="yyyy-MM-dd"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-row> |
| | | <el-button size="mini" type="primary" @click="refreshTable()">æ¥è¯¢</el-button> |
| | | <el-button size="mini" @click="refresh()">éç½®</el-button> |
| | | </el-form-item> |
| | | <el-form-item label="ä¾åºååç§°" prop="supplierName" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-input v-model="entity.supplierName" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="æ ·ååå·" prop="sampleModel" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-input v-model="entity.sampleModel" clearable placeholder="请è¾å
¥" |
| | | size="small" |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-form-item label="æ£éªç¶æ" prop="inspectStatus" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-select v-model="entity.inspectStatus" clearable |
| | | size="small" @change="refreshTable()"> |
| | | <el-option v-for="(a, i) in inspectStatusList" :key="i" :label="a.label" :value="a.value"></el-option> |
| | | </el-select> |
| | | </el-form-item> |
| | | <el-form-item label="ä¸åæ¶é´" prop="date" v-if="(tabIndex === 2 || tabIndex === 3 || tabIndex === 4) && more"> |
| | | <el-date-picker |
| | | v-model="entity.date" |
| | | end-placeholder="ç»ææ¥æ" |
| | | format="yyyy-MM-dd" |
| | | placeholder="éæ©æ¥æ" |
| | | range-separator="è³" |
| | | size="small" |
| | | start-placeholder="å¼å§æ¥æ" |
| | | type="daterange" |
| | | value-format="yyyy-MM-dd"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-form> |
| | | </div> |
| | | <div class="table"> |
| | | <ul class="tab"> |
| | | <li v-for="(m,i) in tabList" :key="m.value" :class="{active:m.value===tabIndex}" @click="handleTab(m)">{{m.label}}</li> |
| | | </ul> |
| | | <div class="table-tab"> |
| | | <div> |
| | | <ul class="tab"> |
| | | <li v-for="(m,i) in tabList" :key="m.value" :class="{active:m.value===tabIndex}" @click="handleTab(m)">{{m.label}}</li> |
| | | </ul> |
| | | </div> |
| | | <div> |
| | | <el-button v-show="tabIndex === 3 || tabIndex === 2" :loading="outLoading" size="small" type="primary" @click="handleOut">导åº</el-button> |
| | | <el-button v-if="tabIndex === 0" size="small" type="primary" @click="copper">éææä¸å</el-button> |
| | | <el-button v-if="tabIndex !== 0" size="small" type="primary" @click="openPrint">æ ç¾æå°</el-button> |
| | | </div> |
| | | </div> |
| | | <!--å¾
ä¸å--> |
| | | <!-- <ValueTable v-show="tabIndex === 0" :key="'a'+ upIndex"--> |
| | | <!-- ref="ValueTable"--> |
| | | <!-- :componentData="componentData"--> |
| | | <!-- :style="getStyle()"--> |
| | | <!-- :tableRowClassName="changeRowClass"--> |
| | | <!-- :url="$api.materialInspection.getPurchaseOrder" />--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData" :column="column" v-if="tabIndex === 0" |
| | | @pagination="pagination" :height="'calc(100vh - 290px)'" key="tableData" |
| | | :page="page" :tableLoading="tableLoading"></lims-table> |
| | | </div> |
| | | <!--æ£éªä¸--> |
| | | <!-- <ValueTable v-show="tabIndex === 1" :key="'b'+ upIndex"--> |
| | | <!-- ref="ValueTable1"--> |
| | | <!-- :componentData="componentData1"--> |
| | | <!-- :style="getStyle()"--> |
| | | <!-- :tableRowClassName="changeRowClass"--> |
| | | <!-- :url="$api.materialInspection.getIfsByStateOne" />--> |
| | | <!-- <!–å·²æ£éª–>--> |
| | | <!-- <ValueTable v-show="tabIndex === 2" :key="'c'+ upIndex"--> |
| | | <!-- ref="ValueTable2"--> |
| | | <!-- :componentData="componentData2"--> |
| | | <!-- :style="getStyle()"--> |
| | | <!-- :tableRowClassName="changeRowClass"--> |
| | | <!-- :url="$api.materialInspection.getIfsByOver" />--> |
| | | <!-- <!–å
¨é¨–>--> |
| | | <!-- <ValueTable v-if="tabIndex === 3" :key="'d'+ upIndex"--> |
| | | <!-- ref="ValueTable3"--> |
| | | <!-- :componentData="componentData3"--> |
| | | <!-- :style="getStyle()"--> |
| | | <!-- :url="$api.materialInspection.getIfsByAll" />--> |
| | | <!-- <!–å£åº¦æ£éª–>--> |
| | | <!-- <ValueTable v-show="tabIndex === 4" :key="'e'+ upIndex"--> |
| | | <!-- ref="ValueTable4"--> |
| | | <!-- :componentData="componentData4"--> |
| | | <!-- :style="getStyle()"--> |
| | | <!-- :tableRowClassName="changeRowClass"--> |
| | | <!-- :url="$api.materialInspection.getIfsByQuarter" />--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData1" :column="column1" v-if="tabIndex === 1" |
| | | :isSelection="true" :handleSelectionChange="selectMethod" |
| | | @pagination="pagination1" :height="'calc(100vh - 290px)'" key="tableData1" |
| | | :page="page1" :tableLoading="tableLoading1"></lims-table> |
| | | </div> |
| | | <!--å·²æ£éª--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData2" :column="column2" v-if="tabIndex === 2" |
| | | :isSelection="true" :handleSelectionChange="selectMethod" |
| | | @pagination="pagination2" :height="'calc(100vh - 290px)'" key="tableData2" |
| | | :page="page2" :tableLoading="tableLoading2"></lims-table> |
| | | </div> |
| | | <!--å
¨é¨--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData3" :column="column3" v-if="tabIndex === 3" |
| | | :isSelection="true" :handleSelectionChange="selectMethod" |
| | | @pagination="pagination3" :height="'calc(100vh - 290px)'" key="tableData3" |
| | | :page="page3" :tableLoading="tableLoading3"></lims-table> |
| | | </div> |
| | | <!--å£åº¦æ£éª--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData4" :column="column4" v-if="tabIndex === 4" |
| | | :isSelection="true" :handleSelectionChange="selectMethod" |
| | | @pagination="pagination4" :height="'calc(100vh - 290px)'" key="tableData4" |
| | | :page="page4" :tableLoading="tableLoading4"></lims-table> |
| | | </div> |
| | | </div> |
| | | </div> |
| | | <!-- <div v-if="active >0 && isCopper == 0" style="width: 100%;height: 100%;">--> |
| | | <!-- <CustomsInspection v-if="active >0&& isCopper == 0" :active="active"--> |
| | | <!-- <div style="width: 100%;height: 100%;">--> |
| | | <!-- <CustomsInspection :active="active"--> |
| | | <!-- :currentId="currentId"--> |
| | | <!-- :customsInspection="customsInspection" :orderType="orderType" />--> |
| | | <!-- </div>--> |
| | | <!-- <div v-if="active >0 && isCopper == 1" style="width: 100%;height: 100%;">--> |
| | | <!-- <CopperOrder v-if="active >0 && isCopper == 1" :active="active" :currentId="currentId"></CopperOrder>--> |
| | | <!-- <div style="width: 100%;height: 100%;">--> |
| | | <!-- <CopperOrder :active="active" :currentId="currentId"></CopperOrder>--> |
| | | <!-- </div>--> |
| | | <!-- 确认å
æ£å¼¹æ¡ --> |
| | | <el-dialog :visible.sync="exemptionVisible" title="确认å
æ£" width="42%"> |
| | |
| | | </template> |
| | | |
| | | <script> |
| | | import ValueTable from "@/components/Table/value-table.vue"; |
| | | import CustomsInspection from "./customsInspection.vue"; |
| | | import PrintDialog from "@/components/materialOrder/printDialog.vue"; |
| | | import ShowInfo from "@/components/materialOrder/showInfo.vue"; |
| | | import DataLookVisible from "@/components/materialOrder/dataLookVisible.vue"; |
| | | import FilesLookVisible from "@/components/materialOrder/filesLookVisible.vue"; |
| | | import DownFileDialog from "@/components/materialOrder/downFileDialog.vue"; |
| | | // import CopperOrder from "@/components/materialOrder/copper-order.vue"; |
| | | import PrintDialog from "@/views/business/materialOrderComponents/materialOrder/printDialog.vue"; |
| | | import ShowInfo from "@/views/business/materialOrderComponents/materialOrder/showInfo.vue"; |
| | | import DataLookVisible from "@/views/business/materialOrderComponents/materialOrder/dataLookVisible.vue"; |
| | | import FilesLookVisible from "@/views/business/materialOrderComponents/materialOrder/filesLookVisible.vue"; |
| | | import DownFileDialog from "@/views/business/materialOrderComponents/materialOrder/downFileDialog.vue"; |
| | | import limsTable from "@/components/Table/lims-table.vue"; |
| | | import { |
| | | getIfsByAll, |
| | | getIfsByOver, |
| | | getIfsByQuarter, |
| | | getIfsByStateOne, |
| | | getPurchaseOrder |
| | | } from "@/api/business/rawMaterialOrder"; |
| | | import {getWarehouseSubmit} from "@/api/business/materialInspection"; |
| | | // import Inspection from "../do/b1-inspect-order-plan/Inspection.vue"; |
| | | |
| | | export default { |
| | | name: "b1-material-inspection-order", |
| | | // import å¼å
¥çç»ä»¶éè¦æ³¨å
¥å°å¯¹è±¡ä¸æè½ä½¿ç¨ |
| | | components: { |
| | | // Inspection, |
| | | // CopperOrder, |
| | | DownFileDialog, FilesLookVisible, DataLookVisible, ShowInfo, PrintDialog, CustomsInspection, ValueTable}, |
| | | components: {limsTable,DownFileDialog, FilesLookVisible, DataLookVisible, ShowInfo, PrintDialog, CustomsInspection}, |
| | | data() { |
| | | // è¿éåæ¾æ°æ® |
| | | return { |
| | | isShowIFS: false, |
| | | entityEmpty: {}, |
| | | tableData: [], |
| | | tableLoading: false, |
| | | column: [ |
| | | {label: 'æ¹å·', prop: 'updateBatchNo'}, |
| | | {label: 'é¶ä»¶å·', prop: 'partNo'}, |
| | | {label: 'é¶ä»¶æè¿°', prop: 'partDesc'}, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return '' |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return '' |
| | | } |
| | | } |
| | | }, |
| | | {label: 'æµè¾¾çéè´æ°é', prop: 'qtyArrived'}, |
| | | {label: 'åä½', prop: 'buyUnitMeas'}, |
| | | {label: '订åå·', prop: 'orderNo'}, |
| | | {label: 'æ¥æ¶æ¶é´', prop: 'receiverDate'}, |
| | | {label: 'æ¥æ£æ¶é´', prop: 'declareDate'}, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | width: '170px', |
| | | operation: [ |
| | | { |
| | | name: 'ä¸å', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.playOrder(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'å
æ£', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.exemption(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¤éæ¥æ£', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.cancelDeclare(row); |
| | | }, |
| | | }, |
| | | ] |
| | | } |
| | | ], |
| | | page: { |
| | | total:0, |
| | | size:10, |
| | | current:1 |
| | | }, |
| | | tableData1: [], |
| | | tableLoading1: false, |
| | | column1: [ |
| | | {label: 'æ¹å·', prop: 'updateBatchNo'}, |
| | | {label: 'å§æç¼å·', prop: 'entrustCode'}, |
| | | {label: 'é¶ä»¶å·', prop: 'partNo'}, |
| | | {label: 'é¶ä»¶æè¿°', prop: 'partDesc'}, |
| | | {label: 'æ ·ååç§°', prop: 'sampleName'}, |
| | | {label: 'æ ·ååå·', prop: 'sampleModel'}, |
| | | {label: 'æ£éªäºº', prop: 'userName'}, |
| | | {label: 'ä¸åæ¶é´', prop: 'sendTime'}, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return '' |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return '' |
| | | } |
| | | } |
| | | }, |
| | | {label: 'æµè¾¾çéè´æ°é', prop: 'qtyArrived'}, |
| | | {label: 'åä½', prop: 'buyUnitMeas'}, |
| | | {label: '订åå·', prop: 'orderNo'}, |
| | | {label: 'æ¥æ¶æ¶é´', prop: 'receiverDate'}, |
| | | {label: 'æ¥æ£æ¶é´', prop: 'declareDate'}, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | width: '140px', |
| | | operation: [ |
| | | { |
| | | name: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleDataLook(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleFileLook(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¤éä¸å', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.cancelOrder(row); |
| | | }, |
| | | }, |
| | | ] |
| | | } |
| | | ], |
| | | page1: { |
| | | total:0, |
| | | size:10, |
| | | current:1 |
| | | }, |
| | | tableData2: [], |
| | | tableLoading2: false, |
| | | column2: [ |
| | | {label: 'å§æç¼å·', prop: 'entrustCode'}, |
| | | {label: 'æ£éªç¶æ', prop: 'inspectStatus'}, |
| | | {label: '订åå·', prop: 'orderNo'}, |
| | | {label: 'æµè¾¾çéè´æ°é', prop: 'qtyArrived'}, |
| | | {label: 'ä¸åæ¶é´', prop: 'sendTime'}, |
| | | {label: 'æ¹å·', prop: 'updateBatchNo'}, |
| | | {label: 'é¶ä»¶å·', prop: 'partNo'}, |
| | | {label: 'é¶ä»¶æè¿°', prop: 'partDesc'}, |
| | | {label: 'ä¾åºååç§°', prop: 'supplierName'}, |
| | | {label: 'ä¸åæ ¼æè¿°', prop: 'unqualifiedDesc'}, |
| | | {label: 'å
æ£', prop: 'isExemption'}, |
| | | {label: 'æ ·ååç§°', prop: 'sampleName'}, |
| | | {label: 'æ ·ååå·', prop: 'sampleModel'}, |
| | | {label: 'æ£éªäºº', prop: 'userName'}, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return '' |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return '' |
| | | } |
| | | } |
| | | }, |
| | | {label: 'åä½', prop: 'buyUnitMeas'}, |
| | | {label: 'æ¥æ¶æ¶é´', prop: 'receiverDate'}, |
| | | {label: 'æ¥æ£æ¶é´', prop: 'declareDate'}, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | width: '300px', |
| | | operation: [ |
| | | { |
| | | name: 'å£åº¦æ£éª', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.playOrderSec(row); |
| | | }, |
| | | disabled: (row) => { |
| | | return row.isQuarter == 0 |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleDataLook(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleFileLook(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¥åä¸è½½', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.download(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'åå§è®°å½', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.viewInspectInfo(row); |
| | | }, |
| | | disabled: (row) => { |
| | | return row.sampleName === null |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¾è¡', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.goPass(row); |
| | | }, |
| | | disabled: (row) => { |
| | | return row.inspectStatus != 2 |
| | | }, |
| | | }, |
| | | { |
| | | name: 'å£åº¦æ¤é', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.repealQuarter(row); |
| | | }, |
| | | disabled: (row) => { |
| | | return row.quarterOrderId == null || row.quarterReportId != null |
| | | }, |
| | | }, |
| | | ] |
| | | } |
| | | ], |
| | | page2: { |
| | | total:0, |
| | | size:10, |
| | | current:1 |
| | | }, |
| | | tableData3: [], |
| | | tableLoading3: false, |
| | | column3: [ |
| | | {label: 'å§æç¼å·', prop: 'entrustCode'}, |
| | | {label: 'æ£éªç¶æ', prop: 'inspectStatus'}, |
| | | {label: '订åå·', prop: 'orderNo'}, |
| | | {label: 'æµè¾¾çéè´æ°é', prop: 'qtyArrived'}, |
| | | {label: 'ä¸åæ¶é´', prop: 'sendTime'}, |
| | | {label: 'æ¹å·', prop: 'updateBatchNo'}, |
| | | {label: 'é¶ä»¶å·', prop: 'partNo'}, |
| | | {label: 'é¶ä»¶æè¿°', prop: 'partDesc'}, |
| | | {label: 'ä¾åºååç§°', prop: 'supplierName'}, |
| | | {label: 'ä¸åæ ¼æè¿°', prop: 'unqualifiedDesc'}, |
| | | {label: 'å
æ£', prop: 'isExemption'}, |
| | | {label: 'æ ·ååç§°', prop: 'sampleName'}, |
| | | {label: 'æ ·ååå·', prop: 'sampleModel'}, |
| | | {label: 'æ£éªäºº', prop: 'userName'}, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return '' |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return '' |
| | | } |
| | | } |
| | | }, |
| | | {label: 'åä½', prop: 'buyUnitMeas'}, |
| | | {label: 'æ¥æ¶æ¶é´', prop: 'receiverDate'}, |
| | | {label: 'æ¥æ£æ¶é´', prop: 'declareDate'}, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | width: '140px', |
| | | operation: [ |
| | | { |
| | | name: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleDataLook(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleFileLook(row); |
| | | }, |
| | | } |
| | | ] |
| | | } |
| | | ], |
| | | page3: { |
| | | total:0, |
| | | size:10, |
| | | current:1 |
| | | }, |
| | | tableData4: [], |
| | | tableLoading4: false, |
| | | column4: [ |
| | | {label: 'å§æç¼å·', prop: 'entrustCode'}, |
| | | {label: 'æ£éªç¶æ', prop: 'inspectStatus'}, |
| | | {label: '订åå·', prop: 'orderNo'}, |
| | | {label: 'æµè¾¾çéè´æ°é', prop: 'qtyArrived'}, |
| | | {label: 'ä¸åæ¶é´', prop: 'sendTime'}, |
| | | {label: 'æ¹å·', prop: 'updateBatchNo'}, |
| | | {label: 'é¶ä»¶å·', prop: 'partNo'}, |
| | | {label: 'é¶ä»¶æè¿°', prop: 'partDesc'}, |
| | | {label: 'ä¾åºååç§°', prop: 'supplierName'}, |
| | | {label: 'ä¸åæ ¼æè¿°', prop: 'unqualifiedDesc'}, |
| | | {label: 'å
æ£', prop: 'isExemption'}, |
| | | {label: 'æ ·ååç§°', prop: 'sampleName'}, |
| | | {label: 'æ ·ååå·', prop: 'sampleModel'}, |
| | | {label: 'æ£éªäºº', prop: 'userName'}, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return '' |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return '' |
| | | } |
| | | } |
| | | }, |
| | | {label: 'åä½', prop: 'buyUnitMeas'}, |
| | | {label: 'æ¥æ¶æ¶é´', prop: 'receiverDate'}, |
| | | {label: 'æ¥æ£æ¶é´', prop: 'declareDate'}, |
| | | { |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | width: '250px', |
| | | operation: [ |
| | | { |
| | | name: 'å£åº¦æ£éª', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.playOrderSec(row); |
| | | }, |
| | | disabled: (row, index) => { |
| | | return row.isQuarter == 0 |
| | | } |
| | | }, |
| | | { |
| | | name: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleDataLook(row); |
| | | } |
| | | }, |
| | | { |
| | | name: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.handleFileLook(row); |
| | | }, |
| | | }, |
| | | { |
| | | name: 'æ¥åä¸è½½', |
| | | type: 'text', |
| | | clickFun: (row) => { |
| | | this.download(row); |
| | | }, |
| | | } |
| | | ] |
| | | } |
| | | ], |
| | | page4: { |
| | | total:0, |
| | | size:10, |
| | | current:1 |
| | | }, |
| | | entity: { |
| | | updateBatchNo: null, |
| | | entrustCode: null, |
| | |
| | | date: null, |
| | | beginDeclareDate: null, |
| | | endDeclareDate: null, |
| | | }, |
| | | componentData: { // è¡¨æ ¼æ°æ® |
| | | entity: { |
| | | updateBatchNo: null, |
| | | partDesc: null, |
| | | state: 0, |
| | | isInspect: 1, |
| | | partNo: null |
| | | }, |
| | | isIndex: true, |
| | | showSelect: false, |
| | | select: false, |
| | | selectMethod:'selectMethod', |
| | | do: [ |
| | | { |
| | | font: 'ä¸å', |
| | | type: 'text', |
| | | method: 'playOrder', |
| | | }, |
| | | { |
| | | font: 'å
æ£', |
| | | type: 'text', |
| | | method: 'exemption', |
| | | }, |
| | | { |
| | | font: 'æ¤éæ¥æ£', |
| | | type: 'text', |
| | | method: 'cancelDeclare', |
| | | }, |
| | | // { |
| | | // font: '产ä¸é¾', |
| | | // type: 'text', |
| | | // method: 'openInfoDialog', |
| | | // } |
| | | ], |
| | | tagField: { |
| | | isExpire: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'è¿æç©æ', |
| | | type: 'warning' |
| | | }] |
| | | }, |
| | | }, |
| | | selectField: {}, |
| | | requiredAdd: [], |
| | | requiredUp: [] |
| | | }, |
| | | componentData1: { |
| | | entity: { |
| | | orderBy: { |
| | | field: 'entrustCode', |
| | | order: 'desc' |
| | | }, |
| | | updateBatchNo: null, |
| | | entrustCode: null, |
| | | partDesc: null, |
| | | state: 1, |
| | | orderState: 1, |
| | | partNo: null |
| | | }, |
| | | isIndex: true, |
| | | showSelect: true, |
| | | select: true, |
| | | selectMethod:'selectMethod', |
| | | do: [ |
| | | // { |
| | | // font: 'å£åº¦æ£éª', |
| | | // type: 'text', |
| | | // method: 'playOrderSec', |
| | | // disabFun: (row, index) => { |
| | | // return row.isQuarter == 0 |
| | | // } |
| | | // }, |
| | | { |
| | | id: 'dataLook', |
| | | font: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | method: 'handleDataLook', |
| | | }, |
| | | { |
| | | font: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | method: 'handleFileLook', |
| | | }, |
| | | { |
| | | font: 'æ¤éä¸å', |
| | | type: 'text', |
| | | method: 'cancelOrder', |
| | | }, |
| | | // { |
| | | // font: '产ä¸é¾', |
| | | // type: 'text', |
| | | // method: 'openInfoDialog', |
| | | // } |
| | | ], |
| | | linkEvent: { |
| | | sampleName: { |
| | | method: 'selectAllByOne' |
| | | }, |
| | | entrustCode: { |
| | | method: 'changeEntrustCode' |
| | | } |
| | | }, |
| | | tagField: { |
| | | inspectStatus: { |
| | | select: [{ |
| | | value: 0, |
| | | label: 'æ£éªä¸', |
| | | type: 'warning' |
| | | },{ |
| | | value: 1, |
| | | label: 'åæ ¼', |
| | | type: 'success' |
| | | },{ |
| | | value: 2, |
| | | label: 'ä¸åæ ¼', |
| | | type: 'danger' |
| | | },{ |
| | | value: 3, |
| | | label: 'æªä¸å', |
| | | type: 'info' |
| | | }] |
| | | }, |
| | | isExpire: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'è¿æç©æ', |
| | | type: 'warning' |
| | | }] |
| | | }, |
| | | }, |
| | | selectField: {}, |
| | | requiredAdd: [], |
| | | requiredUp: [] |
| | | }, |
| | | componentData2: { |
| | | entity: { |
| | | orderBy: { |
| | | field: 'entrustCode', |
| | | order: 'desc' |
| | | }, |
| | | updateBatchNo: null, |
| | | entrustCode: null, |
| | | partDesc: null, |
| | | sampleModel: null, |
| | | state: 2, |
| | | orderState: 4, |
| | | supplierName: '', |
| | | partNo: null, |
| | | beginDeclareDate: null, |
| | | endDeclareDate: null, |
| | | }, |
| | | isIndex: true, |
| | | showSelect: true, |
| | | select: true, |
| | | selectMethod:'selectMethod', |
| | | do: [ |
| | | { |
| | | font: 'å£åº¦æ£éª', |
| | | type: 'text', |
| | | method: 'playOrderSec', |
| | | disabFun: (row, index) => { |
| | | return row.isQuarter == 0 |
| | | } |
| | | }, |
| | | { |
| | | id: 'dataLook', |
| | | font: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | method: 'handleDataLook', |
| | | }, |
| | | { |
| | | font: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | method: 'handleFileLook', |
| | | },{ |
| | | id: 'download', |
| | | font: 'æ¥åä¸è½½', |
| | | type: 'text', |
| | | method: 'download', |
| | | }, |
| | | // { |
| | | // font: '产ä¸é¾', |
| | | // type: 'text', |
| | | // method: 'openInfoDialog', |
| | | // }, |
| | | { |
| | | id: '', |
| | | font: 'åå§è®°å½', |
| | | type: 'text', |
| | | method: 'viewInspectInfo', |
| | | disabFun: (row, index) => { |
| | | return row.sampleName === null |
| | | } |
| | | }, |
| | | { |
| | | id: '', |
| | | font: 'æ¾è¡', |
| | | type: 'text', |
| | | method: 'goPass', |
| | | disabFun: (row, index) => { |
| | | return row.inspectStatus != 2 |
| | | } |
| | | }, |
| | | { |
| | | id: '', |
| | | font: 'å£åº¦æ¤é', |
| | | type: 'text', |
| | | method: 'repealQuarter', |
| | | disabFun: (row, index) => { |
| | | return row.quarterOrderId == null || row.quarterReportId != null |
| | | } |
| | | } |
| | | ], |
| | | linkEvent: { |
| | | sampleName: { |
| | | method: 'selectAllByOne' |
| | | }, |
| | | entrustCode: { |
| | | method: 'changeEntrustCode' |
| | | } |
| | | }, |
| | | tagField: { |
| | | inspectStatus: { |
| | | select: [{ |
| | | value: 0, |
| | | label: 'æ£éªä¸', |
| | | type: 'warning' |
| | | },{ |
| | | value: 1, |
| | | label: 'åæ ¼', |
| | | type: 'success' |
| | | },{ |
| | | value: 2, |
| | | label: 'ä¸åæ ¼', |
| | | type: 'danger' |
| | | },{ |
| | | value: 3, |
| | | label: 'æªä¸å', |
| | | type: 'info' |
| | | },{ |
| | | value: 4, |
| | | label: 'è®©æ¥æ¾è¡', |
| | | type: 'info' |
| | | }] |
| | | }, |
| | | isExemption: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'å
æ£', |
| | | type: 'success' |
| | | }] |
| | | }, |
| | | isExpire: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'è¿æç©æ', |
| | | type: 'warning' |
| | | }] |
| | | }, |
| | | }, |
| | | selectField: {}, |
| | | requiredAdd: [], |
| | | requiredUp: [] |
| | | }, |
| | | componentData4: { |
| | | entity: { |
| | | orderBy: { |
| | | field: 'entrustCode', |
| | | order: 'desc' |
| | | }, |
| | | updateBatchNo: null, |
| | | entrustCode: null, |
| | | partDesc: null, |
| | | sampleModel: null, |
| | | supplierName: '', |
| | | partNo: null, |
| | | beginDeclareDate: null, |
| | | endDeclareDate: null, |
| | | }, |
| | | isIndex: true, |
| | | showSelect: true, |
| | | select: true, |
| | | selectMethod:'selectMethod', |
| | | do: [ |
| | | { |
| | | font: 'å£åº¦æ£éª', |
| | | type: 'text', |
| | | method: 'playOrderSec', |
| | | disabFun: (row, index) => { |
| | | return row.isQuarter == 0 |
| | | } |
| | | }, |
| | | { |
| | | id: 'dataLook', |
| | | font: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | method: 'handleDataLook', |
| | | }, |
| | | { |
| | | font: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | method: 'handleFileLook', |
| | | },{ |
| | | id: 'download', |
| | | font: 'æ¥åä¸è½½', |
| | | type: 'text', |
| | | method: 'download', |
| | | }, |
| | | // { |
| | | // font: '产ä¸é¾', |
| | | // type: 'text', |
| | | // method: 'openInfoDialog', |
| | | // }, |
| | | { |
| | | id: '', |
| | | font: 'åå§è®°å½', |
| | | type: 'text', |
| | | method: 'viewInspectInfo', |
| | | disabFun: (row, index) => { |
| | | return row.sampleName === null |
| | | } |
| | | }, |
| | | // { |
| | | // id: '', |
| | | // font: 'æ¾è¡', |
| | | // type: 'text', |
| | | // method: 'goPass', |
| | | // disabFun: (row, index) => { |
| | | // return row.inspectStatus != 2 |
| | | // } |
| | | // }, |
| | | { |
| | | id: '', |
| | | font: 'å£åº¦æ¤é', |
| | | type: 'text', |
| | | method: 'repealQuarter', |
| | | disabFun: (row, index) => { |
| | | return row.quarterOrderId == null || row.quarterReportId != null |
| | | } |
| | | } |
| | | ], |
| | | linkEvent: { |
| | | sampleName: { |
| | | method: 'selectAllByOne' |
| | | }, |
| | | entrustCode: { |
| | | method: 'changeEntrustCode' |
| | | } |
| | | }, |
| | | tagField: { |
| | | inspectStatus: { |
| | | select: [{ |
| | | value: 0, |
| | | label: 'æ£éªä¸', |
| | | type: 'warning' |
| | | },{ |
| | | value: 1, |
| | | label: 'åæ ¼', |
| | | type: 'success' |
| | | },{ |
| | | value: 2, |
| | | label: 'ä¸åæ ¼', |
| | | type: 'danger' |
| | | },{ |
| | | value: 3, |
| | | label: 'æªä¸å', |
| | | type: 'info' |
| | | },{ |
| | | value: 4, |
| | | label: 'è®©æ¥æ¾è¡', |
| | | type: 'info' |
| | | }] |
| | | }, |
| | | isExemption: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'å
æ£', |
| | | type: 'success' |
| | | }] |
| | | }, |
| | | isExpire: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'è¿æç©æ', |
| | | type: 'warning' |
| | | }] |
| | | }, |
| | | }, |
| | | selectField: {}, |
| | | requiredAdd: [], |
| | | requiredUp: [] |
| | | }, |
| | | componentData3: { |
| | | entity: { |
| | | orderBy: { |
| | | field: 'entrustCode', |
| | | order: 'desc' |
| | | }, |
| | | updateBatchNo: null, |
| | | entrustCode: null, |
| | | partDesc: null, |
| | | sampleModel: null, |
| | | isInspect: 1, |
| | | supplierName: '', |
| | | partNo: null, |
| | | beginDeclareDate: null, |
| | | endDeclareDate: null, |
| | | }, |
| | | isIndex: true, |
| | | showSelect: true, |
| | | select: true, |
| | | selectMethod:'selectMethod', |
| | | do: [ |
| | | { |
| | | id: 'dataLook', |
| | | font: 'æ°æ®æ¥ç', |
| | | type: 'text', |
| | | method: 'handleDataLook', |
| | | }, |
| | | { |
| | | font: 'éä»¶æ¥ç', |
| | | type: 'text', |
| | | method: 'handleFileLook', |
| | | }, |
| | | // { |
| | | // font: '产ä¸é¾', |
| | | // type: 'text', |
| | | // method: 'openInfoDialog', |
| | | // } |
| | | ], |
| | | linkEvent: { |
| | | sampleName: { |
| | | method: 'selectAllByOne' |
| | | }, |
| | | entrustCode: { |
| | | method: 'changeEntrustCode' |
| | | } |
| | | }, |
| | | tagField: { |
| | | inspectStatus: { |
| | | select: [{ |
| | | value: 0, |
| | | label: 'æ£éªä¸', |
| | | type: 'warning' |
| | | },{ |
| | | value: 1, |
| | | label: 'åæ ¼', |
| | | type: 'success' |
| | | },{ |
| | | value: 2, |
| | | label: 'ä¸åæ ¼', |
| | | type: 'danger' |
| | | },{ |
| | | value: 3, |
| | | label: 'æªä¸å', |
| | | type: 'info' |
| | | },{ |
| | | value: 4, |
| | | label: 'è®©æ¥æ¾è¡', |
| | | type: '' |
| | | }] |
| | | }, |
| | | isExemption: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'å
æ£', |
| | | type: 'success' |
| | | }] |
| | | }, |
| | | isExpire: { |
| | | select: [{ |
| | | value: 1, |
| | | label: 'è¿æç©æ', |
| | | type: 'warning' |
| | | }] |
| | | }, |
| | | }, |
| | | selectField: {}, |
| | | requiredAdd: [], |
| | | requiredUp: [] |
| | | }, |
| | | tabList: [ |
| | | { |
| | |
| | | } |
| | | ], |
| | | more:false, |
| | | upIndex: 0, |
| | | tabIndex: 0, |
| | | multipleSelection:[], |
| | | entityCopy: {}, |
| | | entityCopy1: {}, |
| | | entityCopy2: {}, |
| | | entityCopy3: {}, |
| | | entityCopy4: {}, |
| | | active: 0, //1ï¼ä¸åï¼2ï¼æ¥ç |
| | | orderType: 0, //0ï¼åææä¸åï¼1ï¼å£åº¦æ£éªä¸å |
| | | currentId: null, |
| | | customsInspection: {}, |
| | | btnLoading: false, |
| | | quashDialogVisible: false, // æ¤éä¸åæéå¼¹æ¡ |
| | | declareDialogVisible: false, // æ¤éæ¥æ£æéå¼¹æ¡ |
| | |
| | | typeSource: null,// 0:æåä¸åï¼1ï¼åææä¸å, 2: éåä¸ä¸å |
| | | InspectInfoDialog: false, // æ°æ®æ¥çå¼¹æ¡ |
| | | insInfo: {}, |
| | | isCopper: null, |
| | | outLoading:false |
| | | } |
| | | }, |
| | | mounted () { |
| | | this.entityEmpty = this.HaveJson(this.entity) |
| | | this.entityCopy = this.HaveJson(this.componentData.entity) |
| | | this.entityCopy1 = this.HaveJson(this.componentData1.entity) |
| | | this.entityCopy2 = this.HaveJson(this.componentData2.entity) |
| | | this.entityCopy3 = this.HaveJson(this.componentData3.entity) |
| | | this.getPower() |
| | | this.refreshTable() |
| | | }, |
| | | // æ¹æ³éå |
| | | methods: { |
| | | // è·åæé |
| | | getPower(){ |
| | | let power = JSON.parse(sessionStorage.getItem('power')) |
| | | let getIFS = false |
| | | for (var i = 0; i < power.length; i++) { |
| | | if (power[i].menuMethod == 'getIfsByAll') { // è·åIFSçæé |
| | | getIFS = true |
| | | // æ¥è¯¢åè° |
| | | refreshTable() { |
| | | if (this.tabIndex === 0) { |
| | | // å¾
ä¸åæ¥è¯¢ |
| | | this.getPurchaseOrderList() |
| | | } else if (this.tabIndex === 1) { |
| | | // æ£éªä¸æ¥è¯¢ |
| | | this.getIfsByStateOneList() |
| | | } else if (this.tabIndex === 2) { |
| | | // å·²æ£éªæ¥è¯¢ |
| | | this.getIfsByOverList() |
| | | } else if (this.tabIndex === 4) { |
| | | // æ¥è¯¢å£åº¦æ£éª |
| | | this.getIfsByQuarterList() |
| | | } else { |
| | | // å
¨é¨æ¥è¯¢ |
| | | this.getIfsByAllList() |
| | | } |
| | | }, |
| | | // å¾
ä¸åæ¥è¯¢ |
| | | getPurchaseOrderList () { |
| | | this.tableLoading = true |
| | | const params = {...this.entity, isInspect: 1, state: 0} |
| | | getWarehouseSubmit(params).then(res => { |
| | | this.tableLoading = false |
| | | if (res.code === 200) { |
| | | this.tableData = res.data.records |
| | | this.page.total = res.data.total |
| | | } |
| | | } |
| | | if (!getIFS) { |
| | | this.tabList.splice(-1, 1) |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading = false |
| | | }) |
| | | }, |
| | | // æ£éªä¸æ¥è¯¢ |
| | | getIfsByStateOneList () { |
| | | this.tableLoading1 = true |
| | | const params = {...this.entity, orderState: 1, state: 1} |
| | | getIfsByStateOne(params).then(res => { |
| | | this.tableLoading1 = false |
| | | if (res.code === 200) { |
| | | this.tableData1 = res.data.records |
| | | this.page1.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading1 = false |
| | | }) |
| | | }, |
| | | // å·²æ£éªæ¥è¯¢ |
| | | getIfsByOverList () { |
| | | this.tableLoading2 = true |
| | | const params = {...this.entity, orderState: 4, state: 2} |
| | | getIfsByOver(params).then(res => { |
| | | this.tableLoading2 = false |
| | | if (res.code === 200) { |
| | | this.tableData2 = res.data.records |
| | | this.page2.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading2 = false |
| | | }) |
| | | }, |
| | | // æ¥è¯¢å£åº¦æ£éª |
| | | getIfsByQuarterList () { |
| | | this.tableLoading4 = true |
| | | const params = {...this.entity} |
| | | getIfsByOver(params).then(res => { |
| | | this.tableLoading4 = false |
| | | if (res.code === 200) { |
| | | this.tableData4 = res.data.records |
| | | this.page4.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading4 = false |
| | | }) |
| | | }, |
| | | // å
¨é¨ |
| | | getIfsByAllList () { |
| | | this.tableLoading3 = true |
| | | const params = {...this.entity, isInspect: 1} |
| | | getIfsByAll(params).then(res => { |
| | | this.tableLoading3 = false |
| | | if (res.code === 200) { |
| | | this.tableData3 = res.data.records |
| | | this.page3.total = res.data.total |
| | | } |
| | | }).catch(err => { |
| | | this.tableLoading3 = false |
| | | }) |
| | | }, |
| | | // é ç½® |
| | | refresh() { |
| | | this.resetForm('entity') |
| | | this.refreshTable() |
| | | }, |
| | | pagination (page) { |
| | | this.page.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination1 (page) { |
| | | this.page1.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination2 (page) { |
| | | this.page2.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination3 (page) { |
| | | this.page3.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | pagination4 (page) { |
| | | this.page4.size = page.limit |
| | | this.refreshTable() |
| | | }, |
| | | // æ¥çæ£éªæ°æ® |
| | | viewInspectInfo (row) { |
| | |
| | | }, |
| | | // éææä¸å |
| | | copper () { |
| | | this.$router.push("/materialOrder/customsInspection"); |
| | | this.$router.push("/materialOrder/copperOrder"); |
| | | this.$router.push({ path: "/materialOrder/copperOrder", query: {active: 1} }); |
| | | }, |
| | | // æå¼æ ç¾æå°å¼¹æ¡ |
| | | openPrint () { |
| | |
| | | closePrintDialog () { |
| | | this.printDialog = false |
| | | }, |
| | | // æ¥è¯¢åè° |
| | | refreshTable(e) { |
| | | if (this.tabIndex === 0) { |
| | | this.componentData.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData.entity.partDesc = this.entity.partDesc |
| | | this.componentData.entity.partNo = this.entity.partNo |
| | | this.$refs['ValueTable'].selectList(e) |
| | | } else if (this.tabIndex === 1) { |
| | | this.componentData1.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData1.entity.entrustCode = this.entity.entrustCode |
| | | this.componentData1.entity.partDesc = this.entity.partDesc |
| | | this.componentData1.entity.partNo = this.entity.partNo |
| | | this.$refs['ValueTable1'].selectList(e) |
| | | } else if (this.tabIndex === 2) { |
| | | this.componentData2.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData2.entity.entrustCode = this.entity.entrustCode |
| | | this.componentData2.entity.partDesc = this.entity.partDesc |
| | | this.componentData2.entity.supplierName = this.entity.supplierName |
| | | this.componentData2.entity.sampleModel = this.entity.sampleModel |
| | | this.componentData2.entity.partNo = this.entity.partNo |
| | | this.componentData2.entity.inspectStatus = this.entity.inspectStatus |
| | | if (this.entity.date!==null) { |
| | | this.componentData2.entity.beginDeclareDate = this.entity.date[0] + ' 00:00:00' |
| | | this.componentData2.entity.endDeclareDate = this.entity.date[1] + ' 23:59:59' |
| | | } else { |
| | | this.componentData2.entity.beginDeclareDate = '' |
| | | this.componentData2.entity.endDeclareDate = '' |
| | | } |
| | | this.$refs['ValueTable2'].selectList(e) |
| | | } else if (this.tabIndex === 4) { |
| | | this.componentData4.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData4.entity.entrustCode = this.entity.entrustCode |
| | | this.componentData4.entity.partDesc = this.entity.partDesc |
| | | this.componentData4.entity.supplierName = this.entity.supplierName |
| | | this.componentData4.entity.sampleModel = this.entity.sampleModel |
| | | this.componentData4.entity.partNo = this.entity.partNo |
| | | this.componentData4.entity.inspectStatus = this.entity.inspectStatus |
| | | if (this.entity.date!==null) { |
| | | this.componentData4.entity.beginDeclareDate = this.entity.date[0] + ' 00:00:00' |
| | | this.componentData4.entity.endDeclareDate = this.entity.date[1] + ' 23:59:59' |
| | | } else { |
| | | this.componentData4.entity.beginDeclareDate = '' |
| | | this.componentData4.entity.endDeclareDate = '' |
| | | } |
| | | this.$refs['ValueTable4'].selectList(e) |
| | | } else { |
| | | this.componentData3.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData3.entity.entrustCode = this.entity.entrustCode |
| | | this.componentData3.entity.partDesc = this.entity.partDesc |
| | | this.componentData3.entity.supplierName = this.entity.supplierName |
| | | this.componentData3.entity.sampleModel = this.entity.sampleModel |
| | | this.componentData3.entity.partNo = this.entity.partNo |
| | | this.componentData3.entity.inspectStatus = this.entity.inspectStatus |
| | | if (this.entity.date!==null) { |
| | | this.componentData3.entity.beginDeclareDate = this.entity.date[0] + ' 00:00:00' |
| | | this.componentData3.entity.endDeclareDate = this.entity.date[1] + ' 23:59:59' |
| | | } else { |
| | | this.componentData3.entity.beginDeclareDate = '' |
| | | this.componentData3.entity.endDeclareDate = '' |
| | | } |
| | | this.$nextTick(()=> { |
| | | this.$refs['ValueTable3'].selectList(e) |
| | | }) |
| | | } |
| | | }, |
| | | // é ç½® |
| | | refresh() { |
| | | this.entity = this.HaveJson(this.entityEmpty) |
| | | if (this.tabIndex === 0) { |
| | | this.componentData.entity = this.HaveJson(this.entityCopy) |
| | | } else if (this.tabIndex === 1) { |
| | | this.componentData1.entity = this.HaveJson(this.entityCopy1) |
| | | } else if (this.tabIndex === 2) { |
| | | this.componentData2.entity = this.HaveJson(this.entityCopy2) |
| | | } else if (this.tabIndex === 4) { |
| | | this.componentData4.entity = this.HaveJson(this.entityCopy4) |
| | | } else { |
| | | this.componentData3.entity = this.HaveJson(this.entityCopy3) |
| | | } |
| | | this.refreshTable() |
| | | }, |
| | | // ä¸å |
| | | playOrder(num) { |
| | | if (typeof num === "number") { |
| | | this.active = num |
| | | } else { |
| | | this.active = 1 |
| | | this.orderType = 0 |
| | | this.isCopper = 0 |
| | | this.customsInspection = num |
| | | } |
| | | if (num === 0) { |
| | | this.refreshTable('page') |
| | | } |
| | | playOrder(row) { |
| | | this.$router.push({ path: "/materialOrder/customsInspection", query: {orderType: 0, customsInspection: row, active: 1} }); |
| | | }, |
| | | // å£åº¦æ£éªä¸å |
| | | playOrderSec (row) { |
| | | if (typeof row === "number") { |
| | | this.active = row |
| | | if (typeof row !== "object") { |
| | | this.$router.push({ path: "/materialOrder/customsInspection", query: {active: row} }); |
| | | } else { |
| | | this.active = 1 |
| | | this.orderType = 1 |
| | | this.isCopper = 0 |
| | | this.customsInspection = row |
| | | } |
| | | if (row === 0) { |
| | | this.refreshTable('page') |
| | | this.$router.push({ path: "/materialOrder/customsInspection", query: {orderType: 1, customsInspection: row, active: 1} }); |
| | | } |
| | | }, |
| | | // æå¼å
æ£å¼¹æ¡ |
| | |
| | | this.insOrderRow = row |
| | | }, |
| | | cancelQuashOrder (type) { |
| | | console.log('type---', type) |
| | | const url = type === 'enterOrderId' ? this.$api.rawMaterialOrder.repealEnterRawOrder : this.$api.rawMaterialOrder.repealQuarterRawOrder |
| | | const name = type === 'enterOrderId' ? 'enterOrderId' : 'quarterOrderId' |
| | | const paramInfo = type === 'enterOrderId' ? this.insOrderRow.enterOrderId : this.insOrderRow.quarterOrderId |
| | |
| | | // ç¹å»æ ·ååç§°æ¥ç详æ
|
| | | selectAllByOne(row) { |
| | | this.currentId = row.insOrderId |
| | | this.isCopper = row.isCopper |
| | | if (this.isCopper == 1) { |
| | | if (row.isCopper == 1) { |
| | | this.currentId = row.enterOrderId |
| | | } |
| | | this.customsInspection = row |
| | |
| | | }, |
| | | // å¯¼åº |
| | | handleOut(){ |
| | | let entity = this.tabIndex === 3 ? {...this.componentData3.entity} : {...this.componentData2.entity} |
| | | let entity = this.tabIndex === 3 ? {...this.entity, isInspect: 2} : {...this.entity,state: 2, orderState: 4,} |
| | | delete entity.orderBy |
| | | this.outLoading = true |
| | | this.$axios.post(this.$api.rawMaterialOrder.rawAllExport,{ |
| | |
| | | // 忢ä¸åtabè¡¨æ ¼ |
| | | handleTab(m) { |
| | | this.tabIndex = m.value; |
| | | if (this.tabIndex === 0) { |
| | | this.componentData.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData.entity.partDesc = this.entity.partDesc |
| | | } else if (this.tabIndex === 1) { |
| | | this.componentData1.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData1.entity.entrustCode = this.entity.entrustCode |
| | | this.componentData1.entity.partDesc = this.entity.partDesc |
| | | } else if (this.tabIndex === 4) { |
| | | this.componentData4.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData4.entity.entrustCode = this.entity.entrustCode |
| | | this.componentData4.entity.partDesc = this.entity.partDesc |
| | | } else { |
| | | this.componentData2.entity.updateBatchNo = this.entity.updateBatchNo |
| | | this.componentData2.entity.entrustCode = this.entity.entrustCode |
| | | this.componentData2.entity.partDesc = this.entity.partDesc |
| | | } |
| | | this.refreshTable() |
| | | }, |
| | | // è¡¨æ ¼éæ©æ¹æ³ |
| | | selectMethod(val){ |
| | | this.multipleSelection = val |
| | | }, |
| | | changeRowClass({row, rowIndex}) { |
| | | if (row.isFirst == 1) { |
| | | return 'highlight-danger-row-border' |
| | | } |
| | | return '' |
| | | }, |
| | | getStyle(){ |
| | | return 'height: calc(100% - '+(this.more?'94':'44')+'px)' |
| | | } |
| | | }, |
| | | } |
| | | </script> |
| | | |
| | | <style scoped> |
| | | .app-container { |
| | | padding-top: 0; |
| | | } |
| | | .title { |
| | | height: 60px; |
| | | line-height: 60px; |
| | | .table-tab { |
| | | display: flex; |
| | | justify-content: space-between; |
| | | } |
| | | .tab { |
| | | list-style-type: none; |
| | |
| | | @keyup.enter.native="refreshTable"> |
| | | </el-input> |
| | | </el-form-item> |
| | | <el-button v-if="tabIndex === 3 || tabIndex === 4" :icon="!more?'el-icon-arrow-down':'el-icon-arrow-up'" style="color: #3A7BFA;" type="text" @click="more=!more">{{!more?'æ´å¤':'æ¶èµ·'}}</el-button> |
| | | <el-button size="small" icon="el-icon-search" type="primary" @click="refreshTable()">æ¥ è¯¢</el-button> |
| | | <el-button size="small" @click="refresh()" icon="el-icon-refresh">é ç½®</el-button> |
| | | <el-form-item> |
| | | <el-button v-if="tabIndex === 3 || tabIndex === 4" :icon="!more?'el-icon-arrow-down':'el-icon-arrow-up'" style="color: #3A7BFA;" type="text" @click="more=!more">{{!more?'æ´å¤':'æ¶èµ·'}}</el-button> |
| | | <el-button size="mini" icon="el-icon-search" type="primary" @click="refreshTable()">æ¥ è¯¢</el-button> |
| | | <el-button size="mini" @click="refresh()" icon="el-icon-refresh">é ç½®</el-button> |
| | | </el-form-item> |
| | | </el-row> |
| | | <el-row> |
| | | <el-form-item label="æ£éªç¶æ" prop="inspectStatus" v-if="(tabIndex === 3 || tabIndex === 4) && more"> |
| | |
| | | </div> |
| | | <!--å¾
æ¥æ£ãå¾
ä¸å--> |
| | | <div class="table"> |
| | | <lims-table :tableData="tableData" :column="column" v-if="tabIndex === 0 || tabIndex === 1"> |
| | | <lims-table :tableData="tableData" :column="column" v-if="tabIndex === 0 || tabIndex === 1" |
| | | @pagination="pagination" :height="'calc(100vh - 290px)'" |
| | | :page="page" :tableLoading="tableLoading"></lims-table> |
| | | </div> |
| | |
| | | {label: 'é¶ä»¶å·', prop: 'partNo'}, |
| | | {label: 'é¶ä»¶æè¿°', prop: 'partDesc'}, |
| | | {label: 'ä¾åºååç§°', prop: 'supplierName'}, |
| | | {label: 'ç©æç±»å', prop: 'isExpire'}, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return '' |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return '' |
| | | } |
| | | } |
| | | }, |
| | | {label: 'åä½', prop: 'buyUnitMeas'}, |
| | | {label: 'æ¥æ¶æ¶é´', prop: 'receiverDate'}, |
| | | {label: 'æ¥æ£æ¶é´', prop: 'declareDate'}, |
| | |
| | | dataType: 'action', |
| | | fixed: 'right', |
| | | label: 'æä½', |
| | | width: '140px', |
| | | width: '150px', |
| | | operation: [ |
| | | { |
| | | name: 'æ¥æ£', |
| | |
| | | {label: 'æ ·ååç§°', prop: 'sampleName'}, |
| | | {label: 'æ ·ååå·', prop: 'sampleModel'}, |
| | | {label: 'æ£éªäºº', prop: 'userName'}, |
| | | {label: 'ç©æç±»å', prop: 'isExpire'}, |
| | | { |
| | | dataType: 'tag', |
| | | label: 'ç©æç±»å', |
| | | prop: 'isExpire', |
| | | formatData: (params) => { |
| | | if (params == 1) { |
| | | return 'è¿æç©æ' |
| | | } else { |
| | | return '' |
| | | } |
| | | }, |
| | | formatType: (params) => { |
| | | if (params == 1) { |
| | | return 'info' |
| | | } else { |
| | | return '' |
| | | } |
| | | } |
| | | }, |
| | | {label: 'åä½', prop: 'buyUnitMeas'}, |
| | | {label: 'æ¥æ¶æ¶é´', prop: 'receiverDate'}, |
| | | {label: 'æ¥æ£æ¶é´', prop: 'declareDate'}, |
| | |
| | | </el-form> |
| | | <!-- æ£éªé¡¹ç®åæ°è¡¨æ ¼--> |
| | | <div class="table" v-if="radio===0"> |
| | | <lims-table :tableData="tableData" :column="column" |
| | | <lims-table :tableData="tableData" :column="column" key="tableData" |
| | | @pagination="pagination" :height="'calc(100vh - 290px)'" |
| | | :page="page" :tableLoading="tableLoading"></lims-table> |
| | | </div> |
| | | <!-- æ£éªå¯¹è±¡è¡¨æ ¼--> |
| | | <div class="table" v-if="radio===1"> |
| | | <lims-table :tableData="testObjectTableData" :column="testObjectColumn" |
| | | <lims-table :tableData="testObjectTableData" :column="testObjectColumn" key="testObjectTableData" |
| | | @pagination="pagination" :height="'calc(100vh - 290px)'" |
| | | :page="testObjectPage" :tableLoading="tableLoading"></lims-table> |
| | | </div> |