bfg-common 1.5.585 → 1.5.586

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 (104) 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/perPage/PerPage.vue +58 -58
  9. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  10. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  11. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  12. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  13. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  14. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  15. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  16. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  17. package/components/common/diagramMain/port/Port.vue +580 -580
  18. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  19. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  20. package/components/common/pages/backups/DetailView.vue +52 -52
  21. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  22. package/components/common/pages/backups/modals/Modals.vue +243 -243
  23. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  24. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  25. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  26. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  27. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  28. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  29. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  30. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  31. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  32. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  33. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  34. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  35. package/components/common/select/radio/RadioGroup.vue +137 -137
  36. package/components/common/spiceConsole/Drawer.vue +420 -420
  37. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  38. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  39. package/components/common/tools/Actions.vue +207 -207
  40. package/components/common/treeView/TreeView.vue +52 -52
  41. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +325 -324
  42. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +1 -1
  43. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  44. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  45. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +158 -158
  46. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryOld.vue +155 -155
  47. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  48. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  49. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  50. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  51. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  52. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  53. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  54. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  55. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  56. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  57. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  58. package/components/common/vm/actions/common/select/os/New.vue +1 -1
  59. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  60. package/components/common/vm/actions/common/select/storage/Storage.vue +178 -178
  61. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  62. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  63. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  64. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  65. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  66. package/components/common/vm/actions/register/Register.vue +352 -352
  67. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  68. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  69. package/components/common/wizards/common/compatibility/New.vue +99 -99
  70. package/components/common/wizards/common/compatibility/Old.vue +53 -53
  71. package/components/common/wizards/common/steps/computeResource/ComputeResource.vue +86 -86
  72. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  73. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  74. package/components/common/wizards/common/steps/name/New.vue +221 -221
  75. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  76. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  77. package/components/common/wizards/common/steps/name/location/Location.vue +85 -85
  78. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  79. package/components/common/wizards/datastore/add/Add.vue +228 -228
  80. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  81. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  82. package/components/common/wizards/vm/migrate/select/computeResource/ComputeResource.vue +205 -205
  83. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  84. package/composables/useAppVersion.ts +21 -21
  85. package/composables/useLocal.ts +6 -6
  86. package/composables/useLocalCommon.ts +39 -39
  87. package/lib/models/store/host/interfaces.ts +32 -0
  88. package/package.json +1 -1
  89. package/plugins/console.ts +21 -21
  90. package/plugins/date.ts +233 -233
  91. package/plugins/mouse.ts +21 -21
  92. package/plugins/panelStates.ts +70 -70
  93. package/plugins/text.ts +59 -59
  94. package/public/spice-console/application/clientgui.js +854 -854
  95. package/public/spice-console/application/packetfactory.js +211 -211
  96. package/public/spice-console/application/virtualmouse.js +147 -147
  97. package/public/spice-console/lib/images/bitmap.js +203 -203
  98. package/public/spice-console/network/spicechannel.js +440 -440
  99. package/public/spice-console/process/cursorprocess.js +121 -121
  100. package/public/spice-console/process/inputprocess.js +227 -227
  101. package/public/spice-console/process/mainprocess.js +210 -210
  102. package/public/spice-console/run.js +210 -210
  103. package/store/main/mutations.ts +7 -7
  104. package/store/main/state.ts +7 -7
@@ -1,155 +1,155 @@
1
- <template>
2
- <div class="hardware-memory">
3
- <atoms-stack-block :has-children="true" test-id="memory-stack-block">
4
- <template #stackBlockKey>
5
- <div
6
- id="vm-wizard-toggle-block-memory"
7
- data-id="vm-wizard-toggle-block-memory"
8
- class="flex-align-center"
9
- >
10
- <span>{{ localization.common.memory }}</span>
11
- <atoms-the-icon
12
- v-show="props.memoryInvalid"
13
- width="24px"
14
- height="24px"
15
- class="is-error tooltip-trigger"
16
- name="info"
17
- />
18
- </div>
19
- </template>
20
- <template #stackBlockContent>
21
- <div class="flex-align-center">
22
- <atoms-tooltip-error
23
- :has-error="!!props.errorText"
24
- selector="#vm-wizard-memory-field input"
25
- @remove="emits('remove-error')"
26
- >
27
- <template #elem>
28
- <atoms-combobox
29
- id="vm-wizard-memory-field"
30
- v-model="selectedMemory"
31
- :items="props.memoryOptions"
32
- :disabled="props.isMemoryDisabled"
33
- test-id="vm-wizard-memory-field"
34
- class="input-text-color"
35
- @click.stop
36
- @select="emits('select-memory', $event)"
37
- />
38
- </template>
39
- <template #content>{{ props.errorText }}</template>
40
- </atoms-tooltip-error>
41
-
42
- <div class="select ml-1">
43
- <select
44
- id="vm-wizard-memory-type-select"
45
- v-model="memoryType"
46
- :disabled="props.isMemoryDisabled"
47
- data-id="vm-wizard-memory-type-select"
48
- class="input-text-color"
49
- @click.stop
50
- >
51
- <option
52
- v-for="(item, key) in props.memoryTypeOptions"
53
- :key="key"
54
- :value="item.value"
55
- >
56
- {{ item.text }}
57
- </option>
58
- </select>
59
- </div>
60
- </div>
61
- </template>
62
- <template #stackChildren>
63
- <common-vm-actions-common-customize-hardware-virtual-hardware-reservation
64
- v-model:reservation="reservation"
65
- v-model:reservation-type="reservationType"
66
- v-model:reserve-guest-memory="reserveGuestMemory"
67
- :error-validation-fields="props.errorValidationFields"
68
- :multiply="2"
69
- :disabled="props.isDisabled"
70
- component-type="memory"
71
- type="mb"
72
- class="memory-reservation"
73
- @remove-error-by-title="emits('remove-error-by-title', $event)"
74
- @invalid="reservationInvalid = $event"
75
- />
76
- <common-vm-actions-common-customize-hardware-virtual-hardware-limit
77
- v-model:limit="limit"
78
- v-model:limit-type="limitType"
79
- :error-validation-fields="props.errorValidationFields"
80
- :limit-options="props.limitOptions"
81
- :multiply="2"
82
- :disabled="isDisabled"
83
- type="mb"
84
- component-type="memory"
85
- class="memory-limit"
86
- @invalid="limitInvalid = $event"
87
- @remove-error-by-title="emits('remove-error-by-title', $event)"
88
- />
89
- <common-vm-actions-common-customize-hardware-virtual-hardware-memory-hot-plug
90
- v-model:memory-hot-plug="memoryHotPlug"
91
- :disabled="props.isDisabledMemoryHotPlug"
92
- />
93
- </template>
94
- </atoms-stack-block>
95
- </div>
96
- </template>
97
-
98
- <script setup lang="ts">
99
- import type { UI_I_Localization } from '~/lib/models/interfaces'
100
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
101
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
102
-
103
- const selectedMemory = defineModel<number>('selectedMemory', {
104
- required: true,
105
- })
106
- const memoryType = defineModel<string>('memoryType', {
107
- required: true,
108
- })
109
- const reservation = defineModel<string>('reservation', {
110
- required: true,
111
- })
112
- const reservationType = defineModel<string>('reservationType', {
113
- required: true,
114
- })
115
- const reserveGuestMemory = defineModel<boolean>('reserveGuestMemory', {
116
- required: true,
117
- })
118
- const reservationInvalid = defineModel<boolean>('reservationInvalid', {
119
- required: true,
120
- })
121
- const limit = defineModel<string>('limit', {
122
- required: true,
123
- })
124
- const limitType = defineModel<string>('limitType', {
125
- required: true,
126
- })
127
- const limitInvalid = defineModel<boolean>('limitInvalid', {
128
- required: true,
129
- })
130
- const memoryHotPlug = defineModel<boolean>('memoryHotPlug', {
131
- required: true,
132
- })
133
-
134
- const props = defineProps<{
135
- errorValidationFields: UI_I_ErrorValidationField[]
136
- memoryInvalid: boolean
137
- errorText: string
138
- memoryOptions: UI_I_OptionItem[]
139
- isMemoryDisabled: boolean
140
- memoryTypeOptions: UI_I_OptionItem[]
141
- isDisabled: boolean
142
- limitOptions: UI_I_OptionItem[]
143
- isDisabledMemoryHotPlug: boolean
144
- }>()
145
- const emits = defineEmits<{
146
- (event: 'remove-error-by-title', value: string): void
147
- (event: 'select-memory', value: any): void
148
- (event: 'remove-error'): void
149
- }>()
150
-
151
- const localization = computed<UI_I_Localization>(() => useLocal())
152
-
153
- </script>
154
-
155
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <div class="hardware-memory">
3
+ <atoms-stack-block :has-children="true" test-id="memory-stack-block">
4
+ <template #stackBlockKey>
5
+ <div
6
+ id="vm-wizard-toggle-block-memory"
7
+ data-id="vm-wizard-toggle-block-memory"
8
+ class="flex-align-center"
9
+ >
10
+ <span>{{ localization.common.memory }}</span>
11
+ <atoms-the-icon
12
+ v-show="props.memoryInvalid"
13
+ width="24px"
14
+ height="24px"
15
+ class="is-error tooltip-trigger"
16
+ name="info"
17
+ />
18
+ </div>
19
+ </template>
20
+ <template #stackBlockContent>
21
+ <div class="flex-align-center">
22
+ <atoms-tooltip-error
23
+ :has-error="!!props.errorText"
24
+ selector="#vm-wizard-memory-field input"
25
+ @remove="emits('remove-error')"
26
+ >
27
+ <template #elem>
28
+ <atoms-combobox
29
+ id="vm-wizard-memory-field"
30
+ v-model="selectedMemory"
31
+ :items="props.memoryOptions"
32
+ :disabled="props.isMemoryDisabled"
33
+ test-id="vm-wizard-memory-field"
34
+ class="input-text-color"
35
+ @click.stop
36
+ @select="emits('select-memory', $event)"
37
+ />
38
+ </template>
39
+ <template #content>{{ props.errorText }}</template>
40
+ </atoms-tooltip-error>
41
+
42
+ <div class="select ml-1">
43
+ <select
44
+ id="vm-wizard-memory-type-select"
45
+ v-model="memoryType"
46
+ :disabled="props.isMemoryDisabled"
47
+ data-id="vm-wizard-memory-type-select"
48
+ class="input-text-color"
49
+ @click.stop
50
+ >
51
+ <option
52
+ v-for="(item, key) in props.memoryTypeOptions"
53
+ :key="key"
54
+ :value="item.value"
55
+ >
56
+ {{ item.text }}
57
+ </option>
58
+ </select>
59
+ </div>
60
+ </div>
61
+ </template>
62
+ <template #stackChildren>
63
+ <common-vm-actions-common-customize-hardware-virtual-hardware-reservation
64
+ v-model:reservation="reservation"
65
+ v-model:reservation-type="reservationType"
66
+ v-model:reserve-guest-memory="reserveGuestMemory"
67
+ :error-validation-fields="props.errorValidationFields"
68
+ :multiply="2"
69
+ :disabled="props.isDisabled"
70
+ component-type="memory"
71
+ type="mb"
72
+ class="memory-reservation"
73
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
74
+ @invalid="reservationInvalid = $event"
75
+ />
76
+ <common-vm-actions-common-customize-hardware-virtual-hardware-limit
77
+ v-model:limit="limit"
78
+ v-model:limit-type="limitType"
79
+ :error-validation-fields="props.errorValidationFields"
80
+ :limit-options="props.limitOptions"
81
+ :multiply="2"
82
+ :disabled="isDisabled"
83
+ type="mb"
84
+ component-type="memory"
85
+ class="memory-limit"
86
+ @invalid="limitInvalid = $event"
87
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
88
+ />
89
+ <common-vm-actions-common-customize-hardware-virtual-hardware-memory-hot-plug
90
+ v-model:memory-hot-plug="memoryHotPlug"
91
+ :disabled="props.isDisabledMemoryHotPlug"
92
+ />
93
+ </template>
94
+ </atoms-stack-block>
95
+ </div>
96
+ </template>
97
+
98
+ <script setup lang="ts">
99
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
100
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
101
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
102
+
103
+ const selectedMemory = defineModel<number>('selectedMemory', {
104
+ required: true,
105
+ })
106
+ const memoryType = defineModel<string>('memoryType', {
107
+ required: true,
108
+ })
109
+ const reservation = defineModel<string>('reservation', {
110
+ required: true,
111
+ })
112
+ const reservationType = defineModel<string>('reservationType', {
113
+ required: true,
114
+ })
115
+ const reserveGuestMemory = defineModel<boolean>('reserveGuestMemory', {
116
+ required: true,
117
+ })
118
+ const reservationInvalid = defineModel<boolean>('reservationInvalid', {
119
+ required: true,
120
+ })
121
+ const limit = defineModel<string>('limit', {
122
+ required: true,
123
+ })
124
+ const limitType = defineModel<string>('limitType', {
125
+ required: true,
126
+ })
127
+ const limitInvalid = defineModel<boolean>('limitInvalid', {
128
+ required: true,
129
+ })
130
+ const memoryHotPlug = defineModel<boolean>('memoryHotPlug', {
131
+ required: true,
132
+ })
133
+
134
+ const props = defineProps<{
135
+ errorValidationFields: UI_I_ErrorValidationField[]
136
+ memoryInvalid: boolean
137
+ errorText: string
138
+ memoryOptions: UI_I_OptionItem[]
139
+ isMemoryDisabled: boolean
140
+ memoryTypeOptions: UI_I_OptionItem[]
141
+ isDisabled: boolean
142
+ limitOptions: UI_I_OptionItem[]
143
+ isDisabledMemoryHotPlug: boolean
144
+ }>()
145
+ const emits = defineEmits<{
146
+ (event: 'remove-error-by-title', value: string): void
147
+ (event: 'select-memory', value: any): void
148
+ (event: 'remove-error'): void
149
+ }>()
150
+
151
+ const localization = computed<UI_I_Localization>(() => useLocal())
152
+
153
+ </script>
154
+
155
+ <style scoped lang="scss"></style>
@@ -1,154 +1,154 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-new
3
- v-if="isNewView"
4
- v-model:selected-location="selectedLocation"
5
- :index="props.index"
6
- :datastore="props.datastore"
7
- :is-datastore-loading="props.isDatastoreLoading"
8
- :get-datastore-table-func="props.getDatastoreTableFunc"
9
- :api-error="apiError"
10
- :location-options="locationOptions"
11
- :storage-modal-is-show="storageModalIsShow"
12
- :storage-submit="storageSubmit"
13
- @change-location="onChangeLocation"
14
- @change-storage="onChangeStorage"
15
- @hide-storage-modal="onHideStorageModal"
16
- @submit-storage-modal="onSubmitStorageModal"
17
- @remove-validation-error="onRemoveValidationError"
18
- />
19
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-old
20
- v-else
21
- v-model:selected-location="selectedLocation"
22
- :index="props.index"
23
- :datastore="props.datastore"
24
- :is-datastore-loading="props.isDatastoreLoading"
25
- :get-datastore-table-func="props.getDatastoreTableFunc"
26
- :api-error="apiError"
27
- :location-options="locationOptions"
28
- :storage-modal-is-show="storageModalIsShow"
29
- :storage-submit="storageSubmit"
30
- @change-location="onChangeLocation"
31
- @change-storage="onChangeStorage"
32
- @hide-storage-modal="onHideStorageModal"
33
- @submit-storage-modal="onSubmitStorageModal"
34
- @remove-validation-error="onRemoveValidationError"
35
- />
36
- </template>
37
-
38
- <script setup lang="ts">
39
- import type {
40
- UI_I_HTMLSelectElement,
41
- UI_I_Localization,
42
- } from '~/lib/models/interfaces'
43
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
44
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
45
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
46
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
47
-
48
- const props = defineProps<{
49
- location: UI_I_DatastoreTableItem | null
50
- index: number
51
- errorValidationFields: UI_I_ErrorValidationField[]
52
- datastore: UI_I_DatastoreTableItem[]
53
- isDatastoreLoading: boolean
54
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
55
- }>()
56
- const emits = defineEmits<{
57
- (event: 'change', value: UI_I_DatastoreTableItem): void
58
- (event: 'remove-error-by-title', value: string): void
59
- }>()
60
-
61
- const { $store }: any = useNuxtApp()
62
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
63
-
64
- const localization = computed<UI_I_Localization>(() => useLocal())
65
-
66
- const selectedLocation = ref<string>(props.location?.id || '')
67
-
68
- const storages = ref<UI_I_DatastoreTableItem[]>([])
69
- const addStorage = (storage: UI_I_DatastoreTableItem): void => {
70
- const hasStorage = storages.value.some((item) => item.id === storage.id)
71
- if (hasStorage) {
72
- return
73
- }
74
-
75
- storages.value.push(storage)
76
- }
77
- const locationOptions = ref<UI_I_OptionItem[]>([])
78
-
79
- watch(
80
- () => props.location,
81
- (newValue) => {
82
- if (locationOptions.value.length || !newValue) {
83
- return
84
- }
85
-
86
- locationOptions.value = [
87
- {
88
- text: localization.value.common.storeWithVirtualMachine,
89
- value: newValue.id,
90
- },
91
- { text: `${localization.value.common.browse}...`, value: -1 },
92
- ]
93
- selectedLocation.value = newValue.id
94
- storages.value.push(newValue)
95
- addStorage(newValue)
96
- },
97
- { immediate: true }
98
- )
99
-
100
- const storageSubmit = ref<null | Function>(null)
101
- const onSubmitStorageModal = (): void => {
102
- storageSubmit.value = (_isValid: boolean): void => {
103
- storageSubmit.value = null
104
- }
105
- }
106
- const storageModalIsShow = ref<boolean>(false)
107
- const onHideStorageModal = (): void => {
108
- storageModalIsShow.value = false
109
- if (selectedLocation.value === -1)
110
- selectedLocation.value = locationOptions.value[0].value
111
- }
112
- const onChangeStorage = (storage: UI_I_DatastoreTableItem): void => {
113
- locationOptions.value = [
114
- locationOptions.value[0],
115
- { text: storage.name, value: storage.id },
116
- // @ts-ignore
117
- locationOptions.value.at(-1),
118
- ]
119
-
120
- selectedLocation.value = storage.id
121
- emits('change', storage)
122
- addStorage(storage)
123
- onHideStorageModal()
124
- }
125
- const onChangeLocation = (event: UI_I_HTMLSelectElement): void => {
126
- const value = +event.target.value
127
- if (value === -1) {
128
- storageModalIsShow.value = true
129
- return
130
- }
131
-
132
- selectedLocation.value = event.target.value
133
- const storage = storages.value.find((item) => item.id === event.target.value)
134
- storage && emits('change', storage)
135
- }
136
-
137
- const typeError = computed<string>(
138
- () => `disk_devices[${props.index}].location`
139
- )
140
-
141
- const apiError = computed<string>(() => {
142
- return (
143
- props.errorValidationFields?.find(
144
- (message) => message.field === typeError.value
145
- )?.error_message || ''
146
- )
147
- })
148
-
149
- const onRemoveValidationError = (): void => {
150
- emits('remove-error-by-title', typeError.value)
151
- }
152
- </script>
153
-
154
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-new
3
+ v-if="isNewView"
4
+ v-model:selected-location="selectedLocation"
5
+ :index="props.index"
6
+ :datastore="props.datastore"
7
+ :is-datastore-loading="props.isDatastoreLoading"
8
+ :get-datastore-table-func="props.getDatastoreTableFunc"
9
+ :api-error="apiError"
10
+ :location-options="locationOptions"
11
+ :storage-modal-is-show="storageModalIsShow"
12
+ :storage-submit="storageSubmit"
13
+ @change-location="onChangeLocation"
14
+ @change-storage="onChangeStorage"
15
+ @hide-storage-modal="onHideStorageModal"
16
+ @submit-storage-modal="onSubmitStorageModal"
17
+ @remove-validation-error="onRemoveValidationError"
18
+ />
19
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-location-old
20
+ v-else
21
+ v-model:selected-location="selectedLocation"
22
+ :index="props.index"
23
+ :datastore="props.datastore"
24
+ :is-datastore-loading="props.isDatastoreLoading"
25
+ :get-datastore-table-func="props.getDatastoreTableFunc"
26
+ :api-error="apiError"
27
+ :location-options="locationOptions"
28
+ :storage-modal-is-show="storageModalIsShow"
29
+ :storage-submit="storageSubmit"
30
+ @change-location="onChangeLocation"
31
+ @change-storage="onChangeStorage"
32
+ @hide-storage-modal="onHideStorageModal"
33
+ @submit-storage-modal="onSubmitStorageModal"
34
+ @remove-validation-error="onRemoveValidationError"
35
+ />
36
+ </template>
37
+
38
+ <script setup lang="ts">
39
+ import type {
40
+ UI_I_HTMLSelectElement,
41
+ UI_I_Localization,
42
+ } from '~/lib/models/interfaces'
43
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
44
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
45
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
46
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
47
+
48
+ const props = defineProps<{
49
+ location: UI_I_DatastoreTableItem | null
50
+ index: number
51
+ errorValidationFields: UI_I_ErrorValidationField[]
52
+ datastore: UI_I_DatastoreTableItem[]
53
+ isDatastoreLoading: boolean
54
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
55
+ }>()
56
+ const emits = defineEmits<{
57
+ (event: 'change', value: UI_I_DatastoreTableItem): void
58
+ (event: 'remove-error-by-title', value: string): void
59
+ }>()
60
+
61
+ const { $store }: any = useNuxtApp()
62
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
63
+
64
+ const localization = computed<UI_I_Localization>(() => useLocal())
65
+
66
+ const selectedLocation = ref<string>(props.location?.id || '')
67
+
68
+ const storages = ref<UI_I_DatastoreTableItem[]>([])
69
+ const addStorage = (storage: UI_I_DatastoreTableItem): void => {
70
+ const hasStorage = storages.value.some((item) => item.id === storage.id)
71
+ if (hasStorage) {
72
+ return
73
+ }
74
+
75
+ storages.value.push(storage)
76
+ }
77
+ const locationOptions = ref<UI_I_OptionItem[]>([])
78
+
79
+ watch(
80
+ () => props.location,
81
+ (newValue) => {
82
+ if (locationOptions.value.length || !newValue) {
83
+ return
84
+ }
85
+
86
+ locationOptions.value = [
87
+ {
88
+ text: localization.value.common.storeWithVirtualMachine,
89
+ value: newValue.id,
90
+ },
91
+ { text: `${localization.value.common.browse}...`, value: -1 },
92
+ ]
93
+ selectedLocation.value = newValue.id
94
+ storages.value.push(newValue)
95
+ addStorage(newValue)
96
+ },
97
+ { immediate: true }
98
+ )
99
+
100
+ const storageSubmit = ref<null | Function>(null)
101
+ const onSubmitStorageModal = (): void => {
102
+ storageSubmit.value = (_isValid: boolean): void => {
103
+ storageSubmit.value = null
104
+ }
105
+ }
106
+ const storageModalIsShow = ref<boolean>(false)
107
+ const onHideStorageModal = (): void => {
108
+ storageModalIsShow.value = false
109
+ if (selectedLocation.value === -1)
110
+ selectedLocation.value = locationOptions.value[0].value
111
+ }
112
+ const onChangeStorage = (storage: UI_I_DatastoreTableItem): void => {
113
+ locationOptions.value = [
114
+ locationOptions.value[0],
115
+ { text: storage.name, value: storage.id },
116
+ // @ts-ignore
117
+ locationOptions.value.at(-1),
118
+ ]
119
+
120
+ selectedLocation.value = storage.id
121
+ emits('change', storage)
122
+ addStorage(storage)
123
+ onHideStorageModal()
124
+ }
125
+ const onChangeLocation = (event: UI_I_HTMLSelectElement): void => {
126
+ const value = +event.target.value
127
+ if (value === -1) {
128
+ storageModalIsShow.value = true
129
+ return
130
+ }
131
+
132
+ selectedLocation.value = event.target.value
133
+ const storage = storages.value.find((item) => item.id === event.target.value)
134
+ storage && emits('change', storage)
135
+ }
136
+
137
+ const typeError = computed<string>(
138
+ () => `disk_devices[${props.index}].location`
139
+ )
140
+
141
+ const apiError = computed<string>(() => {
142
+ return (
143
+ props.errorValidationFields?.find(
144
+ (message) => message.field === typeError.value
145
+ )?.error_message || ''
146
+ )
147
+ })
148
+
149
+ const onRemoveValidationError = (): void => {
150
+ emits('remove-error-by-title', typeError.value)
151
+ }
152
+ </script>
153
+
154
+ <style scoped lang="scss"></style>