bfg-common 1.5.688 → 1.5.689

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 (133) 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 +3800 -3783
  7. package/assets/localization/local_en.json +3804 -3787
  8. package/assets/localization/local_hy.json +18 -1
  9. package/assets/localization/local_kk.json +18 -1
  10. package/assets/localization/local_ru.json +18 -1
  11. package/assets/localization/local_zh.json +18 -1
  12. package/assets/scss/components/auth.scss +15 -5
  13. package/components/atoms/TheIcon3.vue +50 -50
  14. package/components/atoms/collapse/CollapseNav.vue +170 -170
  15. package/components/atoms/dropdown/tree/Tree.vue +2 -0
  16. package/components/atoms/perPage/PerPage.vue +58 -58
  17. package/components/atoms/switch/Switch.vue +103 -97
  18. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  19. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  20. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  21. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  22. package/components/atoms/wizard/Wizard.vue +1 -1
  23. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  24. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  25. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  26. package/components/common/diagramMain/port/Port.vue +580 -580
  27. package/components/common/layout/theHeader/TheHeaderNew.vue +315 -315
  28. package/components/common/layout/theHeader/TheHeaderOld.vue +262 -262
  29. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  30. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  31. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesNew.vue +102 -115
  32. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesOld.vue +144 -144
  33. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguage.vue +115 -108
  34. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/{New.vue → ChangeLanguageNew.vue} +89 -88
  35. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/{Old.vue → ChangeLanguageOld.vue} +91 -89
  36. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsole.vue +42 -43
  37. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/{New.vue → DefaultConsoleNew.vue} +53 -53
  38. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/{Old.vue → DefaultConsoleOld.vue} +49 -49
  39. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/Inventory.vue +32 -31
  40. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/{New.vue → InventoryNew.vue} +35 -36
  41. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/{Old.vue → InventoryOld.vue} +31 -31
  42. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  43. package/components/common/layout/theHeader/userMenu/modals/preferences/security/New.vue +17 -34
  44. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Old.vue +216 -216
  45. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Security.vue +31 -31
  46. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormat.vue +54 -54
  47. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/{New.vue → TimeFormatNew.vue} +52 -52
  48. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/{Old.vue → TimeFormatOld.vue} +45 -45
  49. package/components/common/layout/theHeader/userMenu/modals/preferences/view/View.vue +45 -46
  50. package/components/common/layout/theHeader/userMenu/modals/preferences/view/{New.vue → ViewNew.vue} +38 -47
  51. package/components/common/layout/theHeader/userMenu/modals/preferences/view/{Old.vue → ViewOld.vue} +112 -112
  52. package/components/common/pages/backups/DetailView.vue +52 -52
  53. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  54. package/components/common/pages/backups/modals/Modals.vue +243 -243
  55. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  56. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  57. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  58. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  59. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  60. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  61. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  62. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  63. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  64. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  65. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  66. package/components/common/qr/Qr.vue +57 -57
  67. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  68. package/components/common/select/radio/RadioGroup.vue +137 -137
  69. package/components/common/spiceConsole/Drawer.vue +420 -420
  70. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  71. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  72. package/components/common/tools/Actions.vue +207 -207
  73. package/components/common/treeView/TreeView.vue +52 -52
  74. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  75. package/components/common/vm/actions/clone/new/New.vue +438 -438
  76. package/components/common/vm/actions/clone/old/Old.vue +1 -0
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +706 -706
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +489 -489
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +253 -253
  82. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  83. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  84. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  85. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  86. package/components/common/vm/actions/common/select/options/Old.vue +109 -109
  87. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  88. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  89. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  90. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  91. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  92. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  93. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  94. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  95. package/components/common/wizards/common/compatibility/New.vue +1 -1
  96. package/components/common/wizards/common/compatibility/Old.vue +1 -1
  97. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  98. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  99. package/components/common/wizards/common/steps/name/New.vue +221 -221
  100. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  101. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  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/nameAndDevice/NameAndDeviceNew.vue +232 -232
  106. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceOld.vue +231 -231
  107. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/AdvancedOptions.vue +43 -43
  108. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/New.vue +101 -101
  109. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/Old.vue +101 -101
  110. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  111. package/composables/useAppVersion.ts +21 -21
  112. package/composables/useEnvLanguage.ts +22 -22
  113. package/composables/useLocal.ts +6 -6
  114. package/composables/useLocalCommon.ts +39 -39
  115. package/lib/models/interfaces.ts +1 -0
  116. package/package.json +2 -2
  117. package/plugins/console.ts +21 -21
  118. package/plugins/mouse.ts +21 -21
  119. package/plugins/panelStates.ts +70 -70
  120. package/plugins/text.ts +59 -59
  121. package/public/spice-console/application/clientgui.js +854 -854
  122. package/public/spice-console/application/packetfactory.js +211 -211
  123. package/public/spice-console/application/virtualmouse.js +147 -147
  124. package/public/spice-console/lib/images/bitmap.js +203 -203
  125. package/public/spice-console/network/spicechannel.js +440 -440
  126. package/public/spice-console/process/cursorprocess.js +128 -128
  127. package/public/spice-console/process/inputprocess.js +227 -227
  128. package/public/spice-console/process/mainprocess.js +212 -212
  129. package/public/spice-console/run.js +210 -210
  130. package/store/main/mutations.ts +7 -7
  131. package/store/main/state.ts +7 -7
  132. package/store/tasks/mappers/recentTasks.ts +123 -123
  133. package/store/tasks/mutations.ts +82 -82
@@ -1,52 +1,52 @@
1
- <template>
2
- <form id="time-format-form">
3
- <div class="flex">
4
- <ui-modal-icon>
5
- <ui-icon-icon3 name="clock" width="20" height="20" />
6
- </ui-modal-icon>
7
-
8
- <div>
9
- <div class="form-first-title">
10
- {{ localization.common.timeFormat }}
11
- </div>
12
- <div class="form-second-title">
13
- {{ props.description }}
14
- </div>
15
- <div
16
- v-for="(item, key) in props.formatOptions"
17
- :key="key"
18
- class="radio"
19
- >
20
- <ui-radio
21
- v-model="timeItem"
22
- :test-id="item.testId"
23
- :label="item.label"
24
- :value="item.value"
25
- size="md"
26
- />
27
- </div>
28
- </div>
29
- </div>
30
- </form>
31
- </template>
32
-
33
- <script setup lang="ts">
34
- import type { UI_I_Localization } from '~/lib/models/interfaces'
35
- import type { UI_I_RadioItem } from '~/components/common/layout/theHeader/userMenu/lib/models/interfaces'
36
- import type { UI_T_TimeValue } from '~/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types'
37
-
38
- const timeItem = defineModel<UI_T_TimeValue>()
39
-
40
- const props = defineProps<{
41
- description: string
42
- formatOptions: UI_I_RadioItem[]
43
- }>()
44
-
45
- const localization = computed<UI_I_Localization>(() => useLocal())
46
- </script>
47
-
48
- <style lang="scss" scoped>
49
- .radio:not(:last-child) {
50
- margin-bottom: 12px;
51
- }
52
- </style>
1
+ <template>
2
+ <form id="time-format-form">
3
+ <div class="flex">
4
+ <ui-modal-icon>
5
+ <ui-icon-icon3 name="clock" width="20" height="20" />
6
+ </ui-modal-icon>
7
+
8
+ <div>
9
+ <div class="form-first-title">
10
+ {{ localization.common.timeFormat }}
11
+ </div>
12
+ <div class="form-second-title">
13
+ {{ props.description }}
14
+ </div>
15
+ <div
16
+ v-for="(item, key) in props.formatOptions"
17
+ :key="key"
18
+ class="radio"
19
+ >
20
+ <ui-radio
21
+ v-model="timeItem"
22
+ :test-id="item.testId"
23
+ :label="item.label"
24
+ :value="item.value"
25
+ size="sm"
26
+ />
27
+ </div>
28
+ </div>
29
+ </div>
30
+ </form>
31
+ </template>
32
+
33
+ <script setup lang="ts">
34
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
35
+ import type { UI_I_RadioItem } from '~/components/common/layout/theHeader/userMenu/lib/models/interfaces'
36
+ import type { UI_T_TimeValue } from '~/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types'
37
+
38
+ const props = defineProps<{
39
+ description: string
40
+ formatOptions: UI_I_RadioItem[]
41
+ }>()
42
+
43
+ const localization = computed<UI_I_Localization>(() => useLocal())
44
+
45
+ const timeItem = defineModel<UI_T_TimeValue>()
46
+ </script>
47
+
48
+ <style lang="scss" scoped>
49
+ .radio:not(:last-child) {
50
+ margin-bottom: 12px;
51
+ }
52
+ </style>
@@ -1,45 +1,45 @@
1
- <template>
2
- <form id="time-format-form" class="compact">
3
- <div class="description">
4
- {{ props.description }}
5
- </div>
6
-
7
- <div v-for="(item, key) in props.formatOptions" :key="key" class="radio">
8
- <input
9
- :id="item.value"
10
- v-model="timeItem"
11
- :data-id="item.testId"
12
- :value="item.value"
13
- type="radio"
14
- />
15
- <label :for="item.value">
16
- {{ item.label }}
17
- </label>
18
- </div>
19
- </form>
20
- </template>
21
-
22
- <script setup lang="ts">
23
- import type { UI_I_RadioItem } from '~/components/common/layout/theHeader/userMenu/lib/models/interfaces'
24
- import type { UI_T_TimeValue } from '~/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types'
25
-
26
- const timeItem = defineModel<UI_T_TimeValue>()
27
-
28
- const props = defineProps<{
29
- description: string
30
- formatOptions: UI_I_RadioItem[]
31
- }>()
32
- </script>
33
-
34
- <style lang="scss" scoped>
35
- .radio {
36
- margin-bottom: 5px;
37
- &:nth-child(2) {
38
- margin-top: 10px;
39
- }
40
- }
41
- input[type='radio']:focus:checked + label::before,
42
- input[type='radio']:focus + label::before {
43
- box-shadow: inset 0 0 0 0.25rem #0094d2;
44
- }
45
- </style>
1
+ <template>
2
+ <form id="time-format-form" class="compact">
3
+ <div class="description">
4
+ {{ props.description }}
5
+ </div>
6
+
7
+ <div v-for="(item, key) in props.formatOptions" :key="key" class="radio">
8
+ <input
9
+ :id="item.value"
10
+ v-model="timeItem"
11
+ :data-id="item.testId"
12
+ :value="item.value"
13
+ type="radio"
14
+ />
15
+ <label :for="item.value">
16
+ {{ item.label }}
17
+ </label>
18
+ </div>
19
+ </form>
20
+ </template>
21
+
22
+ <script setup lang="ts">
23
+ import type { UI_I_RadioItem } from '~/components/common/layout/theHeader/userMenu/lib/models/interfaces'
24
+ import type { UI_T_TimeValue } from '~/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types'
25
+
26
+ const props = defineProps<{
27
+ description: string
28
+ formatOptions: UI_I_RadioItem[]
29
+ }>()
30
+
31
+ const timeItem = defineModel<UI_T_TimeValue>()
32
+ </script>
33
+
34
+ <style lang="scss" scoped>
35
+ .radio {
36
+ margin-bottom: 5px;
37
+ &:nth-child(2) {
38
+ margin-top: 10px;
39
+ }
40
+ }
41
+ input[type='radio']:focus:checked + label::before,
42
+ input[type='radio']:focus + label::before {
43
+ box-shadow: inset 0 0 0 0.25rem #0094d2;
44
+ }
45
+ </style>
@@ -1,46 +1,45 @@
1
- <template>
2
- <component
3
- :is="currentComponent"
4
- v-model="model"
5
- :description="description"
6
- />
7
- </template>
8
-
9
- <script setup lang="ts">
10
- import type { UI_I_Localization } from '~/lib/models/interfaces'
11
-
12
- const props = defineProps<{
13
- newView: boolean
14
- newViewLocal: boolean
15
- }>()
16
-
17
- const emits = defineEmits<{
18
- (event: 'update-is-new-view', value: boolean): void
19
- }>()
20
-
21
- const config = useRuntimeConfig()
22
-
23
- const currentComponent = computed(() =>
24
- props.newView
25
- ? defineAsyncComponent(() => import('./New.vue'))
26
- : defineAsyncComponent(() => import('./Old.vue'))
27
- )
28
-
29
- const localization = computed<UI_I_Localization>(() => useLocal())
30
-
31
- const description = computed<string>(() => {
32
- return localization.value.common.viewDesc.replaceAll(
33
- '{trademark}',
34
- String(config.public[`TRADEMARK_${useEnvLanguage()}`])
35
- )
36
- })
37
-
38
- const model = computed<boolean>({
39
- get() {
40
- return props.newViewLocal
41
- },
42
- set(newValue: boolean) {
43
- emits('update-is-new-view', newValue)
44
- },
45
- })
46
- </script>
1
+ <template>
2
+ <common-layout-the-header-user-menu-modals-preferences-view-new
3
+ v-if="props.newView"
4
+ v-model="model"
5
+ :description="description"
6
+ />
7
+ <common-layout-the-header-user-menu-modals-preferences-view-old
8
+ v-else
9
+ v-model="model"
10
+ :description="description"
11
+ />
12
+ </template>
13
+
14
+ <script setup lang="ts">
15
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
16
+
17
+ const props = defineProps<{
18
+ newView: boolean
19
+ newViewLocal: boolean
20
+ }>()
21
+
22
+ const emits = defineEmits<{
23
+ (event: 'update-is-new-view', value: boolean): void
24
+ }>()
25
+
26
+ const config = useRuntimeConfig()
27
+
28
+ const localization = computed<UI_I_Localization>(() => useLocal())
29
+
30
+ const description = computed<string>(() => {
31
+ return localization.value.common.viewDesc.replaceAll(
32
+ '{trademark}',
33
+ String(config.public[`TRADEMARK_${useEnvLanguage()}`])
34
+ )
35
+ })
36
+
37
+ const model = computed<boolean>({
38
+ get() {
39
+ return props.newViewLocal
40
+ },
41
+ set(newValue: boolean) {
42
+ emits('update-is-new-view', newValue)
43
+ },
44
+ })
45
+ </script>
@@ -1,47 +1,38 @@
1
- <template>
2
- <form id="view-form">
3
- <!-- TODO Shorten code by the new component for the form -->
4
- <div class="flex">
5
- <ui-modal-icon>
6
- <ui-icon-icon3 name="eye-open" width="20" height="20" />
7
- </ui-modal-icon>
8
- <div>
9
- <div class="form-first-title">
10
- {{ localization.common.view }}
11
- </div>
12
- <div class="form-second-title">
13
- {{ props.description }}
14
- </div>
15
-
16
- <div class="flex-align-center new-view-switch-container">
17
- <ui-switch
18
- v-model="newViewLocal"
19
- :label="localization.common.newView"
20
- test-id="view-switch"
21
- />
22
- </div>
23
- </div>
24
- </div>
25
- </form>
26
- </template>
27
-
28
- <script setup lang="ts">
29
- import type { UI_I_Localization } from '~/lib/models/interfaces'
30
-
31
- const newViewLocal = defineModel<boolean>()
32
-
33
- const props = defineProps<{
34
- description: string
35
- }>()
36
-
37
- const localization = computed<UI_I_Localization>(() => useLocal())
38
- </script>
39
-
40
- <style lang="scss" scoped>
41
- .new-view-switch-container {
42
- :deep(.switch-content .switch-label) {
43
- font-size: 13px;
44
- font-weight: 400;
45
- }
46
- }
47
- </style>
1
+ <template>
2
+ <form id="view-form">
3
+ <!-- TODO Shorten code by the new component for the form -->
4
+ <div class="flex">
5
+ <ui-modal-icon>
6
+ <ui-icon-icon3 name="eye-open" width="20" height="20" />
7
+ </ui-modal-icon>
8
+ <div>
9
+ <div class="form-first-title">
10
+ {{ localization.common.view }}
11
+ </div>
12
+ <div class="form-second-title">
13
+ {{ props.description }}
14
+ </div>
15
+
16
+ <div class="flex-align-center">
17
+ <ui-switch
18
+ v-model="newViewLocal"
19
+ :label="localization.common.newView"
20
+ test-id="view-switch"
21
+ />
22
+ </div>
23
+ </div>
24
+ </div>
25
+ </form>
26
+ </template>
27
+
28
+ <script setup lang="ts">
29
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
30
+
31
+ const props = defineProps<{
32
+ description: string
33
+ }>()
34
+
35
+ const newViewLocal = defineModel<boolean>()
36
+
37
+ const localization = computed<UI_I_Localization>(() => useLocal())
38
+ </script>
@@ -1,112 +1,112 @@
1
- <template>
2
- <form id="view-form" class="compact">
3
- <div class="description">
4
- {{ props.description }}
5
- </div>
6
-
7
- <div :title="localization.common.inDevelopment" class="flex-align-center">
8
- <label for="view">{{ localization.common.newView }}</label>
9
- <input
10
- id="view"
11
- v-model="newViewLocal"
12
- :disabled="isDisabled"
13
- type="checkbox"
14
- class="switch"
15
- />
16
- </div>
17
- </form>
18
- </template>
19
-
20
- <script setup lang="ts">
21
- import type { UI_I_Localization } from '~/lib/models/interfaces'
22
-
23
- const newViewLocal = defineModel<boolean>()
24
-
25
- const props = defineProps<{
26
- description: string
27
- }>()
28
-
29
- const localization = computed<UI_I_Localization>(() => useLocal())
30
-
31
- const isDisabled = ref<boolean>(true)
32
- // @ts-ignore
33
- window.tools = new Proxy(
34
- {},
35
- {
36
- set: function (_obj, prop, value): boolean {
37
- if (prop === 'isDev') isDisabled.value = !value
38
- return true
39
- },
40
- }
41
- )
42
- </script>
43
-
44
- <style lang="scss" scoped>
45
- .description {
46
- margin-bottom: 10px;
47
- }
48
-
49
- label {
50
- margin-right: 6px;
51
- }
52
-
53
- input[type='checkbox'] {
54
- --active: var(--checkbox-value-active-color);
55
- --active-inner: var(--checkbox-mark-color);
56
- --border: var(--checkbox-mark-color);
57
- --background: var(--checkbox-mark-background-color);
58
- -webkit-appearance: none;
59
- -moz-appearance: none;
60
- height: 20px;
61
- outline: none;
62
- display: inline-block;
63
- vertical-align: top;
64
- position: relative;
65
- margin: 0;
66
- cursor: pointer;
67
- border: 1px solid var(--bc, var(--border));
68
- background: var(--b, var(--background));
69
- transition: background 0.3s, border-color 0.3s, box-shadow 0.2s;
70
- &:after {
71
- content: '';
72
- display: block;
73
- left: 0;
74
- top: 0;
75
- position: absolute;
76
- transition: transform var(--d-t, 0.3s) var(--d-t-e, ease),
77
- opacity var(--d-o, 0.2s);
78
- }
79
- &:checked {
80
- --b: var(--active);
81
- --bc: var(--active);
82
- --d-o: 0.3s;
83
- --d-t: 0.6s;
84
- --d-t-e: cubic-bezier(0.2, 0.85, 0.32, 1.2);
85
- }
86
- }
87
- input[type='checkbox'] {
88
- &.switch {
89
- width: 35px;
90
- border-radius: 11px;
91
- &:after {
92
- left: 2px;
93
- top: 2px;
94
- bottom: 2px;
95
- border-radius: 50%;
96
- width: 14px;
97
- height: 14px;
98
- border: 1px solid var(--bc, var(--border));
99
- background: var(--ab, var(--border));
100
- transform: translateX(var(--x, 0));
101
- }
102
- &:checked {
103
- --ab: var(--active-inner);
104
- --x: 14px;
105
- }
106
- &:disabled {
107
- cursor: not-allowed;
108
- opacity: 0.5;
109
- }
110
- }
111
- }
112
- </style>
1
+ <template>
2
+ <form id="view-form" class="compact">
3
+ <div class="description">
4
+ {{ props.description }}
5
+ </div>
6
+
7
+ <div :title="localization.common.inDevelopment" class="flex-align-center">
8
+ <label for="view">{{ localization.common.newView }}</label>
9
+ <input
10
+ id="view"
11
+ v-model="newViewLocal"
12
+ :disabled="isDisabled"
13
+ type="checkbox"
14
+ class="switch"
15
+ />
16
+ </div>
17
+ </form>
18
+ </template>
19
+
20
+ <script setup lang="ts">
21
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
22
+
23
+ const props = defineProps<{
24
+ description: string
25
+ }>()
26
+
27
+ const localization = computed<UI_I_Localization>(() => useLocal())
28
+
29
+ const newViewLocal = defineModel<boolean>()
30
+
31
+ const isDisabled = ref<boolean>(true)
32
+ // @ts-ignore
33
+ window.tools = new Proxy(
34
+ {},
35
+ {
36
+ set: function (_obj, prop, value): boolean {
37
+ if (prop === 'isDev') isDisabled.value = !value
38
+ return true
39
+ },
40
+ }
41
+ )
42
+ </script>
43
+
44
+ <style lang="scss" scoped>
45
+ .description {
46
+ margin-bottom: 10px;
47
+ }
48
+
49
+ label {
50
+ margin-right: 6px;
51
+ }
52
+
53
+ input[type='checkbox'] {
54
+ --active: var(--checkbox-value-active-color);
55
+ --active-inner: var(--checkbox-mark-color);
56
+ --border: var(--checkbox-mark-color);
57
+ --background: var(--checkbox-mark-background-color);
58
+ -webkit-appearance: none;
59
+ -moz-appearance: none;
60
+ height: 20px;
61
+ outline: none;
62
+ display: inline-block;
63
+ vertical-align: top;
64
+ position: relative;
65
+ margin: 0;
66
+ cursor: pointer;
67
+ border: 1px solid var(--bc, var(--border));
68
+ background: var(--b, var(--background));
69
+ transition: background 0.3s, border-color 0.3s, box-shadow 0.2s;
70
+ &:after {
71
+ content: '';
72
+ display: block;
73
+ left: 0;
74
+ top: 0;
75
+ position: absolute;
76
+ transition: transform var(--d-t, 0.3s) var(--d-t-e, ease),
77
+ opacity var(--d-o, 0.2s);
78
+ }
79
+ &:checked {
80
+ --b: var(--active);
81
+ --bc: var(--active);
82
+ --d-o: 0.3s;
83
+ --d-t: 0.6s;
84
+ --d-t-e: cubic-bezier(0.2, 0.85, 0.32, 1.2);
85
+ }
86
+ }
87
+ input[type='checkbox'] {
88
+ &.switch {
89
+ width: 35px;
90
+ border-radius: 11px;
91
+ &:after {
92
+ left: 2px;
93
+ top: 2px;
94
+ bottom: 2px;
95
+ border-radius: 50%;
96
+ width: 14px;
97
+ height: 14px;
98
+ border: 1px solid var(--bc, var(--border));
99
+ background: var(--ab, var(--border));
100
+ transform: translateX(var(--x, 0));
101
+ }
102
+ &:checked {
103
+ --ab: var(--active-inner);
104
+ --x: 14px;
105
+ }
106
+ &:disabled {
107
+ cursor: not-allowed;
108
+ opacity: 0.5;
109
+ }
110
+ }
111
+ }
112
+ </style>