bfg-common 1.5.487 → 1.5.489

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 (191) 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 +7 -1
  7. package/assets/localization/local_en.json +17 -11
  8. package/assets/localization/local_hy.json +7 -1
  9. package/assets/localization/local_kk.json +7 -1
  10. package/assets/localization/local_ru.json +7 -1
  11. package/assets/localization/local_zh.json +7 -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/DataGridPagination.vue +97 -97
  16. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  17. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  18. package/components/common/adapterManager/AdapterManager.vue +189 -545
  19. package/components/common/adapterManager/AdapterManagerNew.vue +300 -0
  20. package/components/common/adapterManager/AdapterManagerOld.vue +498 -0
  21. package/components/common/adapterManager/addAdapterModal/AddAdapterModal.vue +70 -0
  22. package/components/common/adapterManager/addAdapterModal/AddAdapterModalNew.vue +77 -0
  23. package/components/common/adapterManager/{AddAdapterModal.vue → addAdapterModal/AddAdapterModalOld.vue} +16 -46
  24. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModal.vue +32 -0
  25. package/components/common/adapterManager/addAdapterWarningModal/AddAdapterWarningModalNew.vue +38 -0
  26. package/components/common/adapterManager/{AddAdapterWarningModal.vue → addAdapterWarningModal/AddAdapterWarningModalOld.vue} +5 -14
  27. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModal.vue +31 -0
  28. package/components/common/adapterManager/noActiveAdaptersModal/NoActiveAdaptersModalNew.vue +34 -0
  29. package/components/common/adapterManager/{NoActiveAdaptersModal.vue → noActiveAdaptersModal/NoActiveAdaptersModalOld.vue} +2 -6
  30. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModal.vue +31 -0
  31. package/components/common/adapterManager/noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalNew.vue +34 -0
  32. package/components/common/adapterManager/{NoConnectedActiveAdaptersModal.vue → noConnectedActiveAdaptersModal/NoConnectedActiveAdaptersModalOld.vue} +2 -6
  33. package/components/common/adapterManager/ui/actions/bar/Bar.vue +57 -0
  34. package/components/common/adapterManager/ui/actions/bar/BarNew.vue +38 -0
  35. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButton.vue +28 -0
  36. package/components/common/adapterManager/ui/actions/moveDownAdapterButton/MoveDownAdapterButtonNew.vue +75 -0
  37. package/components/common/adapterManager/ui/actions/{MoveDownAdapterButton.vue → moveDownAdapterButton/MoveDownAdapterButtonOld.vue} +3 -9
  38. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButton.vue +28 -0
  39. package/components/common/adapterManager/ui/actions/moveUpAdapterButton/MoveUpAdapterButtonNew.vue +76 -0
  40. package/components/common/adapterManager/ui/actions/{MoveUpAdapterButton.vue → moveUpAdapterButton/MoveUpAdapterButtonOld.vue} +3 -9
  41. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapter.vue +24 -0
  42. package/components/common/adapterManager/ui/noSelectedAdapter/NoSelectedAdapterNew.vue +13 -0
  43. package/components/common/adapterManager/ui/secondTitle/SecondTitle.vue +31 -0
  44. package/components/common/adapterManager/ui/secondTitle/SecondTitleNew.vue +36 -0
  45. package/components/common/adapterManager/ui/{SecondTitle.vue → secondTitle/SecondTitleOld.vue} +0 -1
  46. package/components/common/adapterManager/ui/table/Table.vue +59 -133
  47. package/components/common/adapterManager/ui/table/TableNew.vue +136 -0
  48. package/components/common/adapterManager/ui/table/TableOld.vue +141 -0
  49. package/components/common/adapterManager/ui/table/adapters/Adapters.vue +44 -0
  50. package/components/common/adapterManager/ui/table/adapters/AdaptersNew.vue +153 -0
  51. package/components/common/adapterManager/ui/table/{Adapters.vue → adapters/AdaptersOld.vue} +5 -10
  52. package/components/common/adapterManager/ui/table/header/Header.vue +57 -0
  53. package/components/common/adapterManager/ui/table/header/HeaderNew.vue +77 -0
  54. package/components/common/adapterManager/ui/table/{Header.vue → header/HeaderOld.vue} +3 -20
  55. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  56. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  57. package/components/common/browse/lib/models/interfaces.ts +5 -5
  58. package/components/common/context/lib/models/interfaces.ts +33 -33
  59. package/components/common/diagramMain/DiagramMain.vue +905 -900
  60. package/components/common/diagramMain/lib/models/interfaces.ts +5 -2
  61. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +6 -5
  62. package/components/common/diagramMain/modals/Modals.vue +19 -1
  63. package/components/common/diagramMain/modals/lib/config/adapterModal.ts +23 -20
  64. package/components/common/diagramMain/modals/lib/config/networkModal.ts +401 -398
  65. package/components/common/diagramMain/modals/lib/config/switchModal.ts +3 -0
  66. package/components/common/diagramMain/modals/remove/RemoveModal.vue +8 -0
  67. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +106 -95
  68. package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +12 -1
  69. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +0 -2
  70. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +6 -0
  71. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +140 -71
  72. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +4 -4
  73. package/components/common/diagramMain/network/Contents.vue +497 -497
  74. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  75. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  76. package/components/common/pages/backups/DetailView.vue +52 -52
  77. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  78. package/components/common/pages/backups/modals/Modals.vue +243 -243
  79. package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
  80. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  81. package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
  82. package/components/common/pages/backups/modals/createBackup/general/General.vue +141 -141
  83. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
  84. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  85. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  86. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  87. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  88. package/components/common/pages/backups/modals/restore/name/Name.vue +166 -166
  89. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  90. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  91. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  92. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  93. package/components/common/pages/backups/tools/Tools.vue +75 -75
  94. package/components/common/pages/backups/tools/lib/config/tabs.ts +36 -36
  95. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  96. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  97. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  98. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  99. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  100. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  101. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  102. package/components/common/select/radio/RadioGroup.vue +137 -137
  103. package/components/common/spiceConsole/Drawer.vue +392 -392
  104. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  105. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  106. package/components/common/tools/Actions.vue +207 -207
  107. package/components/common/treeView/TreeView.vue +52 -52
  108. package/components/common/vm/actions/add/Add.vue +877 -877
  109. package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
  110. package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +368 -368
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +99 -99
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  120. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  121. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  122. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  123. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  124. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  125. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  126. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  127. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  128. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  129. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  130. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  131. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  132. package/components/common/vm/actions/common/select/name/Name.vue +200 -200
  133. package/components/common/vm/actions/common/select/name/Old.vue +131 -131
  134. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  135. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  136. package/components/common/vm/actions/common/select/storage/new/New.vue +320 -320
  137. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  138. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  139. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  140. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  141. package/components/common/vm/actions/register/Register.vue +267 -267
  142. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  143. package/components/common/vmt/actions/add/Add.vue +549 -549
  144. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  145. package/components/common/wizards/network/add/Add.vue +9 -3
  146. package/components/common/wizards/network/add/AddNew.vue +291 -354
  147. package/components/common/wizards/network/add/AddOld.vue +0 -3
  148. package/components/common/wizards/network/add/lib/config/config.ts +1 -0
  149. package/components/common/wizards/network/add/lib/config/initialData.ts +9 -0
  150. package/components/common/wizards/network/add/lib/config/steps.ts +35 -5
  151. package/components/common/wizards/network/add/lib/models/interfaces.ts +12 -2
  152. package/components/common/wizards/network/add/steps/connectionSettings/ConnectionSettings.vue +83 -0
  153. package/components/common/wizards/network/add/steps/connectionSettings/ConnectionSettingsNew.vue +114 -0
  154. package/components/common/wizards/network/add/steps/{ConnectionSettings.vue → connectionSettings/ConnectionSettingsOld.vue} +11 -42
  155. package/components/common/wizards/network/add/steps/createStandardSwitch/CreateStandardSwitch.vue +99 -0
  156. package/components/common/wizards/network/add/steps/createStandardSwitch/CreateStandardSwitchNew.vue +80 -0
  157. package/components/common/wizards/network/add/steps/{CreateStandardSwitch.vue → createStandardSwitch/CreateStandardSwitchOld.vue} +24 -33
  158. package/components/common/wizards/network/add/steps/ipFourSettings/IpFourSettings.vue +143 -0
  159. package/components/common/wizards/network/add/steps/ipFourSettings/IpFourSettingsNew.vue +224 -0
  160. package/components/common/wizards/network/add/steps/{IpFourSettings.vue → ipFourSettings/IpFourSettingsOld.vue} +13 -101
  161. package/components/common/wizards/network/add/steps/portProperties/PortProperties.vue +214 -0
  162. package/components/common/wizards/network/add/steps/portProperties/PortPropertiesNew.vue +289 -0
  163. package/components/common/wizards/network/add/steps/{PortProperties.vue → portProperties/PortPropertiesOld.vue} +19 -166
  164. package/components/common/wizards/network/add/steps/readyComplete/ReadyComplete.vue +22 -0
  165. package/components/common/wizards/network/add/steps/readyComplete/ReadyCompleteNew.vue +30 -0
  166. package/components/common/wizards/network/add/steps/selectTargetDevice/SelectTargetDevice.vue +7 -2
  167. package/components/common/wizards/network/add/steps/selectTargetDevice/SelectTargetDeviceNew.vue +1 -3
  168. package/components/common/wizards/network/add/steps/selectTargetDevice/SelectTargetDeviceOld.vue +0 -2
  169. package/components/common/wizards/network/add/validations/common.ts +1 -2
  170. package/components/common/wizards/network/add/validations/connectionSettings.ts +14 -7
  171. package/components/common/wizards/network/add/validations/ipFourSettings.ts +24 -10
  172. package/components/common/wizards/network/add/validations/networkValidation.ts +1 -1
  173. package/components/common/wizards/network/add/validations/portProperties.ts +52 -20
  174. package/components/common/wizards/network/add/validations/targetDevice.ts +18 -4
  175. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  176. package/composables/useAppVersion.ts +21 -21
  177. package/composables/useLocal.ts +6 -6
  178. package/composables/useLocalCommon.ts +39 -39
  179. package/package.json +2 -2
  180. package/plugins/date.ts +233 -233
  181. package/plugins/panelStates.ts +70 -70
  182. package/plugins/text.ts +59 -59
  183. package/public/spice-console/lib/images/bitmap.js +203 -203
  184. package/public/spice-console/network/spicechannel.js +440 -440
  185. package/public/spice-console/run.js +210 -210
  186. package/store/main/mutations.ts +7 -7
  187. package/store/main/state.ts +7 -7
  188. package/components/common/wizards/network/add/steps/PhysicalAdapter.vue +0 -13
  189. /package/components/common/adapterManager/ui/actions/{ActionsBar.vue → bar/BarOld.vue} +0 -0
  190. /package/components/common/adapterManager/ui/{NoSelectedAdapter.vue → noSelectedAdapter/NoSelectedAdapterOld.vue} +0 -0
  191. /package/components/common/wizards/network/add/steps/{ReadyComplete.vue → readyComplete/ReadyCompleteOld.vue} +0 -0
@@ -1,200 +1,200 @@
1
- <template>
2
- <common-vm-actions-common-select-name-new
3
- v-if="isNewView"
4
- v-model:vm-name="vmName"
5
- v-model:is-show-help="isShowHelp"
6
- :project="props.project"
7
- :errors="errors"
8
- :data-center="props.dataCenter"
9
- @remove-validation-errors="onRemoveValidationErrors"
10
- @select-node="onSelectNode"
11
- />
12
- <common-vm-actions-common-select-name-old
13
- v-else
14
- v-model:vm-name="vmName"
15
- v-model:is-show-help="isShowHelp"
16
- :project="props.project"
17
- :is-vmt="props.isVmt"
18
- :errors="errors"
19
- :data-center="props.dataCenter"
20
- @remove-validation-errors="onRemoveValidationErrors"
21
- @select-node="onSelectNode"
22
- />
23
- </template>
24
-
25
- <script setup lang="ts">
26
- // import { API_UI_I_Error } from '~/lib/models/store/interfaces'
27
- import type { UI_I_Localization } from '~/lib/models/interfaces'
28
- import type { UI_T_Project } from '~/lib/models/types'
29
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
30
-
31
- const props = withDefaults(
32
- defineProps<{
33
- nameFormSubmit: null | Function
34
- show: boolean
35
- project: UI_T_Project
36
- isVmt?: boolean
37
- validateEmptyName?: boolean
38
- dataCenter?: UI_I_TreeNode // для сферы
39
- existName?: string
40
- }>(),
41
- {
42
- validateEmptyName: false,
43
- isVmt: false,
44
- dataCenter: undefined,
45
- existName: undefined,
46
- }
47
- )
48
- const emits = defineEmits<{
49
- (event: 'submit', value: [string, UI_I_TreeNode | null]): void
50
- (event: 'loading', value: boolean): void
51
- (
52
- event: 'check-name',
53
- value: [[string, UI_I_TreeNode | null], (error: any) => void]
54
- ): void
55
- (event: 'has-errors', value: boolean): void
56
- }>()
57
-
58
- const { $store }: any = useNuxtApp()
59
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
60
-
61
- const localization = computed<UI_I_Localization>(() => useLocal())
62
-
63
- // TODO 100
64
- const vmName = ref<string>(props.existName || '')
65
-
66
- const selectedNode = ref<UI_I_TreeNode | null>(null)
67
- const onSelectNode = (node: UI_I_TreeNode): void => {
68
- selectedNode.value = node
69
- }
70
-
71
- watch(
72
- () => props.nameFormSubmit,
73
- (newValue) => {
74
- newValue && submit(newValue)
75
- }
76
- )
77
-
78
- const isParentDatacenter = (node: UI_I_TreeNode | null): boolean => {
79
- if (!node) return false
80
-
81
- if (node.parent?.type === 'datacenter') return true
82
- if (node.parent?.type === 'folder') return isParentDatacenter(node.parent)
83
- return false
84
- }
85
- const submit = async (cb: Function): Promise<void> => {
86
- const name = vmName.value
87
-
88
- if (props.validateEmptyName && name === '') {
89
- showValidationErrors([
90
- localization.value.common.emptyNameValidationDescription,
91
- ])
92
- cb(false)
93
- return
94
- }
95
- if (name !== '') {
96
- const isNameValid = await checkNameIsValid(name)
97
- if (!isNameValid) {
98
- cb(false)
99
- return
100
- }
101
- }
102
-
103
- if (props.project === 'sphere') {
104
- // const isDatacenterFolder = isParentDatacenter(selectedNode.value)
105
-
106
- if (
107
- // selectedNode.value?.type !== 'datacenter' &&
108
- // selectedNode.value?.type === 'folder' &&
109
- // !isDatacenterFolder
110
- // TODO рефакторинг, здесь сейчас проверяем является ли выбранный элемент датацентром или папкой(вм)
111
- ![3, 7].includes(selectedNode.value?.kind)
112
- ) {
113
- showValidationErrors([
114
- localization.value.common.enterValidLocationVirtualMachine,
115
- ])
116
- cb(false)
117
- return
118
- }
119
- }
120
-
121
- onRemoveValidationErrors()
122
- emits('submit', [name, selectedNode.value])
123
- cb(true)
124
- }
125
- const checkNameIsValid = async (name: string): Promise<boolean> => {
126
- emits('loading', true)
127
-
128
- return new Promise((resolve) => {
129
- emits('check-name', [
130
- [name, selectedNode.value],
131
- (error) => {
132
- emits('loading', false)
133
-
134
- const status = error?.statusCode || 200
135
- switch (status) {
136
- case 400: // Empty name
137
- showValidationErrors([
138
- localization.value.common.emptyNameValidationDescription,
139
- ])
140
- resolve(false)
141
- break
142
- case 405: // Invalid kind
143
- showValidationErrors([
144
- localization.value.common.kindValidationDescription,
145
- ])
146
- resolve(false)
147
- break
148
- case 406: // Invalid name
149
- showValidationErrors([
150
- localization.value.common.vmNameValidationDescription,
151
- ])
152
- resolve(false)
153
- break
154
- case 409: // Name exist
155
- showValidationErrors([
156
- localization.value.common.vmNameExistInSelectedLocation,
157
- ])
158
- resolve(false)
159
- break
160
- }
161
-
162
- resolve(true)
163
- },
164
- ])
165
- })
166
- }
167
-
168
- const errors = ref<string[]>([])
169
- const showValidationErrors = (data: string[]): void => {
170
- errors.value = data
171
- }
172
- const onRemoveValidationErrors = (): void => {
173
- errors.value = []
174
- }
175
- watch(
176
- errors,
177
- (newValue) => {
178
- emits('has-errors', !newValue.length)
179
- },
180
- { immediate: true, deep: true }
181
- )
182
-
183
- watch(
184
- () => props.show,
185
- (newValue) => {
186
- if (!newValue) return
187
-
188
- const input = document.getElementById('virtual-machine-name')
189
- if (!input) return
190
-
191
- setTimeout(() => {
192
- input.focus()
193
- }, 0)
194
- }
195
- )
196
-
197
- const isShowHelp = ref<boolean>(false)
198
- </script>
199
-
200
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-vm-actions-common-select-name-new
3
+ v-if="isNewView"
4
+ v-model:vm-name="vmName"
5
+ v-model:is-show-help="isShowHelp"
6
+ :project="props.project"
7
+ :errors="errors"
8
+ :data-center="props.dataCenter"
9
+ @remove-validation-errors="onRemoveValidationErrors"
10
+ @select-node="onSelectNode"
11
+ />
12
+ <common-vm-actions-common-select-name-old
13
+ v-else
14
+ v-model:vm-name="vmName"
15
+ v-model:is-show-help="isShowHelp"
16
+ :project="props.project"
17
+ :is-vmt="props.isVmt"
18
+ :errors="errors"
19
+ :data-center="props.dataCenter"
20
+ @remove-validation-errors="onRemoveValidationErrors"
21
+ @select-node="onSelectNode"
22
+ />
23
+ </template>
24
+
25
+ <script setup lang="ts">
26
+ // import { API_UI_I_Error } from '~/lib/models/store/interfaces'
27
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
28
+ import type { UI_T_Project } from '~/lib/models/types'
29
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
30
+
31
+ const props = withDefaults(
32
+ defineProps<{
33
+ nameFormSubmit: null | Function
34
+ show: boolean
35
+ project: UI_T_Project
36
+ isVmt?: boolean
37
+ validateEmptyName?: boolean
38
+ dataCenter?: UI_I_TreeNode // для сферы
39
+ existName?: string
40
+ }>(),
41
+ {
42
+ validateEmptyName: false,
43
+ isVmt: false,
44
+ dataCenter: undefined,
45
+ existName: undefined,
46
+ }
47
+ )
48
+ const emits = defineEmits<{
49
+ (event: 'submit', value: [string, UI_I_TreeNode | null]): void
50
+ (event: 'loading', value: boolean): void
51
+ (
52
+ event: 'check-name',
53
+ value: [[string, UI_I_TreeNode | null], (error: any) => void]
54
+ ): void
55
+ (event: 'has-errors', value: boolean): void
56
+ }>()
57
+
58
+ const { $store }: any = useNuxtApp()
59
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
60
+
61
+ const localization = computed<UI_I_Localization>(() => useLocal())
62
+
63
+ // TODO 100
64
+ const vmName = ref<string>(props.existName || '')
65
+
66
+ const selectedNode = ref<UI_I_TreeNode | null>(null)
67
+ const onSelectNode = (node: UI_I_TreeNode): void => {
68
+ selectedNode.value = node
69
+ }
70
+
71
+ watch(
72
+ () => props.nameFormSubmit,
73
+ (newValue) => {
74
+ newValue && submit(newValue)
75
+ }
76
+ )
77
+
78
+ const isParentDatacenter = (node: UI_I_TreeNode | null): boolean => {
79
+ if (!node) return false
80
+
81
+ if (node.parent?.type === 'datacenter') return true
82
+ if (node.parent?.type === 'folder') return isParentDatacenter(node.parent)
83
+ return false
84
+ }
85
+ const submit = async (cb: Function): Promise<void> => {
86
+ const name = vmName.value
87
+
88
+ if (props.validateEmptyName && name === '') {
89
+ showValidationErrors([
90
+ localization.value.common.emptyNameValidationDescription,
91
+ ])
92
+ cb(false)
93
+ return
94
+ }
95
+ if (name !== '') {
96
+ const isNameValid = await checkNameIsValid(name)
97
+ if (!isNameValid) {
98
+ cb(false)
99
+ return
100
+ }
101
+ }
102
+
103
+ if (props.project === 'sphere') {
104
+ // const isDatacenterFolder = isParentDatacenter(selectedNode.value)
105
+
106
+ if (
107
+ // selectedNode.value?.type !== 'datacenter' &&
108
+ // selectedNode.value?.type === 'folder' &&
109
+ // !isDatacenterFolder
110
+ // TODO рефакторинг, здесь сейчас проверяем является ли выбранный элемент датацентром или папкой(вм)
111
+ ![3, 7].includes(selectedNode.value?.kind)
112
+ ) {
113
+ showValidationErrors([
114
+ localization.value.common.enterValidLocationVirtualMachine,
115
+ ])
116
+ cb(false)
117
+ return
118
+ }
119
+ }
120
+
121
+ onRemoveValidationErrors()
122
+ emits('submit', [name, selectedNode.value])
123
+ cb(true)
124
+ }
125
+ const checkNameIsValid = async (name: string): Promise<boolean> => {
126
+ emits('loading', true)
127
+
128
+ return new Promise((resolve) => {
129
+ emits('check-name', [
130
+ [name, selectedNode.value],
131
+ (error) => {
132
+ emits('loading', false)
133
+
134
+ const status = error?.statusCode || 200
135
+ switch (status) {
136
+ case 400: // Empty name
137
+ showValidationErrors([
138
+ localization.value.common.emptyNameValidationDescription,
139
+ ])
140
+ resolve(false)
141
+ break
142
+ case 405: // Invalid kind
143
+ showValidationErrors([
144
+ localization.value.common.kindValidationDescription,
145
+ ])
146
+ resolve(false)
147
+ break
148
+ case 406: // Invalid name
149
+ showValidationErrors([
150
+ localization.value.common.vmNameValidationDescription,
151
+ ])
152
+ resolve(false)
153
+ break
154
+ case 409: // Name exist
155
+ showValidationErrors([
156
+ localization.value.common.vmNameExistInSelectedLocation,
157
+ ])
158
+ resolve(false)
159
+ break
160
+ }
161
+
162
+ resolve(true)
163
+ },
164
+ ])
165
+ })
166
+ }
167
+
168
+ const errors = ref<string[]>([])
169
+ const showValidationErrors = (data: string[]): void => {
170
+ errors.value = data
171
+ }
172
+ const onRemoveValidationErrors = (): void => {
173
+ errors.value = []
174
+ }
175
+ watch(
176
+ errors,
177
+ (newValue) => {
178
+ emits('has-errors', !newValue.length)
179
+ },
180
+ { immediate: true, deep: true }
181
+ )
182
+
183
+ watch(
184
+ () => props.show,
185
+ (newValue) => {
186
+ if (!newValue) return
187
+
188
+ const input = document.getElementById('virtual-machine-name')
189
+ if (!input) return
190
+
191
+ setTimeout(() => {
192
+ input.focus()
193
+ }, 0)
194
+ }
195
+ )
196
+
197
+ const isShowHelp = ref<boolean>(false)
198
+ </script>
199
+
200
+ <style scoped lang="scss"></style>
@@ -1,131 +1,131 @@
1
- <template>
2
- <div class="select-name">
3
- <atoms-alert
4
- v-show="props.errors.length"
5
- :items="props.errors"
6
- status="alert-danger"
7
- test-id="name-alert"
8
- @remove="emits('remove-validation-errors')"
9
- />
10
-
11
- <form id="virtual-machine-form" @submit.prevent>
12
- <label for="virtual-machine-name">{{ localization.common.name }}:</label>
13
- <input
14
- id="virtual-machine-name"
15
- v-model.trim="vmName"
16
- data-id="virtual-machine-name-input"
17
- type="text"
18
- maxlength="54"
19
- />
20
- <div id="vm-name-help-icon" class="content-signpost relative">
21
- <atoms-the-icon
22
- data-id="show-vm-name-help-icon"
23
- class="icon-show-help"
24
- fill="#0072a3"
25
- width="24px"
26
- height="24px"
27
- name="info-circle"
28
- @click="isShowHelp = !isShowHelp"
29
- />
30
- <atoms-tooltip-signpost
31
- v-if="isShowHelp"
32
- test-id="help-signpost"
33
- elem-id="vm-name-help-icon"
34
- @hide="isShowHelp = false"
35
- >
36
- <p>
37
- {{ localization.common.vmNameValidationDescription }}
38
- </p>
39
- </atoms-tooltip-signpost>
40
- </div>
41
- </form>
42
-
43
- <template v-if="props.project === 'sphere'">
44
- <p class="new-vm-name-and-folder-instructions mt-1">
45
- {{ locationDescription }}
46
- </p>
47
- <div class="tree-view-wrap">
48
- <common-vm-actions-add-folder-tree-view
49
- :data-center="props.dataCenter"
50
- @select-node="emits('select-node', $event)"
51
- />
52
- </div>
53
- </template>
54
- </div>
55
- </template>
56
-
57
- <script setup lang="ts">
58
- // import { API_UI_I_Error } from '~/lib/models/store/interfaces'
59
- import type { UI_I_Localization } from '~/lib/models/interfaces'
60
- import type { UI_T_Project } from '~/lib/models/types'
61
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
62
-
63
- const vmName = defineModel<string>('vmName', { required: true })
64
- const isShowHelp = defineModel<boolean>('isShowHelp', { required: true })
65
-
66
- const props = withDefaults(
67
- defineProps<{
68
- project: UI_T_Project
69
- errors: string[]
70
- isVmt: boolean
71
- dataCenter?: UI_I_TreeNode // для сферы
72
- }>(),
73
- {
74
- dataCenter: undefined,
75
- }
76
- )
77
- const emits = defineEmits<{
78
- (event: 'remove-validation-errors'): void
79
- (event: 'select-node', value: UI_I_TreeNode): void
80
- }>()
81
-
82
- const localization = computed<UI_I_Localization>(() => useLocal())
83
-
84
- const locationDescription = computed<string>(() =>
85
- props.isVmt
86
- ? localization.value.vmt.selectLocationTemplate
87
- : localization.value.common.selectLocationVirtualMachine
88
- )
89
- </script>
90
-
91
- <style scoped lang="scss">
92
- .select-name {
93
- form {
94
- display: flex;
95
- align-items: center;
96
- padding-top: 20px;
97
-
98
- label {
99
- width: 216px;
100
- }
101
- input {
102
- width: 345px;
103
- }
104
- }
105
-
106
- .tree-view-wrap {
107
- position: relative;
108
- border: 1px solid #000;
109
- padding: 5px;
110
- max-height: 300px;
111
- min-height: 200px;
112
- overflow: auto;
113
- margin-bottom: 10px;
114
- }
115
- }
116
- .content-signpost {
117
- user-select: none;
118
-
119
- .icon-show-help {
120
- cursor: pointer;
121
- }
122
-
123
- .help-title {
124
- font-size: 22px;
125
- margin-bottom: 24px;
126
- }
127
- .signpost {
128
- max-width: 360px;
129
- }
130
- }
131
- </style>
1
+ <template>
2
+ <div class="select-name">
3
+ <atoms-alert
4
+ v-show="props.errors.length"
5
+ :items="props.errors"
6
+ status="alert-danger"
7
+ test-id="name-alert"
8
+ @remove="emits('remove-validation-errors')"
9
+ />
10
+
11
+ <form id="virtual-machine-form" @submit.prevent>
12
+ <label for="virtual-machine-name">{{ localization.common.name }}:</label>
13
+ <input
14
+ id="virtual-machine-name"
15
+ v-model.trim="vmName"
16
+ data-id="virtual-machine-name-input"
17
+ type="text"
18
+ maxlength="54"
19
+ />
20
+ <div id="vm-name-help-icon" class="content-signpost relative">
21
+ <atoms-the-icon
22
+ data-id="show-vm-name-help-icon"
23
+ class="icon-show-help"
24
+ fill="#0072a3"
25
+ width="24px"
26
+ height="24px"
27
+ name="info-circle"
28
+ @click="isShowHelp = !isShowHelp"
29
+ />
30
+ <atoms-tooltip-signpost
31
+ v-if="isShowHelp"
32
+ test-id="help-signpost"
33
+ elem-id="vm-name-help-icon"
34
+ @hide="isShowHelp = false"
35
+ >
36
+ <p>
37
+ {{ localization.common.vmNameValidationDescription }}
38
+ </p>
39
+ </atoms-tooltip-signpost>
40
+ </div>
41
+ </form>
42
+
43
+ <template v-if="props.project === 'sphere'">
44
+ <p class="new-vm-name-and-folder-instructions mt-1">
45
+ {{ locationDescription }}
46
+ </p>
47
+ <div class="tree-view-wrap">
48
+ <common-vm-actions-add-folder-tree-view
49
+ :data-center="props.dataCenter"
50
+ @select-node="emits('select-node', $event)"
51
+ />
52
+ </div>
53
+ </template>
54
+ </div>
55
+ </template>
56
+
57
+ <script setup lang="ts">
58
+ // import { API_UI_I_Error } from '~/lib/models/store/interfaces'
59
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
60
+ import type { UI_T_Project } from '~/lib/models/types'
61
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
62
+
63
+ const vmName = defineModel<string>('vmName', { required: true })
64
+ const isShowHelp = defineModel<boolean>('isShowHelp', { required: true })
65
+
66
+ const props = withDefaults(
67
+ defineProps<{
68
+ project: UI_T_Project
69
+ errors: string[]
70
+ isVmt: boolean
71
+ dataCenter?: UI_I_TreeNode // для сферы
72
+ }>(),
73
+ {
74
+ dataCenter: undefined,
75
+ }
76
+ )
77
+ const emits = defineEmits<{
78
+ (event: 'remove-validation-errors'): void
79
+ (event: 'select-node', value: UI_I_TreeNode): void
80
+ }>()
81
+
82
+ const localization = computed<UI_I_Localization>(() => useLocal())
83
+
84
+ const locationDescription = computed<string>(() =>
85
+ props.isVmt
86
+ ? localization.value.vmt.selectLocationTemplate
87
+ : localization.value.common.selectLocationVirtualMachine
88
+ )
89
+ </script>
90
+
91
+ <style scoped lang="scss">
92
+ .select-name {
93
+ form {
94
+ display: flex;
95
+ align-items: center;
96
+ padding-top: 20px;
97
+
98
+ label {
99
+ width: 216px;
100
+ }
101
+ input {
102
+ width: 345px;
103
+ }
104
+ }
105
+
106
+ .tree-view-wrap {
107
+ position: relative;
108
+ border: 1px solid #000;
109
+ padding: 5px;
110
+ max-height: 300px;
111
+ min-height: 200px;
112
+ overflow: auto;
113
+ margin-bottom: 10px;
114
+ }
115
+ }
116
+ .content-signpost {
117
+ user-select: none;
118
+
119
+ .icon-show-help {
120
+ cursor: pointer;
121
+ }
122
+
123
+ .help-title {
124
+ font-size: 22px;
125
+ margin-bottom: 24px;
126
+ }
127
+ .signpost {
128
+ max-width: 360px;
129
+ }
130
+ }
131
+ </style>