225 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
			
		
		
	
	
			225 lines
		
	
	
		
			6.2 KiB
		
	
	
	
		
			Vue
		
	
	
	
| <template>
 | |
| 	<el-container>
 | |
| 		<el-header>
 | |
| 			<div class="left-panel">
 | |
| 				<!--  v-auth="'defect.create'" -->
 | |
| 				<el-button type="primary" icon="el-icon-plus" @click="defectAdd" v-auth="'defect.create'"></el-button>
 | |
| 			</div>
 | |
| 			<div class="right-panel">
 | |
| 				<el-input v-model="query.search" placeholder="名称" clearable @keyup.enter="handleQuery"></el-input>
 | |
| 				<el-button type="primary" icon="el-icon-search" @click="handleQuery"></el-button>
 | |
| 			</div>
 | |
| 		</el-header>
 | |
| 		<el-main class="nopadding">
 | |
| 			<scTable ref="table" :apiObj="apiObj" row-key="id">
 | |
| 				<el-table-column label="#" type="index"></el-table-column>
 | |
| 				<el-table-column label="名称" prop="name"></el-table-column>
 | |
| 				<el-table-column label="标识" prop="code"></el-table-column>
 | |
| 				<el-table-column label="分类" prop="cate">
 | |
| 					<template #default="scope">
 | |
| 						<el-tag type="success">{{ scope.row.cate}}</el-tag>
 | |
| 					</template>
 | |
| 				</el-table-column>
 | |
| 				<el-table-column label="不合格分类" prop="okcate">
 | |
| 					<template #default="scope">
 | |
| 						<el-tag :type="typeCpmpute(scope.row.okcate)" effect="plain">{{ okcate_[scope.row.okcate] }}</el-tag>
 | |
| 					</template>
 | |
| 				</el-table-column>
 | |
| 				<el-table-column label="备注" prop="note"></el-table-column>
 | |
| 				<el-table-column label="操作" fixed="right" align="center" width="140">
 | |
| 					<template #default="scope">
 | |
| 						<el-button link size="small" @click="defectEdit(scope.row, scope.$index)" v-auth="'role.update'" type="primary">编辑</el-button>
 | |
| 						<el-divider direction="vertical"></el-divider>
 | |
| 						<el-popconfirm title="确定删除吗?" @confirm="defectDel(scope.row, scope.$index)">
 | |
| 							<template #reference>
 | |
| 								<el-button link size="small" v-auth="'defect.delete'" type="danger">删除</el-button>
 | |
| 							</template>
 | |
| 						</el-popconfirm>
 | |
| 					</template>
 | |
| 				</el-table-column>
 | |
| 			</scTable>
 | |
| 		</el-main>
 | |
| 	</el-container>
 | |
| 	<el-dialog :title="titleMap[type]" v-model="limitedVisible" :width="600">
 | |
| 		<el-form :model="addForm" :rules="rules" ref="addForm" label-width="90px" label-position="left">
 | |
| 			<el-form-item label="名称" prop="name">
 | |
| 				<el-input v-model="addForm.name" clearable></el-input>
 | |
| 			</el-form-item>
 | |
| 			<el-form-item label="标识" prop="code">
 | |
| 				<el-input v-model="addForm.code" clearable></el-input>
 | |
| 			</el-form-item>
 | |
| 			<el-form-item label="分类" prop="cate">
 | |
| 				<el-select style="width: 100%;"
 | |
| 				v-model="addForm.cate" 
 | |
| 				placeholder="请选择">
 | |
| 					<el-option v-for="item in cateOptions" 
 | |
| 					:key="item" 
 | |
| 					:label="item" 
 | |
| 					:value="item"
 | |
| 					></el-option>
 | |
| 				</el-select>
 | |
| 			</el-form-item>
 | |
| 			<el-form-item label="不合格分类">
 | |
| 				<el-select style="width: 100%;"
 | |
| 				v-model="addForm.okcate" 
 | |
| 				placeholder="请选择">
 | |
| 					<el-option v-for="item in options" 
 | |
| 					:key="item.id" 
 | |
| 					:label="item.label" 
 | |
| 					:value="item.id"
 | |
| 					></el-option>
 | |
| 				</el-select>
 | |
| 			</el-form-item>
 | |
| 			<el-form-item label="备注">
 | |
| 				<el-input v-model="addForm.note" clearable></el-input>
 | |
| 			</el-form-item>
 | |
| 		</el-form>
 | |
| 		<template #footer>
 | |
| 			<el-button @click="limitedVisible=false" >取 消</el-button>
 | |
| 			<el-button v-if="type!=='show'" type="primary" :loading="isSaving" @click="submitHandle()">保 存</el-button>
 | |
| 		</template>
 | |
| 	</el-dialog>
 | |
| </template>
 | |
| <script>
 | |
| 	const defaultForm = {
 | |
| 		id:"",
 | |
| 		name: "",
 | |
| 		code: "",
 | |
| 		cate: "尺寸",
 | |
| 		note: "",
 | |
| 		okcate:10,
 | |
| 	};
 | |
| 	export default {
 | |
| 		name: 'dept',
 | |
| 		data() {
 | |
| 			return {
 | |
| 				apiObj: this.$API.qm.defect.list,
 | |
| 				query: {
 | |
| 					search:''
 | |
| 				},
 | |
| 				isSaving: false,
 | |
| 				limitedVisible : false,
 | |
| 				type: "add",
 | |
| 				titleMap: {
 | |
| 					add: '新增',
 | |
| 					edit: '编辑',
 | |
| 					show: '查看'
 | |
| 				},
 | |
| 				options: [
 | |
| 					{id:10,label: '合格'},
 | |
| 					{id:20,label: 'B类合格'},
 | |
| 					{id:30,label: '不合格'},
 | |
| 				],
 | |
| 				cateOptions: ['尺寸', '外观','内质'],
 | |
| 				okcate_: {
 | |
| 					10: '合格',
 | |
| 					20: 'B类合格',
 | |
| 					30: '不合格',
 | |
| 				},
 | |
| 				//表单数据
 | |
| 				addForm: defaultForm,
 | |
| 				//验证规则
 | |
| 				rules: {
 | |
| 					name: [
 | |
| 						{required: true, message: '请输入名称'}
 | |
| 					],
 | |
| 					code: [
 | |
| 						{required: true, message: '请输入标识'}
 | |
| 					],
 | |
| 					cate: [
 | |
| 						{required: true, message: '请输入分类'}
 | |
| 					],
 | |
| 				},
 | |
| 			}
 | |
| 		},
 | |
| 		methods: {
 | |
| 			typeCpmpute(cate){
 | |
| 				if(cate==10){
 | |
| 					return 'success'
 | |
| 				}else if(cate==20){
 | |
| 					return 'warning'
 | |
| 				}else if(cate==30){
 | |
| 					return 'danger'
 | |
| 				}
 | |
| 			},
 | |
| 			//添加
 | |
| 			defectAdd(){
 | |
| 				this.type = "add";
 | |
| 				 // 清空表单数据
 | |
| 				this.addForm.id="";
 | |
| 				this.addForm.name="";
 | |
| 				this.addForm.code="";
 | |
| 				this.addForm.note="";
 | |
| 				this.addForm.cate="尺寸";
 | |
| 				this.addForm.okcate=10;
 | |
| 				this.limitedVisible = true;
 | |
| 				// 清除验证状态
 | |
| 				// this.$refs.addForm.clearValidate();
 | |
| 			},
 | |
| 			submitHandle(){
 | |
| 				let that = this;
 | |
| 				this.$refs.addForm.validate( (valid) => {
 | |
| 					if (valid) {
 | |
| 						this.isSaveing = true;
 | |
| 						let res;
 | |
| 						if(this.type==='add'){
 | |
| 							this.$API.qm.defect.create.req(that.addForm).then(res=>{
 | |
| 								this.isSaveing = false;
 | |
| 								this.limitedVisible = false;
 | |
| 								this.$refs.table.refresh();
 | |
| 							}).catch(e=>{this.isSaveing = false;})
 | |
| 						}else{
 | |
| 							this.$API.qm.defect.update.req(that.addForm.id,that.addForm).then(res=>{
 | |
| 								this.isSaveing = false;
 | |
| 								this.limitedVisible = false;
 | |
| 								this.$refs.table.refresh();
 | |
| 							}).catch(e=>{this.isSaveing = false;})
 | |
| 						}
 | |
| 					}
 | |
| 				})
 | |
| 			},
 | |
| 
 | |
| 			//编辑
 | |
| 			defectEdit(row){
 | |
| 				this.type='edit';
 | |
| 				this.addForm.id=row.id;
 | |
| 				this.addForm.name=row.name;
 | |
| 				this.addForm.code=row.code;
 | |
| 				this.addForm.cate=row.cate;
 | |
| 				this.addForm.note=row.note;
 | |
| 				this.addForm.okcate=row.okcate;
 | |
| 				this.limitedVisible = true;
 | |
| 			},
 | |
| 
 | |
| 			//删除
 | |
| 			async defectDel(row){
 | |
| 				var id = row.id;
 | |
| 				var res = await this.$API.qm.defect.delete.req(id);
 | |
| 				if(res.err_msg){
 | |
| 					this.$message.error(res.err_msg)
 | |
| 				}else{
 | |
| 					this.$refs.table.refresh();
 | |
| 					this.$message.success("删除成功")
 | |
| 				}
 | |
| 			},
 | |
| 			//表格选择后回调事件
 | |
| 			selectionChange(selection){
 | |
| 				this.selection = selection;
 | |
| 			},
 | |
| 			//搜索
 | |
| 			handleQuery(){
 | |
| 				this.$refs.table.queryData(this.query)
 | |
| 			},
 | |
| 			//本地更新数据
 | |
| 			handleSaveSuccess(data, type){
 | |
| 				if(type=='add'){
 | |
| 					this.$refs.table.refresh()
 | |
| 				}else if(type=='edit'){
 | |
| 					this.$refs.table.refresh()
 | |
| 				}
 | |
| 			}
 | |
| 		}
 | |
| 	}
 | |
| </script>
 | |
| <style scoped></style>
 |