bfg-common 1.5.294 → 1.5.295

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 (124) 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/DataGrid.vue +1717 -1717
  9. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  10. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  11. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  12. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  13. package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +52 -52
  14. package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigure.vue +42 -42
  15. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  16. package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +243 -243
  17. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  18. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  19. package/components/common/context/lib/models/interfaces.ts +31 -31
  20. package/components/common/diagramMain/DiagramMain.vue +897 -897
  21. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  22. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  23. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  24. package/components/common/pages/home/headline/Headline.vue +45 -45
  25. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  26. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  27. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  28. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  29. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  30. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  31. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  32. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  33. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  34. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  35. package/components/common/pages/packages/Packages.vue +208 -208
  36. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  37. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  38. package/components/common/recursionTree/RecursionTree.vue +223 -223
  39. package/components/common/select/button/ButtonDropdown.vue +108 -108
  40. package/components/common/spiceConsole/Drawer.vue +377 -377
  41. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  42. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  43. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  44. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  45. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  46. package/components/common/vm/actions/clone/Clone.vue +817 -817
  47. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  48. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  49. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -321
  50. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +227 -227
  51. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  52. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  53. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  54. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +1 -0
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -385
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +154 -154
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  81. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +152 -147
  82. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +128 -122
  83. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +111 -97
  84. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  85. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  86. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  87. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +83 -77
  88. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +8 -3
  89. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +154 -143
  90. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  91. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -43
  92. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  93. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  94. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  95. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  96. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  97. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  98. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  99. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  100. package/components/common/vm/actions/common/select/name/Name.vue +174 -174
  101. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  102. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  103. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  104. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  105. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  106. package/components/common/vmt/actions/add/Add.vue +641 -641
  107. package/components/common/vmt/actions/add/lib/config/steps.ts +107 -107
  108. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
  109. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  110. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  111. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  112. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  113. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  114. package/composables/productNameLocal.ts +30 -30
  115. package/composables/useAppVersion.ts +21 -21
  116. package/package.json +1 -1
  117. package/plugins/date.ts +233 -233
  118. package/plugins/panelStates.ts +70 -70
  119. package/plugins/text.ts +59 -59
  120. package/public/spice-console/lib/images/bitmap.js +203 -203
  121. package/public/spice-console/network/spicechannel.js +387 -387
  122. package/store/main/mutations.ts +7 -7
  123. package/store/main/state.ts +7 -7
  124. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,94 +1,94 @@
1
- import type {
2
- UI_I_DataTableBody,
3
- UI_I_DataTableOptions,
4
- UI_I_DataTableHeader,
5
- } from '~/node_modules/bfg-uikit/components/ui/dataTable/models/interfaces'
6
- import type { UI_I_Localization, UI_I_State } from '~/lib/models/interfaces'
7
- import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
8
- import { networkIconByState } from '~/components/common/lib/config/states'
9
-
10
- export const getHeaderDataFunc = (
11
- localization: UI_I_Localization
12
- ): UI_I_DataTableHeader[] => [
13
- {
14
- col: 0,
15
- colName: 'name',
16
- text: localization.common.name,
17
- isSortable: true,
18
- sort: 'asc',
19
- sortColumn: true,
20
- width: '180px',
21
- show: true,
22
- filter: true,
23
- },
24
- {
25
- col: 1,
26
- colName: 'nsxPortGroupId',
27
- text: localization.common.nsxPortGroupId,
28
- isSortable: true,
29
- sort: 'asc',
30
- width: '180px',
31
- show: true,
32
- filter: true,
33
- },
34
- {
35
- col: 2,
36
- colName: 'distributedSwitch',
37
- text: localization.common.distributedSwitch,
38
- isSortable: true,
39
- sort: 'asc',
40
- width: '180px',
41
- show: true,
42
- filter: true,
43
- },
44
- ]
45
-
46
- export const options: UI_I_DataTableOptions = {
47
- perPageOptions: [
48
- { text: '10', value: 10 },
49
- { text: '50', value: 50 },
50
- { text: '100', value: 100 },
51
- ],
52
- selectType: 'radio',
53
- isSelectable: true,
54
- isFocusable: false,
55
- showPagination: false,
56
- showPageInfo: false,
57
- isSortable: true,
58
- server: false,
59
- isResizable: true,
60
- showSearch: false,
61
- showColumnManager: true,
62
- }
63
-
64
- export const getBodyDataFunc = (
65
- bodyData: UI_I_NetworkTableItem[]
66
- ): UI_I_DataTableBody[] => {
67
- return bodyData.map((network, index: number) => {
68
- const state = network.state?.state || network.state
69
- const nameData = {
70
- id: network.id,
71
- // icon: 'vsphere-icon-network',
72
- icon: `vsphere-icon-${networkIconByState[state]}`,
73
- testId: 'network-item',
74
- }
75
-
76
- return {
77
- row: index,
78
- collapse: false,
79
- isHiddenCollapse: false,
80
- collapseToggle: false,
81
- data: [
82
- { key: 'icon', col: 0, text: network.name, data: nameData },
83
- {
84
- col: 1,
85
- text: '--',
86
- },
87
- {
88
- col: 2,
89
- text: '--',
90
- },
91
- ],
92
- }
93
- })
94
- }
1
+ import type {
2
+ UI_I_DataTableBody,
3
+ UI_I_DataTableOptions,
4
+ UI_I_DataTableHeader,
5
+ } from '~/node_modules/bfg-uikit/components/ui/dataTable/models/interfaces'
6
+ import type { UI_I_Localization, UI_I_State } from '~/lib/models/interfaces'
7
+ import type { UI_I_NetworkTableItem } from '~/lib/models/store/network/interfaces'
8
+ import { networkIconByState } from '~/components/common/lib/config/states'
9
+
10
+ export const getHeaderDataFunc = (
11
+ localization: UI_I_Localization
12
+ ): UI_I_DataTableHeader[] => [
13
+ {
14
+ col: 0,
15
+ colName: 'name',
16
+ text: localization.common.name,
17
+ isSortable: true,
18
+ sort: 'asc',
19
+ sortColumn: true,
20
+ width: '180px',
21
+ show: true,
22
+ filter: true,
23
+ },
24
+ {
25
+ col: 1,
26
+ colName: 'nsxPortGroupId',
27
+ text: localization.common.nsxPortGroupId,
28
+ isSortable: true,
29
+ sort: 'asc',
30
+ width: '180px',
31
+ show: true,
32
+ filter: true,
33
+ },
34
+ {
35
+ col: 2,
36
+ colName: 'distributedSwitch',
37
+ text: localization.common.distributedSwitch,
38
+ isSortable: true,
39
+ sort: 'asc',
40
+ width: '180px',
41
+ show: true,
42
+ filter: true,
43
+ },
44
+ ]
45
+
46
+ export const options: UI_I_DataTableOptions = {
47
+ perPageOptions: [
48
+ { text: '10', value: 10 },
49
+ { text: '50', value: 50 },
50
+ { text: '100', value: 100 },
51
+ ],
52
+ selectType: 'radio',
53
+ isSelectable: true,
54
+ isFocusable: false,
55
+ showPagination: false,
56
+ showPageInfo: false,
57
+ isSortable: true,
58
+ server: false,
59
+ isResizable: true,
60
+ showSearch: false,
61
+ showColumnManager: true,
62
+ }
63
+
64
+ export const getBodyDataFunc = (
65
+ bodyData: UI_I_NetworkTableItem[]
66
+ ): UI_I_DataTableBody[] => {
67
+ return bodyData.map((network, index: number) => {
68
+ const state = network.state?.state || network.state
69
+ const nameData = {
70
+ id: network.id,
71
+ // icon: 'vsphere-icon-network',
72
+ icon: `vsphere-icon-${networkIconByState[state]}`,
73
+ testId: 'network-item',
74
+ }
75
+
76
+ return {
77
+ row: index,
78
+ collapse: false,
79
+ isHiddenCollapse: false,
80
+ collapseToggle: false,
81
+ data: [
82
+ { key: 'icon', col: 0, text: network.name, data: nameData },
83
+ {
84
+ col: 1,
85
+ text: '--',
86
+ },
87
+ {
88
+ col: 2,
89
+ text: '--',
90
+ },
91
+ ],
92
+ }
93
+ })
94
+ }
@@ -1,119 +1,119 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-mac-address-new
3
- v-if="isNewView"
4
- v-model:mac-address="macAddress"
5
- v-model:mac-address-type="macAddressType"
6
- :index="index"
7
- :disabled="disabled"
8
- :error-text="macAddressLocalAndApiErrorsTexts"
9
- :mac-address-local-error-text="macAddressLocalErrorText"
10
- :mac-address-options="macAddressOptions"
11
- @remove-error="onRemoveValidationError"
12
- />
13
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-mac-address-old
14
- v-else
15
- v-model:mac-address="macAddress"
16
- v-model:mac-address-type="macAddressType"
17
- :index="index"
18
- :disabled="disabled"
19
- :error-text="macAddressLocalAndApiErrorsTexts"
20
- :mac-address-local-error-text="macAddressLocalErrorText"
21
- :mac-address-options="macAddressOptions"
22
- @remove-error="onRemoveValidationError"
23
- />
24
- </template>
25
-
26
- <script setup lang="ts">
27
- import type {
28
- UI_I_Localization,
29
- } from '~/lib/models/interfaces'
30
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
31
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
32
- import { macAddressOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/lib/config/options'
33
-
34
- const macAddress = defineModel<string>('macAddress', { required: true })
35
- const macAddressType = defineModel<string>('macAddressType', {
36
- required: true,
37
- })
38
-
39
- const props = defineProps<{
40
- index: number
41
- disabled: boolean
42
- errorValidationFields: UI_I_ErrorValidationField[]
43
- }>()
44
- const emits = defineEmits<{
45
- (event: 'invalid', value: boolean): void
46
- (event: 'remove-error-by-title', value: string): void
47
- }>()
48
-
49
- const { $store }: any = useNuxtApp()
50
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
51
-
52
- const localization = computed<UI_I_Localization>(() => useLocal())
53
-
54
- const macAddressOptions = ref<UI_I_OptionItem[]>(
55
- macAddressOptionsFunc(localization.value)
56
- )
57
-
58
- watch(macAddressType, (newValue) => {
59
- macAddress.value = newValue === 'manual' ? '00:50:56:' : ''
60
- })
61
- // const onChangeMacAddressType = (): void => {
62
- // // emits('update:mac-address-type', event.target.value)
63
- //
64
- // // emits(
65
- // // 'update:mac-address',
66
- // // event.target.value === 'manual' ? '00:50:56:' : ''
67
- // // )
68
- // }
69
- // const onChangeMacAddress = (event: Event): void => {
70
- // const target = event.target as HTMLInputElement
71
- // emits('update:mac-address', target.value)
72
- // }
73
-
74
- const macAddressLocalErrorText = computed<string>(() => {
75
- /* eslint-disable no-useless-escape */
76
- const isValidMacAddress =
77
- /^[0-9a-f]{1,2}([\.:-])(?:[0-9a-f]{1,2}\1){4}[0-9a-f]{1,2}$/.test(
78
- macAddress.value
79
- )
80
-
81
- return macAddressType.value === 'manual' && !isValidMacAddress
82
- ? localization.value.common.invalidMacAddress
83
- : ''
84
- })
85
- watch(macAddressLocalErrorText, (newValue) => {
86
- emits('invalid', !!newValue.length)
87
- })
88
-
89
- const typeError = computed<string>(
90
- () => `network_devices[${props.index}].mac_address`
91
- )
92
-
93
- const apiErrorLocal = computed<string>(() => {
94
- return (
95
- props.errorValidationFields?.find(
96
- (message) => message.field === typeError.value
97
- )?.error_message || ''
98
- )
99
- })
100
-
101
- const macAddressLocalAndApiErrorsTexts = computed<string>(() => {
102
- const localError = macAddressLocalErrorText.value
103
- const apiError = apiErrorLocal.value
104
-
105
- let result = ''
106
- if (localError && !apiError) result = localError
107
- if (!localError && apiError) result = apiError
108
- if (localError && apiError) result = localError + ', ' + apiError
109
- if (!localError && apiError) result = apiError
110
-
111
- return result
112
- })
113
-
114
- const onRemoveValidationError = (): void => {
115
- emits('remove-error-by-title', typeError.value)
116
- }
117
- </script>
118
-
119
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-mac-address-new
3
+ v-if="isNewView"
4
+ v-model:mac-address="macAddress"
5
+ v-model:mac-address-type="macAddressType"
6
+ :index="index"
7
+ :disabled="disabled"
8
+ :error-text="macAddressLocalAndApiErrorsTexts"
9
+ :mac-address-local-error-text="macAddressLocalErrorText"
10
+ :mac-address-options="macAddressOptions"
11
+ @remove-error="onRemoveValidationError"
12
+ />
13
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-network-mac-address-old
14
+ v-else
15
+ v-model:mac-address="macAddress"
16
+ v-model:mac-address-type="macAddressType"
17
+ :index="index"
18
+ :disabled="disabled"
19
+ :error-text="macAddressLocalAndApiErrorsTexts"
20
+ :mac-address-local-error-text="macAddressLocalErrorText"
21
+ :mac-address-options="macAddressOptions"
22
+ @remove-error="onRemoveValidationError"
23
+ />
24
+ </template>
25
+
26
+ <script setup lang="ts">
27
+ import type {
28
+ UI_I_Localization,
29
+ } from '~/lib/models/interfaces'
30
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
31
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
32
+ import { macAddressOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/lib/config/options'
33
+
34
+ const macAddress = defineModel<string>('macAddress', { required: true })
35
+ const macAddressType = defineModel<string>('macAddressType', {
36
+ required: true,
37
+ })
38
+
39
+ const props = defineProps<{
40
+ index: number
41
+ disabled: boolean
42
+ errorValidationFields: UI_I_ErrorValidationField[]
43
+ }>()
44
+ const emits = defineEmits<{
45
+ (event: 'invalid', value: boolean): void
46
+ (event: 'remove-error-by-title', value: string): void
47
+ }>()
48
+
49
+ const { $store }: any = useNuxtApp()
50
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
51
+
52
+ const localization = computed<UI_I_Localization>(() => useLocal())
53
+
54
+ const macAddressOptions = ref<UI_I_OptionItem[]>(
55
+ macAddressOptionsFunc(localization.value)
56
+ )
57
+
58
+ watch(macAddressType, (newValue) => {
59
+ macAddress.value = newValue === 'manual' ? '00:50:56:' : ''
60
+ })
61
+ // const onChangeMacAddressType = (): void => {
62
+ // // emits('update:mac-address-type', event.target.value)
63
+ //
64
+ // // emits(
65
+ // // 'update:mac-address',
66
+ // // event.target.value === 'manual' ? '00:50:56:' : ''
67
+ // // )
68
+ // }
69
+ // const onChangeMacAddress = (event: Event): void => {
70
+ // const target = event.target as HTMLInputElement
71
+ // emits('update:mac-address', target.value)
72
+ // }
73
+
74
+ const macAddressLocalErrorText = computed<string>(() => {
75
+ /* eslint-disable no-useless-escape */
76
+ const isValidMacAddress =
77
+ /^[0-9a-f]{1,2}([\.:-])(?:[0-9a-f]{1,2}\1){4}[0-9a-f]{1,2}$/.test(
78
+ macAddress.value
79
+ )
80
+
81
+ return macAddressType.value === 'manual' && !isValidMacAddress
82
+ ? localization.value.common.invalidMacAddress
83
+ : ''
84
+ })
85
+ watch(macAddressLocalErrorText, (newValue) => {
86
+ emits('invalid', !!newValue.length)
87
+ })
88
+
89
+ const typeError = computed<string>(
90
+ () => `network_devices[${props.index}].mac_address`
91
+ )
92
+
93
+ const apiErrorLocal = computed<string>(() => {
94
+ return (
95
+ props.errorValidationFields?.find(
96
+ (message) => message.field === typeError.value
97
+ )?.error_message || ''
98
+ )
99
+ })
100
+
101
+ const macAddressLocalAndApiErrorsTexts = computed<string>(() => {
102
+ const localError = macAddressLocalErrorText.value
103
+ const apiError = apiErrorLocal.value
104
+
105
+ let result = ''
106
+ if (localError && !apiError) result = localError
107
+ if (!localError && apiError) result = apiError
108
+ if (localError && apiError) result = localError + ', ' + apiError
109
+ if (!localError && apiError) result = apiError
110
+
111
+ return result
112
+ })
113
+
114
+ const onRemoveValidationError = (): void => {
115
+ emits('remove-error-by-title', typeError.value)
116
+ }
117
+ </script>
118
+
119
+ <style scoped lang="scss"></style>