From 9bce6d06fc72b109ebfe1fa779c57e1d62a43b57 Mon Sep 17 00:00:00 2001 From: zss <zss@example.com> Date: 星期五, 13 九月 2024 16:58:56 +0800 Subject: [PATCH] 来样方式改成订单类型 --- src/components/do/b1-ins-order/add.vue | 1293 ++++++++++++++++++++++++++++++++++++++-------------------- 1 files changed, 852 insertions(+), 441 deletions(-) diff --git a/src/components/do/b1-ins-order/add.vue b/src/components/do/b1-ins-order/add.vue index 650f2f4..6c2d005 100644 --- a/src/components/do/b1-ins-order/add.vue +++ b/src/components/do/b1-ins-order/add.vue @@ -131,7 +131,7 @@ </style> <template> - <div class="ins_order_add"> + <div class="ins_order_add" style=" display: block; "> <div v-show="!configShow&&!equipConfigShow&&!cableConfigShow"> <el-row class="title"> <el-col :span="6" style="padding-left: 20px;text-align: left;">濮旀墭鍗曚俊鎭� 鎬讳环锛�<span @@ -154,363 +154,382 @@ <el-button size="medium" type="primary" @click="openConfig" v-if="addObj.sampleType==='鍏夌紗'">鍏夌氦閰嶇疆</el-button> <el-button size="medium" type="primary" @click="save" :loading="saveLoad" v-show="active==1">鎻愪氦</el-button> <!-- 瀹℃牳 --> - <el-button size="medium" @click="upInsOrderOfState(2)" :loading="saveLoad" v-show="active==3" + <el-button size="medium" @click="upInsOrderOfState(2)" :loading="saveLoad" v-show="active==3&&addObj.companyId" :disabled="saveLoad">涓嶉�氳繃</el-button> <el-button size="medium" type="primary" @click="upInsOrderOfState(1)" :loading="saveLoad" - v-show="active==3">閫氳繃</el-button> + v-show="active==3&&addObj.companyId">閫氳繃</el-button> <el-button size="medium" @click="$parent.playOrder(0)"> <span style="color: #3A7BFA;">杩斿洖</span> </el-button> </el-col> </el-row> </div> - <div class="search" v-show="!configShow&&!equipConfigShow&&!cableConfigShow"> - <el-row> - <el-col class="search_thing" :span="6"> - <div class="search_label">濮旀墭缂栧彿锛�</div> - <div class="search_input"> - <el-input v-model="addObj.entrustCode" size="small" placeholder="绯荤粺鐢熸垚" disabled></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>妫�楠岀被鍒細</div> - <div class="search_input"> - <el-select size="small" style="width: 100%;" clearable v-model="addObj.orderType" :disabled="active>1"> - <el-option v-for="(a, ai) in orderType" :key="ai" :value="a.value" :label="a.label"></el-option> - </el-select> - </div> - </el-col> - <el-col class="search_thing" :span="6" > - <div class="search_label"><span class="required-span">* </span>鍒跺崟浜猴細</div> - <div class="search_input"> - <el-input size="small" clearable disabled v-model="addObj.custom"></el-input> - <!-- <el-input readonly size="small" v-model="addObj.custom"> - <template slot="append"><el-button slot="append" icon="el-icon-search" @click="selectUserDia = true" - :disabled="active>1"></el-button></template> - </el-input> --> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>濮旀墭鍗曚綅锛�</div> - <div class="search_input"> - <!-- <el-input size="small" placeholder="鈫愰�夋嫨濮旀墭瀹㈡埛" clearable disabled v-model="addObj.company"></el-input> --> - <el-input readonly size="small" v-model="addObj.company" placeholder="閫夋嫨濮旀墭鍗曚綅"> - <template slot="append"><el-button slot="append" icon="el-icon-search" @click="selectUserDia = true" - :disabled="active>1"></el-button></template> - </el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>鑱旂郴鏂瑰紡锛�</div> - <div class="search_input"> - <el-input size="small" placeholder="閫夋嫨濮旀墭瀹㈡埛" clearable :readonly="active>1" v-model="addObj.phone"></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>绱ф�ョ▼搴︼細</div> - <div class="search_input"> - <el-select size="small" style="width: 100%;" clearable v-model="addObj.type" :disabled="active>1"> - <el-option v-for="(a, ai) in type" :key="ai" :value="a.value" :label="a.label"></el-option> - </el-select> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>鏍峰搧鍚嶇О锛�</div> - <div class="search_input"> - <el-input readonly size="small" v-model="addObj.sample"> - <template slot="append"><el-button slot="append" icon="el-icon-search" @click="selectStandardTree = true" - :disabled="active>1"></el-button></template> - </el-input> - </div> - </el-col> - <!-- <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>鏍峰搧绫诲瀷锛�</div> - <div class="search_input"> - <el-input size="small" clearable disabled v-model="addObj.sampleType"></el-input> - </div> - </el-col> --> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>鏍峰搧鏁伴噺锛�</div> - <div class="search_input"> - <el-input-number size="small" v-model="addObj.sampleNum" :min="1" :max="100" :precision="0" - style="width: 65%;" @change="addStandardTree" :disabled="active>1"></el-input-number> - </div> - </el-col> - <!-- <el-col class="search_thing" :span="6"> - <div class="search_label">鏍峰搧鍗曚綅锛�</div> - <div class="search_input"> - <el-select v-model="addObj.unit" clearable size="small" style="width: 100%;" :disabled="active>1"> - <el-option v-for="(a, i) in units" :key="i" :label="a.label" :value="a.value"></el-option> - </el-select> - </div> - </el-col> --> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>鏉ユ牱鏂瑰紡锛�</div> - <div class="search_input"> - <el-select v-model="addObj.formType" size="small" :disabled="active>1" style="width: 100%;"> - <el-option v-for="(a,ai) in formType" :key="ai" :label="a.label" :value="a.value"></el-option> - </el-select> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label">鎶ュ憡鍙戦�佹柟寮忥細</div> - <div class="search_input"> - <el-radio-group v-model="addObj.send"> - <el-radio :label="1">鑷彇</el-radio> - <el-radio :label="0">鍏朵粬</el-radio> - </el-radio-group> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label">鏍峰搧澶勭悊鏂瑰紡锛�</div> - <div class="search_input"> - <el-radio-group v-model="addObj.processing"> - <el-radio :label="0">濮旀墭鍗曚綅鍙栧洖</el-radio> - <el-radio :label="1">瀹為獙瀹ゅ鐞�</el-radio> - </el-radio-group> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label">宸ョ▼鍚嶇О锛�</div> - <div class="search_input"> - <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.engineering" - :readonly="active>1"></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label">宸ョ▼鍚嶇ОEN锛�</div> - <div class="search_input"> - <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.engineeringEn" - :readonly="active>1"></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>鐢熶骇鍗曚綅锛�</div> - <div class="search_input"> - <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="addObj.production" - :readonly="active>1"></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label"><span class="required-span">* </span>鐢熶骇鍗曚綅EN锛�</div> - <div class="search_input"> - <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="addObj.productionEn" - :readonly="active>1"></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label">鏄惁鐣欐牱锛�</div> - <div class="search_input"> - <el-radio-group v-model="addObj.isLeave"> - <el-radio :label="0">涓嶇暀鏍�</el-radio> - <el-radio :label="1">鐣欐牱</el-radio> - </el-radio-group> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label" style="width: 175px;">鏄惁娑夊強閰嶅鏍峰搧锛�</div> - <div class="search_input" style="width: calc(100% - 175px);"> - <el-radio-group v-model="addObj.mating" @change="$refs.sampleTable.doLayout()"> - <el-radio :label="1">鏄�</el-radio> - <el-radio :label="0">鍚�</el-radio> - </el-radio-group> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label">OTC璁㈠崟鍙凤細</div> - <div class="search_input"> - <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.otcCode" :readonly="active>1"></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6"> - <div class="search_label">濮旀墭浜猴細</div> - <div class="search_input"> - <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.prepareUser" :readonly="active>1"></el-input> - </div> - </el-col> - <el-col class="search_thing" :span="6" style="align-items: flex-start;margin: 8px 0;"> - <div class="search_label">澶囨敞锛�</div> - <div class="search_input"> - <el-input type="textarea" :autosize="{ minRows: 2, maxRows: 2}" size="small" clearable :placeholder="active>1 ? '' : '璇疯緭鍏�'" - v-model="addObj.remark" :readonly="active>1"></el-input> - </div> - </el-col> - <!-- <el-col class="search_thing" :span="6" v-if="active==1"> - <div class="search_label">RTS锛�</div> - <div class="search_input"> - <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="RTS"></el-input> - </div> - </el-col> --> - </el-row> - </div> - <div v-show="!configShow&&!equipConfigShow&&!cableConfigShow"> - <div class="search" v-if="active==1" style="display: flex;background: transparent;"> - <div class="search_thing"> - <div class="search_label">鏍峰搧鍨嬪彿锛�</div> - <div class="search_input"> - <el-select v-model="model" :placeholder="active>1 ? '' : '璇疯緭鍏�'" filterable allow-create default-first-option size="small" - @change="changeModel"> - <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-select v-model="standardMethodListId" :placeholder="active>1 ? '' : '璇疯緭鍏�'" size="small" @focus="methodFocus" - :loading="methodLoad" @change="changeStandardMethodListId"> - <el-option v-for="item in methods" :key="item.id" :label="item.code" :value="item.id"> - </el-option> - </el-select> - </div> - </div> + <div v-show="!configShow&&!equipConfigShow&&!cableConfigShow" class="container"> + <div class="search"> + <el-row> + <el-col class="search_thing" :span="6"> + <div class="search_label">濮旀墭缂栧彿锛�</div> + <div class="search_input"> + <el-input v-model="addObj.entrustCode" size="small" placeholder="绯荤粺鐢熸垚" disabled></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>妫�楠岀被鍒細</div> + <div class="search_input"> + <el-select size="small" style="width: 100%;" clearable v-model="addObj.orderType" :disabled="active>1"> + <el-option v-for="(a, ai) in orderType" :key="ai" :value="a.value" :label="a.label"></el-option> + </el-select> + </div> + </el-col> + <el-col class="search_thing" :span="6" > + <div class="search_label"><span class="required-span">* </span>鍒跺崟浜猴細</div> + <div class="search_input"> + <el-input size="small" clearable disabled v-model="addObj.custom"></el-input> + <!-- <el-input readonly size="small" v-model="addObj.custom"> + <template slot="append"><el-button slot="append" icon="el-icon-search" @click="selectUserDia = true" + :disabled="active>1"></el-button></template> + </el-input> --> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>濮旀墭鍗曚綅锛�</div> + <div class="search_input"> + <!-- <el-input size="small" placeholder="鈫愰�夋嫨濮旀墭瀹㈡埛" clearable disabled v-model="addObj.company"></el-input> --> + <el-input readonly size="small" v-model="addObj.company" placeholder="閫夋嫨濮旀墭鍗曚綅"> + <template slot="append"><el-button slot="append" icon="el-icon-search" @click="selectUserDia = true" + :disabled="active>1"></el-button></template> + </el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>鑱旂郴鏂瑰紡锛�</div> + <div class="search_input"> + <el-input size="small" placeholder="閫夋嫨濮旀墭瀹㈡埛" clearable :readonly="active>1" v-model="addObj.phone"></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6" v-if="addObj.orderType=='C'"> + <div class="search_label"><span class="required-span">* </span>涓嬪崟鑷筹細</div> + <div class="search_input"> + <el-select size="small" style="width: 100%;" clearable v-model="addObj.departmentLimsId" :disabled="active>1" placeholder="閮ㄩ棬"> + <el-option v-for="(a, ai) in deaprtEnum" :key="ai" :value="a.id" :label="a.name"></el-option> + </el-select> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>绱ф�ョ▼搴︼細</div> + <div class="search_input"> + <el-select size="small" style="width: 100%;" clearable v-model="addObj.type" :disabled="active>1"> + <el-option v-for="(a, ai) in type" :key="ai" :value="a.value" :label="a.label"></el-option> + </el-select> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>鏍峰搧鍚嶇О锛�</div> + <div class="search_input"> + <el-input readonly size="small" v-model="addObj.sample"> + <template slot="append"><el-button slot="append" icon="el-icon-search" @click="selectStandardTree = true" + :disabled="active>1"></el-button></template> + </el-input> + </div> + </el-col> + <!-- <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>鏍峰搧绫诲瀷锛�</div> + <div class="search_input"> + <el-input size="small" clearable disabled v-model="addObj.sampleType"></el-input> + </div> + </el-col> --> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>鏍峰搧鏁伴噺锛�</div> + <div class="search_input"> + <el-input-number size="small" v-model="addObj.sampleNum" :min="1" :max="100" :precision="0" + style="width: 65%;" @change="addStandardTree" :disabled="active>1"></el-input-number> + </div> + </el-col> + <!-- <el-col class="search_thing" :span="6"> + <div class="search_label">鏍峰搧鍗曚綅锛�</div> + <div class="search_input"> + <el-select v-model="addObj.unit" clearable size="small" style="width: 100%;" :disabled="active>1"> + <el-option v-for="(a, i) in units" :key="i" :label="a.label" :value="a.value"></el-option> + </el-select> + </div> + </el-col> --> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>璁㈠崟绫诲瀷锛�</div> + <div class="search_input"> + <el-select v-model="addObj.formType" size="small" :disabled="active>1" style="width: 100%;"> + <el-option v-for="(a,ai) in formType" :key="ai" :label="a.label" :value="a.value"></el-option> + </el-select> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label">鎶ュ憡鍙戦�佹柟寮忥細</div> + <div class="search_input"> + <el-radio-group v-model="addObj.send"> + <el-radio :label="1">鑷彇</el-radio> + <el-radio :label="0">鍏朵粬</el-radio> + </el-radio-group> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label">鏍峰搧澶勭悊鏂瑰紡锛�</div> + <div class="search_input"> + <el-radio-group v-model="addObj.processing"> + <el-radio :label="0">濮旀墭鍗曚綅鍙栧洖</el-radio> + <el-radio :label="1">瀹為獙瀹ゅ鐞�</el-radio> + </el-radio-group> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label">宸ョ▼鍚嶇О锛�</div> + <div class="search_input"> + <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.engineering" + :readonly="active>1"></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label">宸ョ▼鍚嶇ОEN锛�</div> + <div class="search_input"> + <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.engineeringEn" + :readonly="active>1"></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>鐢熶骇鍗曚綅锛�</div> + <div class="search_input"> + <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="addObj.production" + :readonly="active>1"></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label"><span class="required-span">* </span>鐢熶骇鍗曚綅EN锛�</div> + <div class="search_input"> + <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="addObj.productionEn" + :readonly="active>1"></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label">鏄惁鐣欐牱锛�</div> + <div class="search_input"> + <el-radio-group v-model="addObj.isLeave"> + <el-radio :label="0">涓嶇暀鏍�</el-radio> + <el-radio :label="1">鐣欐牱</el-radio> + </el-radio-group> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label" style="width: 175px;">鏄惁娑夊強閰嶅鏍峰搧锛�</div> + <div class="search_input" style="width: calc(100% - 175px);"> + <el-radio-group v-model="addObj.mating" @change="$refs.sampleTable.doLayout()"> + <el-radio :label="1">鏄�</el-radio> + <el-radio :label="0">鍚�</el-radio> + </el-radio-group> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label">OTC璁㈠崟鍙凤細</div> + <div class="search_input"> + <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.otcCode" :readonly="active>1"></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6"> + <div class="search_label">濮旀墭浜猴細</div> + <div class="search_input"> + <el-input size="small" :placeholder="active>1 ? '' : '璇疯緭鍏�'" clearable v-model="addObj.prepareUser" :readonly="active>1"></el-input> + </div> + </el-col> + <el-col class="search_thing" :span="6" style="align-items: flex-start;margin: 8px 0;"> + <div class="search_label">澶囨敞锛�</div> + <div class="search_input"> + <el-input type="textarea" :autosize="{ minRows: 2, maxRows: 2}" size="small" clearable :placeholder="active>1 ? '' : '璇疯緭鍏�'" + v-model="addObj.remark" :readonly="active>1"></el-input> + </div> + </el-col> + <!-- <el-col class="search_thing" :span="6" v-if="active==1"> + <div class="search_label">RTS锛�</div> + <div class="search_input"> + <el-input size="small" placeholder="璇疯緭鍏�" clearable v-model="RTS"></el-input> + </div> + </el-col> --> + </el-row> </div> - <el-table class="el-table sampleTable" ref="sampleTable" :data="sampleList" height="250px" tooltip-effect="dark" - border @selection-change="selectSample" highlight-current-row @row-click="rowClick" style="margin-top: 10px;"> - <el-table-column type="selection" width="60" :selectable="selectable" v-if="active==1"></el-table-column> - <el-table-column type="index" label="搴忓彿" width="65" align="center"></el-table-column> - <el-table-column prop="sample" label="鏍峰搧鍚嶇О" align="center" min-width="100"> - <template slot-scope="scope"> - <el-input size="small" v-model="scope.row.sample" clearable :readonly="active>1"></el-input> - </template> - </el-table-column> - <el-table-column prop="sampleCode" label="鏍峰搧缂栧彿" min-width="140" align="center"> - <template slot-scope="scope"> - <el-input size="small" v-model="scope.row.sampleCode" clearable placeholder="涓嶅~鍐欏垯绯荤粺鑷姩鐢熸垚" - :readonly="active>1"></el-input> - </template> - </el-table-column> - <el-table-column prop="model" label="鏍峰搧鍨嬪彿" align="center" min-width="100"> - <template slot-scope="scope"> - <el-select v-model="scope.row.model" filterable allow-create default-first-option placeholder="鏍峰搧鍨嬪彿" - size="small" @change="handleChangeModel" :disabled="active>1" style="width: 100%;"> - <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 prop="modelNum" label="鍨嬪彿鍙傛暟" width="130" align="center" v-if="!(active>1)"> - <template slot-scope="scope"> - <el-input size="small" v-model="scope.row.modelNum" clearable placeholder="闈炲繀濉�" - @keyup.enter.native="methodChange(scope.row.standardMethodListId, scope.row)" - @clear="methodChange(scope.row.standardMethodListId, scope.row)"></el-input> - </template> - </el-table-column> - <el-table-column prop="standardMethodListId" label="妫�楠屾爣鍑�" align="center" min-width="100"> - <template slot-scope="scope"> - <el-select v-model="scope.row.standardMethodListId" :disabled="scope.row.model==null||active>1" - placeholder="妫�楠屾爣鍑�" size="small" :loading="methodLoad" @change="(value)=>methodChange(value, scope.row)" - @focus="methodFocus" :readonly="active>1" style="width: 100%;" clearable @clear="productList = []"> - <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 prop="joinName" label="閰嶅鏍峰搧鍚嶇О" width="140" align="center" v-if="addObj.mating==1"> - <template slot-scope="scope"> - <el-input size="small" type="textarea" :autosize="{ minRows: 1, maxRows: 1}" - v-model="scope.row.joinName"></el-input> - </template> - </el-table-column> - <el-table-column prop="joinModel" label="閰嶅鏍峰搧鍨嬪彿" width="140" align="center" v-if="addObj.mating==1"> - <template slot-scope="scope"> - <el-input size="small" type="textarea" :autosize="{ minRows: 1, maxRows: 1}" - v-model="scope.row.joinModel"></el-input> - </template> - </el-table-column> - <el-table-column prop="joinNum" label="閰嶅鏍峰搧鏁伴噺" width="140" align="center" v-if="addObj.mating==1"> - <template slot-scope="scope"> - <el-input-number size="small" v-model="scope.row.joinNum" :min="1" :max="100" :precision="0" - :controls="false" style="width: 80%;"></el-input-number> - </template> - </el-table-column> - <el-table-column prop="proNum" label="寰呮椤规暟閲�" width="105" align="center"></el-table-column> - </el-table> - <el-table class="el-table" ref="productTable" :data="productList" height="380px" tooltip-effect="dark" border - @selection-change="selectProduct" style="margin-bottom: 10px;" @select="upProductSelect" - :row-class-name="tableRowClassName" v-loading="getProductLoad" @select-all="handleAll"> - <el-table-column type="selection" width="65" :selectable="selectable" v-if="active==1"></el-table-column> - <el-table-column prop="inspectionItem" label="妫�楠岄」" min-width="140" 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" - @input="searchFilterList" - size="mini" - placeholder="璇疯緭鍏�"/> + <div style="height: auto;"> + <div class="search" v-if="active==1" style="display: flex;background: transparent;"> + <div class="search_thing"> + <div class="search_label">鏍峰搧鍨嬪彿锛�</div> + <div class="search_input"> + <el-select v-model="model" :placeholder="active>1 ? '' : '璇疯緭鍏�'" filterable allow-create default-first-option size="small" + @change="changeModel"> + <el-option v-for="item in models" :key="item.value" :label="item.label" :value="item.value"> + </el-option> + </el-select> </div> - </template> - </el-table-column> - <el-table-column prop="inspectionItemSubclass" label="妫�楠岄」瀛愰」" min-width="140" - 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" + </div> + <div class="search_thing"> + <div class="search_label">妫�楠屾爣鍑嗭細</div> + <div class="search_input"> + <el-select v-model="standardMethodListId" :placeholder="active>1 ? '' : '璇疯緭閫夋嫨'" size="small" @focus="methodFocus" + :loading="methodLoad" multiple @change="changeStandardMethodListId"> + <el-option v-for="item in methods" :key="item.id" :label="item.code" :value="item.id"> + </el-option> + </el-select> + </div> + </div> + </div> + <el-table class="el-table sampleTable" ref="sampleTable" :data="sampleList" max-height="400px" tooltip-effect="dark" + border @selection-change="selectSample" highlight-current-row @row-click="rowClick" style="margin-top: 10px;"> + <el-table-column type="selection" width="60" :selectable="selectable" v-if="active==1"></el-table-column> + <el-table-column type="index" label="搴忓彿" width="65" align="center"></el-table-column> + <el-table-column prop="sample" label="鏍峰搧鍚嶇О" align="center" min-width="100"> + <template slot-scope="scope"> + <el-input size="small" v-model="scope.row.sample" clearable :readonly="active>1"></el-input> + </template> + </el-table-column> + <el-table-column prop="sampleCode" label="鏍峰搧缂栧彿" min-width="100" align="center"> + <template slot-scope="scope"> + <el-input size="small" v-model="scope.row.sampleCode" clearable placeholder="涓嶅~鍐欏垯绯荤粺鑷姩鐢熸垚" + :readonly="active>1"></el-input> + </template> + </el-table-column> + <el-table-column prop="model" label="鏍峰搧鍨嬪彿" align="center" min-width="100"> + <template slot-scope="scope"> + <el-select v-model="scope.row.model" filterable allow-create default-first-option placeholder="鏍峰搧鍨嬪彿" + size="small" @change="handleChangeModel" :disabled="active>1" style="width: 100%;"> + <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 prop="modelNum" label="鍨嬪彿鍙傛暟" min-width="100" align="center" v-if="!(active>1)"> + <template slot-scope="scope"> + <el-input size="small" v-model="scope.row.modelNum" clearable placeholder="闈炲繀濉�" + @keyup.enter.native="methodChange(scope.row.standardMethodListId, scope.row)" + @clear="methodChange(scope.row.standardMethodListId, scope.row)"></el-input> + </template> + </el-table-column> + <el-table-column prop="standardMethodListId" label="妫�楠屾爣鍑�" align="center" min-width="100"> + <template slot-scope="scope"> + <el-select v-model="scope.row.standardMethodListId" :disabled="scope.row.model==null||active>1" + placeholder="妫�楠屾爣鍑�" size="small" :loading="methodLoad" @change="(value)=>methodChange(value, scope.row)" + @focus="methodFocus" :readonly="active>1" style="width: 100%;" clearable @clear="productList = []" multiple> + <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 prop="testRequirements" label="璇曢獙鏍囧噯" align="center" min-width="100"> + <template slot-scope="scope"> + <el-select v-model="scope.row.testRequirements" :disabled="scope.row.model==null||active>1" + placeholder="璇曢獙鏍囧噯" size="small" :readonly="active>1" style="width: 100%;" clearable> + <el-option v-for="item in standard" :key="item.id" :label="item.label" :value="item.value"> + </el-option> + </el-select> + </template> + </el-table-column> + <el-table-column prop="joinName" label="閰嶅鏍峰搧鍚嶇О" width="140" align="center" v-if="addObj.mating==1"> + <template slot-scope="scope"> + <el-input size="small" type="textarea" :autosize="{ minRows: 1, maxRows: 1}" + v-model="scope.row.joinName"></el-input> + </template> + </el-table-column> + <el-table-column prop="joinModel" label="閰嶅鏍峰搧鍨嬪彿" width="140" align="center" v-if="addObj.mating==1"> + <template slot-scope="scope"> + <el-input size="small" type="textarea" :autosize="{ minRows: 1, maxRows: 1}" + v-model="scope.row.joinModel"></el-input> + </template> + </el-table-column> + <el-table-column prop="joinNum" label="閰嶅鏍峰搧鏁伴噺" width="140" align="center" v-if="addObj.mating==1"> + <template slot-scope="scope"> + <el-input-number size="small" v-model="scope.row.joinNum" :min="1" :max="100" :precision="0" + :controls="false" style="width: 80%;"></el-input-number> + </template> + </el-table-column> + <el-table-column prop="proNum" label="寰呮椤规暟閲�" width="105" align="center"></el-table-column> + </el-table> + <el-table class="el-table" ref="productTable" :data="productList" max-height="400px" tooltip-effect="dark" border + @selection-change="selectProduct" style="margin-bottom: 10px;" @select="upProductSelect" + :row-class-name="tableRowClassName" v-loading="getProductLoad" @select-all="handleAll"> + <el-table-column type="selection" width="65" :selectable="selectable" v-if="active==1"></el-table-column> + <el-table-column prop="inspectionItemClass" v-if="PROJECT === '瑁呭鐢电紗'" label="妫�楠岄」鍒嗙被" min-width="140" show-overflow-tooltip></el-table-column> + <el-table-column prop="inspectionItemClassEn" v-if="PROJECT === '瑁呭鐢电紗'" label="妫�楠岄」鍒嗙被(EN)" min-width="140" show-overflow-tooltip></el-table-column> + <el-table-column prop="inspectionItem" label="妫�楠岄」" min-width="140" 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" @input="searchFilterList" size="mini" placeholder="璇疯緭鍏�"/> - </div> - </template> - </el-table-column> - <el-table-column prop="inspectionItemClass" v-if="PROJECT === '瑁呭鐢电紗'" label="妫�楠岄」鍒嗙被" min-width="140" show-overflow-tooltip></el-table-column> - <el-table-column prop="inspectionItemClassEn" v-if="PROJECT === '瑁呭鐢电紗'" label="妫�楠岄」鍒嗙被(EN)" min-width="140" show-overflow-tooltip></el-table-column> - <el-table-column prop="sonLaboratory" label="瀛愬疄楠屽" min-width="130" show-overflow-tooltip :filters="filters" - :filter-method="filterHandler"></el-table-column> - <el-table-column prop="methodS" label="璇曢獙鏂规硶" min-width="120" 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" - @input="searchFilterList" - size="mini" - placeholder="璇疯緭鍏�"/> - </div> - </template> - </el-table-column> - <el-table-column prop="unit" label="璁¢噺鍗曚綅" width="100" show-overflow-tooltip></el-table-column> - <el-table-column prop="price" label="鍗曚环" width="100" show-overflow-tooltip></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 prop="section" label="鍖洪棿" min-width="120" show-overflow-tooltip></el-table-column> - <el-table-column prop="ask" label="瑕佹眰鍊�" min-width="220px" v-if="isAskOnlyRead"> - <template slot-scope="scope"> - <el-input size="small" placeholder="瑕佹眰鍊�" v-model="scope.row.ask" clearable type="textarea" - :autosize="{ minRows: 1, maxRows: 3}" @change="e=>requestChange(e,scope.row,'ask')" - v-if="active==1&&isAskOnlyRead"></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 prop="tell" label="瑕佹眰鎻忚堪" min-width="220px"> - <template slot-scope="scope"> - <el-input size="small" placeholder="瑕佹眰鎻忚堪" v-model="scope.row.tell" clearable type="textarea" - :autosize="{ minRows: 1, maxRows: 3}" @change="e=>requestChange(e,scope.row,'tell')" - v-if="active==1&&isAskOnlyRead"></el-input> - <span v-else> - <template >{{ scope.row.tell }}</template> - </span> - </template> - </el-table-column> - </el-table> + </div> + </template> + </el-table-column> + <el-table-column prop="inspectionItemSubclass" label="妫�楠岄」瀛愰」" min-width="140" + 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" + @input="searchFilterList" + size="mini" + placeholder="璇疯緭鍏�"/> + </div> + </template> + </el-table-column> + <el-table-column prop="tell" label="瑕佹眰鎻忚堪" min-width="220px"> + <template slot-scope="scope"> + <el-input size="small" placeholder="瑕佹眰鎻忚堪" v-model="scope.row.tell" clearable type="textarea" + :autosize="{ minRows: 1, maxRows: 3}" @change="e=>requestChange(e,scope.row,'tell')" + v-if="active==1"></el-input> + <span v-else> + <template >{{ scope.row.tell }}</template> + </span> + </template> + </el-table-column> + <el-table-column prop="ask" label="瑕佹眰鍊�" min-width="220px" > + <template slot-scope="scope"> + <el-input size="small" placeholder="瑕佹眰鍊�" v-model="scope.row.ask" clearable type="textarea" + :autosize="{ minRows: 1, maxRows: 3}" @change="e=>requestChange(e,scope.row,'ask')" + v-if="active==1&&scope.row.inspectionValueType!='5'"></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 prop="methodS" label="璇曢獙鏂规硶" min-width="120" 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" + @input="searchFilterList" + size="mini" + placeholder="璇疯緭鍏�"/> + </div> + </template> + </el-table-column> + <el-table-column prop="unit" label="璁¢噺鍗曚綅" width="100" show-overflow-tooltip></el-table-column> + <el-table-column prop="price" label="鍗曚环" width="100" show-overflow-tooltip></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 prop="section" label="鍖洪棿" min-width="120" show-overflow-tooltip></el-table-column> + <el-table-column prop="sonLaboratory" label="瀛愬疄楠屽" min-width="130" show-overflow-tooltip :filters="filters" + :filter-method="filterHandler"></el-table-column> + </el-table> + </div> </div> <el-dialog title="閫夋嫨鍗曚綅" :visible.sync="selectUserDia" width="70%"> <div class="body" style="height: 60vh;" v-if="selectUserDia"> @@ -521,7 +540,7 @@ <el-button type="primary" @click="selectUser">纭� 瀹�</el-button> </span> </el-dialog> - <el-dialog title="閫夋嫨鏍峰搧" :visible.sync="selectStandardTree" width="400px"> + <el-dialog title="閫夋嫨鏍峰搧" :visible.sync="selectStandardTree" width="500px"> <div class="body" style="height: 60vh;overflow-y: auto;user-select: none;" v-if="selectStandardTree"> <el-row> <el-col :span="24"> @@ -561,7 +580,8 @@ <el-button type="primary" @click="addTemplateDia" :loading="templateLoading">纭� 瀹�</el-button> </span> </el-dialog> - <el-dialog title="妫�楠屼笅鍙�" :visible.sync="issuedDialogVisible" width="400px"> + <el-dialog title="妫�楠屼笅鍙�" :visible.sync="issuedDialogVisible" width="400px" :close-on-click-modal="false" + :close-on-press-escape="false" :show-close="false"> <div class="body" style="max-height: 60vh;"> <el-row> <el-col class="search_thing" :span="22"> @@ -594,7 +614,7 @@ </div> <span slot="footer" class="dialog-footer"> <el-row> - <el-button @click="issuedDialogVisible=false">鍙� 娑�</el-button> + <el-button @click="issuedDialogVisible=false;$parent.playOrder(0)">鍙� 娑�</el-button> <el-button type="primary" @click="submitForm2" :loading="upLoad">纭� 瀹�</el-button> </el-row> </span> @@ -617,12 +637,16 @@ </el-row> </span> </el-dialog> - <fiberOpticConfig :currentId="currentId" @saveFiberopticConfig="getTotal()" v-if="configShow" :active="active" /> + <fiberOpticConfig :currentId="currentId" @saveFiberopticConfig="getTotal()" v-if="configShow && examine==0" :active="active" :inspectionItemST='inspectionItemST' /> + <fiberOpticConfigTwo :currentId="currentId" v-if="configShow && examine==1" :active="active" /> <equipConfig :currentId="currentId" v-if="equipConfigShow" :active="active" /> <cableConfig v-if="cableConfigShow" :active="active" /> <!-- 鍗曢�夌壒娈婂�煎鐞嗘--> - <el-dialog title="妫�娴嬪埌鐗规畩椤癸紝璇蜂綔鍑轰互涓嬮�夋嫨" :visible.sync="bsm1Dia" min-width="400px" :show-close="false" - :before-close="beforeClose"> + <el-dialog title="妫�娴嬪埌鐗规畩椤癸紝璇蜂綔鍑轰互涓嬮�夋嫨" :visible.sync="bsm1Dia" + :close-on-press-escape="false" + :close-on-click-modal="false" + min-width="400px" :show-close="false" + :before-close="beforeClose"> <div class="body" style="max-height: 60vh;"> <el-row v-if="bsm1"> <el-col class="search_thing" :span="24" style="height: initial;margin: 5px 0;"> @@ -681,9 +705,16 @@ </el-col> </el-row> --> </div> + <span slot="footer" class="dialog-footer"> + <el-row> + <el-button type="primary" @click="save2" :loading="saveLoad">纭� 瀹�</el-button> + </el-row> + </span> </el-dialog> <!-- 鍏ㄩ�夌壒娈婂�煎鐞嗘--> <el-dialog title="妫�娴嬪埌鐗规畩椤癸紝璇蜂綔鍑轰互涓嬮�夋嫨" :visible.sync="bsm1DiaAll" min-width="400px" :show-close="false" + :close-on-press-escape="false" + :close-on-click-modal="false" :before-close="beforeClose"> <div class="body" style="max-height: 60vh;" v-for="(item, index) in bsm1DiaList" :key="index"> <el-row v-if="item.bsm1"> @@ -735,11 +766,18 @@ </el-col> </el-row> </div> + <span slot="footer" class="dialog-footer"> + <el-row> + <el-button type="primary" @click="save1" :loading="saveLoad">纭� 瀹�</el-button> + </el-row> + </span> </el-dialog> - <el-dialog title="鐗规畩鍊煎~鍐�" :visible.sync="bsm3Dia" width="800px" :show-close="false"> + <el-dialog title="鐗规畩鍊煎~鍐�" :visible.sync="bsm3Dia" + :close-on-click-modal="false" :close-on-press-escape="false" + width="800px" :show-close="false"> <el-table :data="editTable" - style="width: 100%"> + style="width: 100%" height="80vh"> <!-- inspectionItemList --> <el-table-column prop="inspectionItemList" @@ -764,7 +802,7 @@ prop="value" label="璇嗗埆绗﹀��"> <template slot-scope="scope"> - <el-input v-model="scope.row.value" placeholder="璇疯緭鍏�" size="small"></el-input> + <el-input v-model="scope.row.value" placeholder="璇疯緭鍏�" @input="inputValueHandler(scope.row,scope.$index)" size="small"></el-input> </template> </el-table-column> </el-table> @@ -775,7 +813,9 @@ </el-row> </span> </el-dialog> - <el-dialog title="娓╁害寰幆瑕佹眰濉啓" :visible.sync="circulateShow" width="900px" :before-close="beforeCirculateShowClose" :show-close="false"> + <el-dialog title="娓╁害寰幆瑕佹眰濉啓" :visible.sync="circulateShow" width="900px" + :close-on-click-modal="false" :close-on-press-escape="false" + :before-close="beforeCirculateShowClose" :show-close="false"> <div class="search" style="display: flex;background: transparent;"> <div class="search_thing"> <div class="search_label">淇濇俯鏃堕棿锛�</div> @@ -859,8 +899,19 @@ <el-button type="primary" @click="spliceData">淇濆瓨</el-button> </span> </el-dialog> + <el-dialog title="鍗曟牴鍨傜洿鐕冪儳妫�娴嬫鏁板~鍐�" :visible.sync="singleVerticalCombustionShow" width="900px" + :close-on-click-modal="false" :close-on-press-escape="false" + :before-close="beforeCirculateShowClose" :show-close="false"> + <div>111</div> + <span slot="footer" class="dialog-footer"> + <el-button @click="cleanSpliceData">鍙栨秷</el-button> + <el-button type="primary" @click="spliceData">淇濆瓨</el-button> + </span> + </el-dialog> <!-- 鐢靛姏璇曢獙瀹�---娓╁崌璇曢獙/鐑惊鐜� --> - <el-dialog :title="temperatureTitle" :visible.sync="temperatureShow" width="260px" :before-close="temperatureShowClose" :show-close="false"> + <el-dialog :title="temperatureTitle" :visible.sync="temperatureShow" + :close-on-click-modal="false" :close-on-press-escape="false" + width="260px" :before-close="temperatureShowClose" :show-close="false"> <div> <div v-if="isShowInput" style="margin-bottom: 6px"> <span>寰幆娆℃暟:</span> @@ -882,19 +933,24 @@ <script> import ValueTable from '../../tool/value-table.vue' import fiberOpticConfig from './fiberoptic-config.vue' +import fiberOpticConfigTwo from './fiberoptic-config-two.vue' import equipConfig from './equip-config.vue' import cableConfig from './cable-config.vue' import Vue from 'vue' -import {iuCharts} from "../../../util/echarts"; export default { components: { ValueTable, fiberOpticConfig, + fiberOpticConfigTwo, equipConfig, cableConfig }, props: { + examine: { + type: Number, + default: () => 0 + }, active: { type: Number, default: () => 0 @@ -906,6 +962,8 @@ }, data() { return { + inspectionItemST: null, + sampleSelectionList: [],//鏍峰搧琛ㄦ牸閫変腑鏁版嵁 editTable:[], template: null, templates: [], @@ -939,7 +997,9 @@ production: null, productionEn: null, companyId: null, - prepareUser:null + prepareUser:null, + departmentLimsId:null, + departmentLims:null }, sample: { sampleCode: null, @@ -959,7 +1019,7 @@ entity: { orderBy: { field: 'id', - order: 'asc' + order: 'desc' } }, isIndex: true, @@ -1042,7 +1102,7 @@ RTS: '', totalArr: [], model: null, - standardMethodListId: null, + standardMethodListId: [], symbolList:[ 'RTS','A','B','C','D','E','F','G','H','I','J','K','L','M','N','O','P','Q','R','S','T','U','V','W','X','Y','Z'], inspectionItem:null, @@ -1054,6 +1114,7 @@ entrustNum: '', entrustPoint: '' }, + singleVerticalCombustionShow: false, isBsm2Val2:false, opticalProject: [], // 娓╁害寰幆寮规鍏夌氦椤圭洰鍒楄〃 opticalProjectList: [], // 娓╁害寰幆寮规鍏夌氦椤圭洰閫変腑鐨勬暟缁� @@ -1073,7 +1134,10 @@ temperatureTestNum: '', isShowInput: false, temId: '', - sonLaboratoryList:[] + sonLaboratoryList:[], + selectiveEcho: [], // 妫�楠屼笅鍗曠殑鏃跺�欏嬀閫夋楠岄」鐩�,濡傛灉浣跨敤绛涢�夋彁浜ゆ樉绀烘楠岄」鐩负绌� 鍥炴樉鍒楄〃 + deaprtEnum:[], + standard:[] } }, watch: { @@ -1098,6 +1162,25 @@ } } }, + 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 + } + + console.log('0000',this.inspectionItemST); + } + }, sampleList: { deep: true, handler(val) { @@ -1106,11 +1189,11 @@ }, 'addObj.sample'(val) { this.model = null - this.standardMethodListId = null + this.standardMethodListId = [] }, 'addObj.sampleNum'(val) { this.model = null - this.standardMethodListId = null + this.standardMethodListId = [] } }, mounted() { @@ -1120,8 +1203,10 @@ // this.selectInsOrderTemplate() this.getAuthorizedPerson(); this.selectEnumByCategoryForUnit() + this.selectEnumByCategoryForStandard() this.selectStandardMethods() this.selectEnumByCategoryForOrderType() + this.selectDepartmentEnum() // this.selectEnumByCategoryForSonLaboratory() this.selectEnumByCategoryForSampleForm() if (this.active != 1) { @@ -1134,7 +1219,10 @@ ...res.data.insOrder }; this.addObj.type = String(this.addObj.type) - this.sampleList = this.HaveJson(res.data.sampleProduct); + this.sampleList = this.HaveJson(res.data.sampleProduct) + this.sampleList.forEach(m=>{ + m.standardMethodListId = JSON.parse(m.standardMethodListId) + }); this.getProNum() this.addObj.sampleNum = this.sampleList.length this.$nextTick(() => { @@ -1148,6 +1236,20 @@ } }, methods: { + //鐗规畩鍊煎~鍐欏鐞� + inputValueHandler(row,index){ + if(row){ + const nextIndex = index+1 + console.log(nextIndex, this.editTable) + 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 + } + } + } + + }, spliceData () { if (!this.circulateForm.entrustNum || !this.circulateForm.entrustTime || !this.circulateForm.entrustPoint || this.opticalProjectList.length === 0 || this.temperatureData.length === 0) { this.$message.error('璇峰~鍐欏畬鏁存暟鎹�') @@ -1216,6 +1318,9 @@ } }) this.circulateShow = false + this.changeProductList0() + this.currentMethod.insProduct = this.productList0 + this.getProNum() }, spliceTemperatureTest () { if (this.temperatureTest.length === 0) { @@ -1362,6 +1467,22 @@ this.temperatureData = this.temperatureData.slice(0,-deleteNum) } }, + 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, // 妫�楠岄」 @@ -1371,6 +1492,7 @@ const isHaveValue = Object.values(vtw).some(item => { return item }) + this.changeProductList0() if (isHaveValue) { for(let i in vtw) { if (vtw[i]) { @@ -1379,9 +1501,19 @@ }) } } + 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) + }) + }) } }, getAuthorizedPerson() { @@ -1471,47 +1603,58 @@ return str.replace(find, value); }, save() { + if(this.addObj.orderType=='C'&&this.addObj.departmentLimsId){ + this.addObj.departmentLims = this.deaprtEnum.find(m=>m.id==this.addObj.departmentLimsId).name + }else if(this.addObj.orderType&&this.addObj.orderType!='C'&&!this.addObj.departmentLimsId){ + this.addObj.departmentLims = '妫�娴嬩腑蹇�' + this.addObj.departmentLimsId = this.deaprtEnum.find(m=>m.name=='妫�娴嬩腑蹇�').id + } + // else{ + // this.$message.error('璇烽�夋嫨妫�楠岀被鍒�') + // return + // } if (!this.addObj.companyId) { this.$message.error('鏈�夋嫨瀹㈡埛鍗曚綅') + return + } + let noLaboratory = this.totalArr.filter(a => a.state == 1&&!a.sonLaboratory) + if(noLaboratory.length>0){ + let str = '' + noLaboratory.forEach((m,j)=>{ + str += j==noLaboratory.length-1?m.inspectionItem+'-'+m.inspectionItemSubclass:m.inspectionItem+'-'+m.inspectionItemSubclass+',' + }) + this.$message.error(str+'娌℃湁鍏宠仈瀹為獙瀹ゅ锛岃鑱旂郴绠$悊鍛�') return } if (!this.addObj.type) { this.$message.error('鏈�夋嫨绱ф�ョ▼搴�') } else if (!this.addObj.formType) { - this.$message.error('璇疯緭鍏ユ潵鏍锋柟寮�') + this.$message.error('璇疯緭鍏ヨ鍗曠被鍨�') } else if (!this.addObj.orderType) { this.$message.error('璇烽�夋嫨妫�楠岀被鍒�') } else if (!this.addObj.production) { this.$message.error('璇疯緭鍏ョ敓浜у崟浣�') } else if (!this.addObj.productionEn) { this.$message.error('璇疯緭鍏ョ敓浜у崟浣岴N') + }else if (!this.addObj.departmentLimsId) { + this.$message.error('閫夋嫨涓嬪崟鍒板摢涓儴闂�') } else if (this.sampleList.length < 1) { this.$message.error('璇锋坊鍔犱竴涓牱鍝�') } else if (!this.sampleList.every(m => m.sample)) { this.$message.error('璇疯緭鍏ユ牱鍝佸悕绉�') } else if (!this.sampleList.every(m => m.model)) { this.$message.error('璇疯緭鍏ユ牱鍝佸瀷鍙�') - } else if (!this.sampleList.every(m => m.standardMethodListId)) { + } else if (!this.sampleList.every(m => m.standardMethodListId&&m.standardMethodListId.length>0)) { this.$message.error('璇烽�夋嫨妫�楠屾爣鍑�') } else { - const select = this.selectTree.split(' - ') - const productListSelected = this.productListSelected.some(item => item.inspectionItem === '娓╁害寰幆') - let isHaveBushing = '' - this.sampleList.forEach(item => { - if (!item.bushing || item.bushing.length === 0) { - isHaveBushing = false - } - }) - // console.log('isHaveBushing===', isHaveBushing) - if (productListSelected && select[2] === '鍏夌紗' && isHaveBushing === false) { - this.$message.error('鍏夌紗娓╁害寰幆椤圭洰蹇呴』杩涜鍏夌氦閰嶇疆') - - this.$refs.sampleTable.setCurrentRow(this.currentMethod, true) - this.rowClick(this.currentMethod) - this.sampleIds = [this.currentMethod.id] - this.openConfig() - return - } + //鏍¢獙妫�楠岄」鐨勮姹傚�煎拰瑕佹眰鎻忚堪,浠呭鎵樿姹� + // if(this.active==1&&this.isAskOnlyRead){ + // const isTrue = this.checkRequiredValueAndRemark(filterProductList) + // if(!isTrue){ + // this.$message.error('妫�楠岄」鐨勮姹傚�间笌瑕佹眰鎻忚堪涓嶅尮閰嶏紝 璇锋鏌�') + // return + // } + // } let sampleList = this.HaveJson(this.sampleList) let projectNum = this.totalArr.filter(a => a.state == 1).length if(projectNum==0){ @@ -1535,6 +1678,112 @@ this.saveMethod(sampleList) } } + }, + /** + * 鏍¢獙濮旀墭瑕佹眰鐨勬楠岄」鐨勮姹傛弿杩板拰瑕佹眰鍊� + * + */ + checkRequiredValueAndRemark(data){ + let isTrue = true + try{ + data.forEach(ele=>{ + //鍒ゆ柇锛堚墹,鈮�,>,<,=锛夎繖鍑犵鎯呭喌 + //鍒ゆ柇瑕佹眰鍊间腑鐨勬暟瀛楁槸鍚﹀寘鍚湪瑕佹眰鎻忚堪涓� + if(['鈮�','鈮�','>','<','='].includes(ele.ask[0])){ + const askVal = ele.ask.substring(1,ele.ask.length) + if(isNaN(askVal) || ele.tell.indexOf(askVal)<0){ + console.log(1111); + isTrue = false + } + } + //鍒ゆ柇鑼冨洿(10-25),瑕佹眰鍊煎繀椤绘槸- + if(ele.ask.indexOf('-')>0 && ele.ask.length>1){ + //瑕佹眰鎻忚堪鐨剘鍜岃姹傚�肩殑-锛岀瓑鏁� + let tell = ele.tell + if(ele.tell.indexOf('~')>0 || ele.tell.indexOf('锛�') || ele.tell.indexOf('锛�')){ + tell = tell.replace('~','-') + tell = tell.replace('锛�','(') + tell = tell.replace('锛�',')') + } + const splits = ele.ask.split('-') + //婊¤冻鏍煎紡瑕佹眰锛屽苟涓斾袱涓兘鏄暟瀛� + if(splits.length==2 && !isNaN(splits[0]) && !isNaN(splits[1])){ + /** + * 鍒ゆ柇鎯呭喌 + * 1.瑕佹眰鎻忚堪涓庤姹傛弿杩扮浉鍚� + * 2.瑕佹眰鎻忚堪鍖呭惈瑕佹眰鍊� + * 3.瑕佹眰鎻忚堪涓�3N-10N杩欑鎯呭喌 + * 4.瑕佹眰鎻忚堪涓�10卤5杩欑鎯呭喌 + * 5. + */ + let min = Math.min(...splits) + let max = Math.max(...splits) + if(min==max){ + console.log(2222); + isTrue = false + } + //瑕佹眰鎻忚堪涓笉鍖呭惈卤浠ュ強鍖洪棿鐨勬暟瀛楋紝鍒欒繑鍥瀎alse + if(tell.indexOf('卤')<0&&tell.indexOf('-')<0){ + console.log(3333,ele); + console.log(3333333,tell,tell.indexOf('卤')<0,tell.indexOf('-')<0); + isTrue = false + }else if(ele.tell.indexOf('-')==0){ + console.log(4444); + isTrue = false + }else if(tell.indexOf('-')>0){ + if(tell.indexOf('卤')>0){ + ////鏍¢獙瑕佹眰鎻忚堪涓�(10-15)卤5杩欑鍐欐硶鐨勬儏鍐� + const num = tell.split('卤')[1] + const startIndex = tell.indexOf('(') + const endIndex = tell.indexOf(')') + if(startIndex>-1 && endIndex>0 ){ + const str = tell.substring(startIndex,endIndex) + if(str && str.indexOf('-')>0){ + let strList = str.split('-') + const minNum = Number(strList[0]-num) + const maxNum = Number(strList[1]+num) + if(minNum>min || maxNum<max){ + console.log(555555); + isTrue = false + } + } + }else{ + //鏍¢獙瑕佹眰鎻忚堪涓�10卤5杩欑鍐欐硶鐨勬儏鍐� + let splitNums = ele.tell.split('卤') + if(splitNums.length<2){ + console.log(66666); + isTrue = false + }else{ + let minTell = Number(splitNums[0])-Number(splitNums[1]) + let maxTell = Number(splitNums[0])+Number(splitNums[1]) + if(minTell!=min || maxTell!=max){ + console.log(7777777); + isTrue = false + } + } + } + }else{ + const splitTells = tell.split('-') + if(splitTells[0].indexOf(min)<0 || splitTells[1].indexOf(max)<0){ + console.log(88888888); + isTrue = false + } + } + } + }else{ + console.log(89999999); + isTrue = false + } + } + // else if(ele.ask.indexOf('&')>0 && ele.ask.length>1){ + // //鍒ゆ柇 + // } + }) + }catch(error){ + console.log(error); + isTrue = false + } + return isTrue }, save0(){ if(this.editTable.every(m=>m.value)){ @@ -1578,7 +1827,7 @@ } } }else{ - this.$message.error('瑕佹眰鍊间负绌猴紝闇�瑕佸幓鏍囧噯搴撶淮鎶わ紒') + // this.$message.error('瑕佹眰鍊间负绌猴紝闇�瑕佸幓鏍囧噯搴撶淮鎶わ紒') } } // arr.forEach(f => { @@ -1750,6 +1999,22 @@ } }, saveMethod(sampleList){ + let isHaveAsk = this.totalArr.filter(a => (a.ask === null||a.ask=='')&&a.state==1) + if (isHaveAsk.length > 0) { + this.$message({ + type: 'error', + message: '璇峰~鍐欒姹傚�煎悗鍐嶆彁浜�' + }) + return false; + } + let isHaveTell = this.totalArr.filter(a => (a.tell == null||a.tell=='')&&a.state==1) + if (isHaveTell.length > 0) { + this.$message({ + type: 'error', + message: '璇峰~鍐欒姹傛弿杩板悗鍐嶆彁浜�' + }) + return false; + } this.saveLoad = true this.$axios.post(this.$api.insOrder.addInsOrder, { str: JSON.stringify({ @@ -1793,7 +2058,8 @@ state, id: this.currentId, companyId:this.addObj.companyId, - laboratory:this.addObj.laboratory + laboratory:this.addObj.laboratory, + company: this.addObj.company }, { headers: { 'Content-Type': 'application/json' @@ -1823,7 +2089,10 @@ this.distributeData.appointed = ress.data }) setTimeout(() => { - this.issuedDialogVisible = true; + // this.issuedDialogVisible = true; + // this.$message.success('鎻愪氦鎴愬姛') + this.upLoad = false + this.$parent.playOrder(0) }, 1000) }) } else { @@ -1883,9 +2152,15 @@ }) }, getProNum() { - this.sampleList.forEach((m, i) => { - Vue.set(this.sampleList[i], 'proNum', m.insProduct.filter(a => a.state == 1).length) - }) + if (this.active != 1) { + this.sampleList.forEach((m, i) => { + Vue.set(this.sampleList[i], 'proNum', m.insProduct.filter(a => a.state == 1).length) + }) + }else{ + this.sampleSelectionList.forEach((m, i) => { + Vue.set(this.sampleSelectionList[i], 'proNum', m.insProduct.filter(a => a.state == 1).length) + }) + } this.$refs.sampleTable.doLayout() }, searchFilter() { @@ -1901,7 +2176,23 @@ 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--) { @@ -1940,7 +2231,7 @@ this.addObj.factory = trees[0] this.addObj.laboratory = trees[1] this.addObj.sampleType = trees[2] - if (trees[3] === undefined || trees[3] === '') { + if (trees[3] === undefined || trees[3] === '' || trees[3] === '- ') { this.addObj.sample = trees[2] } else { this.addObj.sample = trees[3] @@ -1955,7 +2246,7 @@ this.sample.sample = this.addObj.sample this.sample.model = this.addObj.model this.sample.unit = this.addObj.unit - this.sample.standardMethodListId = null + this.sample.standardMethodListId = [] this.sample.insProduct = [] this.sample.id = this.count this.sample.childSampleList = [] @@ -2000,14 +2291,14 @@ this.sample.sample = this.addObj.sample this.sample.model = this.addObj.model this.sample.unit = this.addObj.unit - this.sample.standardMethodListId = null + this.sample.standardMethodListId = [] this.sample.insProduct = [] - this.sample.id = this.count + 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.count++ } this.computationalPairing(this.sampleList.length) this.bsm2Val2 = this.HaveJson(this.bsm2Val3) @@ -2017,6 +2308,7 @@ val.forEach(a => { this.sampleIds.push(a.id) }) + this.sampleSelectionList = val }, delSample() { this.sampleIds.forEach(a => { @@ -2039,21 +2331,24 @@ }, 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.sampleIds.push(row.id) + this.sampleSelectionList.forEach(ele=>{ + if(ele.id == row.id){ + this.sampleIds.push(row.id) + } + }) } this.productList = row.insProduct + this.productList0 = JSON.parse(JSON.stringify(this.productList)) setTimeout(() => { this.productList.forEach(a => { - if (a.state == 1) this.toggleSelection(a) + if (a.state == 1) { + this.toggleSelection(a) + }else{ + this.$refs.productTable.toggleRowSelection(a, false); + } }) }, 200) }, @@ -2063,6 +2358,9 @@ upProductSelect(selection, row) { this.bsm1DiaList = [] row.state = row.state == 1 ? 0 : 1 + if(row.section === null) { + row.section = "" + } let arr = this.productList.filter(m=>m.state==1&&row.section.includes(m.section)&&m.ask&&m.section.indexOf('[')==-1) if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 1&&arr.length==0) { if (row.section.indexOf('[') > -1) { @@ -2074,6 +2372,7 @@ } else if (row.bsm === '1' && row.section !== '' && row.section !== null && row.state === 0&&arr.length==0) { row.bsm1 = false }else if(arr.length>0){ + try{ row.bsmRow = this.HaveJson(row) let section = arr[0].section let arr0 = JSON.parse(row.section) @@ -2087,6 +2386,7 @@ row.manHour = arr2[index] row.price = arr3[index] row.tell = arr4[index] + } catch(e) {} } if (row.bsm === '1' && row.inspectionItem === '鍏夌氦鎺ュご鎹熻��' && this.sampleList.length > 1 && row.state === 1&&!this.isBsm2Val2) { this.bsm2 = true @@ -2125,7 +2425,7 @@ return item }) const select = this.selectTree.split(' - ') - if (row.inspectionItem === '娓╁害寰幆' && select[2] === '鍏夌紗' && row.state === 1) { + if (row.inspectionItem === '娓╁害寰幆' && select[2] === '鍏夌紗' && row.state === 1&&this.isAskOnlyRead) { this.circulateShow = true; return } else if (row.inspectionItem === '娓╁害寰幆' && select[2] === '鍏夌紗' && row.state === 0) { @@ -2141,6 +2441,15 @@ } else if ((row.inspectionItem === '娓╁崌璇曢獙' || row.inspectionItem === '鐑惊鐜�') && row.state === 0) { this.temperatureShow = false; } + // if (row.inspectionItem === '鍗曟牴鍨傜洿鐕冪儳' && select[2] === '鍏夌紗' && row.state === 1) { + // this.singleVerticalCombustionShow = true; + // return + // } else if (row.inspectionItem === '鍗曟牴鍨傜洿鐕冪儳' && select[2] === '鍏夌紗' && row.state === 0) { + // this.singleVerticalCombustionShow = false; + // } + + this.changeProductList0() + this.currentMethod.insProduct = this.productList0 this.getProNum() }, searchProject () { @@ -2220,7 +2529,8 @@ name: this.templateName, thing: JSON.stringify({ addObj: this.addObj, - sampleList: this.sampleList + sampleList: this.sampleList, + selectTree:this.selectTree }) }, { headers: { @@ -2243,8 +2553,14 @@ this.$axios.post(this.$api.insOrder.selectInsOrderTemplateById + '?id=' + e).then(res => { if (res.code == 201) return let obj = JSON.parse(res.data) + console.log(obj); + //鍒跺崟浜鸿缃负褰撳墠鐧诲綍鐢ㄦ埛 + let user = JSON.parse(localStorage.getItem('user')) + obj.addObj.custom = user.name + obj.addObj.userId = user.userId this.addObj = obj.addObj; this.sampleList = obj.sampleList; + this.selectTree = obj.selectTree }) }, delSampleAndProduct() { @@ -2256,6 +2572,13 @@ category: "鍗曚綅" }).then(res => { this.units = res.data + }) + }, + selectEnumByCategoryForStandard() { + this.$axios.post(this.$api.enums.selectEnumByCategory, { + category: "璇曢獙鏍囧噯" + }).then(res => { + this.standard = res.data }) }, selectEnumByCategoryForOrderType() { @@ -2270,7 +2593,7 @@ }, selectEnumByCategoryForSampleForm() { this.$axios.post(this.$api.enums.selectEnumByCategory, { - category: "鏉ユ牱鏂瑰紡" + category: "璁㈠崟绫诲瀷" }).then(res => { this.formType = res.data if (this.formType.length > 0) { @@ -2281,17 +2604,14 @@ methodChange(val, row) { if (val === null || val === '') return 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) + this.$axios.post(this.$api.standardTree.selectStandardProductList, { - model: row.model + '-' + row.modelNum, - standardMethodListId: val, - factory: this.selectTree, + model: (this.addObj.model?this.addObj.model:row.model) + '-' + row.modelNum, + standardMethodListId: val.join(','), + factory: selectTreeList.join(" - "), }, { headers: { 'Content-Type': 'application/json' @@ -2360,17 +2680,27 @@ }, // 瑕佹眰鍊煎彉鍖栨椂 requestChange(e, row,type) { - this.sampleList.map(item => { - if (this.sampleIds.indexOf(item.id) > -1) { - item.insProduct.map(m => { - if (m.id == row.id) { - m[type] = e; + //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 } - return m; }) } - return item }) + // this.sampleList.map(item => { + // if (this.sampleIds.indexOf(item.id) > -1) { + // item.insProduct.map(m => { + // if (m.id == row.id) { + // m[type] = e; + // } + // return m; + // }) + // } + // return item + // }) }, selectStandardMethods() { this.$axios.get(this.$api.standardTree.selectStandardMethodEnum).then(res => { @@ -2385,6 +2715,7 @@ } }, handleAll(e) { + console.log(1111,this.bsm1DiaAll,this.bsm1Dia) // console.log('e---', e) if (e.length > 0) { this.productList.map(m => { @@ -2395,6 +2726,7 @@ }) } else { this.productList.map(m => { + console.log('m----', m) m.state = 0 return m }) @@ -2428,7 +2760,7 @@ return } const select = this.selectTree.split(' - ') - if (p.inspectionItem === '娓╁害寰幆' && select[2] === '鍏夌紗' && p.state === 1) { + if (p.inspectionItem === '娓╁害寰幆' && select[2] === '鍏夌紗' && p.state === 1&&this.isAskOnlyRead) { this.circulateShow = true; return } else if (p.inspectionItem === '娓╁害寰幆' && select[2] === '鍏夌紗' && p.state === 0) { @@ -2473,6 +2805,8 @@ return item }) } + this.changeProductList0() + this.currentMethod.insProduct = this.productList0 this.getProNum() this.$nextTick(() => { this.$refs.productTable.doLayout() @@ -2530,6 +2864,7 @@ this.$message.error('鏈�変腑鏍峰搧') return } + this.sampleIds = [this.sampleId] this.$axios.post(this.$api.insBushing.selectBushingBySampleId, { sampleId: this.sampleId }).then(res => { @@ -2627,25 +2962,97 @@ } }, upBsmAll (item) { - let sections = JSON.parse(item.bsmRow.section); - let asks = JSON.parse(item.bsmRow.ask); - let tells = JSON.parse(item.bsmRow.tell); - let manHours = JSON.parse(item.bsmRow.manHour); - let prices = JSON.parse(item.bsmRow.price); - for (var a in sections) { - if (item.bsm1Val === sections[a]) { - this.productList.forEach(p => { - if (p.id === item.bsmRow.id) { - p.section = sections[a] - p.ask = asks[a] - p.tell = tells[a] - p.manHour = manHours[a] - p.price = prices[a] - } - }) - break + // console.log(1111,item,this.bsm1DiaList) + for (let i =0;i<this.bsm1DiaList.length;i++){ + this.bsm1DiaList[i].bsm1Val = item.bsm1Val + let sections = JSON.parse(this.bsm1DiaList[i].bsmRow.section); + let asks = JSON.parse(this.bsm1DiaList[i].bsmRow.ask); + let tells = JSON.parse(this.bsm1DiaList[i].bsmRow.tell); + let manHours = JSON.parse(this.bsm1DiaList[i].bsmRow.manHour); + let prices = JSON.parse(this.bsm1DiaList[i].bsmRow.price); + 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('鐗规畩椤圭洰蹇呴』澶勭悊') + } + }) + } + if (this.bsm2) { + if (this.bsm2Val2.length === 0) { + this.$message.error('鐗规畩椤圭洰蹇呴』澶勭悊') + return + } + let set = new Set() + for (let i = 0; i < this.bsm2Val2.length; i++) { + let num0 = set.size + set.add(JSON.stringify(this.bsm2Val2[i])) + let num1 = set.size + if (num1 == num0) { + this.$message.error('鍏宠仈椤圭洰涓嶈兘閲嶅') + return + } + set.add(JSON.stringify(this.bsm2Val2[i].reverse())) + let num2 = set.size + if (num1 == num2) { + this.$message.error('鍏宠仈椤圭洰涓嶈兘閲嶅') + return + } + } + this.isBsm2Val2 = true; + } + this.bsm1DiaAll = false + }, + save2 () { + if (this.bsm1DiaList.length > 0) { + this.bsm1DiaList.forEach(item => { + if (!item.bsm1Val) { + throw this.$message.error('鐗规畩椤圭洰蹇呴』澶勭悊') + } + }) + } + if (this.bsm2) { + if (this.bsm2Val2.length === 0) { + this.$message.error('鐗规畩椤圭洰蹇呴』澶勭悊') + return + } + let set = new Set() + for (let i = 0; i < this.bsm2Val2.length; i++) { + let num0 = set.size + set.add(JSON.stringify(this.bsm2Val2[i])) + let num1 = set.size + if (num1 == num0) { + this.$message.error('鍏宠仈椤圭洰涓嶈兘閲嶅') + return + } + set.add(JSON.stringify(this.bsm2Val2[i].reverse())) + let num2 = set.size + if (num1 == num2) { + this.$message.error('鍏宠仈椤圭洰涓嶈兘閲嶅') + return + } + } + this.isBsm2Val2 = true; + } + this.bsm1Dia = false }, beforeClose(done) { // if (this.bsm1) { @@ -2718,7 +3125,6 @@ getTotal() { this.totalArr = [] this.total = 0; - // console.log(this.sampleList) this.sampleList.forEach(item => { if (item.insProduct && item.insProduct.length > 0) { item.insProduct.forEach(a => { @@ -2811,6 +3217,11 @@ if(this.sonLaboratoryList.length>0){ this.distributeData.sonLaboratory = this.sonLaboratoryList[0].value } + }, + selectDepartmentEnum(){ + this.$axios.get(this.$api.department.selectDepartmentLimsEnum).then(res=>{ + this.deaprtEnum = res.data + }) } } } -- Gitblit v1.9.3