| <template> | 
|     <div> | 
|         <a-card :bordered="false" :bodyStyle="tstyle"> | 
|   | 
|             <div class="table-page-search-wrapper" v-if="hasPerm('WmsMaterial:page')"> | 
|                 <a-form layout="inline"> | 
|                     <a-row :gutter="48"> | 
|                         <a-col :md="8" :sm="24"> | 
|                             <a-form-item label="物料名称"> | 
|                                 <a-input v-model="queryParam.materialname" allow-clear placeholder="请输入物料名称" /> | 
|                             </a-form-item> | 
|                         </a-col> | 
|                         <a-col :md="8" :sm="24"> | 
|                             <a-form-item label="物料编号"> | 
|                                 <a-input v-model="queryParam.materialno" allow-clear placeholder="请输入物料编号" /> | 
|                             </a-form-item> | 
|                         </a-col><template v-if="advanced"> | 
|                             <a-col :md="8" :sm="24"> | 
|                                 <a-form-item label="物料批次"> | 
|                                     <a-input v-model="queryParam.materialbatch" allow-clear placeholder="请输入物料批次" /> | 
|                                 </a-form-item> | 
|                             </a-col> | 
|                             <a-col :md="8" :sm="24"> | 
|                                 <a-form-item label="检验方式"> | 
|                                     <a-select :allowClear="true" style="width: 100%" | 
|                                         v-model="queryParam.inspectionmethod" placeholder="请选择检验方式"> | 
|                                         <a-select-option v-for="(item,index) in inspectionmethodData" :key="index" | 
|                                             :value="item.code">{{ item.name }}</a-select-option> | 
|                                     </a-select> | 
|                                 </a-form-item> | 
|                             </a-col> | 
|                             <a-col :md="8" :sm="24"> | 
|                                 <a-form-item label="物料类别"> | 
|                                     <a-select :allowClear="true" style="width: 100%" v-model="queryParam.materialtype" | 
|                                         placeholder="请选择物料类别"> | 
|                                         <a-select-option v-for="(item,index) in materialtypeData" :key="index" | 
|                                             :value="item.code">{{ item.name }}</a-select-option> | 
|                                     </a-select> | 
|                                 </a-form-item> | 
|                             </a-col> | 
|                             <a-col :md="8" :sm="24"> | 
|                                 <a-form-item label="物料规格"> | 
|                                     <a-input v-model="queryParam.materialspec" allow-clear placeholder="请输入物料规格" /> | 
|                                 </a-form-item> | 
|                             </a-col> | 
|                             <a-col :md="8" :sm="24"> | 
|                                 <a-form-item label="单位类别"> | 
|                                     <a-select :allowClear="true" style="width: 100%" v-model="queryParam.unittype" | 
|                                         placeholder="请选择单位类别"> | 
|                                         <a-select-option v-for="(item,index) in unittypeData" :key="index" | 
|                                             :value="item.code">{{ item.name }}</a-select-option> | 
|                                     </a-select> | 
|                                 </a-form-item> | 
|                             </a-col> | 
|                             <a-col :md="8" :sm="24"> | 
|                                 <a-form-item label="单位编号"> | 
|                                     <a-select :allowClear="true" style="width: 100%" v-model="queryParam.unitno" | 
|                                         placeholder="请选择单位编号"> | 
|                                         <a-select-option v-for="(item,index) in unitnoData" :key="index" | 
|                                             :value="item.code">{{ item.name }}</a-select-option> | 
|                                     </a-select> | 
|                                 </a-form-item> | 
|                             </a-col> | 
|                             <a-col :md="8" :sm="24"> | 
|                                 <a-form-item label="是否关键物料"> | 
|                                     <a-select :allowClear="true" style="width: 100%" v-model="queryParam.keymaterials" | 
|                                         placeholder="请选择是否关键物料"> | 
|                                         <a-select-option v-for="(item,index) in keymaterialsData" :key="index" | 
|                                             :value="item.code">{{ item.name }}</a-select-option> | 
|                                     </a-select> | 
|                                 </a-form-item> | 
|                             </a-col> | 
|                         </template> | 
|   | 
|                         <a-col :md="8" :sm="24"> | 
|                             <span class="table-page-search-submitButtons"> | 
|                                 <a-button type="primary" @click="$refs.table.refresh(true)">查询</a-button> | 
|                                 <a-button style="margin-left: 8px" @click="() => queryParam = {}">重置</a-button> | 
|                                 <a @click="toggleAdvanced" style="margin-left: 8px"> {{ advanced ? '收起' : '展开' }} | 
|                                     <a-icon :type="advanced ? 'up' : 'down'" /> | 
|                                 </a> | 
|                             </span> | 
|                         </a-col> | 
|   | 
|                     </a-row> | 
|                 </a-form> | 
|             </div> | 
|         </a-card> | 
|         <a-card :bordered="false"> | 
|             <s-table ref="table" :columns="columns" :data="loadData" :alert="true" :rowKey="(record) => record.id" | 
|                 :rowSelection="{ selectedRowKeys: selectedRowKeys, onChange: onSelectChange }"> | 
|                 <template class="table-operator" slot="operator" v-if="hasPerm('WmsMaterial:add')"> | 
|                     <a-button type="primary" v-if="hasPerm('WmsMaterial:add')" icon="plus" @click="$refs.addForm.add()"> | 
|                         新增物料</a-button> | 
|                 </template> | 
|                 <span slot="inspectionmethodscopedSlots" slot-scope="text"> | 
|                     <a-tag :color="text===1?'#2db7f5':'#87d068'">{{ 'material_inspection' | dictType(text) }}</a-tag> | 
|                 </span> | 
|                 <span slot="materialtypescopedSlots" slot-scope="text"> | 
|                     {{ 'material_type' | dictType(text) }} | 
|                 </span> | 
|                 <span slot="unittypescopedSlots" slot-scope="text"> | 
|                     {{ 'unit_type' | dictType(text) }} | 
|                 </span> | 
|                 <span slot="unitnoscopedSlots" slot-scope="text"> | 
|                     {{ 'unitno_type' | dictType(text) }} | 
|                 </span> | 
|                 <span slot="keymaterialsscopedSlots" slot-scope="text"> | 
|                     {{ 'yes_or_no' | dictType(text) }} | 
|                 </span> | 
|                 <span slot="action" slot-scope="text, record"> | 
|                     <a v-if="hasPerm('WmsMaterial:edit')" @click="$refs.editForm.edit(record)">编辑</a> | 
|                     <a-divider type="vertical" v-if="hasPerm('WmsMaterial:edit') & hasPerm('WmsMaterial:delete')" /> | 
|                     <a-popconfirm v-if="hasPerm('WmsMaterial:delete')" placement="topRight" title="确认删除?" | 
|                         @confirm="() => WmsMaterialDelete(record)"> | 
|                         <a>删除</a> | 
|                     </a-popconfirm> | 
|                 </span> | 
|             </s-table> | 
|             <add-form ref="addForm" @ok="handleOk" /> | 
|             <edit-form ref="editForm" @ok="handleOk" /> | 
|         </a-card> | 
|     </div> | 
| </template> | 
| <script> | 
|     import { | 
|         STable | 
|     } from '@/components' | 
|     import { | 
|         WmsMaterialPage, | 
|         WmsMaterialDelete | 
|     } from '@/api/modular/main/WmsMaterialManage' | 
|     import addForm from './addForm.vue' | 
|     import editForm from './editForm.vue' | 
|     export default { | 
|         components: { | 
|             STable, | 
|             addForm, | 
|             editForm | 
|         }, | 
|         data() { | 
|             return { | 
|                 advanced: false, // 高级搜索 展开/关闭 | 
|                 queryParam: {}, | 
|                 columns: [{ | 
|                         title: '名称', | 
|                         align: 'center', | 
|                         sorter: true, | 
|                         dataIndex: 'materialname' | 
|                     }, | 
|                     { | 
|                         title: '编号', | 
|                         align: 'center', | 
|                         sorter: true, | 
|                         dataIndex: 'materialno' | 
|                     }, | 
|                     { | 
|                         title: '批次', | 
|                         align: 'center', | 
|                         sorter: true, | 
|                         dataIndex: 'materialbatch' | 
|                     }, | 
|                     { | 
|                         title: '检验方式', | 
|                         align: 'center', | 
|                         dataIndex: 'inspectionmethod', | 
|                         scopedSlots: { | 
|                             customRender: 'inspectionmethodscopedSlots' | 
|                         } | 
|                     }, | 
|                     { | 
|                         title: '物料类别', | 
|                         align: 'center', | 
|                         dataIndex: 'materialtype', | 
|                         scopedSlots: { | 
|                             customRender: 'materialtypescopedSlots' | 
|                         } | 
|                     }, | 
|                     { | 
|                         title: '物料规格', | 
|                         align: 'center', | 
|                         dataIndex: 'materialspec' | 
|                     }, | 
|                     { | 
|                         title: '单位类别', | 
|                         align: 'center', | 
|                         dataIndex: 'unittype', | 
|                         scopedSlots: { | 
|                             customRender: 'unittypescopedSlots' | 
|                         } | 
|                     }, | 
|                     { | 
|                         title: '单位编号', | 
|                         align: 'center', | 
|                         dataIndex: 'unitno', | 
|                         scopedSlots: { | 
|                             customRender: 'unitnoscopedSlots' | 
|                         } | 
|                     }, | 
|                     { | 
|                         title: '安全存量', | 
|                         align: 'center', | 
|                         dataIndex: 'safeqty' | 
|                     }, | 
|                     { | 
|                         title: '关键物料', | 
|                         align: 'center', | 
|                         sorter: true, | 
|                         dataIndex: 'keymaterials', | 
|                         scopedSlots: { | 
|                             customRender: 'keymaterialsscopedSlots' | 
|                         } | 
|                     }, | 
|                     { | 
|                         title: '保质期', | 
|                         align: 'center', | 
|                         dataIndex: 'warranty' | 
|                     }, | 
|                     // { | 
|                     //   title: '最大存量', | 
|                     //   align: 'center', | 
|                     //   dataIndex: 'maximumqty' | 
|                     // }, | 
|                     // { | 
|                     //   title: '最小库龄', | 
|                     //   align: 'center', | 
|                     //   dataIndex: 'minstorageage' | 
|                     // }, | 
|                     // { | 
|                     //   title: '最大库龄', | 
|                     //   align: 'center', | 
|                     //   dataIndex: 'maxstorageage' | 
|                     // } | 
|                 ], | 
|                 tstyle: { | 
|                     'padding-bottom': '0px', | 
|                     'margin-bottom': '10px' | 
|                 }, | 
|                 // 加载数据方法 必须为 Promise 对象 | 
|                 loadData: parameter => { | 
|                     return WmsMaterialPage(Object.assign(parameter, this.queryParam)).then((res) => { | 
|                         res.data.rows = res.data.rows.map((_obj) => { | 
|                             _obj.keymaterials = _obj.keymaterials == 0 ? 'N' : 'Y' | 
|                             return _obj; | 
|                         }) | 
|                         return res.data | 
|                     }) | 
|                 }, | 
|                 inspectionmethodData: [], | 
|                 materialtypeData: [], | 
|                 unittypeData: [], | 
|                 unitnoData: [], | 
|                 keymaterialsData: [], | 
|                 selectedRowKeys: [], | 
|                 selectedRows: [] | 
|             } | 
|         }, | 
|         created() { | 
|             if (this.hasPerm('WmsMaterial:edit') || this.hasPerm('WmsMaterial:delete')) { | 
|                 this.columns.push({ | 
|                     title: '操作', | 
|                     width: '150px', | 
|                     dataIndex: 'action', | 
|                     scopedSlots: { | 
|                         customRender: 'action' | 
|                     } | 
|                 }) | 
|             } | 
|             const inspectionmethodOption = this.$options | 
|             this.inspectionmethodData = inspectionmethodOption.filters['dictData']('material_inspection') | 
|             const materialtypeOption = this.$options | 
|             this.materialtypeData = materialtypeOption.filters['dictData']('material_type') | 
|             const unittypeOption = this.$options | 
|             this.unittypeData = unittypeOption.filters['dictData']('unit_type') | 
|             const unitnoOption = this.$options | 
|             this.unitnoData = unitnoOption.filters['dictData']('unitno_type') | 
|             const keymaterialsOption = this.$options | 
|             this.keymaterialsData = keymaterialsOption.filters['dictData']('yes_or_no') | 
|         }, | 
|         methods: { | 
|             /** | 
|              * 查询参数组装 | 
|              */ | 
|             switchingDate() { | 
|                 const obj = JSON.parse(JSON.stringify(this.queryParam)) | 
|                 return obj | 
|             }, | 
|             WmsMaterialDelete(record) { | 
|                 WmsMaterialDelete(record).then((res) => { | 
|                     if (res.success) { | 
|                         this.$message.success('删除成功') | 
|                         this.$refs.table.refresh() | 
|                     } else { | 
|                         this.$message.error('删除失败') // + res.message | 
|                     } | 
|                 }) | 
|             }, | 
|             toggleAdvanced() { | 
|                 this.advanced = !this.advanced | 
|             }, | 
|             handleOk() { | 
|                 this.$refs.table.refresh() | 
|             }, | 
|             onSelectChange(selectedRowKeys, selectedRows) { | 
|                 this.selectedRowKeys = selectedRowKeys | 
|                 this.selectedRows = selectedRows | 
|             } | 
|         } | 
|     } | 
| </script> | 
| <style lang="less"> | 
|     .table-operator { | 
|         margin-bottom: 18px; | 
|     } | 
|   | 
|     button { | 
|         margin-right: 8px; | 
|     } | 
| </style> |