| | |
| | | </el-select> |
| | | </el-form-item> --> |
| | | <!-- 所属社区 --> |
| | | <!-- <el-form-item class="optionItems" label="所属社区:" prop="status"> |
| | | <el-select v-model="vio.type" placeholder="请选择所属社区"> |
| | | <el-form-item class="optionItems" label="所属社区:" prop="communityId"> |
| | | <el-select v-model="vio.communityId" placeholder="请选择所属社区"> |
| | | <el-option v-for="item in typeList" :key="item.name" :label="item.name" :value="item.value" |
| | | :disabled="item.disabled"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> --> |
| | | </el-form-item> |
| | | <!-- 所属街道 --> |
| | | <!-- <el-form-item class="optionItems" label="所属街道:" prop="status"> |
| | | <el-select v-model="vio.type" placeholder="请选择所属街道"> |
| | | <el-form-item class="optionItems" label="所属街道:" prop="streetId"> |
| | | <el-select v-model="vio.streetId" placeholder="请选择所属街道"> |
| | | <el-option v-for="item in typeList" :key="item.name" :label="item.name" :value="item.value" |
| | | :disabled="item.disabled"> |
| | | </el-option> |
| | | </el-select> |
| | | </el-form-item> --> |
| | | </el-form-item> |
| | | <!-- 事发地点 --> |
| | | <el-form-item class="optionItems" label="事发地点:" prop="site"> |
| | | <el-input placeholder="请输入事发地详细位置" v-model="vio.site"></el-input> |
| | |
| | | </el-form-item> |
| | | <!-- 关联商铺名称 --> |
| | | <el-form-item class="optionItems" label="关联商铺名称:" prop="shopName"> |
| | | <el-input placeholder="请填写关联商铺名称" v-model="vio.shopName" :disabled="vio.linkShop === 1 ?false : true"></el-input> |
| | | <el-input placeholder="请填写关联商铺名称" v-model="vio.shopName" |
| | | :disabled="vio.linkShop === 1 ?false : true"></el-input> |
| | | </el-form-item> |
| | | <!-- 填写车牌号 --> |
| | | <el-form-item class="optionItems" label="填写车牌号:" prop="carNumber"> |
| | |
| | | <!-- 问题描述 --> |
| | | <el-form-item class="optionItems" label="问题描述:" prop="description"> |
| | | <el-input type="textarea" placeholder="请输入内容200字以内" v-model="vio.description"></el-input> |
| | | </el-form-item> |
| | | <!-- 报警时间 --> |
| | | <el-form-item class="optionItems" label="报警时间:" prop="alarmTime"> |
| | | <el-date-picker v-model="vio.alarmTime" type="datetime" placeholder="选择报警时间"> |
| | | </el-date-picker> |
| | | </el-form-item> |
| | | </el-form> |
| | | </div> |
| | |
| | | </div> |
| | | </div> |
| | | <div class="map-area"> |
| | | <!-- <MyMap /> --> |
| | | <MyMap /> |
| | | </div> |
| | | </div> |
| | | </template> |
| | |
| | | MyMap |
| | | }, |
| | | data() { |
| | | const validateNickname = (rule, value, callback) => { |
| | | if (!value) { |
| | | callback(new Error("请填写问题类型")); |
| | | } else { |
| | | callback(); |
| | | } |
| | | }; |
| | | const validatePass = (rule, value, callback) => { |
| | | if (!value) { |
| | | callback(); |
| | | } else { |
| | | // const rep = /^\w+$/; |
| | | // if (!rep.test(value)) { |
| | | // callback(new Error("密码只能是以数字、26个英文字母或者下划线组成的字符串")); |
| | | // } |
| | | callback(); |
| | | } |
| | | }; |
| | | const validateTruename = (rule, value, callback) => { |
| | | const checkCause = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | // const rep = /^[\u4E00-\u9FA5]{2,4}$/; |
| | | // if (!rep.test(value)) { |
| | | // callback("请输入正确的用户姓名"); |
| | | // } |
| | | callback(); |
| | | callback(new Error('案由不能为空')) |
| | | } |
| | | }; |
| | | } |
| | | const checkCategory = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('大类名称不能为空')) |
| | | } |
| | | } |
| | | const checkCommunity = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('所属社区不能为空')); |
| | | } |
| | | } |
| | | const checkDesc = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('问题描述不能为空')) |
| | | } |
| | | } |
| | | const checkSite = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('事发地点不能为空')) |
| | | } |
| | | } |
| | | const checkStreet = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('所属街道不能为空')) |
| | | } |
| | | } |
| | | const checkType = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('小类不能为空')) |
| | | } |
| | | } |
| | | const checkGrade = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('事件等级不能为空')) |
| | | } |
| | | } |
| | | const checkDate = (rule, value, callback) => { |
| | | if (value) { |
| | | callback(); |
| | | } else { |
| | | callback(new Error('报警时间不能为空')) |
| | | } |
| | | } |
| | | return { |
| | | vio: { |
| | | actionCause:"dasdas",//案由 |
| | | carNumber:"川k123456",//车牌号 |
| | | actionCause: "",//案由 |
| | | carNumber: "",//车牌号 |
| | | // category:1,//1:违规2:违建 |
| | | categoryId:0,//大类 |
| | | communityId:0,//所属社区 |
| | | description:"大撒大撒",//问题描述 |
| | | informant:"大苏打",//反映人 |
| | | informantIdCard:"51102519910082831",//身份证号码 |
| | | informantPhoneCode:"17844631885",//反映人联系方式 |
| | | linkShop:0,//是否关联商铺(0否1是) |
| | | shopName:"",//关联商铺名称 |
| | | site:'新地方',//事发地点 |
| | | streetId:0,//所属街道 |
| | | typeId:0,//小类 |
| | | gradeId:'' |
| | | categoryId: '',//大类 |
| | | communityId: '',//所属社区 |
| | | description: '',//问题描述 |
| | | informant: '',//反映人 |
| | | informantIdCard: '',//身份证号码 |
| | | informantPhoneCode: "",//反映人联系方式 |
| | | linkShop: 0,//是否关联商铺(0否1是) |
| | | shopName: "",//关联商铺名称 |
| | | site: '',//事发地点 |
| | | streetId: '',//所属街道 |
| | | typeId: '',//小类 |
| | | gradeId: '',//案件等级 |
| | | alarmTime: '' |
| | | }, |
| | | createRoleRules: { |
| | | name: [ |
| | | { required: true, trigger: "blur", validator: validateNickname }, |
| | | //案由 |
| | | actionCause: [ |
| | | { |
| | | required: true, trigger: 'blur', validator: checkCause, |
| | | } |
| | | ], |
| | | type: [ |
| | | { required: false, trigger: "blur", validator: validatePass }, |
| | | //车牌号 |
| | | carNumber: [ |
| | | { |
| | | required: false, |
| | | } |
| | | ], |
| | | //大类 |
| | | categoryId: [ |
| | | { |
| | | required: true, trigger: 'change', validator: checkCategory |
| | | } |
| | | ], |
| | | //所属社区 |
| | | communityId: [ |
| | | { |
| | | required: true, trigger: 'change', validator: checkCommunity |
| | | } |
| | | ], |
| | | //问题描述 |
| | | description: [ |
| | | { required: false, trigger: "blur", validator: validateTruename }, |
| | | { |
| | | required: true, trigger: 'blur', validator: checkDesc |
| | | } |
| | | ], |
| | | // informant:"大苏打",//反映人 |
| | | // informantIdCard:"51102519910082831",//身份证号码 |
| | | // informantPhoneCode:"17844631885",//反映人联系方式 |
| | | // linkShop:0,//是否关联商铺(0否1是) |
| | | // shopName:"",//关联商铺名称 |
| | | //事发地点 |
| | | site: [ |
| | | { |
| | | required: true, trigger: 'blur', validator: checkSite |
| | | } |
| | | ], |
| | | //所属街道 |
| | | streetId: [ |
| | | { |
| | | required: true, trigger: 'change', validator: checkStreet |
| | | } |
| | | ], |
| | | //小类 |
| | | typeId: [ |
| | | { |
| | | required: true, trigger: 'change', validator: checkType |
| | | } |
| | | ], |
| | | //案件等级 |
| | | gradeId: [ |
| | | { |
| | | required: true, trigger: 'change', validator: checkGrade |
| | | } |
| | | ], |
| | | alarmTime: [ |
| | | { |
| | | required: true, trigger: 'change', validator: checkDate |
| | | } |
| | | ] |
| | | |
| | | }, |
| | | bigKindList: [], |
| | | smallKindList: [], |
| | |
| | | }, |
| | | // 提交注册信息 |
| | | handleSubmit() { |
| | | const { vio } = this; |
| | | this.$axios({ |
| | | method:'post', |
| | | url:'sccg/base-case/addition_violation', |
| | | data:vio |
| | | }) |
| | | .then(res=>{ |
| | | if(res.code === 200){ |
| | | this.$message({ |
| | | type:'success', |
| | | message:res.message |
| | | this.$refs.user.validate((valid) => { |
| | | if (valid) { |
| | | const { vio } = this; |
| | | console.log(vio); |
| | | this.$axios({ |
| | | method: 'post', |
| | | url: 'sccg/base-case/addition_violation', |
| | | data: vio |
| | | }) |
| | | this.$emit('changeDialog',{dialogView:false}); |
| | | }else{ |
| | | this.$message({ |
| | | type:'warning', |
| | | message:res.message, |
| | | }) |
| | | .then(res => { |
| | | if (res.code === 200) { |
| | | this.$message({ |
| | | type: 'success', |
| | | message: res.message |
| | | }) |
| | | this.$emit('changeDialog', { dialogView: false }); |
| | | } else { |
| | | this.$message({ |
| | | type: 'warning', |
| | | message: res.message, |
| | | }) |
| | | } |
| | | }) |
| | | } else { |
| | | return false; |
| | | } |
| | | }) |
| | | } |
| | | }, |
| | | props: ['mytype','changeDialog'] |
| | | props: ['mytype', 'changeDialog'] |
| | | } |
| | | </script> |
| | | <style lang="scss" scoped> |
| | | .vio { |
| | | display: flex; |
| | | padding: 20px 10px 50px; |
| | | |
| | | .input-area { |
| | | flex: 1; |