123456789101112131415161718192021222324252627282930313233343536373839404142434445 |
- <template>
- <el-form-item label="服务地址" prop="config.url">
- <el-input v-model="config.url" placeholder="请输入MQTT服务地址,如:mqtt://localhost:1883" />
- </el-form-item>
- <el-form-item label="用户名" prop="config.username">
- <el-input v-model="config.username" placeholder="请输入用户名" />
- </el-form-item>
- <el-form-item label="密码" prop="config.password">
- <el-input v-model="config.password" placeholder="请输入密码" show-password type="password" />
- </el-form-item>
- <el-form-item label="客户端ID" prop="config.clientId">
- <el-input v-model="config.clientId" placeholder="请输入客户端ID" />
- </el-form-item>
- <el-form-item label="主题" prop="config.topic">
- <el-input v-model="config.topic" placeholder="请输入主题" />
- </el-form-item>
- </template>
- <script lang="ts" setup>
- import { IoTDataBridgeConfigType, MqttConfig } from '@/api/iot/rule/databridge'
- import { useVModel } from '@vueuse/core'
- import { isEmpty } from '@/utils/is'
- defineOptions({ name: 'MqttConfigForm' })
- const props = defineProps<{
- modelValue: any
- }>()
- const emit = defineEmits(['update:modelValue'])
- const config = useVModel(props, 'modelValue', emit) as Ref<MqttConfig>
- /** 组件初始化 */
- onMounted(() => {
- if (!isEmpty(config.value)) {
- return
- }
- config.value = {
- type: IoTDataBridgeConfigType.MQTT,
- url: '',
- username: '',
- password: '',
- clientId: '',
- topic: ''
- }
- })
- </script>
|