inspectionTemplate.vue 6.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267
  1. <template>
  2. <ele-modal
  3. title="选择"
  4. :visible.sync="visible"
  5. :before-close="handleClose"
  6. :close-on-click-modal="false"
  7. :close-on-press-escape="false"
  8. append-to-body
  9. width="60%"
  10. :maxable="true"
  11. >
  12. <el-form
  13. label-width="77px"
  14. class="ele-form-search"
  15. @keyup.enter.native="search"
  16. @submit.native.prevent
  17. >
  18. <el-row type="flex" :gutter="24">
  19. <el-col :span="6">
  20. <el-form-item label="质检类型" label-width="100px">
  21. <el-select
  22. v-model="where.type"
  23. placeholder="请选择"
  24. style="width: 100%"
  25. clearable
  26. >
  27. <el-option
  28. :label="item.label"
  29. v-for="item in typeList"
  30. :key="item.value"
  31. :value="item.value"
  32. />
  33. </el-select>
  34. </el-form-item>
  35. </el-col>
  36. <el-col :span="6">
  37. <el-form-item label="编码" label-width="100px">
  38. <el-input
  39. clearable
  40. v-model.trim="where.qualitySchemeTemplateCode"
  41. placeholder="请输入"
  42. />
  43. </el-form-item>
  44. </el-col>
  45. <el-col :span="6">
  46. <el-form-item label="名称" label-width="100px">
  47. <el-input
  48. clearable
  49. v-model.trim="where.qualitySchemeTemplateName"
  50. placeholder="请输入"
  51. />
  52. </el-form-item>
  53. </el-col>
  54. <el-col :span="4">
  55. <div class="ele-form-actions">
  56. <el-button
  57. type="primary"
  58. class="ele-btn-icon"
  59. size="small"
  60. @click="reload"
  61. >
  62. 查询
  63. </el-button>
  64. <el-button size="small" plain @click="reset">重置</el-button>
  65. </div>
  66. </el-col>
  67. </el-row>
  68. </el-form>
  69. <ele-pro-table
  70. ref="table"
  71. :columns="columns"
  72. :datasource="datasource"
  73. height="calc(100vh - 400px)"
  74. tool-class="ele-toolbar-form"
  75. cache-key="inspectionClassify"
  76. row-key="qualityLevelId"
  77. :current.sync="current"
  78. :highlight-current-row="true"
  79. @current-change="handleCurrentChange"
  80. >
  81. <template v-slot:current="{ row, _index }">
  82. <el-radio class="radio" v-model="radio" :label="row.id"
  83. ><i></i
  84. ></el-radio>
  85. </template>
  86. <template v-slot:type="{ row, _index }">
  87. <span>{{ getQualityType(row) }}</span>
  88. </template>
  89. <template v-slot:status="{ row }">
  90. {{ row.status ? '启用' : '停用' }}
  91. </template>
  92. </ele-pro-table>
  93. <span slot="footer" class="dialog-footer">
  94. <el-button @click="handleClose">取消</el-button>
  95. <el-button type="primary" @click="changeSel">选择</el-button>
  96. </span>
  97. </ele-modal>
  98. </template>
  99. <script>
  100. import { getTemplateList } from '@/api/material/inspectionClassify';
  101. import { getByCode } from '@/api/system/dictionary-data';
  102. export default {
  103. components: {},
  104. data() {
  105. const defaultWhere = {
  106. qualitySchemeTemplateCode: '',
  107. qualitySchemeTemplateName: '',
  108. type: ''
  109. };
  110. return {
  111. visible: false,
  112. selection: [],
  113. current: null,
  114. radio: '',
  115. columns: [
  116. // {
  117. // width: 45,
  118. // type: 'selection',
  119. // columnKey: 'selection',
  120. // align: 'center',
  121. // reserveSelection: true
  122. // },
  123. {
  124. width: 55,
  125. columnKey: 'current',
  126. slot: 'current',
  127. align: 'center'
  128. },
  129. {
  130. columnKey: 'index',
  131. label: '序号',
  132. type: 'index',
  133. width: 55,
  134. align: 'center',
  135. showOverflowTooltip: true,
  136. fixed: 'left'
  137. },
  138. {
  139. prop: 'qualitySchemeTemplateCode',
  140. label: '质检方案编码',
  141. showOverflowTooltip: true,
  142. align: 'center',
  143. minWidth: 110
  144. },
  145. {
  146. prop: 'qualitySchemeTemplateName',
  147. label: '质检方案名称',
  148. align: 'center',
  149. minWidth: 150
  150. },
  151. {
  152. prop: 'type',
  153. label: '质检类型',
  154. slot: 'type',
  155. align: 'center',
  156. minWidth: 150
  157. },
  158. {
  159. label: '状态',
  160. prop: 'status',
  161. slot: 'status',
  162. align: 'center'
  163. },
  164. {
  165. prop: 'templateRemark',
  166. label: '备注',
  167. showOverflowTooltip: true,
  168. align: 'center',
  169. minWidth: 110
  170. }
  171. ],
  172. where: { ...defaultWhere },
  173. typeList: []
  174. };
  175. },
  176. mounted() {
  177. this.getInspectionType();
  178. },
  179. computed: {},
  180. methods: {
  181. datasource({ page, where, limit }) {
  182. console.log(1111);
  183. return getTemplateList({
  184. qualitySchemeTemplateCode: this.where.qualitySchemeTemplateCode,
  185. qualitySchemeTemplateName: this.where.qualitySchemeTemplateName,
  186. type: this.where.type,
  187. pageNum: page,
  188. size: limit
  189. });
  190. },
  191. getQualityType(row) {
  192. if (row.type) {
  193. const data = this.typeList.filter((item) => item.value == row.type);
  194. return data[0].label;
  195. }
  196. return '';
  197. // if (row.type) {
  198. // let label = '';
  199. // this.typeList.forEach((item) => {
  200. // if (item.value == row.type) {
  201. // label = item.label;
  202. // }
  203. // console.log(label, 'label');
  204. // return label;
  205. // });
  206. // }
  207. // return '123';
  208. },
  209. // 多选
  210. selectionChangeHandle(val) {
  211. this.selection = val;
  212. },
  213. open() {
  214. this.visible = true;
  215. },
  216. search() {},
  217. reload() {
  218. this.$refs.table.reload();
  219. },
  220. handleClose() {
  221. this.$nextTick(() => {
  222. this.current = null;
  223. this.radio = '';
  224. });
  225. this.visible = false;
  226. },
  227. changeSel() {
  228. this.$emit('changeSel', this.current);
  229. this.handleClose();
  230. },
  231. handleCurrentChange(row) {
  232. this.radio = row.id;
  233. },
  234. reset() {
  235. this.where = {
  236. qualitySchemeTemplateCode: '',
  237. qualitySchemeTemplateName: '',
  238. type: ''
  239. };
  240. this.reload();
  241. },
  242. async getInspectionType() {
  243. let res = await getByCode('inspection_plan_type');
  244. if (res?.code == 0) {
  245. let list = res.data.map((item) => {
  246. let key = Object.keys(item)[0];
  247. return { value: key, label: item[key] };
  248. });
  249. this.typeList = list;
  250. }
  251. }
  252. }
  253. };
  254. </script>