bfg-common 1.5.351 → 1.5.353

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 (139) 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/collapse/CollapseNav.vue +170 -170
  8. package/components/atoms/collapse/CollapseNavItem.vue +226 -226
  9. package/components/atoms/nav/NavBar.vue +2 -10
  10. package/components/atoms/perPage/PerPage.vue +58 -58
  11. package/components/atoms/table/dataGrid/DataGrid.vue +1717 -1717
  12. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  13. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  14. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  15. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  16. package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +52 -52
  17. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  18. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  19. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  20. package/components/common/context/lib/models/interfaces.ts +33 -33
  21. package/components/common/diagramMain/DiagramMain.vue +897 -897
  22. package/components/common/diagramMain/modals/lib/config/networkModal.ts +398 -398
  23. package/components/common/diagramMain/network/Network.vue +141 -141
  24. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  25. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  26. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  27. package/components/common/pages/home/headline/Headline.vue +45 -45
  28. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  29. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  30. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  31. package/components/common/pages/home/widgets/WidgetsNew.vue +88 -88
  32. package/components/common/pages/home/widgets/WidgetsOld.vue +36 -36
  33. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  34. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  35. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  36. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  37. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  38. package/components/common/pages/packages/Packages.vue +208 -208
  39. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  40. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  41. package/components/common/recursionTree/RecursionTree.vue +223 -223
  42. package/components/common/select/button/ButtonDropdown.vue +112 -112
  43. package/components/common/select/radio/RadioGroup.vue +135 -135
  44. package/components/common/spiceConsole/Drawer.vue +377 -377
  45. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  46. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  47. package/components/common/tools/Actions.vue +207 -207
  48. package/components/common/vm/actions/add/Old.vue +388 -388
  49. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  50. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  51. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  52. package/components/common/vm/actions/clone/Clone.vue +823 -823
  53. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  54. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -321
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +227 -227
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/dropdownItems.ts +155 -155
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -385
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/{StorageModalNew.vue → storageModal/new/New.vue} +5 -1
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/new/lib/config/table.ts +15 -0
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +19 -12
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -94
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +154 -154
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  90. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +155 -155
  91. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +130 -130
  92. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +113 -113
  93. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  94. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  95. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  96. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +95 -95
  97. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +155 -155
  98. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  99. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -44
  100. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  101. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  102. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  103. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  104. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  105. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  106. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +48 -48
  107. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  108. package/components/common/vm/actions/common/select/name/Name.vue +174 -174
  109. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  110. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  111. package/components/common/vm/actions/common/select/storage/Storage.vue +155 -152
  112. package/components/common/vm/actions/common/select/storage/new/New.vue +294 -290
  113. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  114. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  115. package/components/common/vm/actions/editSettings/EditSettings.vue +242 -242
  116. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  117. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
  118. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +104 -104
  119. package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +467 -467
  120. package/components/common/wizards/vm/migrate/Migrate.vue +349 -349
  121. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  122. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  123. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  124. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  125. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  126. package/components/common/wizards/vm/migrate/select/type/lib/config/typeOptions.ts +45 -45
  127. package/composables/productNameLocal.ts +30 -30
  128. package/composables/useAppVersion.ts +21 -21
  129. package/package.json +1 -1
  130. package/plugins/date.ts +233 -233
  131. package/plugins/panelStates.ts +70 -70
  132. package/plugins/text.ts +59 -59
  133. package/public/spice-console/lib/images/bitmap.js +203 -203
  134. package/public/spice-console/network/spicechannel.js +387 -387
  135. package/store/main/mutations.ts +7 -7
  136. package/store/main/state.ts +7 -7
  137. package/store/tasks/mappers/recentTasks.ts +64 -64
  138. /package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/{StorageModalOld.vue → storageModal/Old.vue} +0 -0
  139. /package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/{StorageModal.vue → storageModal/StorageModal.vue} +0 -0
@@ -1,290 +1,294 @@
1
- <template>
2
- <div :class="['select-storage', { 'in-wizard': isInWizard }]">
3
- <Teleport v-if="!props.hideAlert" to="#storage-alert-wrapper">
4
- <ui-alert
5
- v-show="props.errors.length"
6
- :messages="props.errors"
7
- :items="props.errors"
8
- status="alert-danger"
9
- test-id="storage-alert"
10
- size="md"
11
- @hide="emits('remove-error')"
12
- />
13
- </Teleport>
14
-
15
- <div class="table-wrap">
16
- <ui-data-table
17
- :data="data"
18
- :options="tableOptions"
19
- :loading="props.isDatastoreLoading"
20
- :default-layout="false"
21
- :texts="tableTexts"
22
- test-id="select-storage-data-table"
23
- server-off
24
- size="sm"
25
- @select-row="onSelectRow"
26
- >
27
- <template v-if="!props.isInWizard" #insteadOfTitleActions
28
- ><h3 class="storage-count">
29
- {{ storageCount }}
30
- </h3></template
31
- >
32
- <template #name="{ item }">
33
- <ui-icon
34
- name="datastores"
35
- width="18"
36
- height="18"
37
- class="mr-1 row-datastores-icon"
38
- />
39
- {{ item.text }}
40
- </template>
41
- <template #state="{ item }">
42
- <ui-chip :color="item.data.color" size="sm" rounded>
43
- <ui-icon :name="item.data.iconClassName" width="12" height="12" />
44
- {{ item.data.text }}
45
- </ui-chip>
46
- </template>
47
- </ui-data-table>
48
- </div>
49
-
50
- <div v-if="!props.hideCompatibility" class="compatibility-wrap">
51
- <p class="compatibility">
52
- {{ localization.inventorySummary.compatibility }}
53
- </p>
54
- <div class="compatibility-message flex-align-start">
55
- <ui-skeleton-item v-if="loading" width="160px" height="16px" />
56
- <template v-else>
57
- <template v-if="props.selectedStorage">
58
- <ui-icon
59
- name="success-fill"
60
- width="16"
61
- height="16"
62
- class="icon-compatibility-alert"
63
- />
64
- <span class="compatibility-message-description">{{
65
- localization.common.compatibilityChecksSucceeded
66
- }}</span>
67
- </template>
68
- <template v-else>
69
- <!-- <ui-icon name="error" width="16" height="16" />-->
70
- <span class="compatibility-message-description empty">{{
71
- localization.vmWizard.noStorageSelected
72
- }}</span>
73
- </template>
74
- </template>
75
- </div>
76
- </div>
77
- </div>
78
- </template>
79
-
80
- <script setup lang="ts">
81
- import type {
82
- UI_I_DataTable,
83
- UI_I_TableTexts,
84
- } from '~/node_modules/bfg-uikit/components/ui/dataTable/models/interfaces'
85
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
86
- import type { UI_I_Localization } from '~/lib/models/interfaces'
87
- import {
88
- tableBodyFunc,
89
- tableDataFunc,
90
- tableOptions,
91
- } from '~/components/common/vm/actions/common/select/storage/new/lib/config/table'
92
- import { tableTextsFunc } from '~/lib/config/uiTable'
93
-
94
- const selectedRow = defineModel<number | null>('selectedRow')
95
-
96
- const props = defineProps<{
97
- datastore: UI_I_DatastoreTableItem[]
98
- isDatastoreLoading: boolean
99
- errors: string[]
100
- selectedStorage: UI_I_DatastoreTableItem | null
101
- hideCompatibility?: boolean
102
- hideAlert?: boolean
103
- isInWizard?: boolean
104
- }>()
105
- const emits = defineEmits<{
106
- (event: 'remove-error'): void
107
- (event: 'change-storage', value: number): void
108
- }>()
109
-
110
- const localization = computed<UI_I_Localization>(() => useLocal())
111
-
112
- const tableTexts = computed<UI_I_TableTexts>(() =>
113
- tableTextsFunc(localization.value)
114
- )
115
-
116
- const storageCount = computed<string>(() =>
117
- localization.value.vmWizard.storageCount.replace(
118
- '{0}',
119
- data.value.body.length.toString()
120
- )
121
- )
122
- // const loading = ref<boolean>(true)
123
- const data = ref<UI_I_DataTable>(tableDataFunc(localization.value))
124
-
125
- watch(
126
- () => props.datastore,
127
- (newValue: UI_I_DatastoreTableItem[]) => {
128
- // loading.value = true
129
-
130
- // if (!newValue.length || data.value.body.length) return
131
-
132
- data.value.body = tableBodyFunc(
133
- newValue,
134
- localization.value,
135
- selectedRow.value
136
- )
137
-
138
- // loading.value = false
139
- },
140
- { immediate: true, deep: true }
141
- // { deep: true }
142
- )
143
-
144
- const onSelectRow = (selectedData: UI_I_DataTable): void => {
145
- const selectedId = selectedData[0]?.data[0]?.data.id
146
- const selectedItemIndex = props.datastore.findIndex(
147
- (item) => item.id === selectedId
148
- )
149
-
150
- emits('change-storage', selectedItemIndex)
151
- }
152
- </script>
153
-
154
- <style>
155
- :root {
156
- --select-storage-border-color: #e9ebed;
157
- --select-storage-bg-color: #ffffff;
158
- --select-storage-title-color: #4d5d69;
159
- --select-storage-compatibility-bg-color: #ffffff;
160
- --select-storage-compatibility-description-color: #4d5d69;
161
- --select-storage-compatibility-empty-description-color: #9da6ad;
162
- --select-storage-compatibility-table-column-button-hover-bg: #f6f7f8;
163
- --select-storage-compatibility-table-column-button-active-hover-bg: #f0f8fd;
164
- }
165
- :root.dark-theme {
166
- --select-storage-border-color: #e9ebed1f;
167
- --select-storage-bg-color: var(--wizard-right-bg);
168
- --select-storage-title-color: #e9eaec;
169
- --select-storage-compatibility-bg-color: #1b2a371f;
170
- --select-storage-compatibility-description-color: #e9eaec;
171
- --select-storage-compatibility-empty-description-color: #9da6ad;
172
- --select-storage-compatibility-table-column-button-hover-bg: linear-gradient(
173
- 0deg,
174
- rgba(233, 234, 236, 0.04) 0%,
175
- rgba(233, 234, 236, 0.04) 100%
176
- ),
177
- rgba(27, 42, 55, 0.24);
178
- --select-storage-compatibility-table-column-button-active-hover-bg: linear-gradient(
179
- 0deg,
180
- rgba(43, 162, 222, 0.08) 0%,
181
- rgba(43, 162, 222, 0.08) 100%
182
- ),
183
- rgba(27, 42, 55, 0.24);
184
- }
185
- </style>
186
- <style scoped lang="scss">
187
- :root.dark-theme {
188
- .select-storage {
189
- &.in-wizard {
190
- :deep(.column-manager-button) {
191
- &:hover {
192
- background: #b8bcc10a;
193
- }
194
- &.active:hover {
195
- background-color: #2785b614;
196
- }
197
- }
198
- }
199
- }
200
- }
201
- .select-storage {
202
- padding-top: 12px;
203
- padding-bottom: 16px;
204
-
205
- :deep(.title-sm) {
206
- font-size: 12px;
207
- }
208
-
209
- :deep(.table-container.default-layout) {
210
- box-shadow: unset;
211
- padding: 0;
212
- }
213
- .storage-count {
214
- font-size: 16px;
215
- font-weight: 500;
216
- color: var(--select-storage-title-color);
217
- }
218
-
219
- :deep(.column-manager-button) {
220
- span {
221
- font-size: 12px;
222
- font-weight: 500;
223
- }
224
- &:not(.active):hover {
225
- background-color: var(
226
- --select-storage-compatibility-table-column-button-hover-bg
227
- );
228
- color: var(--btn-table-manager-color);
229
- }
230
- &.active:hover {
231
- background-color: var(
232
- --select-storage-compatibility-table-column-button-active-hover-bg
233
- );
234
- }
235
- }
236
-
237
- &:not(.in-wizard) {
238
- :deep(.bottom-grid-content) {
239
- border: 1px solid var(--select-storage-border-color);
240
- border-radius: 8px;
241
- padding: 12px;
242
- background-color: var(--select-storage-bg-color);
243
- }
244
- :deep(.select-row-item) {
245
- background-color: var(--select-storage-bg-color);
246
- }
247
- }
248
-
249
- :deep(.table-title-actions-container) {
250
- justify-content: flex-start;
251
- }
252
- :deep(.table-container .table-title) {
253
- margin-bottom: 12px;
254
- }
255
-
256
- .compatibility-wrap {
257
- margin-top: 24px;
258
-
259
- .compatibility {
260
- font-size: 16px;
261
- font-weight: 500;
262
- color: var(--select-storage-title-color);
263
- margin-bottom: 16px;
264
- }
265
- .compatibility-message {
266
- border-radius: 8px;
267
- border: 1px solid var(--select-storage-border-color);
268
- padding: 12px;
269
- background-color: var(--select-storage-compatibility-bg-color);
270
- gap: 10px;
271
-
272
- .icon-compatibility-alert {
273
- min-width: 16px;
274
- min-height: 16px;
275
- }
276
- .compatibility-message-description {
277
- font-size: 13px;
278
- color: var(--select-storage-compatibility-description-color);
279
-
280
- &.empty {
281
- color: var(--select-storage-compatibility-empty-description-color);
282
- }
283
- }
284
- }
285
- }
286
- .row-datastores-icon {
287
- min-width: 18px;
288
- }
289
- }
290
- </style>
1
+ <template>
2
+ <div :class="['select-storage', { 'in-wizard': isInWizard }]">
3
+ <Teleport v-if="!props.hideAlert" to="#storage-alert-wrapper">
4
+ <ui-alert
5
+ v-show="props.errors.length"
6
+ :messages="props.errors"
7
+ :items="props.errors"
8
+ status="alert-danger"
9
+ test-id="storage-alert"
10
+ size="md"
11
+ @hide="emits('remove-error')"
12
+ />
13
+ </Teleport>
14
+
15
+ <div class="table-wrap">
16
+ <ui-data-table
17
+ :data="data"
18
+ :options="tableOptionsLocal"
19
+ :loading="props.isDatastoreLoading"
20
+ :default-layout="false"
21
+ :texts="tableTexts"
22
+ test-id="select-storage-data-table"
23
+ server-off
24
+ size="sm"
25
+ @select-row="onSelectRow"
26
+ >
27
+ <template v-if="!props.isInWizard" #insteadOfTitleActions
28
+ ><h3 class="storage-count">
29
+ {{ storageCount }}
30
+ </h3></template
31
+ >
32
+ <template #name="{ item }">
33
+ <ui-icon
34
+ name="datastores"
35
+ width="18"
36
+ height="18"
37
+ class="mr-1 row-datastores-icon"
38
+ />
39
+ {{ item.text }}
40
+ </template>
41
+ <template #state="{ item }">
42
+ <ui-chip :color="item.data.color" size="sm" rounded>
43
+ <ui-icon :name="item.data.iconClassName" width="12" height="12" />
44
+ {{ item.data.text }}
45
+ </ui-chip>
46
+ </template>
47
+ </ui-data-table>
48
+ </div>
49
+
50
+ <div v-if="!props.hideCompatibility" class="compatibility-wrap">
51
+ <p class="compatibility">
52
+ {{ localization.inventorySummary.compatibility }}
53
+ </p>
54
+ <div class="compatibility-message flex-align-start">
55
+ <ui-skeleton-item v-if="loading" width="160px" height="16px" />
56
+ <template v-else>
57
+ <template v-if="props.selectedStorage">
58
+ <ui-icon
59
+ name="success-fill"
60
+ width="16"
61
+ height="16"
62
+ class="icon-compatibility-alert"
63
+ />
64
+ <span class="compatibility-message-description">{{
65
+ localization.common.compatibilityChecksSucceeded
66
+ }}</span>
67
+ </template>
68
+ <template v-else>
69
+ <!-- <ui-icon name="error" width="16" height="16" />-->
70
+ <span class="compatibility-message-description empty">{{
71
+ localization.vmWizard.noStorageSelected
72
+ }}</span>
73
+ </template>
74
+ </template>
75
+ </div>
76
+ </div>
77
+ </div>
78
+ </template>
79
+
80
+ <script setup lang="ts">
81
+ import type { UI_I_DataTableOptions } from 'bfg-uikit/components/ui/dataTable/models/interfaces'
82
+ import type {
83
+ UI_I_DataTable,
84
+ UI_I_TableTexts,
85
+ } from '~/node_modules/bfg-uikit/components/ui/dataTable/models/interfaces'
86
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
87
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
88
+ import {
89
+ tableBodyFunc,
90
+ tableDataFunc,
91
+ tableOptions,
92
+ } from '~/components/common/vm/actions/common/select/storage/new/lib/config/table'
93
+ import { tableTextsFunc } from '~/lib/config/uiTable'
94
+
95
+ const selectedRow = defineModel<number | null>('selectedRow')
96
+
97
+ const props = defineProps<{
98
+ datastore: UI_I_DatastoreTableItem[]
99
+ isDatastoreLoading: boolean
100
+ errors: string[]
101
+ selectedStorage: UI_I_DatastoreTableItem | null
102
+ hideCompatibility?: boolean
103
+ hideAlert?: boolean
104
+ isInWizard?: boolean
105
+ tableOptions?: UI_I_DataTableOptions
106
+ }>()
107
+ const emits = defineEmits<{
108
+ (event: 'remove-error'): void
109
+ (event: 'change-storage', value: number): void
110
+ }>()
111
+
112
+ const tableOptionsLocal = computed(() => props.tableOptions || tableOptions)
113
+
114
+ const localization = computed<UI_I_Localization>(() => useLocal())
115
+
116
+ const tableTexts = computed<UI_I_TableTexts>(() =>
117
+ tableTextsFunc(localization.value)
118
+ )
119
+
120
+ const storageCount = computed<string>(() =>
121
+ localization.value.vmWizard.storageCount.replace(
122
+ '{0}',
123
+ data.value.body.length.toString()
124
+ )
125
+ )
126
+ // const loading = ref<boolean>(true)
127
+ const data = ref<UI_I_DataTable>(tableDataFunc(localization.value))
128
+
129
+ watch(
130
+ () => props.datastore,
131
+ (newValue: UI_I_DatastoreTableItem[]) => {
132
+ // loading.value = true
133
+
134
+ // if (!newValue.length || data.value.body.length) return
135
+
136
+ data.value.body = tableBodyFunc(
137
+ newValue,
138
+ localization.value,
139
+ selectedRow.value
140
+ )
141
+
142
+ // loading.value = false
143
+ },
144
+ { immediate: true, deep: true }
145
+ // { deep: true }
146
+ )
147
+
148
+ const onSelectRow = (selectedData: UI_I_DataTable): void => {
149
+ const selectedId = selectedData[0]?.data[0]?.data.id
150
+ const selectedItemIndex = props.datastore.findIndex(
151
+ (item) => item.id === selectedId
152
+ )
153
+
154
+ emits('change-storage', selectedItemIndex)
155
+ }
156
+ </script>
157
+
158
+ <style>
159
+ :root {
160
+ --select-storage-border-color: #e9ebed;
161
+ --select-storage-bg-color: #ffffff;
162
+ --select-storage-title-color: #4d5d69;
163
+ --select-storage-compatibility-bg-color: #ffffff;
164
+ --select-storage-compatibility-description-color: #4d5d69;
165
+ --select-storage-compatibility-empty-description-color: #9da6ad;
166
+ --select-storage-compatibility-table-column-button-hover-bg: #f6f7f8;
167
+ --select-storage-compatibility-table-column-button-active-hover-bg: #f0f8fd;
168
+ }
169
+ :root.dark-theme {
170
+ --select-storage-border-color: #e9ebed1f;
171
+ --select-storage-bg-color: var(--wizard-right-bg);
172
+ --select-storage-title-color: #e9eaec;
173
+ --select-storage-compatibility-bg-color: #1b2a371f;
174
+ --select-storage-compatibility-description-color: #e9eaec;
175
+ --select-storage-compatibility-empty-description-color: #9da6ad;
176
+ --select-storage-compatibility-table-column-button-hover-bg: linear-gradient(
177
+ 0deg,
178
+ rgba(233, 234, 236, 0.04) 0%,
179
+ rgba(233, 234, 236, 0.04) 100%
180
+ ),
181
+ rgba(27, 42, 55, 0.24);
182
+ --select-storage-compatibility-table-column-button-active-hover-bg: linear-gradient(
183
+ 0deg,
184
+ rgba(43, 162, 222, 0.08) 0%,
185
+ rgba(43, 162, 222, 0.08) 100%
186
+ ),
187
+ rgba(27, 42, 55, 0.24);
188
+ }
189
+ </style>
190
+ <style scoped lang="scss">
191
+ :root.dark-theme {
192
+ .select-storage {
193
+ &.in-wizard {
194
+ :deep(.column-manager-button) {
195
+ &:hover {
196
+ background: #b8bcc10a;
197
+ }
198
+ &.active:hover {
199
+ background-color: #2785b614;
200
+ }
201
+ }
202
+ }
203
+ }
204
+ }
205
+ .select-storage {
206
+ padding-top: 12px;
207
+ padding-bottom: 16px;
208
+
209
+ :deep(.title-sm) {
210
+ font-size: 12px;
211
+ }
212
+
213
+ :deep(.table-container.default-layout) {
214
+ box-shadow: unset;
215
+ padding: 0;
216
+ }
217
+ .storage-count {
218
+ font-size: 16px;
219
+ font-weight: 500;
220
+ color: var(--select-storage-title-color);
221
+ }
222
+
223
+ :deep(.column-manager-button) {
224
+ span {
225
+ font-size: 12px;
226
+ font-weight: 500;
227
+ }
228
+ &:not(.active):hover {
229
+ background-color: var(
230
+ --select-storage-compatibility-table-column-button-hover-bg
231
+ );
232
+ color: var(--btn-table-manager-color);
233
+ }
234
+ &.active:hover {
235
+ background-color: var(
236
+ --select-storage-compatibility-table-column-button-active-hover-bg
237
+ );
238
+ }
239
+ }
240
+
241
+ &:not(.in-wizard) {
242
+ :deep(.bottom-grid-content) {
243
+ border: 1px solid var(--select-storage-border-color);
244
+ border-radius: 8px;
245
+ padding: 12px;
246
+ background-color: var(--select-storage-bg-color);
247
+ }
248
+ :deep(.select-row-item) {
249
+ background-color: var(--select-storage-bg-color);
250
+ }
251
+ }
252
+
253
+ :deep(.table-title-actions-container) {
254
+ justify-content: flex-start;
255
+ }
256
+ :deep(.table-container .table-title) {
257
+ margin-bottom: 12px;
258
+ }
259
+
260
+ .compatibility-wrap {
261
+ margin-top: 24px;
262
+
263
+ .compatibility {
264
+ font-size: 16px;
265
+ font-weight: 500;
266
+ color: var(--select-storage-title-color);
267
+ margin-bottom: 16px;
268
+ }
269
+ .compatibility-message {
270
+ border-radius: 8px;
271
+ border: 1px solid var(--select-storage-border-color);
272
+ padding: 12px;
273
+ background-color: var(--select-storage-compatibility-bg-color);
274
+ gap: 10px;
275
+
276
+ .icon-compatibility-alert {
277
+ min-width: 16px;
278
+ min-height: 16px;
279
+ }
280
+ .compatibility-message-description {
281
+ font-size: 13px;
282
+ color: var(--select-storage-compatibility-description-color);
283
+
284
+ &.empty {
285
+ color: var(--select-storage-compatibility-empty-description-color);
286
+ }
287
+ }
288
+ }
289
+ }
290
+ .row-datastores-icon {
291
+ min-width: 18px;
292
+ }
293
+ }
294
+ </style>
@@ -1,6 +1,6 @@
1
- export interface UI_I_StatusData {
2
- iconClassName: string
3
- color: string
4
- isState: boolean
5
- text: string
1
+ export interface UI_I_StatusData {
2
+ iconClassName: string
3
+ color: string
4
+ isState: boolean
5
+ text: string
6
6
  }
@@ -1,21 +1,21 @@
1
- import type { UI_I_StatusData } from '~/components/common/vm/actions/common/select/storage/new/lib/models/interfaces'
2
-
3
- export const getStatus = (
4
- status: boolean,
5
- text1?: string,
6
- text2?: string
7
- ): UI_I_StatusData => {
8
- return status
9
- ? {
10
- iconClassName: 'status-check',
11
- color: 'green',
12
- isState: true,
13
- text: text1 || 'True',
14
- }
15
- : {
16
- iconClassName: 'close',
17
- color: 'red',
18
- isState: true,
19
- text: text2 || 'False',
20
- }
21
- }
1
+ import type { UI_I_StatusData } from '~/components/common/vm/actions/common/select/storage/new/lib/models/interfaces'
2
+
3
+ export const getStatus = (
4
+ status: boolean,
5
+ text1?: string,
6
+ text2?: string
7
+ ): UI_I_StatusData => {
8
+ return status
9
+ ? {
10
+ iconClassName: 'status-check',
11
+ color: 'green',
12
+ isState: true,
13
+ text: text1 || 'True',
14
+ }
15
+ : {
16
+ iconClassName: 'close',
17
+ color: 'red',
18
+ isState: true,
19
+ text: text2 || 'False',
20
+ }
21
+ }