¶Ô±ÈÐÂÎļþ |
| | |
| | | <style scoped> |
| | | .standard { |
| | | padding: 10px 0; |
| | | display: flex; |
| | | } |
| | | |
| | | .left { |
| | | width: 330px; |
| | | height: calc(100% - 40px - 10px); |
| | | background-color: white; |
| | | padding: 15px; |
| | | } |
| | | |
| | | .custom-tree-node { |
| | | width: 100%; |
| | | line-height: 32px; |
| | | } |
| | | |
| | | .custom-tree-node .el-icon-delete { |
| | | color: #3a7bfa; |
| | | opacity: 0; |
| | | font-size: 18px; |
| | | } |
| | | |
| | | .custom-tree-node:hover .el-icon-delete { |
| | | opacity: 1; |
| | | } |
| | | |
| | | .custom-tree-node .el-icon-edit { |
| | | color: #3a7bfa; |
| | | opacity: 0; |
| | | font-size: 18px; |
| | | } |
| | | |
| | | .custom-tree-node:hover .el-icon-edit { |
| | | opacity: 1; |
| | | } |
| | | |
| | | .node_i { |
| | | color: orange; |
| | | font-size: 18px; |
| | | } |
| | | |
| | | .right { |
| | | margin-left: 5px; |
| | | width: calc(100% - 365px); |
| | | height: calc(100% - 40px); |
| | | } |
| | | |
| | | .right .title { |
| | | height: 34px; |
| | | line-height: 34px; |
| | | padding: 0 10px; |
| | | background-color: white; |
| | | } |
| | | |
| | | .standard_table { |
| | | border-top: 1px solid #ebeef5; |
| | | background-color: white; |
| | | } |
| | | |
| | | .product_table { |
| | | border-top: 1px solid #ebeef5; |
| | | height: calc(100% - 235px); |
| | | margin-top: 5px; |
| | | background-color: white; |
| | | user-select: none; |
| | | } |
| | | |
| | | .product_table .el-table { |
| | | height: calc(100% - 35px) !important; |
| | | } |
| | | |
| | | .sort { |
| | | width: 80% !important; |
| | | overflow: hidden; |
| | | } |
| | | |
| | | >>> .el-table__body-wrapper { |
| | | height: calc(100% - 46px) !important; |
| | | } |
| | | |
| | | >>> .header-class { |
| | | height: 40px !important; |
| | | } |
| | | |
| | | >>> .header-class th.el-table__cell > .cell { |
| | | line-height: 20px !important; |
| | | padding-top: 0 !important; |
| | | padding-bottom: 0 !important; |
| | | } |
| | | |
| | | >>> .el-table__row { |
| | | height: 35px !important; |
| | | } |
| | | |
| | | .search { |
| | | border-bottom: 1px solid #ebeef5; |
| | | margin-bottom: 16px; |
| | | display: flex; |
| | | align-items: center; |
| | | box-sizing: border-box; |
| | | padding-bottom: 10px; |
| | | } |
| | | |
| | | .search-item { |
| | | display: flex; |
| | | align-items: center; |
| | | flex-wrap: wrap; |
| | | } |
| | | |
| | | .search-item .el-row { |
| | | display: flex; |
| | | align-items: center; |
| | | } |
| | | |
| | | .search-item .el-col { |
| | | margin-left: 0; |
| | | } |
| | | |
| | | .more-edit .dialog-footer { |
| | | position: absolute; |
| | | top: 15px; |
| | | right: 70px; |
| | | } |
| | | |
| | | >>> .is-disabled .el-textarea__inner { |
| | | background: rgba(0, 0, 0, 0.05) !important; |
| | | } |
| | | >>> .el-table__body-wrapper::-webkit-scrollbar { |
| | | height: 14px; /* 设置æ»å¨æ¡å®½åº¦ */ |
| | | } |
| | | </style> |
| | | <style> |
| | | .standard .el-tree-node__content { |
| | | height: 32px; |
| | | font-size: 14px; |
| | | border-radius: 2px; |
| | | } |
| | | |
| | | .standard |
| | | .el-tree--highlight-current |
| | | .el-tree-node.is-current |
| | | > .el-tree-node__content { |
| | | color: #3a7bfa; |
| | | } |
| | | |
| | | .standard .has-gutter .el-table__cell .cell { |
| | | line-height: 34px; |
| | | background-color: #f8f8f8; |
| | | } |
| | | |
| | | .standard .has-gutter .el-table__cell { |
| | | background-color: #fafafa !important; |
| | | } |
| | | |
| | | .standard .standard_table .el-table__row .cell { |
| | | font-size: 14px; |
| | | } |
| | | |
| | | .standard .el-table .warning-row .cell { |
| | | color: #bababa; |
| | | } |
| | | |
| | | .standard .el-table-filter__list { |
| | | max-height: 400px; |
| | | overflow-y: auto; |
| | | } |
| | | |
| | | .standard .el-upload { |
| | | width: 100%; |
| | | } |
| | | |
| | | .standard .el-upload-dragger { |
| | | width: 100%; |
| | | } |
| | | |
| | | .standard .handleBtn.is-disabled .el-upload:focus { |
| | | color: #c0c4cc !important; |
| | | } |
| | | |
| | | .standard .avatar-uploader .el-upload { |
| | | height: 80px; |
| | | display: flex; |
| | | align-items: center; |
| | | justify-content: center; |
| | | } |
| | | </style> |
| | | |
| | | <template> |
| | | <div class="standard"> |
| | | <div class="left"> |
| | | <el-row> |
| | | <el-col :span="20"> |
| | | <el-input |
| | | v-model="search" |
| | | clearable |
| | | placeholder="è¾å
¥å
³é®åè¿è¡æç´¢" |
| | | size="small" |
| | | style="margin-bottom: 5px" |
| | | suffix-icon="el-icon-search" |
| | | @blur="searchFilter" |
| | | @clear="searchFilter" |
| | | ></el-input> |
| | | </el-col> |
| | | <el-col |
| | | v-if="addPower" |
| | | :span="4" |
| | | style="text-align: center; line-height: 30px" |
| | | > |
| | | <el-button |
| | | circle |
| | | icon="el-icon-plus" |
| | | size="mini" |
| | | type="primary" |
| | | @click="addDia = true" |
| | | ></el-button> |
| | | </el-col> |
| | | </el-row> |
| | | <el-tree |
| | | ref="tree" |
| | | v-loading="treeLoad" |
| | | :allow-drop="allowDrop" |
| | | :data="list" |
| | | :default-expanded-keys="expandedKeys" |
| | | :draggable="true" |
| | | :filter-node-method="filterNode" |
| | | :props="{ children: 'children', label: 'label' }" |
| | | highlight-current |
| | | node-key="label" |
| | | style=" |
| | | height: calc(100% - 30px); |
| | | overflow-y: scroll; |
| | | scrollbar-width: none; |
| | | " |
| | | @node-click="handleNodeClick" |
| | | @node-expand="nodeOpen" |
| | | @node-collapse="nodeClose" |
| | | @node-drop="handleDrop" |
| | | > |
| | | <div slot-scope="{ node, data }" class="custom-tree-node"> |
| | | <el-row style="width: 100%"> |
| | | <el-col |
| | | :class="{ sort: node.level > 3 }" |
| | | :span="19" |
| | | :title="data.label" |
| | | style="text-align: left" |
| | | > |
| | | <span> |
| | | <i |
| | | :class="`node_i ${ |
| | | data.children != undefined |
| | | ? data.code === '[1]' |
| | | ? 'el-icon-folder-opened' |
| | | : 'el-icon-folder' |
| | | : 'el-icon-tickets' |
| | | }`" |
| | | ></i> |
| | | {{ data.label }} |
| | | </span> |
| | | </el-col> |
| | | <el-col |
| | | v-if=" |
| | | checkPermi(['system:standard:delStandardTree']) && |
| | | (node.data.children === null || |
| | | node.data.children === undefined) |
| | | " |
| | | :span="2" |
| | | style="text-align: right" |
| | | > |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | @click="editTreeName(node.data)" |
| | | > |
| | | <i class="el-icon-edit"></i> |
| | | </el-button> |
| | | </el-col> |
| | | <el-col |
| | | v-if=" |
| | | checkPermi(['system:standard:delStandardTree']) && |
| | | (node.data.children === null || |
| | | node.data.children === undefined) |
| | | " |
| | | :span="2" |
| | | style="text-align: right" |
| | | > |
| | | <el-button |
| | | size="mini" |
| | | type="text" |
| | | @click.stop="remove(node, data)" |
| | | > |
| | | <i class="el-icon-delete"></i> |
| | | </el-button> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </el-tree> |
| | | </div> |
| | | <div class="right"> |
| | | <el-row class="title" style="width: 100%"> |
| | | <el-col :span="20" style="font-size: 14px; color: #999">{{ |
| | | selectTree |
| | | }}</el-col> |
| | | <el-col :span="4"> |
| | | <el-button |
| | | v-if="isShowCopy" |
| | | size="small" |
| | | style="position: absolute; right: 50px; top: 1px" |
| | | type="primary" |
| | | @click="openCopyDia" |
| | | >æ¹éå¤å¶</el-button |
| | | > |
| | | </el-col> |
| | | </el-row> |
| | | <el-row v-loading="tableLoad" class="standard_table"> |
| | | <el-table |
| | | ref="standard" |
| | | :data="standardList" |
| | | class="el-table" |
| | | header-row-class-name="header-class" |
| | | height="220" |
| | | highlight-current-row |
| | | style="width: 100%; height: 220px !important" |
| | | tooltip-effect="dark" |
| | | @row-click="rowClick" |
| | | > |
| | | <el-table-column |
| | | label="æ åç¼å·" |
| | | prop="code" |
| | | show-overflow-tooltip |
| | | width="200" |
| | | > |
| | | <template slot-scope="scope"> |
| | | <span style="color: red; font-size: 14px">{{ |
| | | scope.row["code"] |
| | | }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="æ ååç§°" |
| | | prop="name" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="夿³¨" |
| | | prop="remark" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | </el-table> |
| | | </el-row> |
| | | <el-row v-loading="tableLoad2" class="product_table"> |
| | | <el-table |
| | | id="templateParamTable" |
| | | ref="productTable" |
| | | v-loading="productTableLoading" |
| | | :data="productList" |
| | | :fit="true" |
| | | :row-class-name="tableRowClassName" |
| | | border |
| | | class="productTable" |
| | | header-row-class-name="header-class" |
| | | height="100%" |
| | | row-key="id" |
| | | stripe |
| | | style="width: 100%" |
| | | tooltip-effect="dark" |
| | | @select="upProductSelect" |
| | | @selection-change="handleSelectionChange" |
| | | @select-all="handleAll" |
| | | > |
| | | <el-table-column type="selection" width="50"> </el-table-column> |
| | | <el-table-column |
| | | label="产å" |
| | | min-width="100" |
| | | prop="sample" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="åå·" |
| | | min-width="100" |
| | | prop="model" |
| | | show-overflow-tooltip |
| | | ></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 |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="æ£éªé¡¹å项" |
| | | min-width="140" |
| | | prop="inspectionItemSubclass" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="åå®éªå®¤" |
| | | prop="sonLaboratory" |
| | | show-overflow-tooltip |
| | | width="130" |
| | | ></el-table-column> |
| | | <el-table-column label="è¦æ±å¼" min-width="200px" prop="ask"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-if="checkPermi(['system:standard:upStandardProduct'])" |
| | | v-model="scope.row.ask" |
| | | :autosize="{ minRows: 1, maxRows: 3 }" |
| | | clearable |
| | | placeholder="è¦æ±å¼" |
| | | size="small" |
| | | type="textarea" |
| | | @change="(value) => upStandardProductList(value, scope.row.id)" |
| | | ></el-input> |
| | | <span v-else>{{ scope.row.ask }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="è¦æ±æè¿°" min-width="220px" prop="tell"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-if="checkPermi(['system:standard:upStandardProduct'])" |
| | | v-model="scope.row.tell" |
| | | :autosize="{ minRows: 1, maxRows: 3 }" |
| | | clearable |
| | | placeholder="è¦æ±æè¿°" |
| | | size="small" |
| | | type="textarea" |
| | | @change=" |
| | | (value) => upStandardProductListOfTell(value, scope.row.id) |
| | | " |
| | | ></el-input> |
| | | <span v-else>{{ scope.row.ask }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="è¯éªæ¹æ³" prop="method" width="200"> |
| | | <template slot-scope="scope"> |
| | | <el-select |
| | | v-if="checkPermi(['system:standard:upStandardProduct'])" |
| | | v-model="scope.row.methodS" |
| | | clearable |
| | | placeholder="è¯éªæ¹æ³" |
| | | size="small" |
| | | @change=" |
| | | (value) => upStandardProductListOfMethodS(value, scope.row.id) |
| | | " |
| | | > |
| | | <el-option |
| | | v-for="(a, i) in scope.row.method && |
| | | JSON.parse(scope.row.method)" |
| | | :key="i" |
| | | :label="a" |
| | | :value="a" |
| | | ></el-option> |
| | | </el-select> |
| | | <span v-else>{{ scope.row.methodS }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="æ¡ä»¶" |
| | | min-width="140" |
| | | prop="radius" |
| | | show-overflow-tooltip |
| | | > |
| | | <template slot-scope="scope"> |
| | | <el-select |
| | | v-if="checkPermi(['system:standard:upStandardProduct'])" |
| | | v-model="scope.row.radius" |
| | | clearable |
| | | placeholder="æ¡ä»¶" |
| | | size="small" |
| | | @change=" |
| | | (value) => upStandardProductListOfRadius(value, scope.row.id) |
| | | " |
| | | > |
| | | <el-option |
| | | v-for="(a, i) in scope.row.radiusList && |
| | | JSON.parse(scope.row.radiusList)" |
| | | :key="i" |
| | | :label="a" |
| | | :value="a" |
| | | ></el-option> |
| | | </el-select> |
| | | <span v-else>{{ scope.row.radius }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="计éåä½" |
| | | prop="unit" |
| | | show-overflow-tooltip |
| | | width="100" |
| | | ></el-table-column> |
| | | <el-table-column label="åä»·(å
)" prop="price" width="120"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-if="checkPermi(['system:standard:upStandardProduct'])" |
| | | v-model="scope.row.price" |
| | | placeholder="åä»·(å
)" |
| | | size="small" |
| | | @change=" |
| | | (value) => upStandardProductListOfPrice(value, scope.row.id) |
| | | " |
| | | > |
| | | </el-input> |
| | | <span v-else>{{ scope.row.price }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column label="å·¥æ¶ç³»æ°" prop="manHour" width="120"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-if="checkPermi(['system:standard:upStandardProduct'])" |
| | | v-model="scope.row.manHour" |
| | | placeholder="åä»·(å
)" |
| | | size="small" |
| | | @change=" |
| | | (value) => upStandardProductListOfManHour(value, scope.row.id) |
| | | " |
| | | > |
| | | </el-input> |
| | | <span v-else>{{ scope.row.manHour }}</span> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="å·¥æ¶åç»" |
| | | prop="manHourGroup" |
| | | show-overflow-tooltip |
| | | width="100" |
| | | ></el-table-column> |
| | | <el-table-column label="模æ¿" prop="templateId" width="200"> |
| | | <template slot-scope="scope"> |
| | | <el-select |
| | | v-model="scope.row.templateId" |
| | | :disabled="!checkPermi(['system:standard:upStandardProduct'])" |
| | | filterable |
| | | size="small" |
| | | @change=" |
| | | (value) => |
| | | upStandardProductListOfTemplate(value, scope.row.id) |
| | | " |
| | | > |
| | | <el-option |
| | | v-for="(a, ai) in templateList" |
| | | :key="ai" |
| | | :label="a.name" |
| | | :value="a.id" |
| | | ></el-option> |
| | | </el-select> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="åºé´" |
| | | prop="section" |
| | | show-overflow-tooltip |
| | | width="120" |
| | | ></el-table-column> |
| | | <el-table-column label="æä½" prop="section" width="160"> |
| | | <template slot-scope="scope"> |
| | | <el-button type="text" @click="sectionUp(scope.row)" |
| | | >åºé´è®¾ç½®</el-button |
| | | > |
| | | <el-button |
| | | type="text" |
| | | @click="bindSupplierDensitySecond(scope.row)" |
| | | >ç»å®åå®¶</el-button |
| | | > |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | <el-pagination |
| | | :current-page="currentPage" |
| | | :page-size="300" |
| | | :total="total" |
| | | layout="total, prev, pager, next, jumper" |
| | | style="position: absolute; right: 16px; bottom: 1px" |
| | | @current-change="handleCurrentChange" |
| | | > |
| | | </el-pagination> |
| | | </el-row> |
| | | </div> |
| | | <el-dialog :visible.sync="addDia" title="å类添å " width="400px"> |
| | | <div class="body"> |
| | | <el-row style="line-height: 50px"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <span class="required-span">* </span>åå·ï¼ |
| | | </el-col> |
| | | <el-col :offset="1" :span="16"> |
| | | <el-input |
| | | v-model="addOb.model" |
| | | clearable |
| | | placeholder="请è¾å
¥åå·" |
| | | size="small" |
| | | @keyup.enter.native="addStandardTree" |
| | | ></el-input> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="addDia = false">å æ¶</el-button> |
| | | <el-button :loading="addLoad" type="primary" @click="addStandardTree" |
| | | >ç¡® å®</el-button |
| | | > |
| | | </span> |
| | | </el-dialog> |
| | | <el-dialog :visible.sync="updateDia" title="å类修æ¹" width="400px"> |
| | | <div class="body"> |
| | | <el-row style="line-height: 50px"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <span class="required-span">* </span>åå·ï¼ |
| | | </el-col> |
| | | <el-col :offset="1" :span="16"> |
| | | <el-input |
| | | v-model="addOb.model" |
| | | clearable |
| | | placeholder="请è¾å
¥åå·" |
| | | size="small" |
| | | @keyup.enter.native="updateStandardTree" |
| | | ></el-input> |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="updateDia = false">å æ¶</el-button> |
| | | <el-button |
| | | :loading="updateLoad" |
| | | type="primary" |
| | | @click="updateStandardTree" |
| | | >ç¡® å®</el-button |
| | | > |
| | | </span> |
| | | </el-dialog> |
| | | <el-dialog |
| | | :visible.sync="moreEdit" |
| | | class="more-edit" |
| | | title="æ¹éç¼è¾" |
| | | width="90%" |
| | | > |
| | | <div |
| | | class="body" |
| | | style="display: flex; flex-direction: column; height: 85vh" |
| | | > |
| | | <div class="search"> |
| | | <div class="search-item"> |
| | | <el-row style="width: 25%; margin-bottom: 16px"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <!-- <span class="required-span">* </span> --> |
| | | è¦æ±å¼ï¼</el-col |
| | | > |
| | | <el-col :span="16"> |
| | | <el-input |
| | | v-model="moreInfo.ask" |
| | | :disabled="moreSelects.length == 0" |
| | | clearable |
| | | size="small" |
| | | ></el-input> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="width: 25%; margin-bottom: 16px"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <!-- <span class="required-span">* </span> --> |
| | | è¦æ±æè¿°ï¼</el-col |
| | | > |
| | | <el-col |
| | | :span="16" |
| | | style="display: flex; align-items: flex-start; height: 100%" |
| | | > |
| | | <el-input |
| | | v-model="moreInfo.tell" |
| | | :autosize="{ minRows: 1, maxRows: 3 }" |
| | | :disabled="moreSelects.length == 0" |
| | | clearable |
| | | size="small" |
| | | type="textarea" |
| | | ></el-input> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="width: 25%; margin-bottom: 16px"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <!-- <span class="required-span">* </span> --> |
| | | è¯éªæ¹æ³ï¼</el-col |
| | | > |
| | | <el-col :span="16"> |
| | | <el-select |
| | | v-model="moreInfo.methodS" |
| | | :disabled="moreSelects.length == 0" |
| | | clearable |
| | | filterable |
| | | size="small" |
| | | style="width: 100%" |
| | | > |
| | | <el-option |
| | | v-for="(a, ai) in methodList" |
| | | :key="ai" |
| | | :label="a.label" |
| | | :value="a.value" |
| | | ></el-option> |
| | | </el-select> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="width: 25%; margin-bottom: 16px"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <!-- <span class="required-span">* </span> --> |
| | | åä»·(å
)ï¼</el-col |
| | | > |
| | | <el-col :span="16"> |
| | | <el-input |
| | | v-model="moreInfo.price" |
| | | :disabled="moreSelects.length == 0" |
| | | clearable |
| | | size="small" |
| | | ></el-input> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="width: 25%"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <!-- <span class="required-span">* </span> --> |
| | | å·¥æ¶ç³»æ°ï¼</el-col |
| | | > |
| | | <el-col :span="16"> |
| | | <el-input |
| | | v-model="moreInfo.manHour" |
| | | :disabled="moreSelects.length == 0" |
| | | clearable |
| | | size="small" |
| | | ></el-input> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="width: 25%"> |
| | | <el-col :span="6" style="text-align: right"> |
| | | <!-- <span class="required-span">* </span> --> |
| | | 模æ¿ï¼</el-col |
| | | > |
| | | <el-col :span="16"> |
| | | <el-select |
| | | v-model="moreInfo.templateId" |
| | | :disabled="moreSelects.length == 0" |
| | | filterable |
| | | placeholder="模æ¿" |
| | | size="small" |
| | | style="width: 100%" |
| | | > |
| | | <el-option |
| | | v-for="(a, ai) in templateList" |
| | | :key="ai" |
| | | :label="a.name" |
| | | :value="a.id" |
| | | ></el-option> |
| | | </el-select> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="width: 25%"> |
| | | <el-col :span="6" style="text-align: right"> æ¯å¦å¯ç¨ï¼</el-col> |
| | | <el-col :span="16"> |
| | | <el-select |
| | | v-model="moreInfo.state" |
| | | :disabled="moreSelects.length == 0" |
| | | clearable |
| | | filterable |
| | | placeholder="模æ¿" |
| | | size="small" |
| | | style="width: 100%" |
| | | > |
| | | <el-option :value="1" label="å¯ç¨"></el-option> |
| | | <el-option :value="0" label="ä¸å¯ç¨"></el-option> |
| | | </el-select> |
| | | </el-col> |
| | | </el-row> |
| | | <el-row style="width: 100%; margin-top: 8px"> |
| | | <el-col |
| | | :span="24" |
| | | style="display: flex; align-items: center; justify-content: end" |
| | | > |
| | | <el-button size="small" type="danger" @click="clearProduct(1)" |
| | | >éç½®åä»·</el-button |
| | | > |
| | | <el-button size="small" type="danger" @click="clearProduct(2)" |
| | | >é置工æ¶ç³»æ°</el-button |
| | | > |
| | | <el-button |
| | | size="small" |
| | | type="primary" |
| | | @click="sectionUp(moreSelects)" |
| | | >设置åºé´</el-button |
| | | > |
| | | <el-button size="small" @click="moreEdit = false" |
| | | >å æ¶</el-button |
| | | > |
| | | <el-button |
| | | :loading="moreEditLoad" |
| | | size="small" |
| | | type="primary" |
| | | @click="subMoreEdit" |
| | | >ä¿ å</el-button |
| | | > |
| | | </el-col> |
| | | </el-row> |
| | | </div> |
| | | </div> |
| | | <div v-loading="productTableLoading0" style="flex: 1; overflow-y: auto"> |
| | | <el-table |
| | | ref="productTable0" |
| | | :data="productList0" |
| | | :fit="true" |
| | | :row-key="(row) => row.id" |
| | | border |
| | | header-row-class-name="header-class" |
| | | height="96%" |
| | | highlight-current-row |
| | | stripe |
| | | style="width: 100%" |
| | | tooltip-effect="dark" |
| | | @select="handleSelectionChange0" |
| | | @select-all="handleSelectAll0" |
| | | @filter-change="filterHandler" |
| | | > |
| | | <el-table-column type="selection" width="50"> </el-table-column> |
| | | <el-table-column |
| | | label="产å" |
| | | min-width="100" |
| | | prop="sample" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="åå·" |
| | | min-width="100" |
| | | prop="model" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | :filter-multiple="false" |
| | | :filters="filters0" |
| | | column-key="inspectionItem" |
| | | filter-placement="bottom-start" |
| | | label="æ£éªé¡¹" |
| | | min-width="140" |
| | | prop="inspectionItem" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | :filter-multiple="false" |
| | | :filters="filters1" |
| | | column-key="inspectionItemSubclass" |
| | | filter-placement="bottom-start" |
| | | label="æ£éªé¡¹å项" |
| | | min-width="140" |
| | | prop="inspectionItemSubclass" |
| | | show-overflow-tooltip |
| | | ></el-table-column> |
| | | <el-table-column |
| | | :filter-multiple="false" |
| | | :filters="filters" |
| | | column-key="sonLaboratory" |
| | | filter-placement="bottom-start" |
| | | label="åå®éªå®¤" |
| | | prop="sonLaboratory" |
| | | show-overflow-tooltip |
| | | width="130" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="è¦æ±å¼" |
| | | min-width="200px" |
| | | prop="ask" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="è¦æ±æè¿°" |
| | | min-width="220px" |
| | | prop="tell" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="è¯éªæ¹æ³" |
| | | prop="methodS" |
| | | width="200" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="æ¡ä»¶" |
| | | prop="radius" |
| | | width="200" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="计éåä½" |
| | | prop="unit" |
| | | show-overflow-tooltip |
| | | width="100" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="åä»·(å
)" |
| | | prop="price" |
| | | width="120" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="å·¥æ¶ç³»æ°" |
| | | prop="manHour" |
| | | width="120" |
| | | ></el-table-column> |
| | | <el-table-column |
| | | label="å·¥æ¶åç»" |
| | | prop="manHourGroup" |
| | | show-overflow-tooltip |
| | | width="100" |
| | | ></el-table-column> |
| | | <el-table-column label="模æ¿" prop="templateId" width="200"> |
| | | <template slot-scope="scope"> |
| | | {{ |
| | | templateList.find((item) => item.id == scope.row.templateId) |
| | | ? templateList.find( |
| | | (item) => item.id == scope.row.templateId |
| | | ).name |
| | | : "" |
| | | }} |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column |
| | | label="åºé´" |
| | | prop="section" |
| | | show-overflow-tooltip |
| | | width="120" |
| | | ></el-table-column> |
| | | </el-table> |
| | | <el-pagination |
| | | :current-page="currentPage0" |
| | | :page-size="100" |
| | | :total="total0" |
| | | layout="total, prev, pager, next, jumper" |
| | | style="position: absolute; right: 16px; bottom: 4px" |
| | | @current-change="handleCurrentChange0" |
| | | > |
| | | </el-pagination> |
| | | </div> |
| | | </div> |
| | | </el-dialog> |
| | | <el-dialog |
| | | :close-on-click-modal="false" |
| | | :visible.sync="sectionUpDia" |
| | | title="åºé´è®¾ç½®" |
| | | width="80%" |
| | | > |
| | | <div class="body" style="padding: 5px 0"> |
| | | <el-table :data="sectionList" border height="350px" style="width: 100%"> |
| | | <el-table-column align="center" label="åºå·" type="index" width="70"> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="åºé´"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-model="scope.row.thing" |
| | | clearable |
| | | placeholder="åºé´" |
| | | size="small" |
| | | ></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="è¯æ°"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-model="scope.row.cores" |
| | | clearable |
| | | placeholder="è¯æ°" |
| | | size="small" |
| | | ></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="è¦æ±å¼"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-model="scope.row.ask" |
| | | clearable |
| | | placeholder="è¦æ±å¼" |
| | | size="small" |
| | | ></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="è¦æ±æè¿°"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-model="scope.row.tell" |
| | | :autosize="{ minRows: 1, maxRows: 2 }" |
| | | clearable |
| | | placeholder="è¦æ±æè¿°" |
| | | size="small" |
| | | type="textarea" |
| | | ></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="å¯¼ä½æè´¨"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-model="scope.row.conductorMaterial" |
| | | clearable |
| | | placeholder="å¯¼ä½æè´¨" |
| | | size="small" |
| | | ></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <el-table-column align="center" label="导ä½ç±»å"> |
| | | <template slot-scope="scope"> |
| | | <el-input |
| | | v-model="scope.row.conductorType" |
| | | clearable |
| | | placeholder="导ä½ç±»å" |
| | | size="small" |
| | | ></el-input> |
| | | </template> |
| | | </el-table-column> |
| | | <!-- <el-table-column align="center" label="åä»·" width="120">--> |
| | | <!-- <template slot-scope="scope">--> |
| | | <!-- <el-input v-model="scope.row.price" clearable placeholder="åä»·" size="small"></el-input>--> |
| | | <!-- </template>--> |
| | | <!-- </el-table-column>--> |
| | | <!-- <el-table-column align="center" label="å·¥æ¶ç³»æ°" width="120">--> |
| | | <!-- <template slot-scope="scope">--> |
| | | <!-- <el-input v-model="scope.row.manHour" clearable placeholder="å·¥æ¶ç³»æ°" size="small"></el-input>--> |
| | | <!-- </template>--> |
| | | <!-- </el-table-column>--> |
| | | <el-table-column align="center" label="æä½" width="70"> |
| | | <template slot-scope="scope"> |
| | | <el-button |
| | | circle |
| | | icon="el-icon-minus" |
| | | size="mini" |
| | | type="danger" |
| | | @click="sectionList.splice(scope.$index, 1)" |
| | | ></el-button> |
| | | </template> |
| | | </el-table-column> |
| | | </el-table> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="sectionUpDia = false">å æ¶</el-button> |
| | | <el-button :loading="sectionLoad" type="primary" @click="sectionLoadAdd" |
| | | >ä¿ å</el-button |
| | | > |
| | | <el-button |
| | | icon="el-icon-plus" |
| | | type="primary" |
| | | @click="sectionList.push({ thing: '' })" |
| | | ></el-button> |
| | | </span> |
| | | </el-dialog> |
| | | <el-dialog :visible.sync="uploadDia" title="æ°æ®å¯¼å
¥" width="500px"> |
| | | <div style="margin: 0 auto"> |
| | | <el-upload |
| | | ref="upload" |
| | | :action=" |
| | | VUE_APP_BASE_API + '/standardTree/inExcelOfTree/' + isEquipment |
| | | " |
| | | :auto-upload="false" |
| | | :file-list="fileList" |
| | | :headers="token" |
| | | :limit="1" |
| | | :on-change="beforeUpload" |
| | | :on-error="onError" |
| | | :on-success="onSuccess" |
| | | accept=".xlsx" |
| | | drag |
| | | name="file" |
| | | > |
| | | <i class="el-icon-upload"></i> |
| | | <div class="el-upload__text">å°æä»¶æå°æ¤å¤ï¼æ<em>ç¹å»ä¸ä¼ </em></div> |
| | | </el-upload> |
| | | </div> |
| | | <span slot="footer" class="dialog-footer"> |
| | | <el-button @click="uploadDia = false">å æ¶</el-button> |
| | | <el-button :loading="uploading" type="primary" @click="submitUpload()" |
| | | >ä¸ ä¼ </el-button |
| | | > |
| | | </span> |
| | | </el-dialog> |
| | | <!-- <bindSupplierDensityDialogAsk v-if="bindSupplierDensityDialog" |
| | | :bindSupplierDensityDialog="bindSupplierDensityDialog" |
| | | :currentRow="currentSupplierDensityRow" |
| | | @closeBindPartDialog="closeBindSupplierDensityDialog"></bindSupplierDensityDialogAsk> --> |
| | | <!-- <BatchCopy v-if="batchCopyDia" ref="BatchCopy" :selectTree1="selectTree" |
| | | :standardId="standardId" @refreshList="refreshList"></BatchCopy> --> |
| | | </div> |
| | | </template> |
| | | |
| | | <script> |
| | | import Sortable from "sortablejs"; |
| | | import draggable from "vuedraggable"; |
| | | import { |
| | | updateTreeSort, |
| | | resetTreeDragBatch, |
| | | delStandardTree, |
| | | selectStandardTreeList, |
| | | obtainItemParameterList, |
| | | selectTestObjectByName, |
| | | selectStandardMethods, |
| | | addStandardMethodList, |
| | | addStandardTree, |
| | | updateStandardTree, |
| | | selectsStandardMethodByFLSSM, |
| | | upStandardProductList, |
| | | delStandardMethodByFLSSM, |
| | | delStandardProductByIds, |
| | | addStandardProduct, |
| | | selectStandardProductListByMethodId, |
| | | updateSection, |
| | | upStandardProducts, |
| | | getStandardTemplate, |
| | | selectStandardProductByMethodId, |
| | | selectStandardProductEnumByMethodId, |
| | | resetTreeOfPrice, |
| | | resetTreeOfHour, |
| | | } from "@/api/standard/standardLibrary"; |
| | | import { checkPermi } from "@/utils/permission"; // æé夿彿° |
| | | // import bindSupplierDensityDialogAsk from "../do/a5-capacity-scope/bindSupplierDensityDialogAsk.vue"; |
| | | // import BatchCopy from "../do/a5-capacity-scope/BatchCopy.vue"; |
| | | export default { |
| | | components: { |
| | | // BatchCopy, |
| | | // bindSupplierDensityDialogAsk, |
| | | draggable, |
| | | }, |
| | | dicts: ["sys_factory", "sys_sub_lab", "sys_samp_type"], |
| | | data() { |
| | | return { |
| | | tableKey: "productList", |
| | | search: null, |
| | | list: [], |
| | | selectTree: "", |
| | | factory: [], |
| | | addDia: false, |
| | | updateDia: false, // ä¿®æ¹æ ååå¼¹æ¡ |
| | | oldModel: "", |
| | | addOb: { |
| | | factory: null, |
| | | laboratory: null, |
| | | sampleType: null, |
| | | sample: null, |
| | | model: null, |
| | | }, |
| | | laboratory: [], |
| | | addLoad: false, |
| | | updateLoad: false, |
| | | sampleType: [], |
| | | sample: [], |
| | | treeLoad: false, |
| | | addPower: false, |
| | | standardList: [], |
| | | standardEnum: [], |
| | | addStandardDia: false, |
| | | addLoad2: false, |
| | | productList: [], |
| | | productTableLoading: false, |
| | | tableLoad: false, |
| | | tableLoad2: false, |
| | | selects: [], |
| | | addProductDia: false, |
| | | productId: null, |
| | | addLoad3: false, |
| | | productEnum: [], |
| | | expandedKeys: [], |
| | | filters: [], |
| | | sectionUpDia: false, |
| | | sectionLoad: false, |
| | | sectionRow: null, |
| | | sectionList: [], |
| | | templateList: [], |
| | | total: 0, |
| | | currentPage: 1, |
| | | standardId: 0, |
| | | moreEdit: false, |
| | | moreEditLoad: false, |
| | | moreSelects: [], |
| | | total0: 0, |
| | | currentPage0: 1, |
| | | productList0: [], |
| | | moreInfo: { |
| | | ask: "", |
| | | tell: "", |
| | | methodS: "", |
| | | price: "", |
| | | manHour: "", |
| | | templateId: "", |
| | | state: null, |
| | | }, |
| | | methodList: [], |
| | | productTableLoading0: false, |
| | | filters0: [], |
| | | filters1: [], |
| | | pages: 1, |
| | | inspectionItem: null, |
| | | inspectionItemSubclass: null, |
| | | sonLaboratory: null, |
| | | uploadDia: false, |
| | | token: null, |
| | | fileList: [], |
| | | uploading: false, |
| | | isEquipment: true, |
| | | isHaveChildren: {}, |
| | | sortTable: null, |
| | | currentSupplierDensityRow: {}, // éæ©é¶ä»¶ç»å®æ¬æ¡æ°æ®çä¿¡æ¯ |
| | | bindSupplierDensityDialog: false, |
| | | isShowCopy: false, |
| | | batchCopyDia: false, |
| | | VUE_APP_BASE_API: process.env.VUE_APP_BASE_API, |
| | | }; |
| | | }, |
| | | watch: { |
| | | moreEdit(val) { |
| | | if (!val) { |
| | | this.$refs.productTable0.clearSelection(); |
| | | this.moreSelects = []; |
| | | this.currentPage0 = 1; |
| | | this.productList0 = []; |
| | | this.moreInfo = { |
| | | ask: "", |
| | | tell: "", |
| | | methodS: "", |
| | | price: "", |
| | | manHour: "", |
| | | templateId: "", |
| | | }; |
| | | } |
| | | }, |
| | | }, |
| | | mounted() { |
| | | this.selectEnumByCategoryForFactory(); |
| | | this.selectStandardTreeList(); |
| | | this.obtainItemParameterList(); |
| | | this.selectTestObjectByName(); |
| | | this.selectStandardMethods(); |
| | | this.selectEnumByCategoryForSonLaboratory(); |
| | | this.getStandardTemplate(); |
| | | this.selectStandardMethodsSec(); |
| | | this.token = { |
| | | token: sessionStorage.getItem("token"), |
| | | }; |
| | | }, |
| | | methods: { |
| | | checkPermi, |
| | | // ä¿®æ¹æå级åå |
| | | editTreeName(info) { |
| | | this.updateDia = true; |
| | | this.oldModel = info.label; |
| | | }, |
| | | // ææ½æ¶å¤å®ç®æ èç¹è½å¦è¢«æ¾ç½® |
| | | // 'prev'ã'inner' å 'next'ï¼åãæå
¥ãå |
| | | allowDrop(draggingNode, dropNode, type) { |
| | | if (draggingNode.level !== 3) return; |
| | | if (draggingNode.data.level === dropNode.data.level) { |
| | | if (draggingNode.data.parentId === dropNode.data.parentId) { |
| | | return type === "prev" || type === "next"; |
| | | } else { |
| | | return false; |
| | | } |
| | | } else { |
| | | // ä¸å级è¿è¡å¤ç |
| | | return false; |
| | | } |
| | | }, |
| | | // treeææ½æå宿æ¶è§¦åçäºä»¶ |
| | | handleDrop(draggingNode, dropNode, dropType, ev) { |
| | | try { |
| | | this.treeLoad = true; |
| | | updateTreeSort(this.list).then((res) => { |
| | | if (res.code === 200) { |
| | | this.$message.success("æä½æå"); |
| | | } |
| | | this.treeLoad = false; |
| | | }); |
| | | } catch (e) { |
| | | this.treeLoad = false; |
| | | console.log("e----", e); |
| | | } |
| | | }, |
| | | rowDrop(methodId) { |
| | | const that = this; |
| | | const tbody = document.querySelector( |
| | | "#templateParamTable .el-table__body-wrapper tbody" |
| | | ); |
| | | if (!this.sortTable) { |
| | | this.sortTable = Sortable.create(tbody, { |
| | | animation: 200, //å¨ç»æ¶é¿ |
| | | handle: ".el-table__row", //坿æ½åºåclass |
| | | //ææ½ä¸äºä»¶ |
| | | onMove: ({ dragged, related }) => { |
| | | const oldRow = that.productList[dragged.rowIndex]; //æ§ä½ç½®æ°æ® |
| | | const newRow = that.productList[related.rowIndex]; //è¢«ææ½çæ°æ°æ® |
| | | }, |
| | | //ææ½ç»æäºä»¶ |
| | | onEnd: (evt) => { |
| | | const curRow = that.productList.splice(evt.oldIndex, 1)[0]; // å½åè¢«ææ½çä¿¡æ¯ |
| | | that.productList.splice(evt.newIndex, 0, curRow); |
| | | let arr = []; |
| | | this.productList.forEach((item, index) => { |
| | | const obj = Object.assign({ |
| | | sort: index, |
| | | id: item.id, |
| | | }); |
| | | arr.push(obj); |
| | | }); |
| | | this.productTableLoading = true; |
| | | // ææ½å®æåä¼ ç»å端ä¿åæ°æ® |
| | | resetTreeDragBatch({ params: arr }).then((res) => { |
| | | if (res.code === 200) { |
| | | this.$message.success("ä¿åæå"); |
| | | } |
| | | this.productTableLoading = false; |
| | | }); |
| | | }, |
| | | }); |
| | | } |
| | | }, |
| | | hasChildWithId(nodes, name) { |
| | | for (let node of nodes) { |
| | | const comName = node.label + node.code; |
| | | if (comName == name) { |
| | | //夿éå½ç»ææ¡ä»¶ |
| | | this.isHaveChildren = node; |
| | | return node; |
| | | } else if (node.children && node.children.length > 0) { |
| | | //夿childrenæ¯å¦ææ°æ® |
| | | this.hasChildWithId(node.children, name); //éå½è°ç¨ |
| | | } |
| | | } |
| | | }, |
| | | filterNode(value, data) { |
| | | if (!value) return true; |
| | | return data.label.indexOf(value) !== -1; |
| | | }, |
| | | searchFilter() { |
| | | this.$refs.tree.filter(this.search); |
| | | }, |
| | | refresh() { |
| | | this.upIndex++; |
| | | }, |
| | | handleNodeClick(val, node, el) { |
| | | //æ çå¼ |
| | | if (node.childNodes.length === 0) { |
| | | this.isShowCopy = true; |
| | | } else { |
| | | this.isShowCopy = false; |
| | | } |
| | | this.total = 0; |
| | | this.currentPage = 1; |
| | | this.selectTree = ""; |
| | | this.getNodeParent(node); |
| | | this.selectTree = this.selectTree.replace(" - ", ""); |
| | | let data = this.selectTree.split(" - "); |
| | | let data2 = ""; |
| | | for (let index = data.length - 1; index >= 0; index--) { |
| | | data2 += " - " + data[index]; |
| | | } |
| | | this.selectTree = data2.replace(" - ", ""); |
| | | if (node.childNodes.length === 0) { |
| | | this.selectsStandardMethodByFLSSM(); |
| | | } |
| | | let trees = this.selectTree.split(" - "); |
| | | this.addOb.factory = trees[0]; |
| | | this.addOb.laboratory = trees[1]; |
| | | this.addOb.sampleType = trees[2]; |
| | | this.addOb.sample = trees[3]; |
| | | }, |
| | | getNodeParent(val) { |
| | | if (val.parent != null) { |
| | | if (val.data.children === null) { |
| | | this.selectTree += " - " + val.label + " - " + "null"; |
| | | } else { |
| | | this.selectTree += " - " + val.label; |
| | | } |
| | | this.getNodeParent(val.parent); |
| | | } |
| | | }, |
| | | remove(node, data) { |
| | | this.$confirm("æ¯å¦å é¤è¯¥å±çº§", "æç¤º", { |
| | | type: "error", |
| | | }) |
| | | .then(() => { |
| | | // this.treeLoad = true |
| | | this.selectTree = ""; |
| | | this.getNodeParent(node); |
| | | this.selectTree = this.selectTree.replace(" - ", ""); |
| | | let data = this.selectTree.split(" - "); |
| | | let data2 = ""; |
| | | for (let index = data.length - 1; index >= 0; index--) { |
| | | data2 += " - " + data[index]; |
| | | } |
| | | this.selectTree = data2.replace(" - ", ""); |
| | | delStandardTree({ tree: this.selectTree }).then((res) => { |
| | | if (res.code == 201) return; |
| | | this.$message.success("å·²å é¤"); |
| | | let arr = this.selectTree.split(" - "); |
| | | this.deleteStandard(this.list, arr[arr.length - 1]); |
| | | this.selectTree = ""; |
| | | this.standardList = []; |
| | | this.productList = []; |
| | | }); |
| | | }) |
| | | .catch((e) => {}); |
| | | }, |
| | | deleteStandard(arr, label) { |
| | | arr.forEach((item, index) => { |
| | | if (item.label == label) { |
| | | arr.splice(index, 1); |
| | | } else { |
| | | item.children && this.deleteStandard(item.children, label); |
| | | } |
| | | }); |
| | | }, |
| | | 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"); |
| | | }, |
| | | selectEnumByCategoryForFactory() { |
| | | this.getConfigKey("sys_factory").then((response) => { |
| | | this.factory = response.msg; |
| | | }); |
| | | }, |
| | | selectEnumByCategoryForSonLaboratory() { |
| | | let arr = []; |
| | | this.getConfigKey("sys_sub_lab").then((response) => { |
| | | arr = response.msg; |
| | | }); |
| | | arr.forEach((a) => { |
| | | this.filters.push({ |
| | | text: a.label, |
| | | value: a.value, |
| | | }); |
| | | }); |
| | | }, |
| | | selectEnumByCategoryForsampleType() { |
| | | this.getConfigKey("sys_samp_type").then((response) => { |
| | | this.sampleType = response.msg; |
| | | }); |
| | | }, |
| | | selectStandardTreeList() { |
| | | this.treeLoad = true; |
| | | selectStandardTreeList().then((res) => { |
| | | this.list = res.data; |
| | | this.list.forEach((a) => { |
| | | this.expandedKeys.push(a.label); |
| | | }); |
| | | this.treeLoad = false; |
| | | }); |
| | | }, |
| | | obtainItemParameterList() { |
| | | obtainItemParameterList().then((res) => { |
| | | let data = []; |
| | | res.data.forEach((a) => { |
| | | data.push({ |
| | | label: a.laboratoryName, |
| | | value: a.laboratoryName, |
| | | }); |
| | | }); |
| | | this.laboratory = data; |
| | | }); |
| | | }, |
| | | selectTestObjectByName() { |
| | | selectTestObjectByName().then((res) => { |
| | | let data = []; |
| | | res.data.forEach((a) => { |
| | | data.push({ |
| | | label: a.specimenName, |
| | | value: a.specimenName, |
| | | }); |
| | | }); |
| | | this.sampleType = data; |
| | | }); |
| | | }, |
| | | selectStandardMethods() { |
| | | selectStandardMethods().then((res) => { |
| | | let data = []; |
| | | res.data.forEach((a) => { |
| | | data.push({ |
| | | label: a.name, |
| | | value: a.id, |
| | | }); |
| | | }); |
| | | this.standardEnum = data; |
| | | }); |
| | | }, |
| | | addStandardMethodList() { |
| | | if (this.standardId == null || this.standardId == "") { |
| | | this.$message.error("æ åæ¹æ³æªéæ©"); |
| | | return; |
| | | } |
| | | this.addLoad2 = true; |
| | | addStandardMethodList({ |
| | | standardId: this.standardId, |
| | | tree: this.selectTree, |
| | | }).then((res) => { |
| | | this.addLoad2 = false; |
| | | this.addStandardDia = false; |
| | | this.$message.success("æ·»å æå"); |
| | | this.selectsStandardMethodByFLSSM(); |
| | | }); |
| | | }, |
| | | // æäº¤å类添å |
| | | addStandardTree() { |
| | | if (this.addOb.sampleType == null || this.addOb.sampleType == "") { |
| | | this.$message.error("对象ä¸åå¨"); |
| | | return; |
| | | } |
| | | if (this.addOb.model == null || this.addOb.model == "") { |
| | | this.$message.error("请填ååå·"); |
| | | return; |
| | | } |
| | | this.addLoad = true; |
| | | addStandardTree(this.addOb) |
| | | .then((res) => { |
| | | if (res.code === 201) { |
| | | this.addLoad = false; |
| | | return; |
| | | } |
| | | this.$message.success("æ·»å æå"); |
| | | this.addDia = false; |
| | | this.list |
| | | .find((a) => a.label == this.addOb.factory) |
| | | .children.find((a) => a.label == this.addOb.laboratory) |
| | | .children.find((a) => a.label == this.addOb.sampleType) |
| | | .children.find((a) => a.label == this.addOb.sample) |
| | | .children.push({ |
| | | code: "[5]", |
| | | label: this.addOb.model, |
| | | value: this.addOb.model, |
| | | }); |
| | | this.addLoad = false; |
| | | }) |
| | | .catch((e) => { |
| | | this.addDia = false; |
| | | this.addLoad = false; |
| | | }); |
| | | }, |
| | | // ä¿®æ¹åå· |
| | | updateStandardTree() { |
| | | if (this.addOb.sampleType == null || this.addOb.sampleType == "") { |
| | | this.$message.error("对象ä¸åå¨"); |
| | | return; |
| | | } |
| | | if (this.addOb.model == null || this.addOb.model == "") { |
| | | this.$message.error("请填ååå·"); |
| | | return; |
| | | } |
| | | this.addOb.oldModel = this.oldModel; |
| | | this.updateLoad = true; |
| | | updateStandardTree(this.addOb) |
| | | .then((res) => { |
| | | if (res.code === 201) { |
| | | this.updateLoad = false; |
| | | return; |
| | | } |
| | | this.$message.success("æ·»å æå"); |
| | | this.selectStandardTreeList(); |
| | | this.updateDia = false; |
| | | this.updateLoad = false; |
| | | }) |
| | | .catch((e) => { |
| | | this.updateDia = false; |
| | | this.updateLoad = false; |
| | | }); |
| | | }, |
| | | selectsStandardMethodByFLSSM() { |
| | | this.tableLoad = true; |
| | | selectsStandardMethodByFLSSM({ |
| | | tree: this.selectTree, |
| | | }).then((res) => { |
| | | this.tableLoad = false; |
| | | this.standardList = res.data.standardMethodList; |
| | | if (this.standardList && this.standardList.length > 0) { |
| | | this.$refs.standard.setCurrentRow(this.standardList[0]); |
| | | this.rowClick(this.standardList[0]); |
| | | } else { |
| | | this.productList = []; |
| | | } |
| | | }); |
| | | }, |
| | | upStandardProductList(value, index) { |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: index, |
| | | ask: value, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | }); |
| | | }, |
| | | upStandardProductListOfTell(value, index) { |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: index, |
| | | tell: value, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | }); |
| | | }, |
| | | // æ ååºéæ©å®éªæ¹æ³çåè° |
| | | upStandardProductListOfMethodS(value, index) { |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: index, |
| | | methodS: value, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | }); |
| | | }, |
| | | // æ ååºéæ©æ¡ä»¶çåè° |
| | | upStandardProductListOfRadius(value, index) { |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: index, |
| | | radius: value, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | }); |
| | | }, |
| | | upStandardProductListOfPrice(value, index) { |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: index, |
| | | price: value, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | }); |
| | | }, |
| | | upStandardProductListOfManHour(value, index) { |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: index, |
| | | manHour: value, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | }); |
| | | }, |
| | | upStandardProductListOfTemplate(value, index) { |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: index, |
| | | templateId: value, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | }); |
| | | }, |
| | | delStandardMethodByFLSSM(id) { |
| | | this.$confirm("æ¯å¦å é¤å½åæ°æ®?", "è¦å", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning", |
| | | }) |
| | | .then(() => { |
| | | this.tableLoad = true; |
| | | delStandardMethodByFLSSM({ id: id }).then((res) => { |
| | | if (res.code == 201) { |
| | | return; |
| | | } |
| | | this.$message.success("å·²å é¤"); |
| | | this.selectsStandardMethodByFLSSM(); |
| | | }); |
| | | }) |
| | | .catch(() => {}); |
| | | }, |
| | | handleSelectionChange(val) { |
| | | this.selects = []; |
| | | val.forEach((a) => { |
| | | this.selects.push(a.id); |
| | | }); |
| | | }, |
| | | delStandardProductByIds() { |
| | | if (this.selects.length == 0) { |
| | | this.$message.error("æªé䏿°æ®"); |
| | | return; |
| | | } |
| | | this.$confirm( |
| | | "æ¯å¦å é¤å½åéä¸ " + this.selects.length + " æ¡æ°æ®?", |
| | | "è¦å", |
| | | { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning", |
| | | } |
| | | ) |
| | | .then(() => { |
| | | this.tableLoad = true; |
| | | delStandardProductByIds({ |
| | | ids: JSON.stringify(this.selects), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | return; |
| | | } |
| | | this.$message.success("å·²å é¤"); |
| | | this.selectsStandardMethodByFLSSM(); |
| | | }); |
| | | }) |
| | | .catch(() => {}); |
| | | }, |
| | | addStandardProductDo() { |
| | | let selects = this.$refs.ValueTable.multipleSelection; |
| | | if (selects.length == 0) { |
| | | this.$message.error("æªéæ©æ°æ®"); |
| | | return; |
| | | } |
| | | let select = []; |
| | | selects.forEach((a) => { |
| | | select.push(a.id); |
| | | }); |
| | | this.tableLoad = true; |
| | | addStandardProduct({ |
| | | ids: JSON.stringify(select), |
| | | tree: this.selectTree, |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | return; |
| | | } |
| | | this.$message.success("æ·»å æå"); |
| | | this.selectsStandardMethodByFLSSM(); |
| | | }); |
| | | this.addProductDia = false; |
| | | }, |
| | | refreshList() { |
| | | this.batchCopyDia = false; |
| | | const index = this.standardList.findIndex( |
| | | (item) => item.id == this.standardId |
| | | ); |
| | | if (index > -1) { |
| | | this.rowClick(this.standardList[index]); |
| | | } |
| | | }, |
| | | rowClick(row, column, event) { |
| | | this.currentPage = 1; |
| | | this.tableLoad2 = true; |
| | | this.standardId = row.id; |
| | | selectStandardProductListByMethodId({ |
| | | id: row.id, |
| | | tree: this.selectTree, |
| | | page: this.currentPage, |
| | | }).then((res) => { |
| | | this.productList = res.data.productList; |
| | | this.total = res.data.total; |
| | | setTimeout(() => { |
| | | this.productList.forEach((a) => { |
| | | if (a.state == 1) this.toggleSelection(a); |
| | | }); |
| | | }, 300); |
| | | this.tableLoad2 = false; |
| | | const tree = this.selectTree.split(" - "); |
| | | // éæ©æåä¸å±æ æå¯ä»¥ææ½æåº |
| | | if (tree.length === 4) { |
| | | const name = tree[3] + "[4]"; |
| | | this.hasChildWithId(this.list, name); |
| | | if ( |
| | | this.isHaveChildren.children && |
| | | this.isHaveChildren.children.length > 0 |
| | | ) { |
| | | if (this.sortTable) { |
| | | this.sortTable.destroy(); |
| | | this.sortTable = null; |
| | | } |
| | | return; |
| | | } |
| | | } else if (tree.length < 4) { |
| | | if (this.sortTable) { |
| | | this.sortTable.destroy(); |
| | | this.sortTable = null; |
| | | } |
| | | return; |
| | | } |
| | | this.$nextTick(() => { |
| | | this.rowDrop(row.id); |
| | | }); |
| | | }); |
| | | }, |
| | | toggleSelection(row) { |
| | | this.$refs.productTable.toggleRowSelection(row, true); |
| | | }, |
| | | tableRowClassName({ row, rowIndex }) { |
| | | if (row.state === 0) { |
| | | return "warning-row"; |
| | | } |
| | | return ""; |
| | | }, |
| | | upProductSelect(selection, row) { |
| | | row.state = row.state == 1 ? 0 : 1; |
| | | upStandardProductList({ |
| | | str: JSON.stringify({ |
| | | id: row.id, |
| | | state: row.state, |
| | | }), |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | // this.$message.success('å·²ä¿å') |
| | | }); |
| | | }, |
| | | filterHandler(value) { |
| | | for (let column in value) { |
| | | if (value[column].length === 0) { |
| | | if (column === "inspectionItem") { |
| | | this.inspectionItem = null; |
| | | } else if (column === "inspectionItemSubclass") { |
| | | this.inspectionItemSubclass = null; |
| | | } else if (column === "sonLaboratory") { |
| | | this.sonLaboratory = null; |
| | | } |
| | | } else { |
| | | if (column === "inspectionItem") { |
| | | this.inspectionItem = value[column][0]; |
| | | } else if (column === "inspectionItemSubclass") { |
| | | this.inspectionItemSubclass = value[column][0]; |
| | | } else if (column === "sonLaboratory") { |
| | | this.sonLaboratory = value[column][0]; |
| | | } |
| | | } |
| | | this.getList(); |
| | | } |
| | | }, |
| | | handleAll(e) { |
| | | if (e.length > 0) { |
| | | this.productList.map((m) => { |
| | | m.state = 0; |
| | | this.upProductSelect(null, m); |
| | | return m; |
| | | }); |
| | | } else { |
| | | this.productList.map((m) => { |
| | | m.state = 1; |
| | | this.upProductSelect(null, m); |
| | | return m; |
| | | }); |
| | | } |
| | | }, |
| | | // 设置åºé´ |
| | | sectionUp(row) { |
| | | if (Array.isArray(row)) { |
| | | // 弿¯ä¸ä¸ªæ°ç» |
| | | if (row.length === 0) { |
| | | return this.$message.error("è¯·éæ©æ£éªé¡¹"); |
| | | } |
| | | this.sectionRow = {}; |
| | | this.sectionUpDia = true; |
| | | this.sectionList = []; |
| | | } else { |
| | | // 弿¯ä¸ä¸ªå¯¹è±¡ |
| | | this.sectionRow = row; |
| | | this.sectionUpDia = true; |
| | | this.sectionList = []; |
| | | if (this.sectionRow.section != null && this.sectionRow.section != "") { |
| | | JSON.parse(this.sectionRow.section).forEach((a, ai) => { |
| | | if (this.sectionRow.cores !== null) { |
| | | this.sectionList.push({ |
| | | thing: a, |
| | | ask: JSON.parse(this.sectionRow.ask)[ai], |
| | | tell: JSON.parse(this.sectionRow.tell)[ai], |
| | | // price: JSON.parse(this.sectionRow.price)[ai], |
| | | // manHour: JSON.parse(this.sectionRow.manHour)[ai], |
| | | cores: JSON.parse(this.sectionRow.cores)[ai], |
| | | conductorMaterial: |
| | | this.sectionRow.conductorMaterial && |
| | | JSON.parse(this.sectionRow.conductorMaterial)[ai], |
| | | conductorType: |
| | | this.sectionRow.conductorType && |
| | | JSON.parse(this.sectionRow.conductorType)[ai], |
| | | }); |
| | | } else { |
| | | this.sectionList.push({ |
| | | thing: a, |
| | | ask: JSON.parse(this.sectionRow.ask)[ai], |
| | | tell: JSON.parse(this.sectionRow.tell)[ai], |
| | | // price: JSON.parse(this.sectionRow.price)[ai], |
| | | // manHour: JSON.parse(this.sectionRow.manHour)[ai], |
| | | conductorMaterial: |
| | | this.sectionRow.conductorMaterial && |
| | | JSON.parse(this.sectionRow.conductorMaterial)[ai], |
| | | conductorType: |
| | | this.sectionRow.conductorType && |
| | | JSON.parse(this.sectionRow.conductorType)[ai], |
| | | }); |
| | | } |
| | | }); |
| | | } |
| | | } |
| | | }, |
| | | // æäº¤åºé´æå¡«çæ°æ® |
| | | sectionLoadAdd() { |
| | | let sectionList = []; |
| | | let askList = []; |
| | | let tellList = []; |
| | | let priceList = []; |
| | | let manHourList = []; |
| | | let coresList = []; |
| | | let conductorMaterialList = []; |
| | | let conductorTypeList = []; |
| | | this.sectionList.forEach((a) => { |
| | | if (a.thing !== "") { |
| | | sectionList.push(a.thing); |
| | | askList.push(a.ask); |
| | | tellList.push(a.tell); |
| | | // priceList.push(a.price) |
| | | // manHourList.push(a.manHour) |
| | | coresList.push(a.cores); |
| | | conductorMaterialList.push(a.conductorMaterial); |
| | | conductorTypeList.push(a.conductorType); |
| | | } |
| | | }); |
| | | if (sectionList.length === 0) { |
| | | this.sectionRow.section = null; |
| | | this.sectionRow.ask = null; |
| | | this.sectionRow.tell = null; |
| | | // this.sectionRow.price = null |
| | | // this.sectionRow.manHour = null |
| | | this.sectionRow.cores = null; |
| | | this.sectionRow.conductorMaterial = null; |
| | | this.sectionRow.conductorType = null; |
| | | } else { |
| | | this.sectionRow.section = JSON.stringify(sectionList); |
| | | this.sectionRow.ask = JSON.stringify(askList); |
| | | this.sectionRow.tell = JSON.stringify(tellList); |
| | | // this.sectionRow.price = JSON.stringify(priceList) |
| | | // this.sectionRow.manHour = JSON.stringify(manHourList) |
| | | this.sectionRow.cores = JSON.stringify(coresList); |
| | | this.sectionRow.conductorMaterial = JSON.stringify( |
| | | conductorMaterialList |
| | | ); |
| | | this.sectionRow.conductorType = JSON.stringify(conductorTypeList); |
| | | } |
| | | this.sectionLoad = true; |
| | | if (this.moreSelects.length === 0) { |
| | | updateSection({ |
| | | str: JSON.stringify({ |
| | | id: this.sectionRow.id, |
| | | section: this.sectionRow.section, |
| | | ask: this.sectionRow.ask, |
| | | tell: this.sectionRow.tell, |
| | | // price: this.sectionRow.price, |
| | | // manHour: this.sectionRow.manHour, |
| | | cores: this.sectionRow.cores, |
| | | conductorMaterial: this.sectionRow.conductorMaterial, |
| | | conductorType: this.sectionRow.conductorType, |
| | | }), |
| | | }).then((res) => { |
| | | this.sectionLoad = false; |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | this.sectionUpDia = false; |
| | | }); |
| | | } else { |
| | | upStandardProducts({ |
| | | ids: JSON.stringify(this.moreSelects.map((a) => a.id)), |
| | | standardProductList: { |
| | | section: this.sectionRow.section, |
| | | ask: this.sectionRow.ask, |
| | | tell: this.sectionRow.tell, |
| | | // price: this.sectionRow.price, |
| | | // manHour: this.sectionRow.manHour, |
| | | cores: this.sectionRow.cores, |
| | | conductorMaterial: this.sectionRow.conductorMaterial, |
| | | conductorType: this.sectionRow.conductorType, |
| | | }, |
| | | }).then((res) => { |
| | | this.sectionLoad = false; |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | this.sectionUpDia = false; |
| | | this.currentPage0 = 1; |
| | | this.getList(); |
| | | this.rowClick({ |
| | | id: this.standardId, |
| | | }); |
| | | }); |
| | | } |
| | | }, |
| | | bindSupplierDensitySecond(row) { |
| | | this.bindSupplierDensity(row); |
| | | }, |
| | | // æå¼åå®¶ç»å®å¼¹æ¡ |
| | | bindSupplierDensity(row) { |
| | | this.currentSupplierDensityRow = row; |
| | | this.bindSupplierDensityDialog = true; |
| | | }, |
| | | closeBindSupplierDensityDialog() { |
| | | this.bindSupplierDensityDialog = false; |
| | | }, |
| | | getStandardTemplate() { |
| | | getStandardTemplate().then((res) => { |
| | | this.templateList = res.data; |
| | | }); |
| | | }, |
| | | handleCurrentChange(val) { |
| | | this.currentPage = val; |
| | | this.tableLoad2 = true; |
| | | selectStandardProductListByMethodId({ |
| | | id: this.standardId, |
| | | tree: this.selectTree, |
| | | page: val, |
| | | }).then((res) => { |
| | | this.productList = res.data.productList; |
| | | setTimeout(() => { |
| | | this.productList.forEach((a) => { |
| | | if (a.state == 1) this.toggleSelection(a); |
| | | }); |
| | | }, 200); |
| | | this.tableLoad2 = false; |
| | | }); |
| | | }, |
| | | openCopyDia() { |
| | | this.batchCopyDia = true; |
| | | this.$nextTick(() => { |
| | | this.$refs.BatchCopy.getList(); |
| | | }); |
| | | }, |
| | | async handleMore() { |
| | | if ( |
| | | (!this.standardId && this.standardId != 0) || |
| | | this.standardList.length == 0 |
| | | ) { |
| | | return this.$message.error("è¯·éæ©å®éªå®¤ãæ ·å"); |
| | | } |
| | | await this.getList(); |
| | | this.moreEdit = true; |
| | | }, |
| | | selectStandardMethodsSec() { |
| | | selectStandardMethods().then((res) => { |
| | | let data = []; |
| | | res.data.forEach((a) => { |
| | | data.push({ |
| | | label: a.code, |
| | | value: a.code, |
| | | }); |
| | | }); |
| | | this.methodList = data; |
| | | }); |
| | | }, |
| | | subMoreEdit() { |
| | | if (this.moreSelects.length === 0) { |
| | | return this.$message.error("è¯·éæ©æ£éªé¡¹"); |
| | | } |
| | | this.moreEditLoad = true; |
| | | for (let a in this.moreInfo) { |
| | | if (this.moreInfo[a] == "") { |
| | | delete this.moreInfo[a]; |
| | | } |
| | | } |
| | | upStandardProducts({ |
| | | ids: JSON.stringify(this.moreSelects.map((a) => a.id)), |
| | | standardProductList: this.moreInfo, |
| | | }).then((res) => { |
| | | this.moreEditLoad = false; |
| | | if (res.code == 201) { |
| | | this.$message.error("æªä¿å"); |
| | | return; |
| | | } |
| | | this.$message.success("å·²ä¿å"); |
| | | this.currentPage0 = 1; |
| | | this.getList(); |
| | | this.rowClick({ |
| | | id: this.standardId, |
| | | }); |
| | | }); |
| | | }, |
| | | handleSelectAll0(rows) { |
| | | if (rows.length) { |
| | | rows.forEach((a) => { |
| | | if (!this.moreSelects.find((b) => a.id === b.id)) { |
| | | this.moreSelects.push(a); |
| | | } |
| | | }); |
| | | } else { |
| | | this.productList0.forEach((a) => { |
| | | this.moreSelects = this.moreSelects.filter((b) => b.id != a.id); |
| | | }); |
| | | } |
| | | }, |
| | | handleSelectionChange0(val, row) { |
| | | if (this.moreSelects.find((a) => a.id === row.id)) { |
| | | this.moreSelects = this.moreSelects.filter((a) => a.id != row.id); |
| | | } else { |
| | | this.moreSelects.push(row); |
| | | } |
| | | }, |
| | | getList() { |
| | | this.productTableLoading0 = true; |
| | | this.getItemEnum(); |
| | | selectStandardProductByMethodId({ |
| | | id: this.standardId, |
| | | tree: this.selectTree, |
| | | page: this.currentPage0, |
| | | laboratory: this.sonLaboratory, |
| | | items: this.inspectionItemSubclass, |
| | | item: this.inspectionItem, |
| | | }).then((res) => { |
| | | this.productList0 = res.data.records; |
| | | this.total0 = res.data.total; |
| | | this.productTableLoading0 = false; |
| | | this.page = res.data.pages; |
| | | this.$nextTick(() => { |
| | | this.productList0.forEach((a, i) => { |
| | | if (this.moreSelects.find((b) => a.id == b.id)) { |
| | | this.$refs.productTable0.toggleRowSelection( |
| | | this.productList0[i], |
| | | true |
| | | ); |
| | | } |
| | | }); |
| | | }); |
| | | }); |
| | | }, |
| | | handleCurrentChange0(e) { |
| | | this.currentPage0 = e; |
| | | this.getList(); |
| | | }, |
| | | getItemEnum() { |
| | | selectStandardProductEnumByMethodId({ |
| | | id: this.standardId, |
| | | tree: this.selectTree, |
| | | item: this.inspectionItem, |
| | | }).then((res) => { |
| | | this.filters0 = []; |
| | | this.filters1 = []; |
| | | res.data.item.forEach((a) => { |
| | | this.filters0.push({ |
| | | text: a.inspectionItem, |
| | | value: a.inspectionItem, |
| | | }); |
| | | }); |
| | | res.data.items.forEach((a) => { |
| | | if (a != null) { |
| | | this.filters1.push({ |
| | | text: a.inspectionItemSubclass, |
| | | value: a.inspectionItemSubclass, |
| | | }); |
| | | } |
| | | }); |
| | | }); |
| | | }, |
| | | beforeUpload(file, fileList) { |
| | | if ( |
| | | file.raw.type != |
| | | "application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" |
| | | ) { |
| | | this.$message.error("ä¸ä¼ æä»¶æ ¼å¼ä¸æ£ç¡®"); |
| | | this.$refs.upload.clearFiles(); |
| | | return false; |
| | | } |
| | | }, |
| | | submitUpload() { |
| | | if (this.$refs.upload.uploadFiles.length == 0) { |
| | | this.$message.error("æªéæ©æä»¶"); |
| | | return; |
| | | } |
| | | this.uploading = true; |
| | | this.$refs.upload.submit(); |
| | | }, |
| | | onSuccess(response, file, fileList) { |
| | | this.$refs.upload.clearFiles(); |
| | | this.uploadDia = false; |
| | | this.uploading = false; |
| | | if (response.code == 201) { |
| | | this.$message.error(response.message); |
| | | return; |
| | | } |
| | | this.$message.success("ä¸ä¼ æå"); |
| | | this.standardList = []; |
| | | this.productList = []; |
| | | this.selectStandardTreeList(); |
| | | }, |
| | | onError(err, file, fileList) { |
| | | this.$message.error("ä¸ä¼ 失败"); |
| | | this.$refs.upload.clearFiles(); |
| | | this.uploading = false; |
| | | }, |
| | | clearProduct(type) { |
| | | this.$confirm("æ¯å¦æ¸
空?", "è¦å", { |
| | | confirmButtonText: "ç¡®å®", |
| | | cancelButtonText: "åæ¶", |
| | | type: "warning", |
| | | }) |
| | | .then(() => { |
| | | if (type === 1) { |
| | | resetTreeOfPrice({ |
| | | tree: this.selectTree, |
| | | standardId: this.standardId, |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | return; |
| | | } |
| | | this.$message.success("å·²æ¸
空"); |
| | | this.currentPage0 = 1; |
| | | this.getList(); |
| | | this.rowClick({ |
| | | id: this.standardId, |
| | | }); |
| | | }); |
| | | } else if (type === 2) { |
| | | resetTreeOfHour({ |
| | | tree: this.selectTree, |
| | | standardId: this.standardId, |
| | | }).then((res) => { |
| | | if (res.code == 201) { |
| | | return; |
| | | } |
| | | this.$message.success("å·²æ¸
空"); |
| | | this.currentPage0 = 1; |
| | | this.getList(); |
| | | this.rowClick({ |
| | | id: this.standardId, |
| | | }); |
| | | }); |
| | | } |
| | | }) |
| | | .catch(() => {}); |
| | | }, |
| | | }, |
| | | }; |
| | | </script> |