bfg-common 1.5.322 → 1.5.323

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 (130) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/collapse/CollapseNav.vue +170 -170
  8. package/components/atoms/collapse/CollapseNavItem.vue +226 -226
  9. package/components/atoms/nav/NavBar.vue +147 -147
  10. package/components/atoms/perPage/PerPage.vue +58 -58
  11. package/components/atoms/table/dataGrid/DataGrid.vue +1717 -1717
  12. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  13. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  14. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  15. package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
  16. package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +52 -52
  17. package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
  18. package/components/common/backup/storage/actions/delete/Delete.vue +65 -65
  19. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  20. package/components/common/context/lib/models/interfaces.ts +33 -33
  21. package/components/common/diagramMain/DiagramMain.vue +897 -897
  22. package/components/common/diagramMain/modals/lib/config/networkModal.ts +398 -398
  23. package/components/common/diagramMain/network/Network.vue +141 -141
  24. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  25. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  26. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  27. package/components/common/monitor/overview/filters/lib/config/filterOptions.ts +100 -100
  28. package/components/common/pages/home/headline/Headline.vue +45 -45
  29. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  30. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  31. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  32. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  33. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  34. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  35. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  36. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  37. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  38. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  39. package/components/common/pages/packages/Packages.vue +208 -208
  40. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  41. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  42. package/components/common/recursionTree/RecursionTree.vue +223 -223
  43. package/components/common/select/button/ButtonDropdown.vue +112 -112
  44. package/components/common/spiceConsole/Drawer.vue +377 -377
  45. package/components/common/spiceConsole/SpiceConsole.vue +127 -127
  46. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  47. package/components/common/tools/Actions.vue +207 -207
  48. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  49. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  50. package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
  51. package/components/common/vm/actions/clone/Clone.vue +823 -823
  52. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  53. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  54. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +321 -321
  55. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +227 -227
  56. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +100 -100
  57. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  58. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  59. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  60. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +154 -154
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +307 -307
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +385 -385
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +288 -288
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +154 -154
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  85. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +152 -152
  86. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +128 -128
  87. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +111 -111
  88. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  89. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  90. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  91. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +83 -83
  92. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +154 -154
  93. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  94. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -44
  95. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  96. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  97. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  98. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  99. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +118 -118
  100. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  101. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +48 -48
  102. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  103. package/components/common/vm/actions/common/select/name/Name.vue +174 -174
  104. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  105. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  106. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  107. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  108. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  109. package/components/common/vmt/actions/add/Add.vue +641 -641
  110. package/components/common/vmt/actions/add/lib/config/steps.ts +107 -107
  111. package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
  112. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +104 -104
  113. package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +467 -467
  114. package/components/common/wizards/vm/migrate/Migrate.vue +349 -349
  115. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  116. package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
  117. package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
  118. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  119. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  120. package/composables/productNameLocal.ts +30 -30
  121. package/composables/useAppVersion.ts +21 -21
  122. package/package.json +1 -1
  123. package/plugins/date.ts +233 -233
  124. package/plugins/panelStates.ts +70 -70
  125. package/plugins/text.ts +59 -59
  126. package/public/spice-console/lib/images/bitmap.js +203 -203
  127. package/public/spice-console/network/spicechannel.js +387 -387
  128. package/store/main/mutations.ts +7 -7
  129. package/store/main/state.ts +7 -7
  130. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,227 +1,227 @@
1
- <template>
2
- <div>
3
- <common-browse
4
- v-model:selected-file="selectedFile"
5
- v-model:selected-file-type="selectedFileType"
6
- :show="props.show"
7
- :nodes="props.nodes"
8
- :files="files"
9
- :info="selectedNodeInfo"
10
- :file-types="props.fileTypes"
11
- :browse-loading="browseLoading"
12
- @get-nodes="onGetCurrentDirNodes"
13
- @select-node="onSelectNode"
14
- @submit="onSubmit"
15
- @hide="emits('hide')"
16
- />
17
- </div>
18
- </template>
19
-
20
- <script lang="ts" setup>
21
- import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
22
- import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
23
- import type { UI_I_FolderOrFileTreePayload } from '~/lib/models/store/storage/interfaces'
24
- import type { UI_I_CurrentDirNodesArguments } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/lib/models/interfaces'
25
- import type { UI_I_Localization } from '~/lib/models/interfaces'
26
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
27
- import type { UI_I_FileInfo } from '~/components/common/browse/lib/models/interfaces'
28
-
29
- const props = defineProps<{
30
- show: boolean
31
- nodes: UI_I_FileTreeNode[]
32
- files: UI_I_FileTreeNode[]
33
- fileTypes?: UI_I_OptionItem[]
34
- }>()
35
- const emits = defineEmits<{
36
- (event: 'hide'): void
37
- (event: 'submit', value: UI_I_FileTreeNode | null): void
38
- (event: 'get-storage', value: UI_I_TablePayload): void
39
- (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
40
- (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
41
- (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
42
- }>()
43
-
44
- const { $recursion } = useNuxtApp()
45
-
46
- const localization = computed<UI_I_Localization>(() => useLocal())
47
-
48
- const selectedFileType = ref<string | null>(null)
49
- watch(
50
- selectedFileType,
51
- (newValue) => {
52
- if (newValue === null || selectedFile.value === null) return
53
-
54
- const isExist = files.value.includes(selectedFile.value)
55
- if (!isExist) selectedFile.value = null
56
- },
57
- { immediate: true, deep: true }
58
- )
59
- watch(
60
- () => props.fileTypes,
61
- (newValue) => {
62
- if (newValue?.length) selectedFileType.value = newValue[0].value
63
- },
64
- { immediate: true, deep: true }
65
- )
66
-
67
- const getStorage = (): void => {
68
- const payload: UI_I_TablePayload = {
69
- pagination: {
70
- page: 1,
71
- pageSize: 100,
72
- },
73
- sortBy: null,
74
- type: 'datastore',
75
- schema: 'full',
76
- }
77
-
78
- emits('get-storage', payload)
79
- }
80
- getStorage()
81
-
82
- const getFileNodes = (payload: UI_I_FolderOrFileTreePayload): void => {
83
- emits('get-folders-or-files', payload)
84
- }
85
-
86
- const files = computed<UI_I_FileTreeNode[]>(() => {
87
- if (!selectedNode.value) return []
88
-
89
- const files: UI_I_FileTreeNode[] = props.files
90
- if (selectedFileType.value === 'all' || selectedFileType.value === null)
91
- return files
92
-
93
- let type = 3
94
- if (selectedFileType.value === 'iso') type = 2
95
-
96
- return files.filter((file) => file.provisioned_type === type)
97
- })
98
-
99
- const getRootNodeById = (id: string): UI_I_FileTreeNode | null => {
100
- let result = null
101
- props.nodes.forEach((node) => {
102
- const findNode =
103
- node.id === id ? node : $recursion.find(node.nodes, id, 'id', 'nodes')
104
-
105
- findNode && (result = node)
106
- })
107
-
108
- return result
109
- }
110
- const onGetCurrentDirNodes = async ({
111
- node,
112
- cb,
113
- select = false,
114
- type = 'folder',
115
- }: UI_I_CurrentDirNodesArguments): Promise<void> => {
116
- if (!node) return
117
-
118
- const isRootNode = props.nodes?.some((item) => item.id === node.id)
119
-
120
- if (!select && (isRootNode || node.nodesShow)) {
121
- emits('show-datastore-child', node)
122
- cb && cb()
123
- return
124
- }
125
-
126
- const rootNode = getRootNodeById(node.id)
127
- if (!rootNode) return
128
-
129
- const payload: UI_I_FolderOrFileTreePayload = {
130
- type,
131
- id: rootNode.id,
132
- path: node.path,
133
- merge: true,
134
- show: !select,
135
- }
136
-
137
- await getFileNodes(payload)
138
- cb && cb()
139
- }
140
-
141
- const selectedNode = ref<UI_I_FileTreeNode | null>(null)
142
- const selectedFile = ref<UI_I_FileTreeNode | null>(null)
143
- const selectedNodeInfo = computed<UI_I_FileInfo[] | null>(() => {
144
- const node = selectedFile.value || selectedNode.value
145
- if (!node) return null
146
-
147
- const result = [
148
- {
149
- type: 'text',
150
- title: localization.value.common.name,
151
- value: node.name || '',
152
- },
153
- {
154
- type: 'size',
155
- title: localization.value.common.available,
156
- value: node.size || 0,
157
- },
158
- ]
159
-
160
- if (node.type !== 4) {
161
- const modified = node.modified_time || 0
162
- if (modified !== 0) {
163
- result.push({
164
- type: 'date',
165
- title: localization.value.common.modified,
166
- value: +modified * 1000,
167
- })
168
- } else {
169
- result.push({
170
- type: 'text',
171
- title: localization.value.common.modified,
172
- value: ' --',
173
- })
174
- }
175
- }
176
-
177
- return result
178
- })
179
-
180
- // TODO найти решение получше
181
- const browseLoading = ref<boolean>(false)
182
- const onSelectNode = (node: UI_I_FileTreeNode): void => {
183
- selectedNode.value = node
184
- selectedFile.value = null
185
-
186
- onGetCurrentDirNodes({ node, select: true, type: 'file' })
187
-
188
- emits('get-active-device-child', node)
189
-
190
- setTimeout(() => {
191
- browseLoading.value = true
192
- }, 0)
193
- }
194
- watch(
195
- files,
196
- () => {
197
- browseLoading.value = false
198
- },
199
- { immediate: true, deep: true }
200
- )
201
-
202
- const onSubmit = (): void => {
203
- emits('submit', selectedFile.value)
204
- emits('hide')
205
- }
206
-
207
- let helper = false
208
- watch(
209
- () => props.nodes,
210
- (newValue: UI_I_FileTreeNode[]) => {
211
- if (helper || !newValue.length) return
212
- newValue.forEach((node) => {
213
- getFileNodes({
214
- id: node.id,
215
- path: `${node.id}:/`,
216
- type: 'folder',
217
- show: false,
218
- merge: false,
219
- })
220
- })
221
- helper = true
222
- },
223
- { immediate: true }
224
- )
225
- </script>
226
-
227
- <style lang="scss" scoped></style>
1
+ <template>
2
+ <div>
3
+ <common-browse
4
+ v-model:selected-file="selectedFile"
5
+ v-model:selected-file-type="selectedFileType"
6
+ :show="props.show"
7
+ :nodes="props.nodes"
8
+ :files="files"
9
+ :info="selectedNodeInfo"
10
+ :file-types="props.fileTypes"
11
+ :browse-loading="browseLoading"
12
+ @get-nodes="onGetCurrentDirNodes"
13
+ @select-node="onSelectNode"
14
+ @submit="onSubmit"
15
+ @hide="emits('hide')"
16
+ />
17
+ </div>
18
+ </template>
19
+
20
+ <script lang="ts" setup>
21
+ import type { UI_I_FileTreeNode } from '~/components/lib/models/interfaces'
22
+ import type { UI_I_TablePayload } from '~/lib/models/table/interfaces'
23
+ import type { UI_I_FolderOrFileTreePayload } from '~/lib/models/store/storage/interfaces'
24
+ import type { UI_I_CurrentDirNodesArguments } from '~/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/lib/models/interfaces'
25
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
26
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
27
+ import type { UI_I_FileInfo } from '~/components/common/browse/lib/models/interfaces'
28
+
29
+ const props = defineProps<{
30
+ show: boolean
31
+ nodes: UI_I_FileTreeNode[]
32
+ files: UI_I_FileTreeNode[]
33
+ fileTypes?: UI_I_OptionItem[]
34
+ }>()
35
+ const emits = defineEmits<{
36
+ (event: 'hide'): void
37
+ (event: 'submit', value: UI_I_FileTreeNode | null): void
38
+ (event: 'get-storage', value: UI_I_TablePayload): void
39
+ (event: 'get-folders-or-files', value: UI_I_FolderOrFileTreePayload): void
40
+ (event: 'get-active-device-child', value: UI_I_FileTreeNode): void
41
+ (event: 'show-datastore-child', value: UI_I_FileTreeNode): void
42
+ }>()
43
+
44
+ const { $recursion } = useNuxtApp()
45
+
46
+ const localization = computed<UI_I_Localization>(() => useLocal())
47
+
48
+ const selectedFileType = ref<string | null>(null)
49
+ watch(
50
+ selectedFileType,
51
+ (newValue) => {
52
+ if (newValue === null || selectedFile.value === null) return
53
+
54
+ const isExist = files.value.includes(selectedFile.value)
55
+ if (!isExist) selectedFile.value = null
56
+ },
57
+ { immediate: true, deep: true }
58
+ )
59
+ watch(
60
+ () => props.fileTypes,
61
+ (newValue) => {
62
+ if (newValue?.length) selectedFileType.value = newValue[0].value
63
+ },
64
+ { immediate: true, deep: true }
65
+ )
66
+
67
+ const getStorage = (): void => {
68
+ const payload: UI_I_TablePayload = {
69
+ pagination: {
70
+ page: 1,
71
+ pageSize: 100,
72
+ },
73
+ sortBy: null,
74
+ type: 'datastore',
75
+ schema: 'full',
76
+ }
77
+
78
+ emits('get-storage', payload)
79
+ }
80
+ getStorage()
81
+
82
+ const getFileNodes = (payload: UI_I_FolderOrFileTreePayload): void => {
83
+ emits('get-folders-or-files', payload)
84
+ }
85
+
86
+ const files = computed<UI_I_FileTreeNode[]>(() => {
87
+ if (!selectedNode.value) return []
88
+
89
+ const files: UI_I_FileTreeNode[] = props.files
90
+ if (selectedFileType.value === 'all' || selectedFileType.value === null)
91
+ return files
92
+
93
+ let type = 3
94
+ if (selectedFileType.value === 'iso') type = 2
95
+
96
+ return files.filter((file) => file.provisioned_type === type)
97
+ })
98
+
99
+ const getRootNodeById = (id: string): UI_I_FileTreeNode | null => {
100
+ let result = null
101
+ props.nodes.forEach((node) => {
102
+ const findNode =
103
+ node.id === id ? node : $recursion.find(node.nodes, id, 'id', 'nodes')
104
+
105
+ findNode && (result = node)
106
+ })
107
+
108
+ return result
109
+ }
110
+ const onGetCurrentDirNodes = async ({
111
+ node,
112
+ cb,
113
+ select = false,
114
+ type = 'folder',
115
+ }: UI_I_CurrentDirNodesArguments): Promise<void> => {
116
+ if (!node) return
117
+
118
+ const isRootNode = props.nodes?.some((item) => item.id === node.id)
119
+
120
+ if (!select && (isRootNode || node.nodesShow)) {
121
+ emits('show-datastore-child', node)
122
+ cb && cb()
123
+ return
124
+ }
125
+
126
+ const rootNode = getRootNodeById(node.id)
127
+ if (!rootNode) return
128
+
129
+ const payload: UI_I_FolderOrFileTreePayload = {
130
+ type,
131
+ id: rootNode.id,
132
+ path: node.path,
133
+ merge: true,
134
+ show: !select,
135
+ }
136
+
137
+ await getFileNodes(payload)
138
+ cb && cb()
139
+ }
140
+
141
+ const selectedNode = ref<UI_I_FileTreeNode | null>(null)
142
+ const selectedFile = ref<UI_I_FileTreeNode | null>(null)
143
+ const selectedNodeInfo = computed<UI_I_FileInfo[] | null>(() => {
144
+ const node = selectedFile.value || selectedNode.value
145
+ if (!node) return null
146
+
147
+ const result = [
148
+ {
149
+ type: 'text',
150
+ title: localization.value.common.name,
151
+ value: node.name || '',
152
+ },
153
+ {
154
+ type: 'size',
155
+ title: localization.value.common.available,
156
+ value: node.size || 0,
157
+ },
158
+ ]
159
+
160
+ if (node.type !== 4) {
161
+ const modified = node.modified_time || 0
162
+ if (modified !== 0) {
163
+ result.push({
164
+ type: 'date',
165
+ title: localization.value.common.modified,
166
+ value: +modified * 1000,
167
+ })
168
+ } else {
169
+ result.push({
170
+ type: 'text',
171
+ title: localization.value.common.modified,
172
+ value: ' --',
173
+ })
174
+ }
175
+ }
176
+
177
+ return result
178
+ })
179
+
180
+ // TODO найти решение получше
181
+ const browseLoading = ref<boolean>(false)
182
+ const onSelectNode = (node: UI_I_FileTreeNode): void => {
183
+ selectedNode.value = node
184
+ selectedFile.value = null
185
+
186
+ onGetCurrentDirNodes({ node, select: true, type: 'file' })
187
+
188
+ emits('get-active-device-child', node)
189
+
190
+ setTimeout(() => {
191
+ browseLoading.value = true
192
+ }, 0)
193
+ }
194
+ watch(
195
+ files,
196
+ () => {
197
+ browseLoading.value = false
198
+ },
199
+ { immediate: true, deep: true }
200
+ )
201
+
202
+ const onSubmit = (): void => {
203
+ emits('submit', selectedFile.value)
204
+ emits('hide')
205
+ }
206
+
207
+ let helper = false
208
+ watch(
209
+ () => props.nodes,
210
+ (newValue: UI_I_FileTreeNode[]) => {
211
+ if (helper || !newValue.length) return
212
+ newValue.forEach((node) => {
213
+ getFileNodes({
214
+ id: node.id,
215
+ path: `${node.id}:/`,
216
+ type: 'folder',
217
+ show: false,
218
+ merge: false,
219
+ })
220
+ })
221
+ helper = true
222
+ },
223
+ { immediate: true }
224
+ )
225
+ </script>
226
+
227
+ <style lang="scss" scoped></style>
@@ -1,100 +1,100 @@
1
- <template>
2
- <common-vm-actions-common-customize-hardware-virtual-hardware-bus-new
3
- v-if="isNewView"
4
- v-model:bus="bus"
5
- v-model:is-show-help="isShowHelp"
6
- :index="props.index"
7
- :component-type="props.componentType"
8
- :test-id="props.testId"
9
- :error-text="apiError"
10
- :bus-options="busOptions"
11
- :help-id="helpId"
12
- :disabled="disabled"
13
- :help-text="helpText"
14
- @remove-error="onRemoveValidationError"
15
- />
16
- <common-vm-actions-common-customize-hardware-virtual-hardware-bus-old
17
- v-else
18
- v-model:bus="bus"
19
- v-model:is-show-help="isShowHelp"
20
- :index="props.index"
21
- :component-type="props.componentType"
22
- :test-id="props.testId"
23
- :error-text="apiError"
24
- :bus-options="busOptions"
25
- :help-id="helpId"
26
- :disabled="disabled"
27
- :help-text="helpText"
28
- @remove-error="onRemoveValidationError"
29
- />
30
- </template>
31
-
32
- <script setup lang="ts">
33
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
34
- import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
35
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
36
- import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
37
-
38
- const bus = defineModel<string>('bus')
39
-
40
- const props = defineProps<{
41
- index: number
42
- componentType: string
43
- testId: string
44
- errorValidationFields: UI_I_ErrorValidationField<string>[]
45
- disabled?: boolean
46
- shortOptions?: boolean
47
- helpText?: string
48
- guestMachineType?: UI_I_OptionItem | null
49
- computeResource?: UI_I_TreeNode | null
50
- }>()
51
- const emits = defineEmits<{
52
- (event: 'remove-error-by-title', value: string): void
53
- }>()
54
-
55
- const { $store }: any = useNuxtApp()
56
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
57
-
58
- const helpId = ref<string>(`bus-field-help-icon${useUniqueId()}`)
59
-
60
- const busOptions = ref<UI_I_OptionItem[]>([])
61
-
62
- watch(
63
- [() => props.guestMachineType, () => props.computeResource, capabilities],
64
- () => {
65
- if (props.guestMachineType) {
66
- busOptions.value = capabilities.value.bus[props.guestMachineType.value]
67
- if (props.shortOptions) {
68
- busOptions.value = capabilities.value.cdromBus[props.guestMachineType.value]
69
- }
70
- if (busOptions.value) {
71
- const hasSelected = busOptions.value.some(
72
- (option) => option.value === bus.value
73
- )
74
- if (!hasSelected) bus.value = busOptions.value[0].value
75
- }
76
- }
77
- },
78
- { immediate: true, deep: true }
79
- )
80
-
81
- const busValidationType = computed<string>(
82
- () => `disk_devices[${props.index}].bus`
83
- )
84
-
85
- const apiError = computed<string>(() => {
86
- return (
87
- props.errorValidationFields?.find(
88
- (message) => message.field === busValidationType.value
89
- )?.error_message || ''
90
- )
91
- })
92
-
93
- const onRemoveValidationError = (): void => {
94
- emits('remove-error-by-title', busValidationType.value)
95
- }
96
-
97
- const isShowHelp = ref<boolean>(false)
98
- </script>
99
-
100
- <style scoped></style>
1
+ <template>
2
+ <common-vm-actions-common-customize-hardware-virtual-hardware-bus-new
3
+ v-if="isNewView"
4
+ v-model:bus="bus"
5
+ v-model:is-show-help="isShowHelp"
6
+ :index="props.index"
7
+ :component-type="props.componentType"
8
+ :test-id="props.testId"
9
+ :error-text="apiError"
10
+ :bus-options="busOptions"
11
+ :help-id="helpId"
12
+ :disabled="disabled"
13
+ :help-text="helpText"
14
+ @remove-error="onRemoveValidationError"
15
+ />
16
+ <common-vm-actions-common-customize-hardware-virtual-hardware-bus-old
17
+ v-else
18
+ v-model:bus="bus"
19
+ v-model:is-show-help="isShowHelp"
20
+ :index="props.index"
21
+ :component-type="props.componentType"
22
+ :test-id="props.testId"
23
+ :error-text="apiError"
24
+ :bus-options="busOptions"
25
+ :help-id="helpId"
26
+ :disabled="disabled"
27
+ :help-text="helpText"
28
+ @remove-error="onRemoveValidationError"
29
+ />
30
+ </template>
31
+
32
+ <script setup lang="ts">
33
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
34
+ import type { UI_I_ErrorValidationField } from '~/lib/models/store/interfaces'
35
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
36
+ import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
37
+
38
+ const bus = defineModel<string>('bus')
39
+
40
+ const props = defineProps<{
41
+ index: number
42
+ componentType: string
43
+ testId: string
44
+ errorValidationFields: UI_I_ErrorValidationField<string>[]
45
+ disabled?: boolean
46
+ shortOptions?: boolean
47
+ helpText?: string
48
+ guestMachineType?: UI_I_OptionItem | null
49
+ computeResource?: UI_I_TreeNode | null
50
+ }>()
51
+ const emits = defineEmits<{
52
+ (event: 'remove-error-by-title', value: string): void
53
+ }>()
54
+
55
+ const { $store }: any = useNuxtApp()
56
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
57
+
58
+ const helpId = ref<string>(`bus-field-help-icon${useUniqueId()}`)
59
+
60
+ const busOptions = ref<UI_I_OptionItem[]>([])
61
+
62
+ watch(
63
+ [() => props.guestMachineType, () => props.computeResource, capabilities],
64
+ () => {
65
+ if (props.guestMachineType) {
66
+ busOptions.value = capabilities.value.bus[props.guestMachineType.value]
67
+ if (props.shortOptions) {
68
+ busOptions.value = capabilities.value.cdromBus[props.guestMachineType.value]
69
+ }
70
+ if (busOptions.value) {
71
+ const hasSelected = busOptions.value.some(
72
+ (option) => option.value === bus.value
73
+ )
74
+ if (!hasSelected) bus.value = busOptions.value[0].value
75
+ }
76
+ }
77
+ },
78
+ { immediate: true, deep: true }
79
+ )
80
+
81
+ const busValidationType = computed<string>(
82
+ () => `disk_devices[${props.index}].bus`
83
+ )
84
+
85
+ const apiError = computed<string>(() => {
86
+ return (
87
+ props.errorValidationFields?.find(
88
+ (message) => message.field === busValidationType.value
89
+ )?.error_message || ''
90
+ )
91
+ })
92
+
93
+ const onRemoveValidationError = (): void => {
94
+ emits('remove-error-by-title', busValidationType.value)
95
+ }
96
+
97
+ const isShowHelp = ref<boolean>(false)
98
+ </script>
99
+
100
+ <style scoped></style>