bfg-common 1.5.556 → 1.5.558

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 (64) hide show
  1. package/assets/localization/local_be.json +4 -20
  2. package/assets/localization/local_en.json +4 -20
  3. package/assets/localization/local_hy.json +4 -20
  4. package/assets/localization/local_kk.json +4 -20
  5. package/assets/localization/local_ru.json +4 -20
  6. package/assets/localization/local_zh.json +5 -21
  7. package/components/common/modals/confirmByInput/ConfirmByInput.vue +1 -9
  8. package/components/common/modals/confirmByInput/ConfirmByInputNew.vue +2 -7
  9. package/components/common/pages/backups/modals/createBackup/New.vue +2 -8
  10. package/components/common/pages/backups/modals/restore/Restore.vue +5 -9
  11. package/components/common/pages/backups/modals/restore/RestoreNew.vue +3 -13
  12. package/components/common/pages/backups/modals/restore/RestoreOld.vue +18 -6
  13. package/components/common/vm/actions/add/Add.vue +46 -119
  14. package/components/common/vm/actions/add/New.vue +16 -54
  15. package/components/common/vm/actions/add/Old.vue +16 -55
  16. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +14 -81
  17. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +7 -56
  18. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +8 -56
  19. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +73 -142
  20. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +60 -54
  21. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +61 -55
  22. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +139 -159
  23. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +8 -15
  24. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuOld.vue +8 -13
  25. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +62 -75
  26. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +58 -74
  27. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbController.vue +6 -17
  28. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +6 -3
  29. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerOld.vue +6 -3
  30. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +17 -39
  31. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +6 -5
  32. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +6 -5
  33. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/lib/config/options.ts +4 -4
  34. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +6 -93
  35. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +8 -62
  36. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +8 -60
  37. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptions.vue +5 -69
  38. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +12 -32
  39. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsOld.vue +12 -33
  40. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +114 -132
  41. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +41 -6
  42. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderOld.vue +44 -6
  43. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +8 -23
  44. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +21 -31
  45. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +26 -34
  46. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +28 -34
  47. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/Old.vue +24 -30
  48. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/RemoteConsoleOptions.vue +8 -112
  49. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +3 -3
  50. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/{KeymapNew.vue → New.vue} +6 -6
  51. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/{KeymapOld.vue → Old.vue} +5 -5
  52. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +6 -7
  53. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/Tools.vue +4 -38
  54. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +7 -26
  55. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsOld.vue +24 -50
  56. package/components/common/vm/actions/common/lib/models/interfaces.ts +57 -25
  57. package/components/common/vm/actions/editSettings/EditSettings.vue +21 -35
  58. package/components/common/vm/actions/editSettings/EditSettingsOld.vue +14 -41
  59. package/components/common/vm/actions/editSettings/new/New.vue +14 -41
  60. package/components/common/vm/actions/lib/models/interfaces.ts +4 -29
  61. package/components/common/vm/actions/lib/utils.ts +37 -32
  62. package/package.json +1 -3
  63. /package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/{PasswordNew.vue → New.vue} +0 -0
  64. /package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/{PasswordOld.vue → Old.vue} +0 -0
@@ -1,34 +1,36 @@
1
1
  <template>
2
2
  <div class="boot-orders">
3
3
  <atoms-stack-block
4
- :has-children="false"
5
- test-id="boot-options-order-stack-block"
4
+ :has-children="false"
5
+ test-id="boot-options-order-stack-block"
6
6
  >
7
7
  <template #stackBlockKey>
8
8
  {{ localization.common.bootOrder }}
9
9
  </template>
10
10
  <template #stackBlockContent>
11
11
  <atoms-list-drag-drop-list
12
- :items="props.bootList"
12
+ :items="localBootList"
13
13
  :disabled="props.isDisabled"
14
14
  grab-item-key="text"
15
15
  @drop="emits('change-order', $event)"
16
16
  >
17
17
  <template
18
- v-for="(item, index) in props.bootList"
18
+ v-for="(item, index) in localBootList"
19
19
  :key="index"
20
20
  #[`leftSide${index}`]
21
21
  >
22
22
  <input
23
23
  :id="`boot-order-${index}`"
24
- v-model="item.isChecked"
24
+ :key="item.name"
25
+ :checked="item.isChecked"
25
26
  :data-id="item.testId"
26
27
  :disabled="props.isDisabled"
27
28
  type="checkbox"
29
+ @change="onCheckboxChange(index, $event)"
28
30
  />
29
31
  </template>
30
32
  <template
31
- v-for="(item, index) in props.bootList"
33
+ v-for="(item, index) in localBootList"
32
34
  :key="props.bootList.length + index"
33
35
  #[`rightSide${index}`]
34
36
  >
@@ -52,9 +54,45 @@ const props = defineProps<{
52
54
  bootList: UI_I_BootItem[]
53
55
  isDisabled: boolean
54
56
  }>()
57
+
55
58
  const emits = defineEmits<{
56
59
  (event: 'change-order', value: UI_I_DropEvent): void
60
+ (event: 'update:boot-list', value: UI_I_BootItem[]): void
57
61
  }>()
62
+
63
+ // Локальная копия для реактивных изменений
64
+ const localBootList = ref<UI_I_BootItem[]>([])
65
+
66
+ // Синхронизируем с props
67
+ watch(
68
+ () => props.bootList,
69
+ (newBootList) => {
70
+ localBootList.value = newBootList.map((item) => ({ ...item }))
71
+ },
72
+ { deep: true, immediate: true }
73
+ )
74
+
75
+ // Обработчик изменения чекбокса
76
+ const onCheckboxChange = (index: number, event: Event): void => {
77
+ const target = event.target as HTMLInputElement
78
+ localBootList.value[index].isChecked = target.checked
79
+
80
+ // Сохраняем порядок при изменении чекбокса
81
+ let currentOrder = 1
82
+ localBootList.value.forEach((item) => {
83
+ if (item.isChecked) {
84
+ item.order = currentOrder++
85
+ } else {
86
+ item.order = 0
87
+ }
88
+ })
89
+
90
+ // Сортируем список
91
+ localBootList.value.sort((a, b) => a.order - b.order)
92
+
93
+ // Отправляем обновленный список родителю
94
+ emits('update:boot-list', localBootList.value)
95
+ }
58
96
  </script>
59
97
 
60
98
  <style scoped lang="scss">
@@ -1,10 +1,7 @@
1
1
  <template>
2
2
  <common-vm-actions-common-customize-hardware-vmoptions-general-options-new
3
3
  v-if="isNewView"
4
- v-model:vm-name="vmName"
5
- v-model:guest-machine-type="guestMachineType"
6
- v-model:guest-os-family="guestOsFamily"
7
- v-model:guest-os-version="guestOsVersion"
4
+ v-model="model"
8
5
  v-model:block-is-open="blockIsOpen"
9
6
  :name-label="nameLabel"
10
7
  :is-disabled="isDisabled"
@@ -15,10 +12,7 @@
15
12
  />
16
13
  <common-vm-actions-common-customize-hardware-vmoptions-general-options-old
17
14
  v-else
18
- v-model:vm-name="vmName"
19
- v-model:guest-machine-type="guestMachineType"
20
- v-model:guest-os-family="guestOsFamily"
21
- v-model:guest-os-version="guestOsVersion"
15
+ v-model="model"
22
16
  v-model:block-is-open="blockIsOpen"
23
17
  :name-label="nameLabel"
24
18
  :is-disabled="isDisabled"
@@ -32,19 +26,10 @@
32
26
  <script setup lang="ts">
33
27
  import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
34
28
  import type { UI_I_Localization } from '~/lib/models/interfaces'
29
+ import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
35
30
  import { capabilities } from '~/components/common/vm/actions/common/lib/config/capabilities'
36
31
 
37
- const vmName = defineModel<string>('vmName', { required: true })
38
- const guestMachineType = defineModel<UI_I_OptionItem | null>(
39
- 'guestMachineType',
40
- { required: true }
41
- )
42
- const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
43
- required: true,
44
- })
45
- const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
46
- required: true,
47
- })
32
+ const model = defineModel<UI_I_CreateVmData>({ required: true })
48
33
 
49
34
  const props = withDefaults(
50
35
  defineProps<{
@@ -71,18 +56,18 @@ const machineTypeOptions = ref<UI_I_OptionItem[]>(
71
56
 
72
57
  const osOptions = ref<UI_I_OptionItem[]>(capabilities.value.guestOsFamilies)
73
58
  const onChangeOS = (): void => {
74
- guestOsVersion.value = versionsOptions.value[0]
59
+ model.value.guest_os_version = versionsOptions.value[0].value
75
60
  }
76
61
 
77
62
  const versionsOptions = computed<UI_I_OptionItem[]>(() => {
78
- if (!guestOsFamily.value) return []
63
+ if (!model.value.guest_os_family) return []
79
64
 
80
- return capabilities.value.guestOsVersions[guestOsFamily.value.value] || []
65
+ return capabilities.value.guestOsVersions[model.value.guest_os_family.value] || []
81
66
  })
82
67
  watch(
83
68
  versionsOptions,
84
69
  () => {
85
- guestOsVersion.value = versionsOptions.value[0]
70
+ model.value.guest_os_version = versionsOptions.value[0].value
86
71
  }
87
72
  // { immediate: true }
88
73
  )
@@ -19,13 +19,13 @@
19
19
  <template #stackBlockContent>
20
20
  <div v-show="!blockIsOpen" class="vm-name-wrap">
21
21
  <span class="vsphere-icon-vm"></span>
22
- <span data-id="header-vm-name">{{ vmName || '--' }}</span>
22
+ <span data-id="header-vm-name">{{ model.name || '--' }}</span>
23
23
  </div>
24
24
  </template>
25
25
  <template #stackChildren>
26
26
  <ui-stack-block
27
- :has-children="false"
28
- test-id="general-options-vm-name-stack-block"
27
+ :has-children="false"
28
+ test-id="general-options-vm-name-stack-block"
29
29
  >
30
30
  <template #stackBlockKey>
31
31
  {{ props.nameLabel }}
@@ -33,30 +33,30 @@
33
33
  <template #stackBlockContent>
34
34
  <div class="vm-name-wrap">
35
35
  <span class="vsphere-icon-vm"></span>
36
- <span data-id="new-vm-name">{{ vmName || '--' }}</span>
36
+ <span data-id="new-vm-name">{{ model.name || '--' }}</span>
37
37
  </div>
38
- <!-- <span v-if="!props.isEdit">{{ vmName }}</span>-->
38
+ <!-- <span v-if="!props.isEdit">{{ model.name }}</span>-->
39
39
  <!-- <input-->
40
40
  <!-- v-else-->
41
41
  <!-- id="general-option-vm-name"-->
42
- <!-- v-models="vmName"-->
42
+ <!-- v-models="model.name"-->
43
43
  <!-- type="text"-->
44
44
  <!-- />-->
45
45
  </template>
46
46
  </ui-stack-block>
47
47
 
48
48
  <ui-stack-block
49
- :has-children="false"
50
- test-id="general-options-machine-type-stack-block"
49
+ :has-children="false"
50
+ test-id="general-options-machine-type-stack-block"
51
51
  >
52
52
  <template #stackBlockKey>
53
53
  <span class="mt-2">{{ localization.common.machineType }}</span>
54
54
  </template>
55
55
  <template #stackBlockContent>
56
56
  <ui-select
57
- v-if="guestMachineType"
57
+ v-if="model.machine_type"
58
58
  id="guest-machine-type-select"
59
- v-model="guestMachineType"
59
+ v-model="model.machine_type"
60
60
  :items="props.machineTypeOptions"
61
61
  :disabled="props.isDisabled"
62
62
  width="auto"
@@ -68,17 +68,17 @@
68
68
  </ui-stack-block>
69
69
 
70
70
  <ui-stack-block
71
- :has-children="false"
72
- test-id="general-options-guest-os-family-stack-block"
71
+ :has-children="false"
72
+ test-id="general-options-guest-os-family-stack-block"
73
73
  >
74
74
  <template #stackBlockKey>
75
75
  <span class="mt-2">{{ localization.common.guestOsFamily }}</span>
76
76
  </template>
77
77
  <template #stackBlockContent>
78
78
  <ui-select
79
- v-if="guestOsFamily"
79
+ v-if="model.guest_os_family"
80
80
  id="guest-os-family-select"
81
- v-model="guestOsFamily"
81
+ v-model="model.guest_os_family"
82
82
  :items="props.osOptions"
83
83
  :disabled="props.isDisabled"
84
84
  width="auto"
@@ -91,17 +91,17 @@
91
91
  </ui-stack-block>
92
92
 
93
93
  <ui-stack-block
94
- :has-children="false"
95
- test-id="general-options-guest-os-version-stack-block"
94
+ :has-children="false"
95
+ test-id="general-options-guest-os-version-stack-block"
96
96
  >
97
97
  <template #stackBlockKey>
98
98
  <span class="mt-2">{{ localization.common.guestOsVersion }}</span>
99
99
  </template>
100
100
  <template #stackBlockContent>
101
101
  <ui-select
102
- v-if="guestOsVersion"
102
+ v-if="model.guest_os_version"
103
103
  id="guest-os-version-select"
104
- v-model="guestOsVersion"
104
+ v-model="model.guest_os_version"
105
105
  :items="props.versionsOptions"
106
106
  :disabled="props.isDisabled"
107
107
  width="auto"
@@ -118,21 +118,11 @@
118
118
  <script setup lang="ts">
119
119
  import type { UI_I_Localization } from '~/lib/models/interfaces'
120
120
  import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
121
+ import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
122
+
123
+ const model = defineModel<UI_I_CreateVmData>({ required: true })
121
124
 
122
125
  const blockIsOpen = defineModel<boolean>('blockIsOpen', { required: true })
123
- const vmName = defineModel<string>('vmName', { required: true })
124
- const guestMachineType = defineModel<UI_I_OptionItem | null>(
125
- 'guestMachineType',
126
- {
127
- required: true,
128
- }
129
- )
130
- const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
131
- required: true,
132
- })
133
- const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
134
- required: true,
135
- })
136
126
 
137
127
  const props = defineProps<{
138
128
  isDisabled: boolean
@@ -15,42 +15,44 @@
15
15
  </div>
16
16
  </template>
17
17
  <template #stackBlockContent>
18
- <div v-show="!blockIsOpen" data-id="header-vm-name">{{ props.nameLabel }}: {{ vmName }}</div>
18
+ <div v-show="!blockIsOpen" data-id="header-vm-name">
19
+ {{ props.nameLabel }}: {{ model.name }}
20
+ </div>
19
21
  </template>
20
22
  <template #stackChildren>
21
23
  <atoms-stack-block
22
- :has-children="false"
23
- test-id="general-options-vm-name-stack-block"
24
+ :has-children="false"
25
+ test-id="general-options-vm-name-stack-block"
24
26
  >
25
27
  <template #stackBlockKey>
26
28
  {{ props.nameLabel }}
27
29
  </template>
28
30
  <template #stackBlockContent>
29
- <span data-id="vm-name">{{ vmName }}</span>
30
- <!-- <span v-if="!props.isEdit">{{ vmName }}</span>-->
31
+ <span data-id="vm-name">{{ model.name }}</span>
32
+ <!-- <span v-if="!props.isEdit">{{ model.name }}</span>-->
31
33
  <!-- <input-->
32
34
  <!-- v-else-->
33
35
  <!-- id="general-option-vm-name"-->
34
- <!-- v-models="vmName"-->
36
+ <!-- v-models="model.name"-->
35
37
  <!-- type="text"-->
36
38
  <!-- />-->
37
39
  </template>
38
40
  </atoms-stack-block>
39
41
 
40
42
  <atoms-stack-block
41
- :has-children="false"
42
- test-id="general-options-machine-type-stack-block"
43
+ :has-children="false"
44
+ test-id="general-options-machine-type-stack-block"
43
45
  >
44
46
  <template #stackBlockKey>
45
47
  {{ localization.common.machineType }}
46
48
  </template>
47
49
  <template #stackBlockContent>
48
50
  <select
49
- v-if="guestMachineType"
51
+ v-if="model.machine_type"
50
52
  id="guest-machine-type-select"
51
- v-model="guestMachineType"
53
+ v-model="model.machine_type"
52
54
  :disabled="props.isDisabled"
53
- :data-value="guestMachineType?.value"
55
+ :data-value="model.machine_type"
54
56
  data-id="guest-machine-type-select"
55
57
  >
56
58
  <option
@@ -66,19 +68,19 @@
66
68
  </atoms-stack-block>
67
69
 
68
70
  <atoms-stack-block
69
- :has-children="false"
70
- test-id="general-options-guest-os-family-stack-block"
71
+ :has-children="false"
72
+ test-id="general-options-guest-os-family-stack-block"
71
73
  >
72
74
  <template #stackBlockKey>
73
75
  {{ localization.common.guestOsFamily }}
74
76
  </template>
75
77
  <template #stackBlockContent>
76
78
  <select
77
- v-if="guestOsFamily"
79
+ v-if="model.guest_os_family"
78
80
  id="guest-os-family-select"
79
- v-model="guestOsFamily"
81
+ v-model="model.guest_os_family"
80
82
  :disabled="props.isDisabled"
81
- :data-value="guestOsFamily?.value"
83
+ :data-value="model.guest_os_family"
82
84
  data-id="guest-os-family-select"
83
85
  @change="emits('change-os')"
84
86
  >
@@ -95,19 +97,19 @@
95
97
  </atoms-stack-block>
96
98
 
97
99
  <atoms-stack-block
98
- :has-children="false"
99
- test-id="general-options-guest-os-version-stack-block"
100
+ :has-children="false"
101
+ test-id="general-options-guest-os-version-stack-block"
100
102
  >
101
103
  <template #stackBlockKey>
102
104
  {{ localization.common.guestOsVersion }}
103
105
  </template>
104
106
  <template #stackBlockContent>
105
107
  <select
106
- v-if="guestOsVersion"
108
+ v-if="model.guest_os_version"
107
109
  id="guest-os-version-select"
108
- v-model="guestOsVersion"
110
+ v-model="model.guest_os_version"
109
111
  :disabled="props.isDisabled"
110
- :data-value="guestOsVersion?.value"
112
+ :data-value="model.guest_os_version"
111
113
  data-id="guest-os-version-select"
112
114
  >
113
115
  <option
@@ -129,21 +131,11 @@
129
131
  <script setup lang="ts">
130
132
  import type { UI_I_Localization } from '~/lib/models/interfaces'
131
133
  import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
134
+ import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
135
+
136
+ const model = defineModel<UI_I_CreateVmData>({ required: true })
132
137
 
133
138
  const blockIsOpen = defineModel<boolean>('blockIsOpen', { required: true })
134
- const vmName = defineModel<string>('vmName', { required: true })
135
- const guestMachineType = defineModel<UI_I_OptionItem | null>(
136
- 'guestMachineType',
137
- {
138
- required: true,
139
- }
140
- )
141
- const guestOsFamily = defineModel<UI_I_OptionItem | null>('guestOsFamily', {
142
- required: true,
143
- })
144
- const guestOsVersion = defineModel<UI_I_OptionItem | null>('guestOsVersion', {
145
- required: true,
146
- })
147
139
 
148
140
  const props = withDefaults(
149
141
  defineProps<{
@@ -25,111 +25,105 @@
25
25
  <!-- TODO возможно вернем, НЕ УДАЛЯТЬ-->
26
26
 
27
27
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-type-->
28
- <!-- v-models:remote-console-type="remoteConsoleType"-->
28
+ <!-- v-models:remote-console-type="model.type"-->
29
29
  <!-- :error-validation-fields="props.errorValidationFields"-->
30
30
  <!-- :disabled="isDisabled"-->
31
31
  <!-- @input="changeRemoteConsoleType"-->
32
32
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
33
33
  <!-- />-->
34
34
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-keymap
35
- v-model:keymap="keymap"
35
+ v-model="model.keymap"
36
36
  :disabled="props.isDisabled"
37
37
  />
38
38
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-password
39
- v-model:password="password"
39
+ v-model="model.password"
40
40
  :disabled="props.isDisabled"
41
41
  @valid="passwordIsValid = $event"
42
42
  />
43
43
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-power-control-->
44
- <!-- v-if="remoteConsoleType === 'vnc'"-->
44
+ <!-- v-if="model.type === 'vnc'"-->
45
45
  <!-- v-models:power-control="powerControl"-->
46
46
  <!-- />-->
47
47
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-share-policy-->
48
- <!-- v-if="remoteConsoleType === 'vnc'"-->
48
+ <!-- v-if="model.type === 'vnc'"-->
49
49
  <!-- v-models:share-policy="sharePolicy"-->
50
50
  <!-- />-->
51
51
  <!-- TODO возможно вернем, НЕ УДАЛЯТЬ-->
52
52
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-img-compression-->
53
- <!-- v-if="remoteConsoleType === 'spice'"-->
53
+ <!-- v-if="model.type === 'spice'"-->
54
54
  <!-- v-models:img-compression="imgCompression"-->
55
55
  <!-- :error-validation-fields="props.errorValidationFields"-->
56
56
  <!-- :disabled="isDisabled"-->
57
57
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
58
58
  <!-- />-->
59
59
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-jpeg-compression-->
60
- <!-- v-if="remoteConsoleType === 'spice'"-->
60
+ <!-- v-if="model.type === 'spice'"-->
61
61
  <!-- v-models:jpeg-compression="jpegCompression"-->
62
62
  <!-- :error-validation-fields="props.errorValidationFields"-->
63
63
  <!-- :disabled="isDisabled"-->
64
64
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
65
65
  <!-- />-->
66
66
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-zlib-compression-->
67
- <!-- v-if="remoteConsoleType === 'spice'"-->
67
+ <!-- v-if="model.type === 'spice'"-->
68
68
  <!-- v-models:zlib-compression="zlibCompression"-->
69
69
  <!-- :error-validation-fields="props.errorValidationFields"-->
70
70
  <!-- :disabled="isDisabled"-->
71
71
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
72
72
  <!-- />-->
73
73
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-playback-compression-->
74
- <!-- v-if="remoteConsoleType === 'spice'"-->
74
+ <!-- v-if="model.type === 'spice'"-->
75
75
  <!-- :disabled="isDisabled"-->
76
76
  <!-- v-models:playback-compression="playbackCompression"-->
77
77
  <!-- />-->
78
78
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-streaming-mode-->
79
- <!-- v-if="remoteConsoleType === 'spice'"-->
79
+ <!-- v-if="model.type === 'spice'"-->
80
80
  <!-- v-models:streaming-mode="streamingMode"-->
81
81
  <!-- :error-validation-fields="props.errorValidationFields"-->
82
82
  <!-- :disabled="isDisabled"-->
83
83
  <!-- @remove-error-by-title="emits('remove-error-by-title', $event)"-->
84
84
  <!-- />-->
85
85
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-copy-paste
86
- v-if="remoteConsoleType === 'spice'"
87
- v-model:copy-paste="copyPaste"
86
+ v-if="model.type === 'spice'"
87
+ v-model:copy-paste="model.spice.clipboard"
88
88
  :disabled="props.isDisabled"
89
89
  />
90
90
  <!-- TODO возможно вернем, НЕ УДАЛЯТЬ-->
91
91
  <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-mouse-mode-->
92
- <!-- v-if="remoteConsoleType === 'spice'"-->
92
+ <!-- v-if="model.type === 'spice'"-->
93
93
  <!-- v-models:mouse-mode="mouseMode"-->
94
94
  <!-- />-->
95
95
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-file-transfer
96
- v-if="remoteConsoleType === 'spice'"
97
- v-model:file-transfer="fileTransfer"
96
+ v-if="model.type === 'spice'"
97
+ v-model:file-transfer="model.spice.file_transfer"
98
98
  :disabled="props.isDisabled"
99
99
  />
100
100
  <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-usb-redirection
101
- v-if="remoteConsoleType === 'spice'"
101
+ v-if="model.type === 'spice'"
102
102
  v-model:usb-redirection="usbRedirection"
103
103
  :disabled="props.isDisabled"
104
104
  />
105
- <!-- TODO 700-->
106
- <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-folder-sharing-->
107
- <!-- v-if="remoteConsoleType === 'spice'"-->
108
- <!-- v-model:folder-sharing="folderSharing"-->
109
- <!-- :disabled="props.isDisabled"-->
110
- <!-- />-->
105
+ <!-- TODO 700-->
106
+ <!-- <common-vm-actions-common-customize-hardware-vmoptions-remote-console-options-folder-sharing-->
107
+ <!-- v-if="model.type === 'spice'"-->
108
+ <!-- v-model:folder-sharing="model.spice.folder_sharing"-->
109
+ <!-- :disabled="props.isDisabled"-->
110
+ <!-- />-->
111
111
  </template>
112
112
  </ui-stack-block>
113
113
  </template>
114
114
 
115
115
  <script setup lang="ts">
116
116
  import type { UI_I_Localization } from '~/lib/models/interfaces'
117
+ import type { UI_I_CreateVmData } from '~/components/common/vm/actions/common/lib/models/interfaces'
118
+
119
+ const model = defineModel<UI_I_CreateVmData['options']['remote_console']>({ required: true })
117
120
 
118
- const keymap = defineModel<string>('keymap', { required: true })
119
- const password = defineModel<string>('password', { required: true })
120
121
  const passwordIsValid = defineModel<boolean>('passwordIsValid', {
121
122
  required: true,
122
123
  })
123
- const remoteConsoleType = defineModel<string>('remoteConsoleType', {
124
- required: true,
125
- })
126
- const copyPaste = defineModel<boolean>('copyPaste', { required: true })
127
- const fileTransfer = defineModel<boolean>('fileTransfer', { required: true })
128
- const usbRedirection = defineModel<number>('usbRedirection', {
129
- required: true,
130
- })
131
- // TODO 700
132
- // const folderSharing = defineModel<boolean>('folderSharing', { required: true })
124
+
125
+ // TODO use from model
126
+ const usbRedirection = ref<number>(3)
133
127
 
134
128
  const props = defineProps<{
135
129
  // TODO возможно вернем, НЕ УДАЛЯТЬ