bfg-common 1.5.583 → 1.5.585

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 (113) 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 +3 -1
  7. package/assets/localization/local_en.json +3 -1
  8. package/assets/localization/local_hy.json +3 -1
  9. package/assets/localization/local_kk.json +3 -1
  10. package/assets/localization/local_ru.json +3 -1
  11. package/assets/localization/local_zh.json +3 -1
  12. package/components/atoms/TheIcon3.vue +50 -50
  13. package/components/atoms/collapse/CollapseNav.vue +170 -170
  14. package/components/atoms/perPage/PerPage.vue +58 -58
  15. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  16. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  17. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  18. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  19. package/components/common/backup/storage/actions/add/Add.vue +252 -251
  20. package/components/common/backup/storage/actions/add/Old.vue +3 -2
  21. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  22. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +2 -2
  23. package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +7 -7
  24. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  25. package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
  26. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  27. package/components/common/diagramMain/port/Port.vue +580 -580
  28. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  29. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  30. package/components/common/monitor/overview/filters/lib/config/filterOptions.ts +2 -2
  31. package/components/common/pages/backups/DetailView.vue +52 -52
  32. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  33. package/components/common/pages/backups/modals/Modals.vue +243 -243
  34. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  35. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  36. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  37. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  38. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  39. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  40. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  41. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  42. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  43. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  44. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  45. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  46. package/components/common/select/radio/RadioGroup.vue +137 -137
  47. package/components/common/spiceConsole/Drawer.vue +420 -420
  48. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  49. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  50. package/components/common/tools/Actions.vue +207 -207
  51. package/components/common/treeView/TreeView.vue +52 -52
  52. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  53. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  54. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +158 -158
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryOld.vue +155 -155
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  61. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  62. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  63. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  64. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  65. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  66. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  67. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  68. package/components/common/vm/actions/common/select/storage/Storage.vue +178 -178
  69. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  70. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  71. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  72. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  73. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  74. package/components/common/vm/actions/register/Register.vue +352 -352
  75. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  76. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  77. package/components/common/wizards/common/compatibility/New.vue +99 -99
  78. package/components/common/wizards/common/compatibility/Old.vue +53 -53
  79. package/components/common/wizards/common/steps/computeResource/ComputeResource.vue +86 -86
  80. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  81. package/components/common/wizards/common/steps/computeResource/Old.vue +104 -103
  82. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  83. package/components/common/wizards/common/steps/name/New.vue +221 -221
  84. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  85. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  86. package/components/common/wizards/common/steps/name/location/Location.vue +85 -85
  87. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  88. package/components/common/wizards/common/steps/name/location/Old.vue +1 -0
  89. package/components/common/wizards/datastore/add/Add.vue +228 -228
  90. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  91. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  92. package/components/common/wizards/vm/migrate/select/computeResource/ComputeResource.vue +205 -205
  93. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  94. package/composables/useAppVersion.ts +21 -21
  95. package/composables/useLocal.ts +6 -6
  96. package/composables/useLocalCommon.ts +39 -39
  97. package/package.json +1 -1
  98. package/plugins/console.ts +21 -21
  99. package/plugins/date.ts +233 -233
  100. package/plugins/mouse.ts +21 -21
  101. package/plugins/panelStates.ts +70 -70
  102. package/plugins/text.ts +59 -59
  103. package/public/spice-console/application/clientgui.js +854 -854
  104. package/public/spice-console/application/packetfactory.js +211 -211
  105. package/public/spice-console/application/virtualmouse.js +147 -147
  106. package/public/spice-console/lib/images/bitmap.js +203 -203
  107. package/public/spice-console/network/spicechannel.js +440 -440
  108. package/public/spice-console/process/cursorprocess.js +121 -121
  109. package/public/spice-console/process/inputprocess.js +227 -227
  110. package/public/spice-console/process/mainprocess.js +210 -210
  111. package/public/spice-console/run.js +210 -210
  112. package/store/main/mutations.ts +7 -7
  113. 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>