bfg-common 1.5.260 → 1.5.261

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (160) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/assets/localization/local_be.json +7 -3
  7. package/assets/localization/local_en.json +7 -3
  8. package/assets/localization/local_hy.json +7 -3
  9. package/assets/localization/local_kk.json +7 -3
  10. package/assets/localization/local_ru.json +7 -3
  11. package/assets/localization/local_zh.json +7 -3
  12. package/assets/scss/clarity/local_ar.json +2 -1
  13. package/components/atoms/TheIcon3.vue +50 -50
  14. package/components/atoms/perPage/PerPage.vue +58 -58
  15. package/components/atoms/table/dataGrid/DataGrid.vue +1717 -1717
  16. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  17. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  18. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  19. package/components/common/backup/storage/actions/add/Add.vue +250 -250
  20. package/components/common/backup/storage/actions/add/Old.vue +116 -116
  21. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  22. package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +52 -52
  23. package/components/common/backup/storage/actions/add/steps/name/New.vue +102 -102
  24. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigure.vue +42 -42
  25. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  26. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyCompleteNew.vue +160 -160
  27. package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +243 -243
  28. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  29. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  30. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  31. package/components/common/browse/lib/models/interfaces.ts +5 -5
  32. package/components/common/context/lib/models/interfaces.ts +31 -31
  33. package/components/common/diagramMain/DiagramMain.vue +897 -897
  34. package/components/common/diagramMain/Header.vue +214 -214
  35. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  36. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  37. package/components/common/diagramMain/lib/models/types.ts +21 -21
  38. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  39. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  40. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  41. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  42. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  43. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  44. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  45. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  46. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  47. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  48. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  49. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  50. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  51. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  52. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  53. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  54. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  55. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  56. package/components/common/diagramMain/port/Ports.vue +47 -47
  57. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  58. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  59. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  60. package/components/common/pages/home/headline/Headline.vue +45 -45
  61. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  62. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  63. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  64. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  65. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  66. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  67. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  68. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  69. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  70. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  71. package/components/common/pages/packages/Packages.vue +208 -208
  72. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  73. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  74. package/components/common/recursionTree/RecursionTree.vue +223 -223
  75. package/components/common/select/button/ButtonDropdown.vue +108 -108
  76. package/components/common/spiceConsole/Drawer.vue +377 -377
  77. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  78. package/components/common/vm/actions/add/Add.vue +823 -823
  79. package/components/common/vm/actions/add/Old.vue +382 -382
  80. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  81. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  82. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  83. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  84. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -321
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -385
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +75 -75
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +40 -40
  116. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  117. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  118. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  119. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  120. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +31 -31
  121. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +31 -31
  122. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  123. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  124. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +128 -128
  125. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  127. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  128. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  129. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  130. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  131. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  132. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  133. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  134. package/components/common/vm/actions/common/select/name/Name.vue +174 -174
  135. package/components/common/vm/actions/common/select/name/Old.vue +1 -1
  136. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  137. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  138. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  139. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  140. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  141. package/components/common/vmt/actions/add/Add.vue +641 -0
  142. package/components/common/vmt/actions/add/lib/config/steps.ts +107 -0
  143. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -0
  144. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  145. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  146. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  147. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +135 -135
  148. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  149. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  150. package/composables/productNameLocal.ts +30 -30
  151. package/composables/useAppVersion.ts +21 -21
  152. package/package.json +1 -1
  153. package/plugins/date.ts +233 -233
  154. package/plugins/panelStates.ts +70 -70
  155. package/plugins/text.ts +59 -59
  156. package/public/spice-console/lib/images/bitmap.js +203 -203
  157. package/public/spice-console/network/spicechannel.js +387 -387
  158. package/store/main/mutations.ts +7 -7
  159. package/store/main/state.ts +7 -7
  160. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,163 +1,163 @@
1
- <template>
2
- <div class="wizard-content__container">
3
- <div class="wizard-content">
4
- <atoms-alert
5
- v-if="isShowErrorMessage"
6
- status="alert-danger"
7
- :items="validationMessagesArray"
8
- test-id="switch-properties-alert"
9
- @remove="onHideErrorMessageAlert"
10
- />
11
- <form id="switch-properties-form">
12
- <div class="horizontal-flex-container">
13
- <label class="property-label-group" for="network-label">
14
- {{ localization.common.numberOfPorts }}
15
- </label>
16
- <div class="margin-left-property-value-group">
17
- <div class="property-value-group">
18
- <fieldset>
19
- {{ props.initialData.num_ports }}
20
- </fieldset>
21
- </div>
22
- </div>
23
- </div>
24
- <div class="horizontal-flex-container">
25
- <label class="property-label-group">
26
- {{ localization.common.mtuBytes }}
27
- </label>
28
- <div class="margin-left-property-value-group">
29
- <div class="property-value-group tooltip-field-container">
30
- <fieldset>
31
- <atoms-tooltip-error :has-error="!!props.errorMessages.mtu">
32
- <template #elem>
33
- <input
34
- id="mtu"
35
- v-model="fieldsValues.mtu"
36
- data-id="mtu-input"
37
- type="number"
38
- name="mtu"
39
- :class="[
40
- 'tooltip-field',
41
- {
42
- 'danger-not-valid': props.errorMessages.mtu,
43
- },
44
- ]"
45
- @click.stop
46
- />
47
- </template>
48
- <template #content>
49
- {{ props.errorMessages.mtu }}
50
- </template>
51
- </atoms-tooltip-error>
52
- </fieldset>
53
- </div>
54
- </div>
55
- </div>
56
- </form>
57
- </div>
58
- </div>
59
- </template>
60
-
61
- <script setup lang="ts">
62
- import type { UI_I_Localization } from '~/lib/models/interfaces'
63
- import type {
64
- UI_I_SwitchPropertiesFields,
65
- UI_I_EditSettingsErrorMessage,
66
- UI_I_ModalsInitialData,
67
- } from '~/components/common/diagramMain/lib/models/interfaces'
68
- import type { UI_T_PortPropertiesFieldName } from '~/components/common/diagramMain/lib/models/types'
69
- import { validationMessagesArrayFunc } from '~/components/common/diagramMain/modals/lib/utils'
70
-
71
- // Props from up
72
- const props = withDefaults(
73
- defineProps<{
74
- isShowErrorMessageAlert: boolean
75
- initialData?: UI_I_ModalsInitialData
76
- errorMessages: UI_I_EditSettingsErrorMessage
77
- hasErrorMessages?: boolean
78
- }>(),
79
- {
80
- initialData: () => ({}),
81
- }
82
- )
83
-
84
- const validationMessagesArray = computed(() =>
85
- validationMessagesArrayFunc(['mtu'], props.errorMessages)
86
- )
87
-
88
- // UI_I_Localization
89
- const localization = computed<UI_I_Localization>(() => useLocal())
90
-
91
- // For showing component validation errors on the top of modal
92
- const isShowErrorMessage = computed<boolean>(
93
- () => props.isShowErrorMessageAlert && props.hasErrorMessages
94
- )
95
-
96
- const fieldsValues = ref<UI_I_SwitchPropertiesFields>({
97
- mtu: props.initialData.mtu || 0,
98
- num_ports: props.initialData.num_ports || '',
99
- })
100
-
101
- // Validation
102
- const emits = defineEmits<{
103
- (
104
- event: 'change-error-messages',
105
- errorMessage: string,
106
- fieldName: keyof UI_I_EditSettingsErrorMessage
107
- ): void
108
- (event: 'hide-error-message-alert'): void
109
- (
110
- event: 'change-edit-properties-data',
111
- switchPropertiesData: UI_I_SwitchPropertiesFields
112
- ): void
113
- }>()
114
-
115
- const onHideErrorMessageAlert = () => emits('hide-error-message-alert')
116
- const onChangeData = (data: UI_I_SwitchPropertiesFields) =>
117
- emits('change-edit-properties-data', data)
118
-
119
- const changeErrorMessage = (
120
- errorMessage: string,
121
- fieldName: keyof UI_I_EditSettingsErrorMessage
122
- ) => emits('change-error-messages', errorMessage, fieldName)
123
-
124
- const messageTexts = (local: UI_I_Localization) => ({
125
- mtu: local.common.mtuInvalidMessage,
126
- })
127
-
128
- const setMessageOnChangedField = (
129
- values: number,
130
- name: UI_T_PortPropertiesFieldName,
131
- text: string
132
- ) => {
133
- if (values < 1280 || values > 65535) {
134
- changeErrorMessage(text, name)
135
- return
136
- }
137
- changeErrorMessage('', name)
138
- }
139
-
140
- watch(
141
- fieldsValues,
142
- (newValues: UI_I_SwitchPropertiesFields) => {
143
- setMessageOnChangedField(
144
- newValues.mtu,
145
- 'mtu',
146
- messageTexts(localization.value).mtu
147
- )
148
- onChangeData(newValues)
149
- !props.hasErrorMessages && onHideErrorMessageAlert()
150
- },
151
- {
152
- deep: true,
153
- }
154
- )
155
-
156
- onMounted(() => {
157
- onChangeData(fieldsValues.value)
158
- })
159
-
160
- onUnmounted(() => {
161
- onHideErrorMessageAlert()
162
- })
163
- </script>
1
+ <template>
2
+ <div class="wizard-content__container">
3
+ <div class="wizard-content">
4
+ <atoms-alert
5
+ v-if="isShowErrorMessage"
6
+ status="alert-danger"
7
+ :items="validationMessagesArray"
8
+ test-id="switch-properties-alert"
9
+ @remove="onHideErrorMessageAlert"
10
+ />
11
+ <form id="switch-properties-form">
12
+ <div class="horizontal-flex-container">
13
+ <label class="property-label-group" for="network-label">
14
+ {{ localization.common.numberOfPorts }}
15
+ </label>
16
+ <div class="margin-left-property-value-group">
17
+ <div class="property-value-group">
18
+ <fieldset>
19
+ {{ props.initialData.num_ports }}
20
+ </fieldset>
21
+ </div>
22
+ </div>
23
+ </div>
24
+ <div class="horizontal-flex-container">
25
+ <label class="property-label-group">
26
+ {{ localization.common.mtuBytes }}
27
+ </label>
28
+ <div class="margin-left-property-value-group">
29
+ <div class="property-value-group tooltip-field-container">
30
+ <fieldset>
31
+ <atoms-tooltip-error :has-error="!!props.errorMessages.mtu">
32
+ <template #elem>
33
+ <input
34
+ id="mtu"
35
+ v-model="fieldsValues.mtu"
36
+ data-id="mtu-input"
37
+ type="number"
38
+ name="mtu"
39
+ :class="[
40
+ 'tooltip-field',
41
+ {
42
+ 'danger-not-valid': props.errorMessages.mtu,
43
+ },
44
+ ]"
45
+ @click.stop
46
+ />
47
+ </template>
48
+ <template #content>
49
+ {{ props.errorMessages.mtu }}
50
+ </template>
51
+ </atoms-tooltip-error>
52
+ </fieldset>
53
+ </div>
54
+ </div>
55
+ </div>
56
+ </form>
57
+ </div>
58
+ </div>
59
+ </template>
60
+
61
+ <script setup lang="ts">
62
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
63
+ import type {
64
+ UI_I_SwitchPropertiesFields,
65
+ UI_I_EditSettingsErrorMessage,
66
+ UI_I_ModalsInitialData,
67
+ } from '~/components/common/diagramMain/lib/models/interfaces'
68
+ import type { UI_T_PortPropertiesFieldName } from '~/components/common/diagramMain/lib/models/types'
69
+ import { validationMessagesArrayFunc } from '~/components/common/diagramMain/modals/lib/utils'
70
+
71
+ // Props from up
72
+ const props = withDefaults(
73
+ defineProps<{
74
+ isShowErrorMessageAlert: boolean
75
+ initialData?: UI_I_ModalsInitialData
76
+ errorMessages: UI_I_EditSettingsErrorMessage
77
+ hasErrorMessages?: boolean
78
+ }>(),
79
+ {
80
+ initialData: () => ({}),
81
+ }
82
+ )
83
+
84
+ const validationMessagesArray = computed(() =>
85
+ validationMessagesArrayFunc(['mtu'], props.errorMessages)
86
+ )
87
+
88
+ // UI_I_Localization
89
+ const localization = computed<UI_I_Localization>(() => useLocal())
90
+
91
+ // For showing component validation errors on the top of modal
92
+ const isShowErrorMessage = computed<boolean>(
93
+ () => props.isShowErrorMessageAlert && props.hasErrorMessages
94
+ )
95
+
96
+ const fieldsValues = ref<UI_I_SwitchPropertiesFields>({
97
+ mtu: props.initialData.mtu || 0,
98
+ num_ports: props.initialData.num_ports || '',
99
+ })
100
+
101
+ // Validation
102
+ const emits = defineEmits<{
103
+ (
104
+ event: 'change-error-messages',
105
+ errorMessage: string,
106
+ fieldName: keyof UI_I_EditSettingsErrorMessage
107
+ ): void
108
+ (event: 'hide-error-message-alert'): void
109
+ (
110
+ event: 'change-edit-properties-data',
111
+ switchPropertiesData: UI_I_SwitchPropertiesFields
112
+ ): void
113
+ }>()
114
+
115
+ const onHideErrorMessageAlert = () => emits('hide-error-message-alert')
116
+ const onChangeData = (data: UI_I_SwitchPropertiesFields) =>
117
+ emits('change-edit-properties-data', data)
118
+
119
+ const changeErrorMessage = (
120
+ errorMessage: string,
121
+ fieldName: keyof UI_I_EditSettingsErrorMessage
122
+ ) => emits('change-error-messages', errorMessage, fieldName)
123
+
124
+ const messageTexts = (local: UI_I_Localization) => ({
125
+ mtu: local.common.mtuInvalidMessage,
126
+ })
127
+
128
+ const setMessageOnChangedField = (
129
+ values: number,
130
+ name: UI_T_PortPropertiesFieldName,
131
+ text: string
132
+ ) => {
133
+ if (values < 1280 || values > 65535) {
134
+ changeErrorMessage(text, name)
135
+ return
136
+ }
137
+ changeErrorMessage('', name)
138
+ }
139
+
140
+ watch(
141
+ fieldsValues,
142
+ (newValues: UI_I_SwitchPropertiesFields) => {
143
+ setMessageOnChangedField(
144
+ newValues.mtu,
145
+ 'mtu',
146
+ messageTexts(localization.value).mtu
147
+ )
148
+ onChangeData(newValues)
149
+ !props.hasErrorMessages && onHideErrorMessageAlert()
150
+ },
151
+ {
152
+ deep: true,
153
+ }
154
+ )
155
+
156
+ onMounted(() => {
157
+ onChangeData(fieldsValues.value)
158
+ })
159
+
160
+ onUnmounted(() => {
161
+ onHideErrorMessageAlert()
162
+ })
163
+ </script>