| | |
| | | <div class="grid-content"> |
| | | <el-select placeholder="请选择" v-model="searchFormArrays[index].condition"> |
| | | <el-option |
| | | v-for="condition in item.fieldType=='text' ? searchConditions:switchSearchConditions" |
| | | v-for="condition in item.fieldType==='text' || item.fieldType==='combox' ? |
| | | item.fieldType==='text' ? searchConditions:switchSearchConditions:dateConditions" |
| | | :key="condition.value" |
| | | :label="condition.label" |
| | | :value="condition.value"> |
| | |
| | | </el-col> |
| | | <el-col :span="12"> |
| | | <div class="grid-content"> |
| | | <el-input v-if="item.fieldType==='text' || item.fieldType===''" v-model="searchFormArrays[index].fieldValue" type="text" placeholder="请输入"></el-input> |
| | | <el-select v-else-if="item.fieldType==='combox'" v-model="searchFormArrays[index].fieldValue" placeholder="请选择"> |
| | | <el-input v-if="item.fieldType==='text' || item.fieldType===''" v-model="searchFormArrays[index].fieldValue" type="text" placeholder="请输入" :display="item.display"></el-input> |
| | | <el-select v-else-if="item.fieldType==='combox'" v-model="searchFormArrays[index].fieldValue" placeholder="请选择" :display="item.display"> |
| | | <el-option |
| | | v-for="option in item.data" |
| | | :key="option.itemValue" |
| | |
| | | :value="option.itemValue"> |
| | | </el-option> |
| | | </el-select> |
| | | <el-switch v-else-if="item.fieldType==='truefalse'" v-model="searchFormArrays[index].fieldValue"></el-switch> |
| | | <el-switch v-else-if="item.fieldType==='truefalse'" v-model="searchFormArrays[index].fieldValue" :display="item.display"></el-switch> |
| | | <el-date-picker v-else-if="item.fieldType==='datetime'" :display="item.display" |
| | | v-model="searchFormArrays[index].fieldValue" |
| | | type="date" |
| | | placeholder="选择日期"> |
| | | </el-date-picker> |
| | | <vci-web-refer |
| | | v-else-if="item.fieldType==='refer'" |
| | | :referConfig="item.referConfigData || {}" |
| | | :value="searchFormArrays[index].fieldValue" |
| | | :disabled="item.referConfig.showField" |
| | | :display="item.display" |
| | | @setReferValue="setReferValue"> |
| | | </vci-web-refer> |
| | | </div> |
| | | </el-col> |
| | | <el-col :span="2"> |
| | |
| | | |
| | | <script> |
| | | import { getDictionary } from "@/api/omd/enum"; |
| | | import vciWebRefer from '../refer/vciWebRefer.vue'; |
| | | export default { |
| | | components: { vciWebRefer }, |
| | | name: "advancedQuery", |
| | | props: { |
| | | // 对话框显示隐藏控制 |
| | |
| | | // 对话框显示控制 |
| | | isShowDialog: this.visible, |
| | | initOptions: [], |
| | | // 字段是输入框类型的条件数组 |
| | | // 字段类型是输入框类型的条件数组 |
| | | searchConditions: [ |
| | | { |
| | | value: "_equal", |
| | |
| | | },{ |
| | | value: "_notlike", |
| | | label: "不包含", |
| | | },{ |
| | | value: "_ge", //大于,默认为大于等于 |
| | | label: "大于", |
| | | },{ |
| | | value: "_le", //小于,默认为小于等于 |
| | | label: "小于", |
| | | }, |
| | | } |
| | | ], |
| | | // 字段是单选或下拉框类型的条件数组 |
| | | // 字段类型是单选或下拉框类型的条件数组 |
| | | switchSearchConditions: [ |
| | | { |
| | | value: "_equal", |
| | |
| | | value: "_notequal", |
| | | label: "不等于", |
| | | } |
| | | ], |
| | | // 字段类型是日期 |
| | | dateConditions: [ |
| | | { |
| | | value: "_equal", |
| | | label: "等于", |
| | | },{ |
| | | value: "_notequal", |
| | | label: "不等于", |
| | | },{ |
| | | value: "_ge", //大于,默认为大于等于 |
| | | label: "大于", |
| | | },{ |
| | | value: "_le", //小于,默认为小于等于 |
| | | label: "小于", |
| | | }, |
| | | ], |
| | | searchFormArrays: [], |
| | | fieldValue: '', |
| | |
| | | localStorage.setItem(item.comboxKey,JSON.stringify(res.data.data)); |
| | | }) |
| | | } |
| | | }else if(item.fieldType==='refer'){ |
| | | item = Object.assign(item,{referConfigData:{ |
| | | title: item.referConfig.textField, |
| | | showField: item.showField || item.field, |
| | | field: item.field, |
| | | placeholder: item.inputTip || '', |
| | | options: item.referConfig, |
| | | }}) |
| | | //console.log(item.referConfigData.options.type); |
| | | //console.log(item); |
| | | } |
| | | let add = { |
| | | queryField: String(item.queryField), |
| | |
| | | } |
| | | this.searchFormArrays.push(add) |
| | | }); |
| | | console.log(this.initOptions); |
| | | //console.log(this.searchFormArrays); |
| | | } |
| | | }, |
| | | methods: { |
| | | |
| | | /** 为参照类型时值选择之后的处理 */ |
| | | setReferValue(data){ |
| | | // if(data.field) { |
| | | |
| | | // } |
| | | //console.log(data); |
| | | }, |
| | | |
| | | // 属性切换时查询条件和查询值也需要对输入框进行切换 |
| | | // changeField(index) { |
| | |
| | | const searchConditions = this.searchFormArrays; |
| | | for(let index = 0; index < searchConditions.length; index++) { |
| | | //console.log(condtionParam['conditionMap['+searchConditions[index].queryField+']']+'' == 'undefined'); |
| | | if(searchConditions[index].fieldValue.trim() != '' || searchConditions[index].fieldValue+''==='false') { |
| | | if(searchConditions[index].fieldValue+'' != '' || searchConditions[index].fieldValue+''==='false') { |
| | | // 存在相同的查询条件 |
| | | if(condtionParam['conditionMap['+searchConditions[index].queryField+']']+'' != 'undefined' ) { |
| | | this.$message.warning("存在重复查询条件,请仔细核对!"); |
| | |
| | | condtionParam['conditionMap['+searchConditions[index].queryField+searchConditions[index].condition+']'] = searchConditions[index].fieldValue; |
| | | } |
| | | } |
| | | // 查询条件没有出现重复属性,并且过滤掉了空值,传递给父组件 |
| | | // 查询条件没有出现重复属性,并且过滤掉了空值,就传递给父组件 |
| | | // console.log(condtionParam); |
| | | this.$emit('echoContion',condtionParam) |
| | | this.isShowDialog = false; |
| | |
| | | line-height: 40px; |
| | | height: 40px; |
| | | } |
| | | .grid-content > .el-date-editor.el-input, .el-date-editor.el-input__inner{ |
| | | width: 100%; |
| | | } |
| | | |
| | | |
| | | </style> |