bfg-common 1.4.777 → 1.4.779

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 (170) hide show
  1. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  2. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  3. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  4. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  5. package/assets/localization/local_be.json +1 -1
  6. package/assets/localization/local_en.json +1 -1
  7. package/assets/localization/local_hy.json +1 -1
  8. package/assets/localization/local_kk.json +1 -1
  9. package/assets/localization/local_ru.json +1 -1
  10. package/assets/localization/local_zh.json +1 -1
  11. package/assets/scss/clarity/local_ar.json +1 -1
  12. package/assets/scss/common/normalize.scss +361 -361
  13. package/components/atoms/TheIcon3.vue +50 -50
  14. package/components/atoms/modal/bySteps/BySteps.vue +253 -253
  15. package/components/atoms/stack/StackBlock.vue +185 -185
  16. package/components/atoms/table/dataGrid/DataGrid.vue +1703 -1703
  17. package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +222 -222
  18. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +91 -91
  19. package/components/common/browse/BrowseNew.vue +237 -237
  20. package/components/common/browse/BrowseOld.vue +217 -217
  21. package/components/common/browse/blocks/contents/Files.vue +37 -37
  22. package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
  23. package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +96 -96
  24. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  25. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  26. package/components/common/browse/lib/models/interfaces.ts +5 -5
  27. package/components/common/context/Context.vue +111 -111
  28. package/components/common/context/lib/models/interfaces.ts +30 -30
  29. package/components/common/context/recursion/Recursion.vue +87 -87
  30. package/components/common/context/recursion/RecursionNew.vue +237 -237
  31. package/components/common/context/recursion/RecursionOld.vue +227 -227
  32. package/components/common/diagramMain/Header.vue +211 -211
  33. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  34. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  35. package/components/common/diagramMain/lib/models/types.ts +21 -21
  36. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  37. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +330 -330
  38. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  39. package/components/common/diagramMain/modals/editSettings/EditSettings.vue +497 -497
  40. package/components/common/diagramMain/modals/editSettings/EditSettingsModal.vue +812 -812
  41. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  42. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  43. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  44. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  45. package/components/common/diagramMain/modals/editSettings/tabs/TrafficShaping.vue +398 -398
  46. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  47. package/components/common/diagramMain/modals/editSettings/tabs/port/PortProperties.vue +205 -205
  48. package/components/common/diagramMain/modals/lib/config/diagramConfig.ts +23 -23
  49. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  50. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  51. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  52. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  53. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  54. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  55. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  56. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  57. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  58. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  59. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  60. package/components/common/diagramMain/port/Ports.vue +47 -47
  61. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  62. package/components/common/layout/theHeader/helpMenu/aboutNew/AboutNew.vue +103 -103
  63. package/components/common/mainNavigationPanel/MainNavigationPanel.vue +151 -151
  64. package/components/common/mainNavigationPanel/MainNavigationPanelOld.vue +300 -300
  65. package/components/common/modals/confirmByInput/ConfirmByInput.vue +206 -206
  66. package/components/common/modals/unsavedChanges/UnsavedChanges.vue +56 -56
  67. package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModal.vue +250 -250
  68. package/components/common/pages/home/StatusContent.vue +49 -49
  69. package/components/common/pages/home/headline/Headline.vue +44 -44
  70. package/components/common/pages/home/headline/HeadlineNew.vue +71 -71
  71. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  72. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  73. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  74. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  75. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  76. package/components/common/pages/home/widgets/hosts/HostsNew.vue +100 -100
  77. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  78. package/components/common/pages/home/widgets/services/lib/config/config.ts +108 -108
  79. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  80. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  81. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  82. package/components/common/pages/packages/Packages.vue +208 -208
  83. package/components/common/recursionTree/RecursionTree.vue +223 -223
  84. package/components/common/select/button/ButtonDropdown.vue +108 -108
  85. package/components/common/spiceConsole/Drawer.vue +370 -370
  86. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  87. package/components/common/split/horizontal/HorizontalNew.vue +376 -376
  88. package/components/common/split/horizontal/HorizontalOld.vue +337 -337
  89. package/components/common/split/vertical/Vertical.vue +160 -160
  90. package/components/common/vm/actions/add/Add.vue +621 -621
  91. package/components/common/vm/actions/clone/Clone.vue +639 -639
  92. package/components/common/vm/actions/clone/lib/config/steps.ts +129 -129
  93. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +271 -271
  94. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +271 -271
  95. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +174 -174
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +2 -2
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +117 -117
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +161 -161
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +165 -165
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +357 -357
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +44 -44
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +281 -281
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +124 -124
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -95
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +69 -69
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +27 -14
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +84 -84
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  126. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
  127. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +81 -81
  128. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  129. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +56 -56
  130. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  131. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  132. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +104 -104
  133. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  134. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  136. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  137. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +42 -42
  141. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  142. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  143. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  144. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +141 -141
  145. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  146. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  147. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  148. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  149. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  150. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +39 -39
  151. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  152. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  153. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  154. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  155. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +38 -38
  156. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  157. package/components/common/vm/actions/common/select/storage/Storage.vue +130 -130
  158. package/components/common/vm/actions/common/select/storage/StorageOld.vue +129 -129
  159. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  160. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  161. package/composables/productNameLocal.ts +30 -30
  162. package/composables/useAppVersion.ts +21 -21
  163. package/package.json +1 -1
  164. package/plugins/date.ts +233 -233
  165. package/plugins/recursion.ts +311 -311
  166. package/public/spice-console/lib/images/bitmap.js +203 -203
  167. package/public/spice-console/network/spicechannel.js +383 -383
  168. package/store/main/mutations.ts +7 -7
  169. package/store/main/state.ts +7 -7
  170. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,205 +1,205 @@
1
- <template>
2
- <div class="wizard-content__container">
3
- <div class="wizard-content wizard-content-port">
4
- <atoms-alert
5
- v-if="isShowErrorMessage"
6
- status="alert-danger"
7
- :items="validationMessagesArray"
8
- test-id="port-properties-alert"
9
- @remove="onHideErrorMessageAlert"
10
- />
11
- <form id="port-properties-form">
12
- <b class="property-label-group">
13
- {{ localization.common.vmKernelPortSettings }}
14
- </b>
15
- <div class="horizontal-flex-container">
16
- <label class="property-label-group">
17
- {{ localization.common.tcpIpStack }}
18
- </label>
19
- <div class="margin-left-property-value-group">
20
- <div class="property-value-group">
21
- {{ localization.common[fieldsValues.tcpIp] }}
22
- </div>
23
- </div>
24
- </div>
25
- <div class="horizontal-flex-container">
26
- <label class="property-label-group">
27
- {{ localization.common.mtu }}
28
- </label>
29
- <div class="margin-left-property-value-group">
30
- <div class="property-value-group tooltip-field-container">
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
- </div>
53
- </div>
54
- </div>
55
-
56
- <div class="edit-vmkernel-adapter-section">
57
- <b class="property-label-group">
58
- {{ localization.common.availableServices }}
59
- </b>
60
- <template
61
- v-for="(enabledService, key) in portPropertiesEnabledServices"
62
- :key="enabledService.modelValue"
63
- >
64
- <div class="horizontal-flex-container">
65
- <label class="property-label-group">
66
- {{ enabledService.mainLabel }}
67
- </label>
68
- <div class="margin-left-property-value-group">
69
- <div class="property-value-group tooltip-field-container">
70
- <label>
71
- <input
72
- :id="`property-value-group-${key}`"
73
- v-model="fieldsValues.services[enabledService.modelValue]"
74
- :data-id="enabledService.testId"
75
- type="checkbox"
76
- />
77
- {{ enabledService.label }}
78
- </label>
79
- </div>
80
- </div>
81
- </div>
82
- </template>
83
- </div>
84
- </form>
85
- </div>
86
- </div>
87
- </template>
88
-
89
- <script setup lang="ts">
90
- import type { UI_I_Localization } from '~/lib/models/interfaces'
91
- import {
92
- UI_I_PortPropertiesFields,
93
- UI_I_ModalsInitialData,
94
- UI_I_EditSettingsErrorMessage,
95
- } from '~/components/common/diagramMain/lib/models/interfaces'
96
- import type { UI_T_PortPropertiesFieldName } from '~/components/common/diagramMain/lib/models/types'
97
- import { portPropertiesEnabledServicesFunc } from '~/components/common/diagramMain/modals/lib/config'
98
- import { validationMessagesArrayFunc } from '~/components/common/diagramMain/modals/lib/utils'
99
-
100
- // Props from up
101
- const props = withDefaults(
102
- defineProps<{
103
- isShowErrorMessageAlert: boolean
104
- initialData?: UI_I_ModalsInitialData
105
- errorMessages: UI_I_EditSettingsErrorMessage
106
- hasErrorMessages?: boolean
107
- }>(),
108
- {
109
- initialData: () => ({}),
110
- }
111
- )
112
-
113
- const validationMessagesArray = computed(() =>
114
- validationMessagesArrayFunc(['mtu'], props.errorMessages)
115
- )
116
-
117
- // UI_I_Localization
118
- const localization = computed<UI_I_Localization>(() => useLocal())
119
-
120
- // Enabled services data with localization
121
- const portPropertiesEnabledServices = computed(() =>
122
- portPropertiesEnabledServicesFunc(localization.value)
123
- )
124
-
125
- // For showing component validation errors on the top of modal
126
- const isShowErrorMessage = computed<boolean>(
127
- () => props.isShowErrorMessageAlert && props.hasErrorMessages
128
- )
129
-
130
- const fieldsValues = ref<UI_I_PortPropertiesFields>(
131
- useDeepCopy({
132
- tcpIp: props.initialData.tcpIp,
133
- mtu: props.initialData.mtu,
134
- services: props.initialData.services,
135
- }) as UI_I_PortPropertiesFields
136
- )
137
-
138
- // Validation
139
- const emits = defineEmits<{
140
- (
141
- event: 'change-error-messages',
142
- errorMessage: string,
143
- fieldName: keyof UI_I_EditSettingsErrorMessage
144
- ): void
145
- (event: 'hide-error-message-alert'): void
146
- (
147
- event: 'change-port-edit-properties-data',
148
- newPortEditPropertiesData: UI_I_PortPropertiesFields
149
- ): void
150
- }>()
151
-
152
- const onHideErrorMessageAlert = (): void => emits('hide-error-message-alert')
153
-
154
- const onChangeData = (data: UI_I_PortPropertiesFields): void =>
155
- emits('change-port-edit-properties-data', data)
156
-
157
- const changeErrorMessage = (
158
- errorMessage: string,
159
- fieldName: keyof UI_I_EditSettingsErrorMessage
160
- ) => emits('change-error-messages', errorMessage, fieldName)
161
-
162
- const messageTexts = (local: UI_I_Localization) => ({
163
- mtu: local.mtuInvalidError,
164
- })
165
-
166
- const setMessageOnChangedField = (
167
- values: number[],
168
- index: number,
169
- name: UI_T_PortPropertiesFieldName,
170
- text: string
171
- ) => {
172
- if (values[index] >= 1280 && values[index] <= 65535) {
173
- changeErrorMessage('', name)
174
- } else {
175
- changeErrorMessage(text, name)
176
- }
177
- }
178
-
179
- watch(
180
- fieldsValues,
181
- (newValues: UI_I_PortPropertiesFields): void => {
182
- setMessageOnChangedField(
183
- [newValues.mtu],
184
- 0,
185
- 'mtu',
186
- messageTexts(localization.value).mtu
187
- )
188
- onChangeData(newValues)
189
- !props.hasErrorMessages && onHideErrorMessageAlert()
190
- },
191
- {
192
- deep: true,
193
- }
194
- )
195
-
196
- onMounted(() => {
197
- onChangeData(fieldsValues.value)
198
- })
199
-
200
- onUnmounted((): void => {
201
- onHideErrorMessageAlert()
202
- })
203
- </script>
204
-
205
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <div class="wizard-content__container">
3
+ <div class="wizard-content wizard-content-port">
4
+ <atoms-alert
5
+ v-if="isShowErrorMessage"
6
+ status="alert-danger"
7
+ :items="validationMessagesArray"
8
+ test-id="port-properties-alert"
9
+ @remove="onHideErrorMessageAlert"
10
+ />
11
+ <form id="port-properties-form">
12
+ <b class="property-label-group">
13
+ {{ localization.common.vmKernelPortSettings }}
14
+ </b>
15
+ <div class="horizontal-flex-container">
16
+ <label class="property-label-group">
17
+ {{ localization.common.tcpIpStack }}
18
+ </label>
19
+ <div class="margin-left-property-value-group">
20
+ <div class="property-value-group">
21
+ {{ localization.common[fieldsValues.tcpIp] }}
22
+ </div>
23
+ </div>
24
+ </div>
25
+ <div class="horizontal-flex-container">
26
+ <label class="property-label-group">
27
+ {{ localization.common.mtu }}
28
+ </label>
29
+ <div class="margin-left-property-value-group">
30
+ <div class="property-value-group tooltip-field-container">
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
+ </div>
53
+ </div>
54
+ </div>
55
+
56
+ <div class="edit-vmkernel-adapter-section">
57
+ <b class="property-label-group">
58
+ {{ localization.common.availableServices }}
59
+ </b>
60
+ <template
61
+ v-for="(enabledService, key) in portPropertiesEnabledServices"
62
+ :key="enabledService.modelValue"
63
+ >
64
+ <div class="horizontal-flex-container">
65
+ <label class="property-label-group">
66
+ {{ enabledService.mainLabel }}
67
+ </label>
68
+ <div class="margin-left-property-value-group">
69
+ <div class="property-value-group tooltip-field-container">
70
+ <label>
71
+ <input
72
+ :id="`property-value-group-${key}`"
73
+ v-model="fieldsValues.services[enabledService.modelValue]"
74
+ :data-id="enabledService.testId"
75
+ type="checkbox"
76
+ />
77
+ {{ enabledService.label }}
78
+ </label>
79
+ </div>
80
+ </div>
81
+ </div>
82
+ </template>
83
+ </div>
84
+ </form>
85
+ </div>
86
+ </div>
87
+ </template>
88
+
89
+ <script setup lang="ts">
90
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
91
+ import {
92
+ UI_I_PortPropertiesFields,
93
+ UI_I_ModalsInitialData,
94
+ UI_I_EditSettingsErrorMessage,
95
+ } from '~/components/common/diagramMain/lib/models/interfaces'
96
+ import type { UI_T_PortPropertiesFieldName } from '~/components/common/diagramMain/lib/models/types'
97
+ import { portPropertiesEnabledServicesFunc } from '~/components/common/diagramMain/modals/lib/config'
98
+ import { validationMessagesArrayFunc } from '~/components/common/diagramMain/modals/lib/utils'
99
+
100
+ // Props from up
101
+ const props = withDefaults(
102
+ defineProps<{
103
+ isShowErrorMessageAlert: boolean
104
+ initialData?: UI_I_ModalsInitialData
105
+ errorMessages: UI_I_EditSettingsErrorMessage
106
+ hasErrorMessages?: boolean
107
+ }>(),
108
+ {
109
+ initialData: () => ({}),
110
+ }
111
+ )
112
+
113
+ const validationMessagesArray = computed(() =>
114
+ validationMessagesArrayFunc(['mtu'], props.errorMessages)
115
+ )
116
+
117
+ // UI_I_Localization
118
+ const localization = computed<UI_I_Localization>(() => useLocal())
119
+
120
+ // Enabled services data with localization
121
+ const portPropertiesEnabledServices = computed(() =>
122
+ portPropertiesEnabledServicesFunc(localization.value)
123
+ )
124
+
125
+ // For showing component validation errors on the top of modal
126
+ const isShowErrorMessage = computed<boolean>(
127
+ () => props.isShowErrorMessageAlert && props.hasErrorMessages
128
+ )
129
+
130
+ const fieldsValues = ref<UI_I_PortPropertiesFields>(
131
+ useDeepCopy({
132
+ tcpIp: props.initialData.tcpIp,
133
+ mtu: props.initialData.mtu,
134
+ services: props.initialData.services,
135
+ }) as UI_I_PortPropertiesFields
136
+ )
137
+
138
+ // Validation
139
+ const emits = defineEmits<{
140
+ (
141
+ event: 'change-error-messages',
142
+ errorMessage: string,
143
+ fieldName: keyof UI_I_EditSettingsErrorMessage
144
+ ): void
145
+ (event: 'hide-error-message-alert'): void
146
+ (
147
+ event: 'change-port-edit-properties-data',
148
+ newPortEditPropertiesData: UI_I_PortPropertiesFields
149
+ ): void
150
+ }>()
151
+
152
+ const onHideErrorMessageAlert = (): void => emits('hide-error-message-alert')
153
+
154
+ const onChangeData = (data: UI_I_PortPropertiesFields): void =>
155
+ emits('change-port-edit-properties-data', data)
156
+
157
+ const changeErrorMessage = (
158
+ errorMessage: string,
159
+ fieldName: keyof UI_I_EditSettingsErrorMessage
160
+ ) => emits('change-error-messages', errorMessage, fieldName)
161
+
162
+ const messageTexts = (local: UI_I_Localization) => ({
163
+ mtu: local.mtuInvalidError,
164
+ })
165
+
166
+ const setMessageOnChangedField = (
167
+ values: number[],
168
+ index: number,
169
+ name: UI_T_PortPropertiesFieldName,
170
+ text: string
171
+ ) => {
172
+ if (values[index] >= 1280 && values[index] <= 65535) {
173
+ changeErrorMessage('', name)
174
+ } else {
175
+ changeErrorMessage(text, name)
176
+ }
177
+ }
178
+
179
+ watch(
180
+ fieldsValues,
181
+ (newValues: UI_I_PortPropertiesFields): void => {
182
+ setMessageOnChangedField(
183
+ [newValues.mtu],
184
+ 0,
185
+ 'mtu',
186
+ messageTexts(localization.value).mtu
187
+ )
188
+ onChangeData(newValues)
189
+ !props.hasErrorMessages && onHideErrorMessageAlert()
190
+ },
191
+ {
192
+ deep: true,
193
+ }
194
+ )
195
+
196
+ onMounted(() => {
197
+ onChangeData(fieldsValues.value)
198
+ })
199
+
200
+ onUnmounted((): void => {
201
+ onHideErrorMessageAlert()
202
+ })
203
+ </script>
204
+
205
+ <style scoped lang="scss"></style>
@@ -1,23 +1,23 @@
1
- import type { UI_I_Localization } from '~/lib/models/interfaces'
2
- import type { UI_I_NavigationItem } from '~/components/common/diagramMain/lib/models/interfaces'
3
-
4
- export const switchMainNavigationFunc = (
5
- localization: UI_I_Localization,
6
- testId: string
7
- ): UI_I_NavigationItem[] => [
8
- {
9
- text: localization.common.migrateVmKernelAdapter,
10
- value: 'migrate-vmkernel-adapter',
11
- testId: `${testId}-migrate-vm-kernel-adapter`,
12
- },
13
- {
14
- text: localization.common.viewSettings,
15
- value: 'switch-view-settings',
16
- testId: `${testId}-view-settings`,
17
- },
18
- {
19
- text: localization.common.remove,
20
- value: 'switch-remove',
21
- testId: `${testId}-remove`,
22
- },
23
- ]
1
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
2
+ import type { UI_I_NavigationItem } from '~/components/common/diagramMain/lib/models/interfaces'
3
+
4
+ export const switchMainNavigationFunc = (
5
+ localization: UI_I_Localization,
6
+ testId: string
7
+ ): UI_I_NavigationItem[] => [
8
+ {
9
+ text: localization.common.migrateVmKernelAdapter,
10
+ value: 'migrate-vmkernel-adapter',
11
+ testId: `${testId}-migrate-vm-kernel-adapter`,
12
+ },
13
+ {
14
+ text: localization.common.viewSettings,
15
+ value: 'switch-view-settings',
16
+ testId: `${testId}-view-settings`,
17
+ },
18
+ {
19
+ text: localization.common.remove,
20
+ value: 'switch-remove',
21
+ testId: `${testId}-remove`,
22
+ },
23
+ ]