bfg-common 1.5.161 → 1.5.162

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 (120) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/components/atoms/TheIcon3.vue +50 -50
  3. package/components/atoms/perPage/PerPage.vue +58 -58
  4. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  5. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  6. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  7. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  8. package/components/common/context/lib/models/interfaces.ts +31 -31
  9. package/components/common/context/recursion/RecursionNew.vue +238 -238
  10. package/components/common/diagramMain/DiagramMain.vue +897 -897
  11. package/components/common/diagramMain/Header.vue +214 -214
  12. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  13. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  14. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +1040 -1040
  15. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  16. package/components/common/pages/home/headline/Headline.vue +45 -45
  17. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  18. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  19. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  20. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  21. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  22. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  23. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  24. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  25. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  26. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  27. package/components/common/pages/packages/Packages.vue +208 -208
  28. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  29. package/components/common/readyToComplete/New.vue +66 -66
  30. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  31. package/components/common/recursionTree/RecursionTree.vue +223 -223
  32. package/components/common/select/button/ButtonDropdown.vue +108 -108
  33. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  34. package/components/common/vm/actions/add/Add.vue +785 -785
  35. package/components/common/vm/actions/add/New.vue +556 -556
  36. package/components/common/vm/actions/add/Old.vue +371 -371
  37. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  38. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  39. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  40. package/components/common/vm/actions/add/lib/config/steps.ts +263 -263
  41. package/components/common/vm/actions/clone/Clone.vue +810 -810
  42. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  43. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +626 -626
  44. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  45. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  46. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  47. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  48. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  49. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  50. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  51. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  52. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  53. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  54. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +375 -375
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +149 -149
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +74 -74
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +83 -83
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  75. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  76. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  77. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  78. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  79. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  80. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  81. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  82. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  83. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  84. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  85. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  86. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  87. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +39 -39
  88. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  89. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  90. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  91. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +134 -134
  92. package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +44 -44
  93. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  94. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  95. package/components/common/vm/actions/common/select/createType/New.vue +84 -84
  96. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  97. package/components/common/vm/actions/common/select/name/Name.vue +167 -167
  98. package/components/common/vm/actions/common/select/os/New.vue +122 -122
  99. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  100. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  101. package/components/common/vm/actions/common/select/storage/Storage.vue +129 -129
  102. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +326 -326
  103. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  104. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  105. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  106. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  107. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  108. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  109. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +137 -137
  110. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  111. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  112. package/composables/productNameLocal.ts +30 -30
  113. package/composables/useAppVersion.ts +21 -21
  114. package/package.json +2 -2
  115. package/plugins/date.ts +233 -233
  116. package/public/spice-console/lib/images/bitmap.js +203 -203
  117. package/public/spice-console/network/spicechannel.js +383 -383
  118. package/store/main/mutations.ts +7 -7
  119. package/store/main/state.ts +7 -7
  120. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,375 +1,375 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-new
3
- v-if="isNewView"
4
- v-model:delete-files-from-datastore="deleteFilesFromDatastore"
5
- v-model:size="size"
6
- v-model:hard-disk-type="hardDiskType"
7
- v-model:disk-provisioning="diskProvisioning"
8
- v-model:sharing="sharing"
9
- v-model:limit-iops="limitIops"
10
- v-model:limit-iops-type="limitIopsType"
11
- v-model:limit-iops-invalid="limitIopsInvalid"
12
- v-model:disk-mode="diskMode"
13
- v-model:cache="cache"
14
- v-model:bus="bus"
15
- :is-removable="isRemovable"
16
- :label="label"
17
- :hard-disk-invalid="hardDiskInvalid"
18
- :error-text="hardDiskLocalAndApiErrorsTexts"
19
- :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
20
- :is-disabled-size="isDisabledSize"
21
- :hard-disk-type-options="hardDiskTypeOptions"
22
- :max-hard-disk="maxHardDisk"
23
- :location="location"
24
- :is-running="isRunning"
25
- :is-new-hard-disk="!isNotNewHardDisk"
26
- :is-edit="props.isEdit"
27
- :datastore="props.datastore"
28
- :get-datastore-table-func="props.getDatastoreTableFunc"
29
- :error-validation-fields="props.errorValidationFields"
30
- :index="props.index"
31
- :type="props.type"
32
- :hard-disk="props.hardDisk"
33
- :guest-machine-type="props.guestMachineType"
34
- :is-new-type="isNewType"
35
- :compute-resource="props.computeResource"
36
- @remove="emits('remove')"
37
- @roll-back="emits('roll-back')"
38
- @validate-size="onValidateSize"
39
- @change-storage="onChangeStorage"
40
- @remove-error-by-title="emits('remove-error-by-title', $event)"
41
- />
42
- <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-old
43
- v-else
44
- v-model:delete-files-from-datastore="deleteFilesFromDatastore"
45
- v-model:size="size"
46
- v-model:hard-disk-type="hardDiskType"
47
- v-model:disk-provisioning="diskProvisioning"
48
- v-model:sharing="sharing"
49
- v-model:limit-iops="limitIops"
50
- v-model:limit-iops-type="limitIopsType"
51
- v-model:limit-iops-invalid="limitIopsInvalid"
52
- v-model:disk-mode="diskMode"
53
- v-model:cache="cache"
54
- v-model:bus="bus"
55
- :is-removable="isRemovable"
56
- :label="label"
57
- :hard-disk-invalid="hardDiskInvalid"
58
- :error-text="hardDiskLocalAndApiErrorsTexts"
59
- :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
60
- :is-disabled-size="isDisabledSize"
61
- :hard-disk-type-options="hardDiskTypeOptions"
62
- :max-hard-disk="maxHardDisk"
63
- :location="location"
64
- :is-running="isRunning"
65
- :is-new-hard-disk="!isNotNewHardDisk"
66
- :is-edit="props.isEdit"
67
- :datastore="props.datastore"
68
- :get-datastore-table-func="props.getDatastoreTableFunc"
69
- :error-validation-fields="props.errorValidationFields"
70
- :index="props.index"
71
- :type="props.type"
72
- :hard-disk="props.hardDisk"
73
- :guest-machine-type="props.guestMachineType"
74
- :is-new-type="isNewType"
75
- :compute-resource="props.computeResource"
76
- @remove="emits('remove')"
77
- @roll-back="emits('roll-back')"
78
- @validate-size="onValidateSize"
79
- @change-storage="onChangeStorage"
80
- @remove-error-by-title="emits('remove-error-by-title', $event)"
81
- />
82
- </template>
83
-
84
- <script setup lang="ts">
85
- import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
86
- import type {
87
- UI_I_SendDataNewHardDisk,
88
- UI_I_SendDataNewHardDiskStorage,
89
- } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
90
- import type { UI_T_HardDiskType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
91
- import type { UI_I_Localization } from '~/lib/models/interfaces'
92
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
93
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
94
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
95
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
96
- import { binaryOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/binaryOptions'
97
-
98
- const props = defineProps<{
99
- storage: UI_I_DatastoreTableItem | null
100
- hardDisk: UI_I_SendDataNewHardDisk
101
- type: UI_T_HardDiskType
102
- index: number
103
- errorValidationFields: UI_I_ErrorValidationField[]
104
- getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
105
- datastore: UI_I_DatastoreTableItem[]
106
- isEdit: boolean
107
- state?: string | number
108
- guestMachineType?: UI_I_OptionItem | null
109
- computeResource?: UI_I_TreeNode | null
110
- }>()
111
- const emits = defineEmits<{
112
- (event: 'send-data', value: UI_I_SendDataNewHardDisk): void
113
- (event: 'invalid', value: boolean): void
114
- (event: 'remove'): void
115
- (event: 'roll-back'): void
116
- (event: 'remove-error-by-title', value: string): void
117
- }>()
118
-
119
- const { $store, $binary }: any = useNuxtApp()
120
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
121
-
122
- const localization = computed<UI_I_Localization>(() => useLocal())
123
-
124
- const isRunning = computed<boolean>(() => {
125
- return props.state === 2
126
- })
127
-
128
- const isRemovable = computed<boolean>(() => {
129
- return (
130
- !props.isEdit ||
131
- !isRunning.value ||
132
- (isRunning.value && bus.value === 'virtio')
133
- )
134
- })
135
-
136
- const isNewType = computed<boolean>(
137
- () => props.type === 'new' || props.type === 'clone'
138
- )
139
-
140
- const typeError = computed<string>(() => `disk_devices[${props.index}].size`)
141
-
142
- const apiErrorLocal = computed<string>(() => {
143
- return (
144
- props.errorValidationFields?.find(
145
- (message) => message.field === typeError.value
146
- )?.error_message || ''
147
- )
148
- })
149
-
150
- // PC-1796
151
- const isNotNewHardDisk = computed<boolean>(
152
- () => props.type === 'edit' || props.type === 'removed'
153
- )
154
- const label = computed<string>(() => {
155
- // if (props.type === 'edit' || props.type === 'removed')
156
- if (isNotNewHardDisk.value)
157
- return `${localization.value.common.hardDisk} ${props.index + 1}`
158
-
159
- return `${localization.value.common.newHardDisk} *`
160
- })
161
-
162
- const maxHardDisk = computed<number>(() => {
163
- const hardDiskSizeMb = $binary.gbToMb(props.hardDisk.size)
164
-
165
- if (props.type === 'exist') return hardDiskSizeMb
166
-
167
- if (!storage.value) return 0
168
- const free = storage.value.capacity.free_mb || storage.value.capacity // TODO fix
169
-
170
- if (props.isEdit)
171
- return free + hardDiskSizeMb
172
-
173
- return free
174
- })
175
- const hardDiskTypeErrorLocalText = computed<string>(() => {
176
- if (+sizeInMb.value > maxHardDisk.value) {
177
- return localization.value.common.diskCapacitySpecifiedGreater
178
- }
179
-
180
- if (+sizeInMb.value <= 0) {
181
- return localization.value.common.diskCapacityCannotZero
182
- }
183
-
184
- return ''
185
- })
186
-
187
- const hardDiskLocalAndApiErrorsTexts = computed<string>(() => {
188
- const localError = hardDiskTypeErrorLocalText.value
189
- const apiError = apiErrorLocal.value
190
-
191
- let result = ''
192
- if (localError && !apiError) result = localError
193
- if (!localError && apiError) result = apiError
194
- if (localError && apiError) result = localError + ', ' + apiError
195
- if (!localError && apiError) result = apiError
196
-
197
- return result
198
- })
199
-
200
- const deleteFilesFromDatastore = ref<boolean>(false)
201
-
202
- const hardDiskType = ref<string>('gb')
203
- const hardDiskTypeOptions = ref<UI_I_OptionItem[]>(
204
- binaryOptionsFunc(localization.value)
205
- )
206
-
207
- const size = ref<number>(props.hardDisk.size) // Изначально всегда приходит в gb
208
- const sizeInMb = computed<number>(() => {
209
- if (hardDiskType.value === 'mb') {
210
- return size.value
211
- }
212
-
213
- return $binary.universalFromTo(size.value, hardDiskType.value, 'mb')
214
- })
215
- const onValidateSize = (): void => {
216
- if (props.type !== 'edit') return
217
- if (sizeInMb.value < $binary.gbToMb(props.hardDisk.size)) {
218
- size.value = $binary.universalFromTo(
219
- props.hardDisk.size,
220
- 'gb',
221
- hardDiskType.value
222
- )
223
- }
224
- }
225
-
226
- const isDisabledSize = computed<boolean>(() => {
227
- return props.type === 'exist' || (props.type === 'edit' && readOnly.value)
228
- })
229
-
230
- const location = ref<UI_I_DatastoreTableItem | null>(props.storage || null)
231
- const storage = ref<UI_I_DatastoreTableItem | null>(props.storage)
232
- watch(
233
- () => props.storage,
234
- (newValue) => {
235
- location.value = newValue
236
- storage.value = newValue
237
- },
238
- {
239
- immediate: true,
240
- deep: true,
241
- }
242
- )
243
- const onChangeStorage = (item: UI_I_DatastoreTableItem): void => {
244
- storage.value = item
245
- }
246
-
247
- const diskProvisioning = ref<string>('thick')
248
- const sharing = ref<string>('')
249
- const shares = ref<number>(0)
250
-
251
- const limitIops = ref<number>(16)
252
- const limitIopsType = ref<string>('unlimited')
253
- const limitIopsInvalid = ref<boolean>(false)
254
-
255
- const diskMode = ref<string>('dependent')
256
-
257
- const cache = ref<string>('none')
258
-
259
- const bus = ref<string>('ide')
260
-
261
- const readOnly = ref<boolean>(false)
262
-
263
- const discard = ref<string>('')
264
-
265
- const io = ref<string>('')
266
-
267
- const target = ref<string>('')
268
-
269
- watch(
270
- [
271
- sizeInMb,
272
- storage,
273
- diskProvisioning,
274
- sharing,
275
- limitIops,
276
- limitIopsType,
277
- diskMode,
278
- cache,
279
- bus,
280
- deleteFilesFromDatastore,
281
- (): void => props.type,
282
- ],
283
- () => {
284
- const limitIopsLocal =
285
- limitIopsType.value === 'unlimited' ? 0 : limitIops.value
286
- const storageLocal: UI_I_SendDataNewHardDiskStorage = {
287
- id: storage.value?.id || '',
288
- name: storage.value?.name || '',
289
- type: storage.value?.type_text || '',
290
- pool: storage.value?.pool_name || '',
291
- user: '',
292
- endpoint: '',
293
- password: '',
294
- protocol: '',
295
- options: '',
296
- }
297
-
298
- emits('send-data', {
299
- create: props.hardDisk.create,
300
- attach: props.hardDisk.attach,
301
- source: props.hardDisk.source,
302
- size: Math.ceil(sizeInMb.value),
303
- bus: bus.value,
304
- target: target.value,
305
- storage: storageLocal,
306
- device_type: 'disk',
307
- provision_type: diskProvisioning.value,
308
- disk_mode: diskMode.value,
309
- sharing: sharing.value === 'yes',
310
- read_only: readOnly.value,
311
- shares: shares.value,
312
- cache: cache.value,
313
- io: io.value,
314
- limit_iops: limitIopsLocal,
315
- discard: discard.value,
316
- capacity: Math.ceil(sizeInMb.value),
317
- boot_order: props.hardDisk.boot_order,
318
- detach: props.type === 'removed',
319
- remove: props.type === 'removed' && deleteFilesFromDatastore.value, // Проверяем если удалили диск и указали Delete files from datastore
320
- })
321
- },
322
- { immediate: true }
323
- )
324
-
325
- // Добавляем данные для редактирования
326
- watch(
327
- () => props.hardDisk,
328
- (newValue) => {
329
- // TODO refactoring
330
- if (props.type === 'exist') {
331
- diskProvisioning.value = newValue.provision_type || 'thick'
332
- return
333
- }
334
- // if (props.type !== 'edit') return
335
- if (props.type !== 'edit' && props.type !== 'clone') return
336
-
337
- diskProvisioning.value = newValue.provision_type || 'thick'
338
- sharing.value = newValue.sharing ? 'yes' : ''
339
- shares.value = newValue.shares || 0
340
- // limitIopsType.value = newValue.io === 'native' ? 'unlimited' : 'custom'
341
- limitIopsType.value = newValue.limit_iops === 0 ? 'unlimited' : 'custom'
342
- limitIops.value = newValue.limit_iops || 16
343
- diskMode.value = newValue.disk_mode || 'dependent'
344
- cache.value = newValue.cache || 'none'
345
- bus.value = newValue.bus || 'ide'
346
- readOnly.value = newValue.read_only || false
347
- discard.value = newValue.discard || ''
348
- io.value = newValue.io || ''
349
- target.value = newValue.target || ''
350
- },
351
- { immediate: true }
352
- )
353
- watch(
354
- isRunning,
355
- (newValue) => {
356
- if (newValue && props.type === 'new') {
357
- bus.value = 'virtio'
358
- }
359
- },
360
- { immediate: true }
361
- )
362
-
363
- const hardDiskInvalid = computed<boolean>(() => {
364
- return !!hardDiskTypeErrorLocalText.value || limitIopsInvalid.value
365
- })
366
- watch(
367
- hardDiskInvalid,
368
- (newValue) => {
369
- emits('invalid', newValue)
370
- },
371
- { immediate: true }
372
- )
373
- </script>
374
-
375
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-new
3
+ v-if="isNewView"
4
+ v-model:delete-files-from-datastore="deleteFilesFromDatastore"
5
+ v-model:size="size"
6
+ v-model:hard-disk-type="hardDiskType"
7
+ v-model:disk-provisioning="diskProvisioning"
8
+ v-model:sharing="sharing"
9
+ v-model:limit-iops="limitIops"
10
+ v-model:limit-iops-type="limitIopsType"
11
+ v-model:limit-iops-invalid="limitIopsInvalid"
12
+ v-model:disk-mode="diskMode"
13
+ v-model:cache="cache"
14
+ v-model:bus="bus"
15
+ :is-removable="isRemovable"
16
+ :label="label"
17
+ :hard-disk-invalid="hardDiskInvalid"
18
+ :error-text="hardDiskLocalAndApiErrorsTexts"
19
+ :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
20
+ :is-disabled-size="isDisabledSize"
21
+ :hard-disk-type-options="hardDiskTypeOptions"
22
+ :max-hard-disk="maxHardDisk"
23
+ :location="location"
24
+ :is-running="isRunning"
25
+ :is-new-hard-disk="!isNotNewHardDisk"
26
+ :is-edit="props.isEdit"
27
+ :datastore="props.datastore"
28
+ :get-datastore-table-func="props.getDatastoreTableFunc"
29
+ :error-validation-fields="props.errorValidationFields"
30
+ :index="props.index"
31
+ :type="props.type"
32
+ :hard-disk="props.hardDisk"
33
+ :guest-machine-type="props.guestMachineType"
34
+ :is-new-type="isNewType"
35
+ :compute-resource="props.computeResource"
36
+ @remove="emits('remove')"
37
+ @roll-back="emits('roll-back')"
38
+ @validate-size="onValidateSize"
39
+ @change-storage="onChangeStorage"
40
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
41
+ />
42
+ <common-vm-actions-common-customize-hardware-virtual-hardware-new-hard-disk-old
43
+ v-else
44
+ v-model:delete-files-from-datastore="deleteFilesFromDatastore"
45
+ v-model:size="size"
46
+ v-model:hard-disk-type="hardDiskType"
47
+ v-model:disk-provisioning="diskProvisioning"
48
+ v-model:sharing="sharing"
49
+ v-model:limit-iops="limitIops"
50
+ v-model:limit-iops-type="limitIopsType"
51
+ v-model:limit-iops-invalid="limitIopsInvalid"
52
+ v-model:disk-mode="diskMode"
53
+ v-model:cache="cache"
54
+ v-model:bus="bus"
55
+ :is-removable="isRemovable"
56
+ :label="label"
57
+ :hard-disk-invalid="hardDiskInvalid"
58
+ :error-text="hardDiskLocalAndApiErrorsTexts"
59
+ :hard-disk-type-error-local-text="hardDiskTypeErrorLocalText"
60
+ :is-disabled-size="isDisabledSize"
61
+ :hard-disk-type-options="hardDiskTypeOptions"
62
+ :max-hard-disk="maxHardDisk"
63
+ :location="location"
64
+ :is-running="isRunning"
65
+ :is-new-hard-disk="!isNotNewHardDisk"
66
+ :is-edit="props.isEdit"
67
+ :datastore="props.datastore"
68
+ :get-datastore-table-func="props.getDatastoreTableFunc"
69
+ :error-validation-fields="props.errorValidationFields"
70
+ :index="props.index"
71
+ :type="props.type"
72
+ :hard-disk="props.hardDisk"
73
+ :guest-machine-type="props.guestMachineType"
74
+ :is-new-type="isNewType"
75
+ :compute-resource="props.computeResource"
76
+ @remove="emits('remove')"
77
+ @roll-back="emits('roll-back')"
78
+ @validate-size="onValidateSize"
79
+ @change-storage="onChangeStorage"
80
+ @remove-error-by-title="emits('remove-error-by-title', $event)"
81
+ />
82
+ </template>
83
+
84
+ <script setup lang="ts">
85
+ import type { UI_I_DatastoreTableItem } from '~/lib/models/store/storage/interfaces'
86
+ import type {
87
+ UI_I_SendDataNewHardDisk,
88
+ UI_I_SendDataNewHardDiskStorage,
89
+ } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces'
90
+ import type { UI_T_HardDiskType } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types'
91
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
92
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
93
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
94
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
95
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
96
+ import { binaryOptionsFunc } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/binaryOptions'
97
+
98
+ const props = defineProps<{
99
+ storage: UI_I_DatastoreTableItem | null
100
+ hardDisk: UI_I_SendDataNewHardDisk
101
+ type: UI_T_HardDiskType
102
+ index: number
103
+ errorValidationFields: UI_I_ErrorValidationField[]
104
+ getDatastoreTableFunc: (payload: UI_I_TablePayload) => Promise<void>
105
+ datastore: UI_I_DatastoreTableItem[]
106
+ isEdit: boolean
107
+ state?: string | number
108
+ guestMachineType?: UI_I_OptionItem | null
109
+ computeResource?: UI_I_TreeNode | null
110
+ }>()
111
+ const emits = defineEmits<{
112
+ (event: 'send-data', value: UI_I_SendDataNewHardDisk): void
113
+ (event: 'invalid', value: boolean): void
114
+ (event: 'remove'): void
115
+ (event: 'roll-back'): void
116
+ (event: 'remove-error-by-title', value: string): void
117
+ }>()
118
+
119
+ const { $store, $binary }: any = useNuxtApp()
120
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
121
+
122
+ const localization = computed<UI_I_Localization>(() => useLocal())
123
+
124
+ const isRunning = computed<boolean>(() => {
125
+ return props.state === 2
126
+ })
127
+
128
+ const isRemovable = computed<boolean>(() => {
129
+ return (
130
+ !props.isEdit ||
131
+ !isRunning.value ||
132
+ (isRunning.value && bus.value === 'virtio')
133
+ )
134
+ })
135
+
136
+ const isNewType = computed<boolean>(
137
+ () => props.type === 'new' || props.type === 'clone'
138
+ )
139
+
140
+ const typeError = computed<string>(() => `disk_devices[${props.index}].size`)
141
+
142
+ const apiErrorLocal = computed<string>(() => {
143
+ return (
144
+ props.errorValidationFields?.find(
145
+ (message) => message.field === typeError.value
146
+ )?.error_message || ''
147
+ )
148
+ })
149
+
150
+ // PC-1796
151
+ const isNotNewHardDisk = computed<boolean>(
152
+ () => props.type === 'edit' || props.type === 'removed'
153
+ )
154
+ const label = computed<string>(() => {
155
+ // if (props.type === 'edit' || props.type === 'removed')
156
+ if (isNotNewHardDisk.value)
157
+ return `${localization.value.common.hardDisk} ${props.index + 1}`
158
+
159
+ return `${localization.value.common.newHardDisk} *`
160
+ })
161
+
162
+ const maxHardDisk = computed<number>(() => {
163
+ const hardDiskSizeMb = $binary.gbToMb(props.hardDisk.size)
164
+
165
+ if (props.type === 'exist') return hardDiskSizeMb
166
+
167
+ if (!storage.value) return 0
168
+ const free = storage.value.capacity.free_mb || storage.value.capacity // TODO fix
169
+
170
+ if (props.isEdit)
171
+ return free + hardDiskSizeMb
172
+
173
+ return free
174
+ })
175
+ const hardDiskTypeErrorLocalText = computed<string>(() => {
176
+ if (+sizeInMb.value > maxHardDisk.value) {
177
+ return localization.value.common.diskCapacitySpecifiedGreater
178
+ }
179
+
180
+ if (+sizeInMb.value <= 0) {
181
+ return localization.value.common.diskCapacityCannotZero
182
+ }
183
+
184
+ return ''
185
+ })
186
+
187
+ const hardDiskLocalAndApiErrorsTexts = computed<string>(() => {
188
+ const localError = hardDiskTypeErrorLocalText.value
189
+ const apiError = apiErrorLocal.value
190
+
191
+ let result = ''
192
+ if (localError && !apiError) result = localError
193
+ if (!localError && apiError) result = apiError
194
+ if (localError && apiError) result = localError + ', ' + apiError
195
+ if (!localError && apiError) result = apiError
196
+
197
+ return result
198
+ })
199
+
200
+ const deleteFilesFromDatastore = ref<boolean>(false)
201
+
202
+ const hardDiskType = ref<string>('gb')
203
+ const hardDiskTypeOptions = ref<UI_I_OptionItem[]>(
204
+ binaryOptionsFunc(localization.value)
205
+ )
206
+
207
+ const size = ref<number>(props.hardDisk.size) // Изначально всегда приходит в gb
208
+ const sizeInMb = computed<number>(() => {
209
+ if (hardDiskType.value === 'mb') {
210
+ return size.value
211
+ }
212
+
213
+ return $binary.universalFromTo(size.value, hardDiskType.value, 'mb')
214
+ })
215
+ const onValidateSize = (): void => {
216
+ if (props.type !== 'edit') return
217
+ if (sizeInMb.value < $binary.gbToMb(props.hardDisk.size)) {
218
+ size.value = $binary.universalFromTo(
219
+ props.hardDisk.size,
220
+ 'gb',
221
+ hardDiskType.value
222
+ )
223
+ }
224
+ }
225
+
226
+ const isDisabledSize = computed<boolean>(() => {
227
+ return props.type === 'exist' || (props.type === 'edit' && readOnly.value)
228
+ })
229
+
230
+ const location = ref<UI_I_DatastoreTableItem | null>(props.storage || null)
231
+ const storage = ref<UI_I_DatastoreTableItem | null>(props.storage)
232
+ watch(
233
+ () => props.storage,
234
+ (newValue) => {
235
+ location.value = newValue
236
+ storage.value = newValue
237
+ },
238
+ {
239
+ immediate: true,
240
+ deep: true,
241
+ }
242
+ )
243
+ const onChangeStorage = (item: UI_I_DatastoreTableItem): void => {
244
+ storage.value = item
245
+ }
246
+
247
+ const diskProvisioning = ref<string>('thick')
248
+ const sharing = ref<string>('')
249
+ const shares = ref<number>(0)
250
+
251
+ const limitIops = ref<number>(16)
252
+ const limitIopsType = ref<string>('unlimited')
253
+ const limitIopsInvalid = ref<boolean>(false)
254
+
255
+ const diskMode = ref<string>('dependent')
256
+
257
+ const cache = ref<string>('none')
258
+
259
+ const bus = ref<string>('ide')
260
+
261
+ const readOnly = ref<boolean>(false)
262
+
263
+ const discard = ref<string>('')
264
+
265
+ const io = ref<string>('')
266
+
267
+ const target = ref<string>('')
268
+
269
+ watch(
270
+ [
271
+ sizeInMb,
272
+ storage,
273
+ diskProvisioning,
274
+ sharing,
275
+ limitIops,
276
+ limitIopsType,
277
+ diskMode,
278
+ cache,
279
+ bus,
280
+ deleteFilesFromDatastore,
281
+ (): void => props.type,
282
+ ],
283
+ () => {
284
+ const limitIopsLocal =
285
+ limitIopsType.value === 'unlimited' ? 0 : limitIops.value
286
+ const storageLocal: UI_I_SendDataNewHardDiskStorage = {
287
+ id: storage.value?.id || '',
288
+ name: storage.value?.name || '',
289
+ type: storage.value?.type_text || '',
290
+ pool: storage.value?.pool_name || '',
291
+ user: '',
292
+ endpoint: '',
293
+ password: '',
294
+ protocol: '',
295
+ options: '',
296
+ }
297
+
298
+ emits('send-data', {
299
+ create: props.hardDisk.create,
300
+ attach: props.hardDisk.attach,
301
+ source: props.hardDisk.source,
302
+ size: Math.ceil(sizeInMb.value),
303
+ bus: bus.value,
304
+ target: target.value,
305
+ storage: storageLocal,
306
+ device_type: 'disk',
307
+ provision_type: diskProvisioning.value,
308
+ disk_mode: diskMode.value,
309
+ sharing: sharing.value === 'yes',
310
+ read_only: readOnly.value,
311
+ shares: shares.value,
312
+ cache: cache.value,
313
+ io: io.value,
314
+ limit_iops: limitIopsLocal,
315
+ discard: discard.value,
316
+ capacity: Math.ceil(sizeInMb.value),
317
+ boot_order: props.hardDisk.boot_order,
318
+ detach: props.type === 'removed',
319
+ remove: props.type === 'removed' && deleteFilesFromDatastore.value, // Проверяем если удалили диск и указали Delete files from datastore
320
+ })
321
+ },
322
+ { immediate: true }
323
+ )
324
+
325
+ // Добавляем данные для редактирования
326
+ watch(
327
+ () => props.hardDisk,
328
+ (newValue) => {
329
+ // TODO refactoring
330
+ if (props.type === 'exist') {
331
+ diskProvisioning.value = newValue.provision_type || 'thick'
332
+ return
333
+ }
334
+ // if (props.type !== 'edit') return
335
+ if (props.type !== 'edit' && props.type !== 'clone') return
336
+
337
+ diskProvisioning.value = newValue.provision_type || 'thick'
338
+ sharing.value = newValue.sharing ? 'yes' : ''
339
+ shares.value = newValue.shares || 0
340
+ // limitIopsType.value = newValue.io === 'native' ? 'unlimited' : 'custom'
341
+ limitIopsType.value = newValue.limit_iops === 0 ? 'unlimited' : 'custom'
342
+ limitIops.value = newValue.limit_iops || 16
343
+ diskMode.value = newValue.disk_mode || 'dependent'
344
+ cache.value = newValue.cache || 'none'
345
+ bus.value = newValue.bus || 'ide'
346
+ readOnly.value = newValue.read_only || false
347
+ discard.value = newValue.discard || ''
348
+ io.value = newValue.io || ''
349
+ target.value = newValue.target || ''
350
+ },
351
+ { immediate: true }
352
+ )
353
+ watch(
354
+ isRunning,
355
+ (newValue) => {
356
+ if (newValue && props.type === 'new') {
357
+ bus.value = 'virtio'
358
+ }
359
+ },
360
+ { immediate: true }
361
+ )
362
+
363
+ const hardDiskInvalid = computed<boolean>(() => {
364
+ return !!hardDiskTypeErrorLocalText.value || limitIopsInvalid.value
365
+ })
366
+ watch(
367
+ hardDiskInvalid,
368
+ (newValue) => {
369
+ emits('invalid', newValue)
370
+ },
371
+ { immediate: true }
372
+ )
373
+ </script>
374
+
375
+ <style scoped lang="scss"></style>