Showing
3 changed files
with
275 additions
and
357 deletions
| 1 | +<template> | |
| 2 | + <div style="margin-left: -5vw"> | |
| 3 | + <BasicForm :showResetButton="false" :showSubmitButton="false" @register="registerServer" /> | |
| 4 | + </div> | |
| 5 | +</template> | |
| 6 | +<script setup lang="ts"> | |
| 7 | + import { BasicForm, useForm } from '/@/components/Form'; | |
| 8 | + import { serverSchemas } from '../index'; | |
| 9 | + | |
| 10 | + const [registerServer, { getFieldsValue, setFieldsValue }] = useForm({ | |
| 11 | + labelWidth: 180, | |
| 12 | + schemas: serverSchemas, | |
| 13 | + actionColOptions: { | |
| 14 | + span: 14, | |
| 15 | + }, | |
| 16 | + }); | |
| 17 | + //回显表单值 | |
| 18 | + const editBootStrapFormFunc = (v) => { | |
| 19 | + setFieldsValue(v); | |
| 20 | + }; | |
| 21 | + | |
| 22 | + const getBootStrapFormFunc = () => { | |
| 23 | + const value = getFieldsValue(); | |
| 24 | + if (!value) return; | |
| 25 | + return value; | |
| 26 | + }; | |
| 27 | + defineExpose({ | |
| 28 | + getBootStrapFormFunc, | |
| 29 | + editBootStrapFormFunc, | |
| 30 | + }); | |
| 31 | +</script> | |
| 32 | +<style lang="less" scoped></style> | ... | ... |
| ... | ... | @@ -45,268 +45,6 @@ export const modelSchemas: FormSchema[] = [ |
| 45 | 45 | }, |
| 46 | 46 | ]; |
| 47 | 47 | |
| 48 | -export const serverSchemas: FormSchema[] = [ | |
| 49 | - //servers | |
| 50 | - { | |
| 51 | - field: 'shortId', | |
| 52 | - component: 'InputNumber', | |
| 53 | - label: 'Short ID', | |
| 54 | - required: true, | |
| 55 | - defaultValue: 123, | |
| 56 | - colProps: { span: 8 }, | |
| 57 | - }, | |
| 58 | - { | |
| 59 | - field: 'lifetime', | |
| 60 | - component: 'InputNumber', | |
| 61 | - label: '客户端注册生存期', | |
| 62 | - required: true, | |
| 63 | - defaultValue: 300, | |
| 64 | - colProps: { span: 8 }, | |
| 65 | - }, | |
| 66 | - { | |
| 67 | - field: 'defaultMinPeriod', | |
| 68 | - component: 'InputNumber', | |
| 69 | - label: '两次通知之间的最短期限', | |
| 70 | - required: true, | |
| 71 | - defaultValue: 1, | |
| 72 | - colProps: { span: 8 }, | |
| 73 | - }, | |
| 74 | - { | |
| 75 | - field: 'binding', | |
| 76 | - component: 'Select', | |
| 77 | - label: 'Binding', | |
| 78 | - defaultValue: 'UQ', | |
| 79 | - componentProps: { | |
| 80 | - options: [ | |
| 81 | - { | |
| 82 | - label: 'U: UDP connection in standard mode', | |
| 83 | - value: 'U', | |
| 84 | - }, | |
| 85 | - { | |
| 86 | - label: 'UQ: UDP connection in queue mode', | |
| 87 | - value: 'UQ', | |
| 88 | - }, | |
| 89 | - { | |
| 90 | - label: 'T: TCP connection in standard mode', | |
| 91 | - value: 'T', | |
| 92 | - }, | |
| 93 | - { | |
| 94 | - label: 'TQ: TCP connection in queue mode', | |
| 95 | - value: 'TQ', | |
| 96 | - }, | |
| 97 | - { | |
| 98 | - label: 'S: SMS connection in standard mode', | |
| 99 | - value: 'S', | |
| 100 | - }, | |
| 101 | - { | |
| 102 | - label: 'SQ: SMS connection in queue mode', | |
| 103 | - value: 'SQ', | |
| 104 | - }, | |
| 105 | - { | |
| 106 | - label: 'US: both UDP and SMS connections active, both in standard mode', | |
| 107 | - value: 'US', | |
| 108 | - }, | |
| 109 | - { | |
| 110 | - label: 'TS: both TCP and SMS connections active, both in standard mode', | |
| 111 | - value: 'TS', | |
| 112 | - }, | |
| 113 | - { | |
| 114 | - label: | |
| 115 | - 'UQS: both UDP and SMS connections active; UDP in queue mode, SMS in standard mode', | |
| 116 | - value: 'UQS', | |
| 117 | - }, | |
| 118 | - { | |
| 119 | - label: | |
| 120 | - 'TQS: both TCP and SMS connections active; TCP in queue mode, SMS in standard mode', | |
| 121 | - value: 'TQS', | |
| 122 | - }, | |
| 123 | - ], | |
| 124 | - }, | |
| 125 | - colProps: { span: 11 }, | |
| 126 | - }, | |
| 127 | - { | |
| 128 | - field: 'notifIfDisabled', | |
| 129 | - label: '启用', | |
| 130 | - colProps: { span: 22 }, | |
| 131 | - component: 'Checkbox', | |
| 132 | - defaultValue: true, | |
| 133 | - renderComponentContent: '禁用或脱机时的通知存储', | |
| 134 | - }, | |
| 135 | - //servers | |
| 136 | - //Bootstrap Server | |
| 137 | - { | |
| 138 | - field: 'securityMode', | |
| 139 | - component: 'Select', | |
| 140 | - label: '配置模式', | |
| 141 | - defaultValue: 'NO_SEC', | |
| 142 | - componentProps: { | |
| 143 | - options: [ | |
| 144 | - { | |
| 145 | - label: 'No Security', | |
| 146 | - value: 'NO_SEC', | |
| 147 | - }, | |
| 148 | - { | |
| 149 | - label: 'Pre-Shared Key', | |
| 150 | - value: 'PSK', | |
| 151 | - }, | |
| 152 | - { | |
| 153 | - label: 'Raw Public Key', | |
| 154 | - value: 'RPK', | |
| 155 | - }, | |
| 156 | - { | |
| 157 | - label: 'X.509 Certificate', | |
| 158 | - value: 'X509', | |
| 159 | - }, | |
| 160 | - ], | |
| 161 | - }, | |
| 162 | - colProps: { span: 8 }, | |
| 163 | - }, | |
| 164 | - { | |
| 165 | - field: 'host', | |
| 166 | - component: 'Input', | |
| 167 | - label: 'Host', | |
| 168 | - required: true, | |
| 169 | - defaultValue: 'localhost', | |
| 170 | - colProps: { span: 8 }, | |
| 171 | - }, | |
| 172 | - { | |
| 173 | - field: 'port', | |
| 174 | - component: 'InputNumber', | |
| 175 | - label: 'Port', | |
| 176 | - required: true, | |
| 177 | - defaultValue: 5687, | |
| 178 | - colProps: { span: 8 }, | |
| 179 | - }, | |
| 180 | - { | |
| 181 | - field: 'serverId', | |
| 182 | - component: 'InputNumber', | |
| 183 | - label: 'Short ID', | |
| 184 | - required: true, | |
| 185 | - defaultValue: 111, | |
| 186 | - colProps: { span: 8 }, | |
| 187 | - }, | |
| 188 | - { | |
| 189 | - field: 'clientHoldOffTime', | |
| 190 | - component: 'InputNumber', | |
| 191 | - label: '拖延时间', | |
| 192 | - required: true, | |
| 193 | - defaultValue: 1, | |
| 194 | - colProps: { span: 8 }, | |
| 195 | - }, | |
| 196 | - { | |
| 197 | - field: 'bootstrapServerAccountTimeout2', | |
| 198 | - component: 'InputNumber', | |
| 199 | - label: '超时后的帐户', | |
| 200 | - required: true, | |
| 201 | - defaultValue: 0, | |
| 202 | - colProps: { span: 8 }, | |
| 203 | - }, | |
| 204 | - { | |
| 205 | - field: 'serverPublicKey', | |
| 206 | - component: 'InputTextArea', | |
| 207 | - label: '服务器公钥', | |
| 208 | - required: true, | |
| 209 | - defaultValue: `3059301306072a8648ce3d020106082a8648ce3d03010703420004e353af009b814ee2f9ab393a975e0c | |
| 210 | - 39e2fff60e3603fd6ee54a43b89a4f56258a7aa9c7e4a577760edb289dc955d91968473ee8a1bfc2b9c423563796113009`, | |
| 211 | - colProps: { span: 22 }, | |
| 212 | - componentProps: { | |
| 213 | - autoSize: { | |
| 214 | - maxRows: 10, | |
| 215 | - }, | |
| 216 | - }, | |
| 217 | - ifShow: ({ values }) => | |
| 218 | - isCertificate(Reflect.get(values, 'securityMode')) || | |
| 219 | - isPawPublicKey(Reflect.get(values, 'securityMode')), | |
| 220 | - }, | |
| 221 | - //Bootstrap Server | |
| 222 | - //LwM2M Server | |
| 223 | - { | |
| 224 | - field: 'securityMode1', | |
| 225 | - component: 'Select', | |
| 226 | - label: '配置模式', | |
| 227 | - defaultValue: 'NO_SEC', | |
| 228 | - componentProps: { | |
| 229 | - options: [ | |
| 230 | - { | |
| 231 | - label: 'No Security', | |
| 232 | - value: 'NO_SEC', | |
| 233 | - }, | |
| 234 | - { | |
| 235 | - label: 'Pre-Shared Key', | |
| 236 | - value: 'PSK', | |
| 237 | - }, | |
| 238 | - { | |
| 239 | - label: 'Raw Public Key', | |
| 240 | - value: 'RPK', | |
| 241 | - }, | |
| 242 | - { | |
| 243 | - label: 'X.509 Certificate', | |
| 244 | - value: 'X509', | |
| 245 | - }, | |
| 246 | - ], | |
| 247 | - }, | |
| 248 | - colProps: { span: 8 }, | |
| 249 | - }, | |
| 250 | - { | |
| 251 | - field: 'host1', | |
| 252 | - component: 'Input', | |
| 253 | - label: 'Host', | |
| 254 | - required: true, | |
| 255 | - defaultValue: 'localhost', | |
| 256 | - colProps: { span: 8 }, | |
| 257 | - }, | |
| 258 | - { | |
| 259 | - field: 'port1', | |
| 260 | - component: 'InputNumber', | |
| 261 | - label: 'Port', | |
| 262 | - required: true, | |
| 263 | - defaultValue: 5685, | |
| 264 | - colProps: { span: 8 }, | |
| 265 | - }, | |
| 266 | - { | |
| 267 | - field: 'serverId1', | |
| 268 | - component: 'InputNumber', | |
| 269 | - label: 'Short ID', | |
| 270 | - required: true, | |
| 271 | - defaultValue: 123, | |
| 272 | - colProps: { span: 8 }, | |
| 273 | - }, | |
| 274 | - { | |
| 275 | - field: 'clientHoldOffTime1', | |
| 276 | - component: 'InputNumber', | |
| 277 | - label: '拖延时间', | |
| 278 | - required: true, | |
| 279 | - defaultValue: 1, | |
| 280 | - colProps: { span: 8 }, | |
| 281 | - }, | |
| 282 | - { | |
| 283 | - field: 'bootstrapServerAccountTimeout1', | |
| 284 | - component: 'InputNumber', | |
| 285 | - label: '超时后的帐户', | |
| 286 | - required: true, | |
| 287 | - defaultValue: 0, | |
| 288 | - colProps: { span: 8 }, | |
| 289 | - }, | |
| 290 | - { | |
| 291 | - field: 'serverPublicKey1', | |
| 292 | - component: 'InputTextArea', | |
| 293 | - label: '服务器公钥', | |
| 294 | - required: true, | |
| 295 | - defaultValue: `3059301306072a8648ce3d020106082a8648ce3d03010703420004e353af009b814ee2f9ab393a975e0 | |
| 296 | - c39e2fff60e3603fd6ee54a43b89a4f56258a7aa9c7e4a577760edb289dc955d91968473ee8a1bfc2b9c423563796113009`, | |
| 297 | - colProps: { span: 22 }, | |
| 298 | - componentProps: { | |
| 299 | - autoSize: { | |
| 300 | - maxRows: 10, | |
| 301 | - }, | |
| 302 | - }, | |
| 303 | - ifShow: ({ values }) => | |
| 304 | - isCertificate(Reflect.get(values, 'securityMode1')) || | |
| 305 | - isPawPublicKey(Reflect.get(values, 'securityMode1')), | |
| 306 | - }, | |
| 307 | - //LwM2M Server | |
| 308 | -]; | |
| 309 | - | |
| 310 | 48 | export const settingsSchemas: FormSchema[] = [ |
| 311 | 49 | { |
| 312 | 50 | field: 'fwUpdateStrategy', |
| ... | ... | @@ -556,3 +294,169 @@ export const deviceSchemas: FormSchema[] = [ |
| 556 | 294 | `, |
| 557 | 295 | }, |
| 558 | 296 | ]; |
| 297 | + | |
| 298 | +export const serverSchemas: FormSchema[] = [ | |
| 299 | + { | |
| 300 | + field: 'securityMode', | |
| 301 | + component: 'Select', | |
| 302 | + label: '安全配置模式', | |
| 303 | + defaultValue: 'NO_SEC', | |
| 304 | + componentProps: { | |
| 305 | + options: [ | |
| 306 | + { | |
| 307 | + label: 'No Security', | |
| 308 | + value: 'NO_SEC', | |
| 309 | + }, | |
| 310 | + { | |
| 311 | + label: 'Pre-Shared Key', | |
| 312 | + value: 'PSK', | |
| 313 | + }, | |
| 314 | + { | |
| 315 | + label: 'Raw Public Key', | |
| 316 | + value: 'RPK', | |
| 317 | + }, | |
| 318 | + { | |
| 319 | + label: 'X.509 Certificate', | |
| 320 | + value: 'X509', | |
| 321 | + }, | |
| 322 | + ], | |
| 323 | + }, | |
| 324 | + colProps: { span: 8 }, | |
| 325 | + }, | |
| 326 | + { | |
| 327 | + field: 'shortServerId', | |
| 328 | + component: 'InputNumber', | |
| 329 | + label: '短服务器ID', | |
| 330 | + required: true, | |
| 331 | + defaultValue: 123, | |
| 332 | + colProps: { span: 8 }, | |
| 333 | + }, | |
| 334 | + { | |
| 335 | + field: 'host', | |
| 336 | + component: 'Input', | |
| 337 | + label: '主机', | |
| 338 | + required: true, | |
| 339 | + defaultValue: '0.0.0.0', | |
| 340 | + colProps: { span: 8 }, | |
| 341 | + }, | |
| 342 | + { | |
| 343 | + field: 'port', | |
| 344 | + component: 'Input', | |
| 345 | + label: '端口', | |
| 346 | + required: true, | |
| 347 | + defaultValue: 5685, | |
| 348 | + colProps: { span: 8 }, | |
| 349 | + }, | |
| 350 | + { | |
| 351 | + field: 'clientHoldOffTime', | |
| 352 | + component: 'InputNumber', | |
| 353 | + label: '延迟时间', | |
| 354 | + required: true, | |
| 355 | + defaultValue: 1, | |
| 356 | + colProps: { span: 8 }, | |
| 357 | + }, | |
| 358 | + { | |
| 359 | + field: 'bootstrapServerAccountTimeout', | |
| 360 | + component: 'InputNumber', | |
| 361 | + label: '超时后的帐户', | |
| 362 | + required: true, | |
| 363 | + defaultValue: 0, | |
| 364 | + colProps: { span: 8 }, | |
| 365 | + }, | |
| 366 | + { | |
| 367 | + field: 'lifetime', | |
| 368 | + component: 'InputNumber', | |
| 369 | + label: '注册生存期', | |
| 370 | + required: true, | |
| 371 | + defaultValue: 300, | |
| 372 | + colProps: { span: 8 }, | |
| 373 | + }, | |
| 374 | + { | |
| 375 | + field: 'defaultMinPeriod', | |
| 376 | + component: 'InputNumber', | |
| 377 | + label: '两次通知之间的最小周期', | |
| 378 | + required: true, | |
| 379 | + defaultValue: 1, | |
| 380 | + colProps: { span: 8 }, | |
| 381 | + }, | |
| 382 | + { | |
| 383 | + field: 'binding', | |
| 384 | + component: 'Select', | |
| 385 | + label: 'Binding', | |
| 386 | + defaultValue: 'UQ', | |
| 387 | + componentProps: { | |
| 388 | + options: [ | |
| 389 | + { | |
| 390 | + label: 'U: Client is reachable via the UDP binding at any time.', | |
| 391 | + value: 'U', | |
| 392 | + }, | |
| 393 | + { | |
| 394 | + label: 'M: Client is reachable via the MQTT binding at any time.', | |
| 395 | + value: 'M', | |
| 396 | + }, | |
| 397 | + { | |
| 398 | + label: 'H: Client is reachable via the HTTP binding at any time.', | |
| 399 | + value: 'H', | |
| 400 | + }, | |
| 401 | + { | |
| 402 | + label: 'T: Client is reachable via the TCP binding at any time.', | |
| 403 | + value: 'T', | |
| 404 | + }, | |
| 405 | + { | |
| 406 | + label: 'S: Client is reachable via the SMS binding at any time.', | |
| 407 | + value: 'S', | |
| 408 | + }, | |
| 409 | + { | |
| 410 | + label: | |
| 411 | + 'N: Client MUST send the response to such a request over the Non-IP binding (is supported since LWM', | |
| 412 | + value: 'N', | |
| 413 | + }, | |
| 414 | + { | |
| 415 | + label: 'UQ: UDP connection in queue mode (is not supported since LWM2M 1.1)', | |
| 416 | + value: 'UQ', | |
| 417 | + }, | |
| 418 | + { | |
| 419 | + label: | |
| 420 | + 'UQS: both UDP and SMS connections active; UDP in queue mode, SMS in standard mode (is not supported since LWM2M 1.1)', | |
| 421 | + value: 'UQS', | |
| 422 | + }, | |
| 423 | + { | |
| 424 | + label: 'TQ: TCP connection in queue mode (is not supported since LWM2M 1.1)', | |
| 425 | + value: 'TQ:', | |
| 426 | + }, | |
| 427 | + { | |
| 428 | + label: | |
| 429 | + 'TQS: both TCP and SMS connections active; TCP in queue mode, SMS in standard mode (is not supported since LWM2M 1.1) ', | |
| 430 | + value: 'TQS', | |
| 431 | + }, | |
| 432 | + { | |
| 433 | + label: 'SQ: SMS connection in queue mode (is not supported since LWM2M 1.1)', | |
| 434 | + value: 'SQ', | |
| 435 | + }, | |
| 436 | + ], | |
| 437 | + }, | |
| 438 | + colProps: { span: 11 }, | |
| 439 | + }, | |
| 440 | + { | |
| 441 | + field: 'notifIfDisabled', | |
| 442 | + label: '是否启用', | |
| 443 | + colProps: { span: 22 }, | |
| 444 | + component: 'Checkbox', | |
| 445 | + defaultValue: true, | |
| 446 | + renderComponentContent: '禁用或脱机时的通知存储', | |
| 447 | + }, | |
| 448 | + { | |
| 449 | + field: 'serverPublicKey', | |
| 450 | + component: 'InputTextArea', | |
| 451 | + label: '服务器公钥', | |
| 452 | + required: true, | |
| 453 | + colProps: { span: 22 }, | |
| 454 | + componentProps: { | |
| 455 | + maxLength: 255, | |
| 456 | + placeholder: '请输入服务器公钥', | |
| 457 | + }, | |
| 458 | + ifShow: ({ values }) => | |
| 459 | + isCertificate(Reflect.get(values, 'securityMode')) || | |
| 460 | + isPawPublicKey(Reflect.get(values, 'securityMode')), | |
| 461 | + }, | |
| 462 | +]; | ... | ... |
| ... | ... | @@ -6,21 +6,39 @@ |
| 6 | 6 | :animated="true" |
| 7 | 7 | @change="handleChange" |
| 8 | 8 | > |
| 9 | - <TabPane key="1" tab="LWM2M Model"> | |
| 9 | + <TabPane forceRender key="1" tab="LWM2M Model"> | |
| 10 | 10 | <BasicForm :showResetButton="false" :showSubmitButton="false" @register="registerModel" /> |
| 11 | 11 | </TabPane> |
| 12 | - <TabPane key="2" tab="Servers"> | |
| 13 | - <div style="display: flex; width: 43vw; border: 1px solid gray; border-radius: 5px"> | |
| 14 | - <div style="margin-left: -4.6vw; margin-top: 1.5vh"> | |
| 15 | - <BasicForm | |
| 16 | - :showResetButton="false" | |
| 17 | - :showSubmitButton="false" | |
| 18 | - @register="registerServer" | |
| 19 | - /> | |
| 12 | + <TabPane forceRender key="2" tab="Bootstrap"> | |
| 13 | + <div> | |
| 14 | + <Checkbox v-model:checked="bootstrapServerUpdateEnable">包括引导服务器更新</Checkbox> | |
| 15 | + <Card | |
| 16 | + v-for="(item, index) in dynamicBOOTSTRAP.bootstrap" | |
| 17 | + :key="item" | |
| 18 | + title="LwM2M Server" | |
| 19 | + style="width: 99%; margin-top: 2vh" | |
| 20 | + > | |
| 21 | + <template #extra> | |
| 22 | + <Button size="small" type="dashed" @click="handleRemove(index)"> | |
| 23 | + <template #icon> | |
| 24 | + <MinusCircleOutlined /> | |
| 25 | + </template> | |
| 26 | + </Button> | |
| 27 | + </template> | |
| 28 | + <!-- BootStrapForm表单项 --> | |
| 29 | + <BootStrapForm :ref="dynamicBindRef.BootStrapFormItemRef" :index="index" :item="item" /> | |
| 30 | + </Card> | |
| 31 | + <div style="margin-top: 2vh"> | |
| 32 | + <Button size="middle" type="dashed" @click="handleAdd"> | |
| 33 | + <template #icon> | |
| 34 | + <PlusCircleOutlined /> | |
| 35 | + </template> | |
| 36 | + Add LwM2M Server | |
| 37 | + </Button> | |
| 20 | 38 | </div> |
| 21 | 39 | </div> |
| 22 | 40 | </TabPane> |
| 23 | - <TabPane key="3" tab="Other settings"> | |
| 41 | + <TabPane forceRender key="3" tab="Other settings"> | |
| 24 | 42 | <div |
| 25 | 43 | style=" |
| 26 | 44 | display: flex; |
| ... | ... | @@ -39,7 +57,7 @@ |
| 39 | 57 | </div> |
| 40 | 58 | </div> |
| 41 | 59 | </TabPane> |
| 42 | - <TabPane key="4" tab="Json Config Profile Device"> | |
| 60 | + <TabPane forceRender key="4" tab="Json Config Profile Device"> | |
| 43 | 61 | <BasicForm :showResetButton="false" :showSubmitButton="false" @register="registerDevice" /> |
| 44 | 62 | </TabPane> |
| 45 | 63 | </Tabs> |
| ... | ... | @@ -47,10 +65,13 @@ |
| 47 | 65 | </template> |
| 48 | 66 | |
| 49 | 67 | <script lang="ts"> |
| 50 | - import { defineComponent, ref, reactive, nextTick } from 'vue'; | |
| 51 | - import { Tabs } from 'ant-design-vue'; | |
| 68 | + import { defineComponent, ref, reactive, nextTick, unref } from 'vue'; | |
| 69 | + import { Tabs, Card } from 'ant-design-vue'; | |
| 52 | 70 | import { BasicForm, useForm } from '/@/components/Form'; |
| 53 | - import { modelSchemas, serverSchemas, settingsSchemas, deviceSchemas } from './index'; | |
| 71 | + import { modelSchemas, settingsSchemas, deviceSchemas } from './index'; | |
| 72 | + import BootStrapForm from './cpns/BootStrapForm.vue'; | |
| 73 | + import { MinusCircleOutlined, PlusCircleOutlined } from '@ant-design/icons-vue'; | |
| 74 | + import { Button, Checkbox } from 'ant-design-vue'; | |
| 54 | 75 | |
| 55 | 76 | export default defineComponent({ |
| 56 | 77 | name: 'index', |
| ... | ... | @@ -58,18 +79,26 @@ |
| 58 | 79 | Tabs, |
| 59 | 80 | TabPane: Tabs.TabPane, |
| 60 | 81 | BasicForm, |
| 82 | + BootStrapForm, | |
| 83 | + MinusCircleOutlined, | |
| 84 | + Card, | |
| 85 | + PlusCircleOutlined, | |
| 86 | + Button, | |
| 87 | + Checkbox, | |
| 61 | 88 | }, |
| 62 | 89 | setup() { |
| 90 | + const bootstrapServerUpdateEnable = ref(false); | |
| 91 | + const dynamicBOOTSTRAP: any = reactive({ | |
| 92 | + bootstrap: [{}], | |
| 93 | + }); | |
| 94 | + const dynamicBindRef: any = { | |
| 95 | + BootStrapFormItemRef: ref([]), | |
| 96 | + }; | |
| 63 | 97 | const currentKey = ref('1'); |
| 64 | 98 | const currentSize = ref('large'); |
| 65 | 99 | let allObj: any = reactive({}); |
| 66 | 100 | let allEchoObj: any = reactive({}); |
| 67 | 101 | let allEchoStatus = ref(false); |
| 68 | - let bootstrapObj = reactive({ | |
| 69 | - servers: {}, | |
| 70 | - bootstrapServer: {}, | |
| 71 | - lwm2mServer: {}, | |
| 72 | - }); | |
| 73 | 102 | let clientLwM2mSettingsObj = reactive({}); |
| 74 | 103 | let observeAttrObj = reactive({ |
| 75 | 104 | attribute: [], |
| ... | ... | @@ -90,20 +119,6 @@ |
| 90 | 119 | }, |
| 91 | 120 | }); |
| 92 | 121 | const [ |
| 93 | - registerServer, | |
| 94 | - { | |
| 95 | - resetFields: resetServerValue, | |
| 96 | - validate: serverValidate, | |
| 97 | - setFieldsValue: serverSetFieldsValueFunc, | |
| 98 | - }, | |
| 99 | - ] = useForm({ | |
| 100 | - labelWidth: 180, | |
| 101 | - schemas: serverSchemas, | |
| 102 | - actionColOptions: { | |
| 103 | - span: 14, | |
| 104 | - }, | |
| 105 | - }); | |
| 106 | - const [ | |
| 107 | 122 | registerSettings, |
| 108 | 123 | { |
| 109 | 124 | resetFields: resetSettingsValue, |
| ... | ... | @@ -126,6 +141,12 @@ |
| 126 | 141 | }, |
| 127 | 142 | }); |
| 128 | 143 | |
| 144 | + const handleAdd = () => { | |
| 145 | + dynamicBOOTSTRAP.bootstrap.push({}); | |
| 146 | + }; | |
| 147 | + const handleRemove = (index) => { | |
| 148 | + dynamicBOOTSTRAP.bootstrap.splice(index, 1); | |
| 149 | + }; | |
| 129 | 150 | const handleChange = (e) => { |
| 130 | 151 | if (allEchoStatus.value) { |
| 131 | 152 | switch (e) { |
| ... | ... | @@ -133,36 +154,14 @@ |
| 133 | 154 | break; |
| 134 | 155 | case '2': |
| 135 | 156 | nextTick(() => { |
| 136 | - serverSetFieldsValueFunc({ | |
| 137 | - //servers | |
| 138 | - binding: allEchoObj?.bootstrap?.servers?.binding, | |
| 139 | - shortId: allEchoObj?.bootstrap?.servers?.shortId, | |
| 140 | - lifetime: allEchoObj?.bootstrap?.servers?.lifetime, | |
| 141 | - notifIfDisabled: allEchoObj?.bootstrap?.servers?.notifIfDisabled, | |
| 142 | - defaultMinPeriod: allEchoObj?.bootstrap?.servers?.defaultMinPeriod, | |
| 143 | - bootstrapServerAccountTimeout: | |
| 144 | - allEchoObj?.bootstrap?.servers?.bootstrapServerAccountTimeout, | |
| 145 | - //servers | |
| 146 | - //lwm2mServer | |
| 147 | - host1: allEchoObj?.bootstrap?.lwm2mServer?.host, | |
| 148 | - port1: allEchoObj?.bootstrap?.lwm2mServer?.port, | |
| 149 | - serverId1: allEchoObj?.bootstrap?.lwm2mServer?.serverId, | |
| 150 | - securityMode1: allEchoObj?.bootstrap?.lwm2mServer?.securityMode, | |
| 151 | - serverPublicKey1: allEchoObj?.bootstrap?.lwm2mServer?.serverPublicKey, | |
| 152 | - clientHoldOffTime1: allEchoObj?.bootstrap?.lwm2mServer?.clientHoldOffTime, | |
| 153 | - bootstrapServerAccountTimeout1: | |
| 154 | - allEchoObj?.bootstrap?.lwm2mServer?.bootstrapServerAccountTimeout, | |
| 155 | - //lwm2mServer | |
| 156 | - //bootstrapServer | |
| 157 | - host: allEchoObj?.bootstrap?.bootstrapServer?.host, | |
| 158 | - port: allEchoObj?.bootstrap?.bootstrapServer?.port, | |
| 159 | - serverId: allEchoObj?.bootstrap?.bootstrapServer?.serverId, | |
| 160 | - securityMode: allEchoObj?.bootstrap?.bootstrapServer?.securityMode, | |
| 161 | - serverPublicKey: allEchoObj?.bootstrap?.bootstrapServer?.serverPublicKey, | |
| 162 | - clientHoldOffTime: allEchoObj?.bootstrap?.bootstrapServer?.clientHoldOffTime, | |
| 163 | - bootstrapServerAccountTimeout2: | |
| 164 | - allEchoObj?.bootstrap?.servers?.bootstrapServerAccountTimeout, | |
| 165 | - //bootstrapServer | |
| 157 | + bootstrapServerUpdateEnable.value = allEchoObj.bootstrapServerUpdateEnable; | |
| 158 | + dynamicBOOTSTRAP.bootstrap = allEchoObj.bootstrap; | |
| 159 | + dynamicBOOTSTRAP.bootstrap.forEach((bootstrap, index: number) => { | |
| 160 | + nextTick(() => { | |
| 161 | + unref(dynamicBindRef.BootStrapFormItemRef)[index]?.editBootStrapFormFunc( | |
| 162 | + bootstrap | |
| 163 | + ); | |
| 164 | + }); | |
| 166 | 165 | }); |
| 167 | 166 | }); |
| 168 | 167 | break; |
| ... | ... | @@ -196,43 +195,22 @@ |
| 196 | 195 | allEchoStatus.value = true; |
| 197 | 196 | } |
| 198 | 197 | }; |
| 198 | + const tempBootStrap: any = []; | |
| 199 | + const getBootStrapFormValue = () => { | |
| 200 | + //获取BootStrap的值 | |
| 201 | + unref(dynamicBindRef.BootStrapFormItemRef)?.map((item: any) => | |
| 202 | + tempBootStrap.push(item.getBootStrapFormFunc()) | |
| 203 | + ); | |
| 204 | + }; | |
| 199 | 205 | |
| 200 | 206 | const getDataFunc = async () => { |
| 201 | 207 | const objectListVal = getObjectListValue(); |
| 202 | 208 | const deviceVal = getDeviceValue(); |
| 203 | 209 | console.log('第一个tab', objectListVal); |
| 204 | 210 | console.log('第四个tab', deviceVal); |
| 205 | - const serverVal = await serverValidate(); | |
| 211 | + getBootStrapFormValue(); | |
| 206 | 212 | const settingsVal = await settingsValidate(); |
| 207 | - if (!serverVal) return; | |
| 208 | 213 | if (!settingsVal) return; |
| 209 | - Reflect.set(bootstrapObj.servers, 'binding', serverVal.binding); | |
| 210 | - Reflect.set(bootstrapObj.servers, 'shortId', serverVal.shortId); | |
| 211 | - Reflect.set(bootstrapObj.servers, 'lifetime', serverVal.lifetime); | |
| 212 | - Reflect.set(bootstrapObj.servers, 'notifIfDisabled', serverVal.notifIfDisabled); | |
| 213 | - Reflect.set(bootstrapObj.servers, 'defaultMinPeriod', serverVal.defaultMinPeriod); | |
| 214 | - Reflect.set(bootstrapObj.bootstrapServer, 'serverId', serverVal.serverId); | |
| 215 | - Reflect.set(bootstrapObj.bootstrapServer, 'host', serverVal.host); | |
| 216 | - Reflect.set(bootstrapObj.bootstrapServer, 'port', serverVal.port); | |
| 217 | - Reflect.set(bootstrapObj.bootstrapServer, 'securityMode', serverVal.securityMode); | |
| 218 | - Reflect.set(bootstrapObj.bootstrapServer, 'serverPublicKey', serverVal.serverPublicKey); | |
| 219 | - Reflect.set(bootstrapObj.bootstrapServer, 'clientHoldOffTime', serverVal.clientHoldOffTime); | |
| 220 | - Reflect.set( | |
| 221 | - bootstrapObj.servers, | |
| 222 | - 'bootstrapServerAccountTimeout', | |
| 223 | - serverVal.bootstrapServerAccountTimeout2 | |
| 224 | - ); | |
| 225 | - Reflect.set(bootstrapObj.lwm2mServer, 'serverId', serverVal.serverId1); | |
| 226 | - Reflect.set(bootstrapObj.lwm2mServer, 'host', serverVal.host1); | |
| 227 | - Reflect.set(bootstrapObj.lwm2mServer, 'port', serverVal.port1); | |
| 228 | - Reflect.set(bootstrapObj.lwm2mServer, 'securityMode', serverVal.securityMode1); | |
| 229 | - Reflect.set(bootstrapObj.lwm2mServer, 'serverPublicKey', serverVal.serverPublicKey1); | |
| 230 | - Reflect.set(bootstrapObj.lwm2mServer, 'clientHoldOffTime', serverVal.clientHoldOffTime1); | |
| 231 | - Reflect.set( | |
| 232 | - bootstrapObj.lwm2mServer, | |
| 233 | - 'bootstrapServerAccountTimeout', | |
| 234 | - serverVal.bootstrapServerAccountTimeout1 | |
| 235 | - ); | |
| 236 | 214 | delete settingsVal.unit; |
| 237 | 215 | delete settingsVal.unit2; |
| 238 | 216 | clientLwM2mSettingsObj = { |
| ... | ... | @@ -243,8 +221,9 @@ |
| 243 | 221 | clientLwM2mSettings: clientLwM2mSettingsObj, |
| 244 | 222 | }, |
| 245 | 223 | ...{ |
| 246 | - bootstrap: bootstrapObj, | |
| 224 | + bootstrap: tempBootStrap, | |
| 247 | 225 | }, |
| 226 | + ...{ bootstrapServerUpdateEnable: bootstrapServerUpdateEnable.value }, | |
| 248 | 227 | ...{ |
| 249 | 228 | observeAttr: observeAttrObj, |
| 250 | 229 | }, |
| ... | ... | @@ -257,7 +236,6 @@ |
| 257 | 236 | allEchoStatus.value = false; |
| 258 | 237 | nextTick(() => { |
| 259 | 238 | resetObjectListValue(); |
| 260 | - resetServerValue(); | |
| 261 | 239 | resetSettingsValue(); |
| 262 | 240 | resetDeviceValue(); |
| 263 | 241 | }); |
| ... | ... | @@ -267,13 +245,17 @@ |
| 267 | 245 | currentKey, |
| 268 | 246 | currentSize, |
| 269 | 247 | registerModel, |
| 270 | - registerServer, | |
| 271 | 248 | registerSettings, |
| 272 | 249 | registerDevice, |
| 273 | 250 | getDataFunc, |
| 274 | 251 | setStepFieldsValueFunc, |
| 275 | 252 | handleChange, |
| 276 | 253 | resetStepFieldsValueFunc, |
| 254 | + dynamicBOOTSTRAP, | |
| 255 | + dynamicBindRef, | |
| 256 | + handleAdd, | |
| 257 | + handleRemove, | |
| 258 | + bootstrapServerUpdateEnable, | |
| 277 | 259 | }; |
| 278 | 260 | }, |
| 279 | 261 | }); | ... | ... |