bfg-common 1.5.512 → 1.5.513

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 (128) 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 +1 -1
  7. package/assets/localization/local_en.json +1 -1
  8. package/assets/localization/local_hy.json +1 -1
  9. package/assets/localization/local_kk.json +1 -1
  10. package/assets/localization/local_ru.json +1 -1
  11. package/assets/localization/local_zh.json +1 -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/atoms/table/info/lib/models/interfaces.ts +1 -0
  19. package/components/common/backup/storage/actions/add/Add.vue +251 -251
  20. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  21. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  22. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  23. package/components/common/browse/lib/models/interfaces.ts +5 -5
  24. package/components/common/countdownTimer/CountdownTimer.vue +11 -4
  25. package/components/common/countdownTimer/CountdownTimerNew.vue +13 -5
  26. package/components/common/diagramMain/network/Contents.vue +497 -497
  27. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  28. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  29. package/components/common/layout/theHeader/modals/reconnect/ReconnectNew.vue +1 -0
  30. package/components/common/pages/backups/DetailView.vue +52 -52
  31. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  32. package/components/common/pages/backups/modals/Modals.vue +243 -243
  33. package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
  34. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  35. package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
  36. package/components/common/pages/backups/modals/createBackup/general/General.vue +141 -141
  37. package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
  38. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  39. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  40. package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
  41. package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
  42. package/components/common/pages/backups/modals/restore/name/Name.vue +166 -166
  43. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  44. package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
  45. package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
  46. package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
  47. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  48. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  49. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  50. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  51. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  52. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  53. package/components/common/readyToComplete/New.vue +9 -0
  54. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  55. package/components/common/select/radio/RadioGroup.vue +137 -137
  56. package/components/common/spiceConsole/Drawer.vue +420 -392
  57. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  58. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  59. package/components/common/spiceConsole/lib/models/types.ts +1 -0
  60. package/components/common/tools/Actions.vue +207 -207
  61. package/components/common/treeView/TreeView.vue +52 -52
  62. package/components/common/vm/actions/add/Add.vue +895 -895
  63. package/components/common/vm/actions/add/New.vue +695 -695
  64. package/components/common/vm/actions/add/Old.vue +414 -414
  65. package/components/common/vm/actions/add/lib/config/steps.ts +347 -347
  66. package/components/common/vm/actions/clone/Clone.vue +863 -863
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +368 -368
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +99 -99
  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/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
  76. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
  77. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
  78. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
  79. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  80. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  81. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  82. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  83. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
  84. package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
  85. package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
  86. package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
  87. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  88. package/components/common/vm/actions/common/select/os/Old.vue +152 -152
  89. package/components/common/vm/actions/common/select/os/Os.vue +139 -139
  90. package/components/common/vm/actions/common/select/storage/new/New.vue +320 -320
  91. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  92. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  93. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  94. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  95. package/components/common/vm/actions/register/Register.vue +285 -285
  96. package/components/common/vm/actions/register/lib/config/steps.ts +86 -86
  97. package/components/common/wizards/common/steps/name/Name.vue +179 -179
  98. package/components/common/wizards/common/steps/name/New.vue +221 -221
  99. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  100. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  101. package/components/common/wizards/common/steps/name/location/Location.vue +85 -85
  102. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  103. package/components/common/wizards/datastore/add/Add.vue +228 -228
  104. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  105. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  106. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  107. package/composables/useAppVersion.ts +21 -21
  108. package/composables/useLocal.ts +6 -6
  109. package/composables/useLocalCommon.ts +39 -39
  110. package/package.json +1 -1
  111. package/plugins/console.ts +21 -22
  112. package/plugins/date.ts +233 -233
  113. package/plugins/mouse.ts +21 -0
  114. package/plugins/panelStates.ts +70 -70
  115. package/plugins/text.ts +59 -59
  116. package/public/spice-console/application/clientgui.js +854 -849
  117. package/public/spice-console/application/packetfactory.js +211 -206
  118. package/public/spice-console/application/virtualmouse.js +146 -109
  119. package/public/spice-console/lib/images/bitmap.js +203 -203
  120. package/public/spice-console/network/spicechannel.js +440 -440
  121. package/public/spice-console/process/cursorprocess.js +121 -111
  122. package/public/spice-console/process/inputprocess.js +227 -203
  123. package/public/spice-console/process/mainprocess.js +210 -78
  124. package/public/spice-console/run.js +210 -210
  125. package/public/spice-console/spiceobjects/spiceobjects.js +49 -28
  126. package/public/spice-console-minify/run.min.js +1 -1
  127. package/store/main/mutations.ts +7 -7
  128. package/store/main/state.ts +7 -7
@@ -1,86 +1,86 @@
1
- import type { UI_I_WizardStep } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
2
- import { UI_E_WIZARD_STATUS } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/enums'
3
- import type { UI_I_Localization } from '~/lib/models/interfaces'
4
-
5
- export const dynamicSteps = {
6
- selectName: 0,
7
- selectNameFolder: 1,
8
- selectComputeResource: 2,
9
- readyComplete: 3,
10
- }
11
-
12
- export const stepsFunc = (
13
- localization: UI_I_Localization
14
- ): UI_I_WizardStep[] => {
15
- return [
16
- // Procurator
17
- {
18
- id: dynamicSteps.selectName,
19
- stepName: '',
20
- title: localization.common.selectName,
21
- subTitle: localization.common.specifyUniqueName,
22
- status: UI_E_WIZARD_STATUS.SELECTED,
23
- isValid: true,
24
- testId: 'vm-select-name',
25
- fields: {
26
- name: {
27
- field: '',
28
- alert: '',
29
- },
30
- },
31
- },
32
- // Sphere
33
- {
34
- id: dynamicSteps.selectNameFolder,
35
- stepName: '',
36
- title: localization.vmWizard.selectNameFolder,
37
- subTitle: localization.common.specifyUniqueNameTargetLocation,
38
- status: UI_E_WIZARD_STATUS.INACTIVE,
39
- isValid: true,
40
- testId: 'vm-select-name-folder',
41
- fields: {
42
- name: {
43
- field: '',
44
- alert: '',
45
- },
46
- },
47
- },
48
- // Sphere
49
- {
50
- id: dynamicSteps.selectComputeResource,
51
- stepName: '',
52
- title: localization.vmWizard.selectComputeResource,
53
- subTitle: localization.common.selectDestinationComputeResourceOperation,
54
- status: UI_E_WIZARD_STATUS.INACTIVE,
55
- isValid: true,
56
- testId: 'vm-select-compute-resource',
57
- fields: {
58
- computeResource: {
59
- field: '',
60
- alert: '',
61
- },
62
- },
63
- },
64
- {
65
- id: dynamicSteps.readyComplete,
66
- stepName: '',
67
- title: localization.vmWizard.readyComplete,
68
- subTitle: localization.vmWizard.lastCreateSubtitle,
69
- status: UI_E_WIZARD_STATUS.INACTIVE,
70
- isValid: true,
71
- testId: 'vm-ready-complete',
72
- fields: {},
73
- },
74
- ]
75
- }
76
-
77
- export const stepsSchemeInitial = [
78
- // 0 Procurator
79
- [dynamicSteps.selectName, dynamicSteps.readyComplete],
80
- // 1 Sphere
81
- [
82
- dynamicSteps.selectNameFolder,
83
- dynamicSteps.selectComputeResource,
84
- dynamicSteps.readyComplete,
85
- ],
86
- ]
1
+ import type { UI_I_WizardStep } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/interfaces'
2
+ import { UI_E_WIZARD_STATUS } from '~/node_modules/bfg-uikit/components/ui/wizard/lib/models/enums'
3
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
4
+
5
+ export const dynamicSteps = {
6
+ selectName: 0,
7
+ selectNameFolder: 1,
8
+ selectComputeResource: 2,
9
+ readyComplete: 3,
10
+ }
11
+
12
+ export const stepsFunc = (
13
+ localization: UI_I_Localization
14
+ ): UI_I_WizardStep[] => {
15
+ return [
16
+ // Procurator
17
+ {
18
+ id: dynamicSteps.selectName,
19
+ stepName: '',
20
+ title: localization.common.selectName,
21
+ subTitle: localization.common.specifyUniqueName,
22
+ status: UI_E_WIZARD_STATUS.SELECTED,
23
+ isValid: true,
24
+ testId: 'vm-select-name',
25
+ fields: {
26
+ name: {
27
+ field: '',
28
+ alert: '',
29
+ },
30
+ },
31
+ },
32
+ // Sphere
33
+ {
34
+ id: dynamicSteps.selectNameFolder,
35
+ stepName: '',
36
+ title: localization.vmWizard.selectNameFolder,
37
+ subTitle: localization.common.specifyUniqueNameTargetLocation,
38
+ status: UI_E_WIZARD_STATUS.INACTIVE,
39
+ isValid: true,
40
+ testId: 'vm-select-name-folder',
41
+ fields: {
42
+ name: {
43
+ field: '',
44
+ alert: '',
45
+ },
46
+ },
47
+ },
48
+ // Sphere
49
+ {
50
+ id: dynamicSteps.selectComputeResource,
51
+ stepName: '',
52
+ title: localization.vmWizard.selectComputeResource,
53
+ subTitle: localization.common.selectDestinationComputeResourceOperation,
54
+ status: UI_E_WIZARD_STATUS.INACTIVE,
55
+ isValid: true,
56
+ testId: 'vm-select-compute-resource',
57
+ fields: {
58
+ computeResource: {
59
+ field: '',
60
+ alert: '',
61
+ },
62
+ },
63
+ },
64
+ {
65
+ id: dynamicSteps.readyComplete,
66
+ stepName: '',
67
+ title: localization.vmWizard.readyComplete,
68
+ subTitle: localization.vmWizard.lastCreateSubtitle,
69
+ status: UI_E_WIZARD_STATUS.INACTIVE,
70
+ isValid: true,
71
+ testId: 'vm-ready-complete',
72
+ fields: {},
73
+ },
74
+ ]
75
+ }
76
+
77
+ export const stepsSchemeInitial = [
78
+ // 0 Procurator
79
+ [dynamicSteps.selectName, dynamicSteps.readyComplete],
80
+ // 1 Sphere
81
+ [
82
+ dynamicSteps.selectNameFolder,
83
+ dynamicSteps.selectComputeResource,
84
+ dynamicSteps.readyComplete,
85
+ ],
86
+ ]
@@ -1,179 +1,179 @@
1
- <template>
2
- <common-wizards-common-steps-name-new
3
- v-if="isNewView"
4
- v-model:name="name"
5
- v-model:location="location"
6
- :has-location="props.hasLocation"
7
- :errors="errors"
8
- :location-nodes="props.locationNodes"
9
- :test-ids="props.testIds"
10
- @remove-validation-errors="onRemoveValidationErrors"
11
- />
12
- <common-wizards-common-steps-name-old
13
- v-else
14
- v-model:name="name"
15
- v-model:location="location"
16
- :has-location="props.hasLocation"
17
- :errors="errors"
18
- :location-nodes="props.locationNodes"
19
- :location-description="props.locationDescription"
20
- :test-ids="props.testIds"
21
- @remove-validation-errors="onRemoveValidationErrors"
22
- />
23
- </template>
24
-
25
- <script setup lang="ts">
26
- import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
27
- import type { UI_I_Localization } from '~/lib/models/interfaces'
28
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
29
- import type { UI_I_NameTestIds } from '~/components/common/wizards/common/steps/name/lib/models/interfaces'
30
-
31
- // TODO 100
32
- const name = defineModel<string>('name', { required: true })
33
- const location = defineModel<UI_I_TreeNode | null>('location') // для сферы
34
-
35
- const props = withDefaults(
36
- defineProps<{
37
- nameFormSubmit: null | Function
38
- show: boolean
39
- nameRequestUrl: string
40
- validationDescription: string
41
- nameExistValidationDescription: string
42
- testIds: UI_I_NameTestIds
43
- hasLocation?: boolean
44
- validateEmptyName?: boolean
45
- locationNodes?: UI_I_TreeNode[]
46
- locationDescription?: string
47
- allowedLocationKinds?: number[]
48
- }>(),
49
- {
50
- hasLocation: false,
51
- validateEmptyName: false,
52
- locationDescription: '',
53
- locationNodes: () => [],
54
- allowedLocationKinds: () => [],
55
- }
56
- )
57
- const emits = defineEmits<{
58
- (event: 'submit', value: [string, UI_I_TreeNode | null]): void
59
- (event: 'has-errors', value: boolean): void
60
- }>()
61
-
62
- const { $store }: any = useNuxtApp()
63
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
64
-
65
- const localization = computed<UI_I_Localization>(() => useLocal())
66
-
67
- watch(
68
- () => props.nameFormSubmit,
69
- (newValue) => {
70
- newValue && submit(newValue)
71
- }
72
- )
73
-
74
- // TODO defineExpose({
75
- // submit,
76
- // })
77
- const submit = async (cb: Function): Promise<void> => {
78
- if (props.validateEmptyName && name.value === '') {
79
- showValidationErrors([
80
- localization.value.common.emptyNameValidationDescription,
81
- ])
82
- cb(false)
83
- return
84
- }
85
- if (name.value !== '') {
86
- const isNameValid = await checkNameIsValid(name.value)
87
- if (!isNameValid) {
88
- cb(false)
89
- return
90
- }
91
- }
92
-
93
- if (props.hasLocation) {
94
- if (
95
- !location.value ||
96
- (location.value &&
97
- !props.allowedLocationKinds.includes(location.value.kind))
98
- ) {
99
- showValidationErrors([
100
- props.validationDescription,
101
- ])
102
- cb(false)
103
- return
104
- }
105
- }
106
-
107
- onRemoveValidationErrors()
108
- emits('submit', [name.value, location.value])
109
- cb(true)
110
- }
111
- const checkNameIsValid = async (nameLocal: string): Promise<boolean> => {
112
- const nameRequestUrlLocal = props.nameRequestUrl.replace('{name}', nameLocal)
113
- const { error } = await useMyFetch<null, API_UI_I_Error>(
114
- nameRequestUrlLocal,
115
- {
116
- method: 'GET',
117
- }
118
- )
119
- const status = error.value?.statusCode || 200
120
- switch (status) {
121
- case 400: // Empty name
122
- showValidationErrors([
123
- localization.value.common.emptyNameValidationDescription,
124
- ])
125
- return false
126
- case 405: // Invalid kind
127
- showValidationErrors([
128
- localization.value.common.kindValidationDescription,
129
- ])
130
- return false
131
- case 406: // Invalid name
132
- showValidationErrors([
133
- localization.value.common.nameValidationDescription,
134
- ])
135
- return false
136
- case 409: // Name exist
137
- showValidationErrors([
138
- props.nameExistValidationDescription,
139
- ])
140
- return false
141
- }
142
-
143
- return true
144
- }
145
-
146
- const errors = ref<string[]>([])
147
- const showValidationErrors = (data: string[]): void => {
148
- errors.value = data
149
- }
150
- const onRemoveValidationErrors = (): void => {
151
- errors.value = []
152
- }
153
- watch(
154
- errors,
155
- (newValue) => {
156
- emits('has-errors', !newValue.length)
157
- },
158
- { immediate: true, deep: true }
159
- )
160
-
161
- // TODO defineExpose({
162
- // focusNameInput,
163
- // })
164
- watch(
165
- () => props.show,
166
- (newValue) => {
167
- if (!newValue) return
168
-
169
- const input = document.getElementById('virtual-machine-name')
170
- if (!input) return
171
-
172
- setTimeout(() => {
173
- input.focus()
174
- }, 0)
175
- }
176
- )
177
- </script>
178
-
179
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-wizards-common-steps-name-new
3
+ v-if="isNewView"
4
+ v-model:name="name"
5
+ v-model:location="location"
6
+ :has-location="props.hasLocation"
7
+ :errors="errors"
8
+ :location-nodes="props.locationNodes"
9
+ :test-ids="props.testIds"
10
+ @remove-validation-errors="onRemoveValidationErrors"
11
+ />
12
+ <common-wizards-common-steps-name-old
13
+ v-else
14
+ v-model:name="name"
15
+ v-model:location="location"
16
+ :has-location="props.hasLocation"
17
+ :errors="errors"
18
+ :location-nodes="props.locationNodes"
19
+ :location-description="props.locationDescription"
20
+ :test-ids="props.testIds"
21
+ @remove-validation-errors="onRemoveValidationErrors"
22
+ />
23
+ </template>
24
+
25
+ <script setup lang="ts">
26
+ import type { API_UI_I_Error } from '~/lib/models/store/interfaces'
27
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
28
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
29
+ import type { UI_I_NameTestIds } from '~/components/common/wizards/common/steps/name/lib/models/interfaces'
30
+
31
+ // TODO 100
32
+ const name = defineModel<string>('name', { required: true })
33
+ const location = defineModel<UI_I_TreeNode | null>('location') // для сферы
34
+
35
+ const props = withDefaults(
36
+ defineProps<{
37
+ nameFormSubmit: null | Function
38
+ show: boolean
39
+ nameRequestUrl: string
40
+ validationDescription: string
41
+ nameExistValidationDescription: string
42
+ testIds: UI_I_NameTestIds
43
+ hasLocation?: boolean
44
+ validateEmptyName?: boolean
45
+ locationNodes?: UI_I_TreeNode[]
46
+ locationDescription?: string
47
+ allowedLocationKinds?: number[]
48
+ }>(),
49
+ {
50
+ hasLocation: false,
51
+ validateEmptyName: false,
52
+ locationDescription: '',
53
+ locationNodes: () => [],
54
+ allowedLocationKinds: () => [],
55
+ }
56
+ )
57
+ const emits = defineEmits<{
58
+ (event: 'submit', value: [string, UI_I_TreeNode | null]): void
59
+ (event: 'has-errors', value: boolean): void
60
+ }>()
61
+
62
+ const { $store }: any = useNuxtApp()
63
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
64
+
65
+ const localization = computed<UI_I_Localization>(() => useLocal())
66
+
67
+ watch(
68
+ () => props.nameFormSubmit,
69
+ (newValue) => {
70
+ newValue && submit(newValue)
71
+ }
72
+ )
73
+
74
+ // TODO defineExpose({
75
+ // submit,
76
+ // })
77
+ const submit = async (cb: Function): Promise<void> => {
78
+ if (props.validateEmptyName && name.value === '') {
79
+ showValidationErrors([
80
+ localization.value.common.emptyNameValidationDescription,
81
+ ])
82
+ cb(false)
83
+ return
84
+ }
85
+ if (name.value !== '') {
86
+ const isNameValid = await checkNameIsValid(name.value)
87
+ if (!isNameValid) {
88
+ cb(false)
89
+ return
90
+ }
91
+ }
92
+
93
+ if (props.hasLocation) {
94
+ if (
95
+ !location.value ||
96
+ (location.value &&
97
+ !props.allowedLocationKinds.includes(location.value.kind))
98
+ ) {
99
+ showValidationErrors([
100
+ props.validationDescription,
101
+ ])
102
+ cb(false)
103
+ return
104
+ }
105
+ }
106
+
107
+ onRemoveValidationErrors()
108
+ emits('submit', [name.value, location.value])
109
+ cb(true)
110
+ }
111
+ const checkNameIsValid = async (nameLocal: string): Promise<boolean> => {
112
+ const nameRequestUrlLocal = props.nameRequestUrl.replace('{name}', nameLocal)
113
+ const { error } = await useMyFetch<null, API_UI_I_Error>(
114
+ nameRequestUrlLocal,
115
+ {
116
+ method: 'GET',
117
+ }
118
+ )
119
+ const status = error.value?.statusCode || 200
120
+ switch (status) {
121
+ case 400: // Empty name
122
+ showValidationErrors([
123
+ localization.value.common.emptyNameValidationDescription,
124
+ ])
125
+ return false
126
+ case 405: // Invalid kind
127
+ showValidationErrors([
128
+ localization.value.common.kindValidationDescription,
129
+ ])
130
+ return false
131
+ case 406: // Invalid name
132
+ showValidationErrors([
133
+ localization.value.common.nameValidationDescription,
134
+ ])
135
+ return false
136
+ case 409: // Name exist
137
+ showValidationErrors([
138
+ props.nameExistValidationDescription,
139
+ ])
140
+ return false
141
+ }
142
+
143
+ return true
144
+ }
145
+
146
+ const errors = ref<string[]>([])
147
+ const showValidationErrors = (data: string[]): void => {
148
+ errors.value = data
149
+ }
150
+ const onRemoveValidationErrors = (): void => {
151
+ errors.value = []
152
+ }
153
+ watch(
154
+ errors,
155
+ (newValue) => {
156
+ emits('has-errors', !newValue.length)
157
+ },
158
+ { immediate: true, deep: true }
159
+ )
160
+
161
+ // TODO defineExpose({
162
+ // focusNameInput,
163
+ // })
164
+ watch(
165
+ () => props.show,
166
+ (newValue) => {
167
+ if (!newValue) return
168
+
169
+ const input = document.getElementById('virtual-machine-name')
170
+ if (!input) return
171
+
172
+ setTimeout(() => {
173
+ input.focus()
174
+ }, 0)
175
+ }
176
+ )
177
+ </script>
178
+
179
+ <style scoped lang="scss"></style>