mirror of
https://github.com/TeaOSLab/EdgeAdmin.git
synced 2025-11-03 20:40:26 +08:00
73 lines
2.0 KiB
JavaScript
73 lines
2.0 KiB
JavaScript
// 浏览条件列表
|
||
Vue.component("http-request-conds-view", {
|
||
props: ["v-conds"],
|
||
data: function () {
|
||
let conds = this.vConds
|
||
if (conds == null) {
|
||
conds = {
|
||
isOn: true,
|
||
connector: "or",
|
||
groups: []
|
||
}
|
||
}
|
||
|
||
let that = this
|
||
conds.groups.forEach(function (group) {
|
||
group.conds.forEach(function (cond) {
|
||
cond.typeName = that.typeName(cond)
|
||
})
|
||
})
|
||
|
||
return {
|
||
initConds: conds,
|
||
version: 0 // 为了让组件能及时更新加入此变量
|
||
}
|
||
},
|
||
computed: {
|
||
// 之所以使用computed,是因为需要动态更新
|
||
conds: function () {
|
||
return this.initConds
|
||
}
|
||
},
|
||
methods: {
|
||
typeName: function (cond) {
|
||
let c = window.REQUEST_COND_COMPONENTS.$find(function (k, v) {
|
||
return v.type == cond.type
|
||
})
|
||
if (c != null) {
|
||
return c.name;
|
||
}
|
||
return cond.param + " " + cond.operator
|
||
},
|
||
notifyChange: function () {
|
||
this.version++
|
||
let that = this
|
||
this.initConds.groups.forEach(function (group) {
|
||
group.conds.forEach(function (cond) {
|
||
cond.typeName = that.typeName(cond)
|
||
})
|
||
})
|
||
}
|
||
},
|
||
template: `<div>
|
||
<span v-if="version < 0">{{version}}</span>
|
||
<div v-if="conds.groups.length > 0">
|
||
<div v-for="(group, groupIndex) in conds.groups">
|
||
<var v-for="(cond, index) in group.conds" style="font-style: normal;display: inline-block; margin-bottom:0.5em">
|
||
<span class="ui label tiny">
|
||
<var v-if="cond.type.length == 0 || cond.type == 'params'" style="font-style: normal">{{cond.param}} <var>{{cond.operator}}</var></var>
|
||
<var v-if="cond.type.length > 0 && cond.type != 'params'" style="font-style: normal">{{cond.typeName}}: </var>
|
||
{{cond.value}}
|
||
</span>
|
||
|
||
<var v-if="index < group.conds.length - 1"> {{group.connector}} </var>
|
||
</var>
|
||
<div class="ui divider" v-if="groupIndex != conds.groups.length - 1" style="margin-top:0.3em;margin-bottom:0.5em"></div>
|
||
<div>
|
||
<span class="ui label tiny olive" v-if="group.description != null && group.description.length > 0">{{group.description}}</span>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
</div>`
|
||
}) |