bfg-common 1.5.110 → 1.5.111

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 (191) 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 +9 -11
  7. package/assets/localization/local_en.json +1 -3
  8. package/assets/localization/local_hy.json +9 -11
  9. package/assets/localization/local_kk.json +9 -11
  10. package/assets/localization/local_ru.json +8 -8
  11. package/assets/localization/local_zh.json +9 -11
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/perPage/PerPage.vue +58 -58
  14. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  15. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  16. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  17. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  18. package/components/common/context/lib/models/interfaces.ts +31 -31
  19. package/components/common/context/recursion/Recursion.vue +87 -87
  20. package/components/common/context/recursion/RecursionNew.vue +238 -238
  21. package/components/common/diagramMain/DiagramMain.vue +897 -897
  22. package/components/common/diagramMain/Header.vue +214 -214
  23. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +4 -5
  24. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +4 -5
  25. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  26. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  27. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  28. package/components/common/pages/home/headline/Headline.vue +45 -45
  29. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  30. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  31. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  32. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  33. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  34. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  35. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  36. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  37. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  38. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  39. package/components/common/pages/packages/Packages.vue +208 -208
  40. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  41. package/components/common/portlets/customAttributes/Portlet.vue +667 -667
  42. package/components/common/portlets/tag/Portlet.vue +433 -433
  43. package/components/common/readyToComplete/New.vue +66 -66
  44. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  45. package/components/common/recursionTree/RecursionTree.vue +223 -223
  46. package/components/common/select/button/ButtonDropdown.vue +108 -108
  47. package/components/common/spiceConsole/Drawer.vue +370 -370
  48. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  49. package/components/common/split/horizontal/HorizontalOld.vue +337 -337
  50. package/components/common/split/vertical/Vertical.vue +160 -160
  51. package/components/common/tools/Actions.vue +202 -202
  52. package/components/common/vm/actions/add/Add.vue +785 -785
  53. package/components/common/vm/actions/add/New.vue +556 -556
  54. package/components/common/vm/actions/add/Old.vue +371 -371
  55. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  56. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  57. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  58. package/components/common/vm/actions/add/lib/config/steps.ts +263 -263
  59. package/components/common/vm/actions/clone/Clone.vue +798 -798
  60. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  61. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +626 -626
  62. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  63. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +275 -275
  64. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +272 -272
  65. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +177 -177
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +698 -698
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +468 -468
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +99 -99
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +118 -118
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +198 -198
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +194 -194
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +122 -122
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +368 -368
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +266 -266
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +250 -250
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +149 -161
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +74 -0
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +83 -0
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/StorageModalNew.vue +74 -74
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +45 -45
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -286
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +124 -125
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -95
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +70 -70
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +85 -85
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +82 -82
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +57 -57
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +105 -105
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  119. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  120. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  121. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  122. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  123. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  124. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +43 -43
  125. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  126. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  127. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  128. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +144 -144
  129. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  130. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  131. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  132. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  133. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  134. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +40 -40
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  136. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  137. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  141. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  142. package/components/common/vm/actions/common/select/compatibility/Compatibility.vue +100 -100
  143. package/components/common/vm/actions/common/select/compatibility/New.vue +165 -165
  144. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  145. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +134 -134
  146. package/components/common/vm/actions/common/select/computeResource/New.vue +141 -141
  147. package/components/common/vm/actions/common/select/computeResource/Old.vue +99 -99
  148. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  149. package/components/common/vm/actions/common/select/computeResource/treeView/Old.vue +48 -48
  150. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  151. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  152. package/components/common/vm/actions/common/select/createType/New.vue +84 -84
  153. package/components/common/vm/actions/common/select/createType/Old.vue +70 -70
  154. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  155. package/components/common/vm/actions/common/select/name/Name.vue +167 -167
  156. package/components/common/vm/actions/common/select/name/New.vue +246 -246
  157. package/components/common/vm/actions/common/select/name/Old.vue +119 -119
  158. package/components/common/vm/actions/common/select/os/New.vue +122 -122
  159. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  160. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  161. package/components/common/vm/actions/common/select/storage/Old.vue +129 -129
  162. package/components/common/vm/actions/common/select/storage/Storage.vue +131 -130
  163. package/components/common/vm/actions/common/select/storage/new/New.vue +193 -189
  164. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +326 -326
  165. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  166. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  167. package/components/common/vm/actions/common/select/template/Template.vue +64 -64
  168. package/components/common/vm/actions/common/select/template/TemplateTreeView.vue +88 -88
  169. package/components/common/vm/actions/editSettings/new/New.vue +186 -185
  170. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  171. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  172. package/components/common/wizards/datastore/add/nfs/accessibility/Accessibility.vue +60 -60
  173. package/components/common/wizards/datastore/add/readyComplete/ReadyComplete.vue +92 -92
  174. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +105 -105
  175. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  176. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  177. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  178. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  179. package/components/common/wizards/vm/migrate/select/network/table/network/Network.vue +150 -150
  180. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  181. package/components/common/wizards/vm/migrate/select/priority/Priority.vue +43 -43
  182. package/composables/productNameLocal.ts +30 -30
  183. package/composables/useAppVersion.ts +21 -21
  184. package/package.json +1 -1
  185. package/plugins/date.ts +233 -233
  186. package/plugins/directives.ts +24 -24
  187. package/public/spice-console/lib/images/bitmap.js +203 -203
  188. package/public/spice-console/network/spicechannel.js +383 -383
  189. package/store/main/mutations.ts +7 -7
  190. package/store/main/state.ts +7 -7
  191. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,189 +1,193 @@
1
- <template>
2
- <div class="select-storage">
3
- <Teleport to="#storage-alert-wrapper">
4
- <ui-alert
5
- v-show="props.errors.length"
6
- status="alert-danger"
7
- :messages="props.errors"
8
- test-id="storage-alert"
9
- :items="props.errors"
10
- @remove="emits('remove-error')"
11
- />
12
- </Teleport>
13
-
14
- <div class="table-wrap">
15
- <ui-data-table
16
- test-id="select-storage-data-table"
17
- :data="data"
18
- :options="tableOptions"
19
- :loading="loading"
20
- server-off
21
- :default-layout="false"
22
- size="sm"
23
- @select-row="onSelectRow"
24
- >
25
- <template #insteadOfTitleActions
26
- ><h3 class="storage-count">
27
- {{ storageCount }}
28
- </h3></template
29
- >
30
- <template #state="{ item }">
31
- <ui-chip :color="item.data.color" rounded>
32
- <ui-icon :name="item.data.iconClassName" width="14" height="14" />
33
- {{ item.data.text }}
34
- </ui-chip>
35
- </template>
36
- </ui-data-table>
37
- </div>
38
-
39
- <div v-if="!props.hideCompatibility" class="compatibility-wrap">
40
- <p class="compatibility">
41
- {{ localization.inventorySummary.compatibility }}
42
- </p>
43
- <div class="compatibility-message flex-align-center">
44
- <ui-skeleton-item v-if="loading" width="160px" height="16px" />
45
- <template v-else>
46
- <template v-if="props.selectedStorage">
47
- <ui-icon name="success-fill" width="16" height="16" />
48
- <span class="compatibility-message-description">{{
49
- localization.common.compatibilityChecksSucceeded
50
- }}</span>
51
- </template>
52
- <template v-else>
53
- <!-- <ui-icon name="error" width="16" height="16" />-->
54
- <span class="compatibility-message-description">{{
55
- localization.vmWizard.noStorageSelected
56
- }}</span>
57
- </template>
58
- </template>
59
- </div>
60
- </div>
61
- </div>
62
- </template>
63
-
64
- <script setup lang="ts">
65
- import type { UI_I_DataTable } from 'bfg-uikit/components/ui/dataTable/models/interfaces'
66
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
67
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
68
- import type { UI_I_Localization } from '~/lib/models/interfaces'
69
- import {
70
- tableBodyFunc,
71
- tableDataFunc,
72
- tableOptions,
73
- } from '~/components/common/vm/actions/common/select/storage/new/lib/config/table'
74
-
75
- const selectedRow = defineModel<number | null>('selectedRow')
76
-
77
- const props = defineProps<{
78
- datastore: UI_I_DatastoreTableItem[]
79
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
80
- errors: string[]
81
- selectedStorage: UI_I_DatastoreTableItem | null
82
- hideCompatibility?: boolean
83
- }>()
84
- const emits = defineEmits<{
85
- (event: 'remove-error'): void
86
- (event: 'change-storage', value: number): void
87
- }>()
88
-
89
- const localization = computed<UI_I_Localization>(() => useLocal())
90
-
91
- const storageCount = computed<string>(() =>
92
- localization.value.vmWizard.storageCount.replace(
93
- '{0}',
94
- data.value.body.length.toString()
95
- )
96
- )
97
- const loading = ref<boolean>(true)
98
- const data = ref<UI_I_DataTable>(tableDataFunc(localization.value))
99
-
100
- watch(
101
- () => props.datastore,
102
- (newValue: UI_I_DatastoreTableItem[]) => {
103
- if (!newValue.length || data.value.body.length) return
104
-
105
- data.value.body = tableBodyFunc(
106
- newValue,
107
- localization.value,
108
- selectedRow.value
109
- )
110
-
111
- loading.value = false
112
- },
113
- { immediate: true, deep: true }
114
- )
115
-
116
- const onSelectRow = (selectedData: UI_I_DataTable): void => {
117
- const selectedId = selectedData[0]?.data[0]?.key
118
- const selectedItemIndex = props.datastore.findIndex(
119
- (item) => item.id === selectedId
120
- )
121
-
122
- emits('change-storage', selectedItemIndex)
123
- }
124
- </script>
125
-
126
- <style>
127
- :root {
128
- --select-storage-border-color: #e9ebed;
129
- --select-storage-bg-color: #ffffff;
130
- --select-storage-title-color: #4d5d69;
131
- --select-storage-compatibility-description-color: #4d5d69;
132
- }
133
- :root.dark-theme {
134
- --select-storage-border-color: #e9ebed1f;
135
- --select-storage-bg-color: var(--wizard-right-bg);
136
- --select-storage-title-color: #e9eaec;
137
- --select-storage-compatibility-description-color: #9da6ad;
138
- }
139
- </style>
140
- <style scoped lang="scss">
141
- .select-storage {
142
- padding-top: 16px;
143
-
144
- .storage-count {
145
- font-size: 16px;
146
- font-weight: 500;
147
- color: var(--select-storage-title-color);
148
- }
149
-
150
- :deep(.bottom-grid-content) {
151
- border: 1px solid var(--select-storage-border-color);
152
- border-radius: 8px;
153
- padding: 12px;
154
- background-color: var(--select-storage-bg-color);
155
- }
156
- :deep(.select-row-item) {
157
- background-color: var(--select-storage-bg-color);
158
- }
159
- :deep(.table-title-actions-container) {
160
- justify-content: flex-start;
161
- }
162
- :deep(.table-container .table-title) {
163
- margin-bottom: 12px;
164
- }
165
-
166
- .compatibility-wrap {
167
- margin-top: 24px;
168
-
169
- .compatibility {
170
- font-size: 16px;
171
- font-weight: 500;
172
- color: var(--select-storage-title-color);
173
- margin-bottom: 16px;
174
- }
175
- .compatibility-message {
176
- border-radius: 8px;
177
- border: 1px solid var(--select-storage-border-color);
178
- padding: 12px;
179
- background-color: var(--select-storage-bg-color);
180
- gap: 12px;
181
-
182
- .compatibility-message-description {
183
- font-size: 13px;
184
- color: var(--select-storage-compatibility-description-color);
185
- }
186
- }
187
- }
188
- }
189
- </style>
1
+ <template>
2
+ <div class="select-storage">
3
+ <Teleport v-if="!props.hideAlert" to="#storage-alert-wrapper">
4
+ <ui-alert
5
+ v-show="props.errors.length"
6
+ status="alert-danger"
7
+ :messages="props.errors"
8
+ test-id="storage-alert"
9
+ :items="props.errors"
10
+ @remove="emits('remove-error')"
11
+ />
12
+ </Teleport>
13
+
14
+ <div class="table-wrap">
15
+ <ui-data-table
16
+ test-id="select-storage-data-table"
17
+ :data="data"
18
+ :options="tableOptions"
19
+ :loading="loading"
20
+ server-off
21
+ :default-layout="false"
22
+ size="sm"
23
+ @select-row="onSelectRow"
24
+ >
25
+ <template #insteadOfTitleActions
26
+ ><h3 class="storage-count">
27
+ {{ storageCount }}
28
+ </h3></template
29
+ >
30
+ <template #state="{ item }">
31
+ <ui-chip :color="item.data.color" rounded>
32
+ <ui-icon :name="item.data.iconClassName" width="14" height="14" />
33
+ {{ item.data.text }}
34
+ </ui-chip>
35
+ </template>
36
+ </ui-data-table>
37
+ </div>
38
+
39
+ <div v-if="!props.hideCompatibility" class="compatibility-wrap">
40
+ <p class="compatibility">
41
+ {{ localization.inventorySummary.compatibility }}
42
+ </p>
43
+ <div class="compatibility-message flex-align-center">
44
+ <ui-skeleton-item v-if="loading" width="160px" height="16px" />
45
+ <template v-else>
46
+ <template v-if="props.selectedStorage">
47
+ <ui-icon name="success-fill" width="16" height="16" />
48
+ <span class="compatibility-message-description">{{
49
+ localization.common.compatibilityChecksSucceeded
50
+ }}</span>
51
+ </template>
52
+ <template v-else>
53
+ <!-- <ui-icon name="error" width="16" height="16" />-->
54
+ <span class="compatibility-message-description">{{
55
+ localization.vmWizard.noStorageSelected
56
+ }}</span>
57
+ </template>
58
+ </template>
59
+ </div>
60
+ </div>
61
+ </div>
62
+ </template>
63
+
64
+ <script setup lang="ts">
65
+ import type { UI_I_DataTable } from 'bfg-uikit/components/ui/dataTable/models/interfaces'
66
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
67
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
68
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
69
+ import {
70
+ tableBodyFunc,
71
+ tableDataFunc,
72
+ tableOptions,
73
+ } from '~/components/common/vm/actions/common/select/storage/new/lib/config/table'
74
+
75
+ const selectedRow = defineModel<number | null>('selectedRow')
76
+
77
+ const props = defineProps<{
78
+ datastore: UI_I_DatastoreTableItem[]
79
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
80
+ errors: string[]
81
+ selectedStorage: UI_I_DatastoreTableItem | null
82
+ hideCompatibility?: boolean
83
+ hideAlert?: boolean
84
+ }>()
85
+ const emits = defineEmits<{
86
+ (event: 'remove-error'): void
87
+ (event: 'change-storage', value: number): void
88
+ }>()
89
+
90
+ const localization = computed<UI_I_Localization>(() => useLocal())
91
+
92
+ const storageCount = computed<string>(() =>
93
+ localization.value.vmWizard.storageCount.replace(
94
+ '{0}',
95
+ data.value.body.length.toString()
96
+ )
97
+ )
98
+ const loading = ref<boolean>(true)
99
+ const data = ref<UI_I_DataTable>(tableDataFunc(localization.value))
100
+
101
+ watch(
102
+ () => props.datastore,
103
+ (newValue: UI_I_DatastoreTableItem[]) => {
104
+ loading.value = true
105
+
106
+ // if (!newValue.length || data.value.body.length) return
107
+
108
+ data.value.body = tableBodyFunc(
109
+ newValue,
110
+ localization.value,
111
+ selectedRow.value
112
+ )
113
+
114
+ loading.value = false
115
+ },
116
+ { immediate: true, deep: true }
117
+ // { deep: true }
118
+ )
119
+
120
+ const onSelectRow = (selectedData: UI_I_DataTable): void => {
121
+ const selectedId = selectedData[0]?.data[0]?.key
122
+ const selectedItemIndex = props.datastore.findIndex(
123
+ (item) => item.id === selectedId
124
+ )
125
+
126
+ emits('change-storage', selectedItemIndex)
127
+ }
128
+ </script>
129
+
130
+ <style>
131
+ :root {
132
+ --select-storage-border-color: #e9ebed;
133
+ --select-storage-bg-color: #ffffff;
134
+ --select-storage-title-color: #4d5d69;
135
+ --select-storage-compatibility-description-color: #4d5d69;
136
+ }
137
+ :root.dark-theme {
138
+ --select-storage-border-color: #e9ebed1f;
139
+ --select-storage-bg-color: var(--wizard-right-bg);
140
+ --select-storage-title-color: #e9eaec;
141
+ --select-storage-compatibility-description-color: #9da6ad;
142
+ }
143
+ </style>
144
+ <style scoped lang="scss">
145
+ .select-storage {
146
+ padding-top: 16px;
147
+
148
+ .storage-count {
149
+ font-size: 16px;
150
+ font-weight: 500;
151
+ color: var(--select-storage-title-color);
152
+ }
153
+
154
+ :deep(.bottom-grid-content) {
155
+ border: 1px solid var(--select-storage-border-color);
156
+ border-radius: 8px;
157
+ padding: 12px;
158
+ background-color: var(--select-storage-bg-color);
159
+ }
160
+ :deep(.select-row-item) {
161
+ background-color: var(--select-storage-bg-color);
162
+ }
163
+ :deep(.table-title-actions-container) {
164
+ justify-content: flex-start;
165
+ }
166
+ :deep(.table-container .table-title) {
167
+ margin-bottom: 12px;
168
+ }
169
+
170
+ .compatibility-wrap {
171
+ margin-top: 24px;
172
+
173
+ .compatibility {
174
+ font-size: 16px;
175
+ font-weight: 500;
176
+ color: var(--select-storage-title-color);
177
+ margin-bottom: 16px;
178
+ }
179
+ .compatibility-message {
180
+ border-radius: 8px;
181
+ border: 1px solid var(--select-storage-border-color);
182
+ padding: 12px;
183
+ background-color: var(--select-storage-bg-color);
184
+ gap: 12px;
185
+
186
+ .compatibility-message-description {
187
+ font-size: 13px;
188
+ color: var(--select-storage-compatibility-description-color);
189
+ }
190
+ }
191
+ }
192
+ }
193
+ </style>