iot-ui-vue/src/views/rule-engine/Scene/Save/Device/ReadProperties.vue

81 lines
1.8 KiB
Vue

<template>
<a-row :gutter='[24]'>
<a-col :span='10'>
<a-form-item
name='readProperties'
:rules="[{ required: true, message: '请选择属性' }]"
>
<a-select
show-search
mode='multiple'
max-tag-count='responsive'
placeholder='请选择属性'
style='width: 100%'
v-model:value='readProperties'
:options='properties'
:filter-option='filterSelectNode'
@change='change'
/>
</a-form-item>
</a-col>
<a-col :span='14'>
<a-form-item>定时读取所选属性值</a-form-item>
</a-col>
</a-row>
</template>
<script setup lang='ts' name='ReadProperties'>
import { filterSelectNode } from '@/utils/comm'
import type { PropType } from 'vue'
type Emit = {
(e: 'update:value', data: Array<string>): void
(e: 'update:action', data: string): void
}
const props = defineProps({
value: {
type: Array as PropType<Array<string>>,
default: () => []
},
action: {
type: String,
default: ''
},
properties: {
type: Array,
default: () => []
}
})
const emit = defineEmits<Emit>()
const readProperties = ref<string[]>(props.value)
const change = (values: string[], optionItems: any[]) => {
const names = optionItems.map((item) => item.name);
let extraStr = '';
let isLimit = false;
let indexOf = 0;
extraStr = names.reduce((_prev, next, index) => {
if (_prev.length <= 30) {
indexOf = index;
return index === 0 ? next : _prev + '、' + next;
} else {
isLimit = true;
}
return _prev;
}, '');
if (isLimit && names.length - 1 > indexOf) {
extraStr += `${optionItems.length}个属性`;
}
emit('update:value', values)
emit('update:action', `读取 ${extraStr}`)
}
</script>
<style scoped>
</style>