bfg-common 1.5.152 → 1.5.154

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 (150) 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/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/perPage/PerPage.vue +58 -58
  8. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  9. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  10. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  11. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  12. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  13. package/components/common/browse/lib/models/interfaces.ts +5 -5
  14. package/components/common/context/lib/models/interfaces.ts +31 -31
  15. package/components/common/context/recursion/RecursionNew.vue +238 -238
  16. package/components/common/diagramMain/DiagramMain.vue +897 -897
  17. package/components/common/diagramMain/Header.vue +214 -214
  18. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  19. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  20. package/components/common/diagramMain/lib/models/types.ts +21 -21
  21. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  22. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  23. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  24. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  25. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  26. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  27. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  28. package/components/common/diagramMain/modals/editSettings/tabs/port/PortProperties.vue +205 -205
  29. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  30. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  31. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  32. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  33. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  34. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  35. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  36. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  37. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  38. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  39. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  40. package/components/common/diagramMain/port/Ports.vue +47 -47
  41. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  42. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  43. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  44. package/components/common/pages/home/headline/Headline.vue +45 -45
  45. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  46. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  47. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  48. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  49. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  50. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  51. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  52. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  53. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  54. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  55. package/components/common/pages/packages/Packages.vue +208 -208
  56. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  57. package/components/common/readyToComplete/New.vue +66 -66
  58. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  59. package/components/common/recursionTree/RecursionTree.vue +223 -223
  60. package/components/common/select/button/ButtonDropdown.vue +108 -108
  61. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  62. package/components/common/vm/actions/add/Add.vue +785 -785
  63. package/components/common/vm/actions/add/New.vue +556 -556
  64. package/components/common/vm/actions/add/Old.vue +371 -371
  65. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  66. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  67. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  68. package/components/common/vm/actions/add/lib/config/steps.ts +263 -263
  69. package/components/common/vm/actions/clone/Clone.vue +801 -801
  70. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  71. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +626 -626
  72. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +99 -99
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +373 -373
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +149 -149
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +74 -74
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +83 -83
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  103. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  104. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  105. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  106. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  107. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  108. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  109. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  110. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  111. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  112. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  113. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  114. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  115. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  116. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  117. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  118. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  119. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +134 -134
  120. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  121. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  122. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  123. package/components/common/vm/actions/common/select/createType/New.vue +84 -84
  124. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  125. package/components/common/vm/actions/common/select/name/Name.vue +167 -167
  126. package/components/common/vm/actions/common/select/os/New.vue +122 -122
  127. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  128. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  129. package/components/common/vm/actions/common/select/storage/Storage.vue +131 -131
  130. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +326 -326
  131. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  132. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  133. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  134. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +104 -105
  135. package/components/common/wizards/vm/migrate/Migrate.vue +343 -343
  136. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  137. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  138. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  139. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +137 -137
  140. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  141. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  142. package/composables/productNameLocal.ts +30 -30
  143. package/composables/useAppVersion.ts +21 -21
  144. package/package.json +1 -1
  145. package/plugins/date.ts +233 -233
  146. package/public/spice-console/lib/images/bitmap.js +203 -203
  147. package/public/spice-console/network/spicechannel.js +383 -383
  148. package/store/main/mutations.ts +7 -7
  149. package/store/main/state.ts +7 -7
  150. 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>