bfg-common 1.5.673 → 1.5.675

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 (125) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  3. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  4. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  5. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  6. package/components/atoms/TheIcon3.vue +50 -50
  7. package/components/atoms/collapse/CollapseNav.vue +170 -170
  8. package/components/atoms/perPage/PerPage.vue +58 -58
  9. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  10. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  11. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  12. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  13. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  14. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  15. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  16. package/components/common/diagramMain/port/Port.vue +580 -580
  17. package/components/common/layout/bottomPanel/BottomPanel.vue +84 -0
  18. package/components/common/layout/bottomPanel/New.vue +243 -0
  19. package/components/common/layout/bottomPanel/Old.vue +160 -0
  20. package/components/common/layout/bottomPanel/alarms/Alarms.vue +76 -0
  21. package/components/common/layout/bottomPanel/alarms/lib/models/interfaces.ts +23 -0
  22. package/components/common/layout/bottomPanel/alarms/new/New.vue +212 -0
  23. package/components/common/layout/bottomPanel/alarms/new/lib/config/config.ts +193 -0
  24. package/components/common/layout/bottomPanel/alarms/new/lib/models/enums.ts +10 -0
  25. package/components/common/layout/bottomPanel/alarms/new/lib/models/interfaces.ts +12 -0
  26. package/components/common/layout/bottomPanel/alarms/old/Old.vue +191 -0
  27. package/components/common/layout/bottomPanel/alarms/old/lib/config/alarmTables.ts +89 -0
  28. package/components/common/layout/bottomPanel/alarms/old/lib/config/tableKeys.ts +11 -0
  29. package/components/common/layout/bottomPanel/alarms/old/lib/models/types.ts +8 -0
  30. package/components/common/layout/bottomPanel/lib/config/statusFilter.ts +19 -0
  31. package/components/common/layout/bottomPanel/lib/models/types.ts +1 -0
  32. package/components/common/layout/bottomPanel/recentTasks/RecentTasks.vue +49 -0
  33. package/components/common/layout/bottomPanel/recentTasks/lib/models/interfaces.ts +14 -0
  34. package/components/common/layout/bottomPanel/recentTasks/new/New.vue +430 -0
  35. package/components/common/layout/bottomPanel/recentTasks/new/lib/config/config.ts +259 -0
  36. package/components/common/layout/bottomPanel/recentTasks/old/Old.vue +277 -0
  37. package/components/common/layout/bottomPanel/recentTasks/old/lib/config/recentTaskTable.ts +240 -0
  38. package/components/common/layout/bottomPanel/recentTasks/old/lib/config/tableKeys.ts +15 -0
  39. package/components/common/layout/bottomPanel/recentTasks/old/lib/models/types.ts +14 -0
  40. package/components/common/layout/theHeader/TheHeaderNew.vue +315 -315
  41. package/components/common/layout/theHeader/TheHeaderOld.vue +262 -262
  42. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  43. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  44. package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePassword.vue +93 -93
  45. package/components/common/layout/theHeader/userMenu/modals/changePassword/New.vue +193 -193
  46. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesOld.vue +144 -144
  47. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  48. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Old.vue +216 -216
  49. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Security.vue +31 -31
  50. package/components/common/pages/backups/DetailView.vue +52 -52
  51. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  52. package/components/common/pages/backups/modals/Modals.vue +243 -243
  53. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  54. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  55. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  56. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  57. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  58. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  59. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  60. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  61. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  62. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  63. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  64. package/components/common/qr/Qr.vue +57 -57
  65. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  66. package/components/common/select/radio/RadioGroup.vue +137 -137
  67. package/components/common/spiceConsole/Drawer.vue +420 -420
  68. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  69. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  70. package/components/common/tools/Actions.vue +207 -207
  71. package/components/common/treeView/TreeView.vue +52 -52
  72. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  73. package/components/common/vm/actions/clone/new/New.vue +438 -438
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +698 -698
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +489 -489
  78. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  79. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  80. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  81. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  82. package/components/common/vm/actions/common/select/options/Old.vue +110 -110
  83. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  84. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  85. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  86. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  87. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  88. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  89. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  90. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  91. package/components/common/wizards/common/compatibility/New.vue +99 -99
  92. package/components/common/wizards/common/compatibility/Old.vue +53 -53
  93. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  94. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  95. package/components/common/wizards/common/steps/name/New.vue +221 -221
  96. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  97. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  98. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  99. package/components/common/wizards/datastore/add/Add.vue +228 -228
  100. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  101. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  102. package/composables/useAppVersion.ts +21 -21
  103. package/composables/useEnvLanguage.ts +22 -22
  104. package/composables/useLocal.ts +6 -6
  105. package/composables/useLocalCommon.ts +39 -39
  106. package/lib/models/enums.ts +65 -1
  107. package/package.json +1 -1
  108. package/plugins/console.ts +21 -21
  109. package/plugins/mouse.ts +21 -21
  110. package/plugins/panelStates.ts +70 -70
  111. package/plugins/text.ts +59 -59
  112. package/public/spice-console/application/clientgui.js +854 -854
  113. package/public/spice-console/application/packetfactory.js +211 -211
  114. package/public/spice-console/application/virtualmouse.js +147 -147
  115. package/public/spice-console/lib/images/bitmap.js +203 -203
  116. package/public/spice-console/network/spicechannel.js +440 -440
  117. package/public/spice-console/process/cursorprocess.js +128 -128
  118. package/public/spice-console/process/inputprocess.js +227 -227
  119. package/public/spice-console/process/mainprocess.js +212 -212
  120. package/public/spice-console/run.js +210 -210
  121. package/store/main/mutations.ts +7 -7
  122. package/store/main/state.ts +7 -7
  123. package/store/tasks/actions.ts +165 -165
  124. package/store/tasks/mappers/recentTasks.ts +123 -123
  125. package/store/tasks/mutations.ts +82 -82
@@ -1,50 +1,50 @@
1
- <template>
2
- <div class="select-template">
3
- <atoms-alert
4
- v-show="props.errors.length"
5
- :items="props.errors"
6
- status="alert-danger"
7
- test-id="template-alert"
8
- @remove="emits('remove')"
9
- />
10
-
11
- <p class="template-description">
12
- {{ localization.vmWizard.selectTemplateForCreatingVm }}
13
- </p>
14
- <div class="tree-view-wrap">
15
- <common-vm-actions-common-select-template-tree-view
16
- :templates-tree="props.templatesTree"
17
- @select-node="emits('select', $event)"
18
- />
19
- </div>
20
- </div>
21
- </template>
22
-
23
- <script setup lang="ts">
24
- import type { UI_I_Localization } from '~/lib/models/interfaces'
25
- import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
26
-
27
- const props = defineProps<{
28
- templatesTree: UI_I_TreeNode[]
29
- errors: string[]
30
- }>()
31
-
32
- const emits = defineEmits<{
33
- (event: 'remove'): void
34
- (event: 'select', value: UI_I_TreeNode): void
35
- }>()
36
-
37
- const localization = computed<UI_I_Localization>(() => useLocal())
38
- </script>
39
-
40
- <style scoped lang="scss">
41
- .tree-view-wrap {
42
- position: relative;
43
- border: 1px solid #000;
44
- padding: 5px;
45
- max-height: 300px;
46
- min-height: 200px;
47
- overflow: auto;
48
- margin-bottom: 10px;
49
- }
50
- </style>
1
+ <template>
2
+ <div class="select-template">
3
+ <atoms-alert
4
+ v-show="props.errors.length"
5
+ :items="props.errors"
6
+ status="alert-danger"
7
+ test-id="template-alert"
8
+ @remove="emits('remove')"
9
+ />
10
+
11
+ <p class="template-description">
12
+ {{ localization.vmWizard.selectTemplateForCreatingVm }}
13
+ </p>
14
+ <div class="tree-view-wrap">
15
+ <common-vm-actions-common-select-template-tree-view
16
+ :templates-tree="props.templatesTree"
17
+ @select-node="emits('select', $event)"
18
+ />
19
+ </div>
20
+ </div>
21
+ </template>
22
+
23
+ <script setup lang="ts">
24
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
25
+ import type { UI_I_TreeNode } from '~/components/common/recursionTree/lib/models/interfaces'
26
+
27
+ const props = defineProps<{
28
+ templatesTree: UI_I_TreeNode[]
29
+ errors: string[]
30
+ }>()
31
+
32
+ const emits = defineEmits<{
33
+ (event: 'remove'): void
34
+ (event: 'select', value: UI_I_TreeNode): void
35
+ }>()
36
+
37
+ const localization = computed<UI_I_Localization>(() => useLocal())
38
+ </script>
39
+
40
+ <style scoped lang="scss">
41
+ .tree-view-wrap {
42
+ position: relative;
43
+ border: 1px solid #000;
44
+ padding: 5px;
45
+ max-height: 300px;
46
+ min-height: 200px;
47
+ overflow: auto;
48
+ margin-bottom: 10px;
49
+ }
50
+ </style>
@@ -1,88 +1,88 @@
1
- <template>
2
- <div class="skeleton-wrap">
3
- <div class="tabs">
4
- <ui-skeleton-item width="64px" height="16px" />
5
- <ui-skeleton-item width="64px" height="16px" />
6
- </div>
7
- <div class="actions">
8
- <ui-skeleton-item width="80px" height="16px" />
9
- <ui-skeleton-item width="152px" height="32px" border-radius="6px" />
10
- </div>
11
- <div class="stack-block-wrap">
12
- <div class="stack-block">
13
- <div class="stack-label flex-1">
14
- <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
15
- <ui-skeleton-item height="16px" />
16
- </div>
17
- <div class="stack-value flex-1">
18
- <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
19
- </div>
20
- </div>
21
-
22
- <div v-for="item in 2" :key="item" class="stack-block">
23
- <div class="stack-label flex-1">
24
- <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
25
- <ui-skeleton-item height="16px" />
26
- </div>
27
- <div class="stack-value flex-1">
28
- <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
29
- <ui-skeleton-item width="80px" height="32px" border-radius="8px" />
30
- </div>
31
- </div>
32
-
33
- <div v-for="item in 5" :key="item" class="stack-block">
34
- <div class="stack-label flex-1">
35
- <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
36
- <ui-skeleton-item height="16px" />
37
- </div>
38
- <div class="stack-value flex-1">
39
- <ui-skeleton-item width="196px" height="32px" border-radius="8px" />
40
- </div>
41
- </div>
42
- </div>
43
- </div>
44
- </template>
45
-
46
- <script setup lang="ts"></script>
47
-
48
- <style scoped lang="scss">
49
- .skeleton-wrap {
50
- padding: 0 32px;
51
-
52
- .tabs {
53
- display: flex;
54
- align-items: center;
55
- gap: 32px;
56
- padding: 8px 0 12px;
57
- border-bottom: 1px solid var(--divider-color);
58
- }
59
-
60
- .actions {
61
- display: flex;
62
- align-items: center;
63
- justify-content: space-between;
64
- margin: 12px 0;
65
- }
66
-
67
- .stack-block-wrap {
68
- display: grid;
69
- grid-gap: 12px;
70
-
71
- .stack-block {
72
- display: flex;
73
- align-items: center;
74
- gap: 12px;
75
- padding: 8px 12px;
76
- background: var(--stack-block-bg-color);
77
- border-radius: 6px;
78
-
79
- .stack-label,
80
- .stack-value {
81
- display: flex;
82
- align-items: center;
83
- gap: 8px;
84
- }
85
- }
86
- }
87
- }
88
- </style>
1
+ <template>
2
+ <div class="skeleton-wrap">
3
+ <div class="tabs">
4
+ <ui-skeleton-item width="64px" height="16px" />
5
+ <ui-skeleton-item width="64px" height="16px" />
6
+ </div>
7
+ <div class="actions">
8
+ <ui-skeleton-item width="80px" height="16px" />
9
+ <ui-skeleton-item width="152px" height="32px" border-radius="6px" />
10
+ </div>
11
+ <div class="stack-block-wrap">
12
+ <div class="stack-block">
13
+ <div class="stack-label flex-1">
14
+ <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
15
+ <ui-skeleton-item height="16px" />
16
+ </div>
17
+ <div class="stack-value flex-1">
18
+ <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
19
+ </div>
20
+ </div>
21
+
22
+ <div v-for="item in 2" :key="item" class="stack-block">
23
+ <div class="stack-label flex-1">
24
+ <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
25
+ <ui-skeleton-item height="16px" />
26
+ </div>
27
+ <div class="stack-value flex-1">
28
+ <ui-skeleton-item width="102px" height="32px" border-radius="8px" />
29
+ <ui-skeleton-item width="80px" height="32px" border-radius="8px" />
30
+ </div>
31
+ </div>
32
+
33
+ <div v-for="item in 5" :key="item" class="stack-block">
34
+ <div class="stack-label flex-1">
35
+ <ui-skeleton-item width="16px" height="16px" border-radius="50%" />
36
+ <ui-skeleton-item height="16px" />
37
+ </div>
38
+ <div class="stack-value flex-1">
39
+ <ui-skeleton-item width="196px" height="32px" border-radius="8px" />
40
+ </div>
41
+ </div>
42
+ </div>
43
+ </div>
44
+ </template>
45
+
46
+ <script setup lang="ts"></script>
47
+
48
+ <style scoped lang="scss">
49
+ .skeleton-wrap {
50
+ padding: 0 32px;
51
+
52
+ .tabs {
53
+ display: flex;
54
+ align-items: center;
55
+ gap: 32px;
56
+ padding: 8px 0 12px;
57
+ border-bottom: 1px solid var(--divider-color);
58
+ }
59
+
60
+ .actions {
61
+ display: flex;
62
+ align-items: center;
63
+ justify-content: space-between;
64
+ margin: 12px 0;
65
+ }
66
+
67
+ .stack-block-wrap {
68
+ display: grid;
69
+ grid-gap: 12px;
70
+
71
+ .stack-block {
72
+ display: flex;
73
+ align-items: center;
74
+ gap: 12px;
75
+ padding: 8px 12px;
76
+ background: var(--stack-block-bg-color);
77
+ border-radius: 6px;
78
+
79
+ .stack-label,
80
+ .stack-value {
81
+ display: flex;
82
+ align-items: center;
83
+ gap: 8px;
84
+ }
85
+ }
86
+ }
87
+ }
88
+ </style>
@@ -1,35 +1,35 @@
1
- <template>
2
- <common-wizards-common-compatibility-new
3
- v-if="isNewView"
4
- :status="props.status"
5
- :text="props.text"
6
- :loading="props.loading"
7
- />
8
- <common-wizards-common-compatibility-old
9
- v-else
10
- :status="props.status"
11
- :text="props.text"
12
- />
13
- </template>
14
-
15
- <script lang="ts" setup>
16
- import type {
17
- UI_T_CompatibilityStatus
18
- } from "~/components/common/wizards/common/compatibility/lib/models/types";
19
-
20
- const props = withDefaults(
21
- defineProps<{
22
- text: string
23
- status: UI_T_CompatibilityStatus
24
- loading?: boolean
25
- }>(),
26
- {
27
- loading: false,
28
- }
29
- )
30
-
31
- const { $store }: any = useNuxtApp()
32
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
33
- </script>
34
-
35
- <style lang="scss" scoped></style>
1
+ <template>
2
+ <common-wizards-common-compatibility-new
3
+ v-if="isNewView"
4
+ :status="props.status"
5
+ :text="props.text"
6
+ :loading="props.loading"
7
+ />
8
+ <common-wizards-common-compatibility-old
9
+ v-else
10
+ :status="props.status"
11
+ :text="props.text"
12
+ />
13
+ </template>
14
+
15
+ <script lang="ts" setup>
16
+ import type {
17
+ UI_T_CompatibilityStatus
18
+ } from "~/components/common/wizards/common/compatibility/lib/models/types";
19
+
20
+ const props = withDefaults(
21
+ defineProps<{
22
+ text: string
23
+ status: UI_T_CompatibilityStatus
24
+ loading?: boolean
25
+ }>(),
26
+ {
27
+ loading: false,
28
+ }
29
+ )
30
+
31
+ const { $store }: any = useNuxtApp()
32
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
33
+ </script>
34
+
35
+ <style lang="scss" scoped></style>
@@ -1,99 +1,99 @@
1
- <template>
2
- <div class="compatibility-wrap">
3
- <p class="compatibility">
4
- {{ localization.inventorySummary.compatibility }}
5
- </p>
6
- <div class="compatibility-message flex-align-start">
7
- <ui-skeleton-item v-if="props.loading" width="160px" height="16px" />
8
- <template v-else-if="props.text">
9
- <ui-icon
10
- v-show="props.status === 'error'"
11
- name="error"
12
- width="16"
13
- height="16"
14
- class="icon-compatibility-alert"
15
- />
16
-
17
- <ui-icon
18
- v-show="props.status === 'success'"
19
- name="success-fill"
20
- width="16"
21
- height="16"
22
- class="icon-compatibility-alert"
23
- />
24
- <span
25
- :class="[
26
- 'compatibility-message-description',
27
- { 'not-selected': props.status === 'none' },
28
- ]"
29
- >{{ props.text }}</span
30
- >
31
- </template>
32
- </div>
33
- </div>
34
- </template>
35
-
36
- <script lang="ts" setup>
37
- import type { UI_I_Localization } from '~/lib/models/interfaces'
38
- import type { UI_T_CompatibilityStatus } from '~/components/common/wizards/common/compatibility/lib/models/types'
39
-
40
- const props = withDefaults(
41
- defineProps<{
42
- text: string
43
- status: UI_T_CompatibilityStatus
44
- loading?: boolean
45
- }>(),
46
- {
47
- loading: true,
48
- }
49
- )
50
-
51
- const localization = computed<UI_I_Localization>(() => useLocal())
52
- </script>
53
-
54
- <style>
55
- :root {
56
- --compatibility-border-color: #e9ebed;
57
- --compatibility-bg-color: #ffffff;
58
- --compatibility-title-color: #4d5d69;
59
- --compatibility-empty-escription-color: #9da6ad;
60
- --compatibility-description-color: #4d5d69;
61
- }
62
- :root.dark-theme {
63
- --compatibility-border-color: #e9ebed1f;
64
- --compatibility-bg-color: #1b2a371f;
65
- --compatibility-title-color: #e9eaec;
66
- --compatibility-empty-escription-color: #9da6ad;
67
- --compatibility-description-color: #e9eaec;
68
- }
69
- </style>
70
- <style lang="scss" scoped>
71
- .compatibility-wrap {
72
- .compatibility {
73
- font-size: 16px;
74
- font-weight: 500;
75
- color: var(--compatibility-title-color);
76
- margin-bottom: 16px;
77
- }
78
- .compatibility-message {
79
- border-radius: 8px;
80
- border: 1px solid var(--compatibility-border-color);
81
- padding: 12px;
82
- background-color: var(--compatibility-bg-color);
83
- gap: 10px;
84
-
85
- .icon-compatibility-alert {
86
- min-width: 16px;
87
- min-height: 16px;
88
- }
89
- .compatibility-message-description {
90
- font-size: 13px;
91
- color: var(--compatibility-description-color);
92
-
93
- &.not-selected {
94
- color: var(--compatibility-empty-escription-color);
95
- }
96
- }
97
- }
98
- }
99
- </style>
1
+ <template>
2
+ <div class="compatibility-wrap">
3
+ <p class="compatibility">
4
+ {{ localization.inventorySummary.compatibility }}
5
+ </p>
6
+ <div class="compatibility-message flex-align-start">
7
+ <ui-skeleton-item v-if="props.loading" width="160px" height="16px" />
8
+ <template v-else-if="props.text">
9
+ <ui-icon
10
+ v-show="props.status === 'error'"
11
+ name="error"
12
+ width="16"
13
+ height="16"
14
+ class="icon-compatibility-alert"
15
+ />
16
+
17
+ <ui-icon
18
+ v-show="props.status === 'success'"
19
+ name="success-fill"
20
+ width="16"
21
+ height="16"
22
+ class="icon-compatibility-alert"
23
+ />
24
+ <span
25
+ :class="[
26
+ 'compatibility-message-description',
27
+ { 'not-selected': props.status === 'none' },
28
+ ]"
29
+ >{{ props.text }}</span
30
+ >
31
+ </template>
32
+ </div>
33
+ </div>
34
+ </template>
35
+
36
+ <script lang="ts" setup>
37
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
38
+ import type { UI_T_CompatibilityStatus } from '~/components/common/wizards/common/compatibility/lib/models/types'
39
+
40
+ const props = withDefaults(
41
+ defineProps<{
42
+ text: string
43
+ status: UI_T_CompatibilityStatus
44
+ loading?: boolean
45
+ }>(),
46
+ {
47
+ loading: true,
48
+ }
49
+ )
50
+
51
+ const localization = computed<UI_I_Localization>(() => useLocal())
52
+ </script>
53
+
54
+ <style>
55
+ :root {
56
+ --compatibility-border-color: #e9ebed;
57
+ --compatibility-bg-color: #ffffff;
58
+ --compatibility-title-color: #4d5d69;
59
+ --compatibility-empty-escription-color: #9da6ad;
60
+ --compatibility-description-color: #4d5d69;
61
+ }
62
+ :root.dark-theme {
63
+ --compatibility-border-color: #e9ebed1f;
64
+ --compatibility-bg-color: #1b2a371f;
65
+ --compatibility-title-color: #e9eaec;
66
+ --compatibility-empty-escription-color: #9da6ad;
67
+ --compatibility-description-color: #e9eaec;
68
+ }
69
+ </style>
70
+ <style lang="scss" scoped>
71
+ .compatibility-wrap {
72
+ .compatibility {
73
+ font-size: 16px;
74
+ font-weight: 500;
75
+ color: var(--compatibility-title-color);
76
+ margin-bottom: 16px;
77
+ }
78
+ .compatibility-message {
79
+ border-radius: 8px;
80
+ border: 1px solid var(--compatibility-border-color);
81
+ padding: 12px;
82
+ background-color: var(--compatibility-bg-color);
83
+ gap: 10px;
84
+
85
+ .icon-compatibility-alert {
86
+ min-width: 16px;
87
+ min-height: 16px;
88
+ }
89
+ .compatibility-message-description {
90
+ font-size: 13px;
91
+ color: var(--compatibility-description-color);
92
+
93
+ &.not-selected {
94
+ color: var(--compatibility-empty-escription-color);
95
+ }
96
+ }
97
+ }
98
+ }
99
+ </style>
@@ -1,53 +1,53 @@
1
- <template>
2
- <div class="compatibility">
3
- <p class="compatibility__title">
4
- {{ localization.inventorySummary.compatibility }}
5
- </p>
6
- <div class="flex-align-center compatibility__content">
7
- <template v-if="props.text">
8
- <div class="compatibility__message">
9
- <div v-show="iconStatus" :class="['icon', iconStatus]" />
10
- <span>{{ props.text }}</span>
11
- </div>
12
- </template>
13
- </div>
14
- </div>
15
- </template>
16
-
17
- <script lang="ts" setup>
18
- import type { UI_I_Localization } from '~/lib/models/interfaces'
19
- import type { UI_T_CompatibilityStatus } from '~/components/common/wizards/common/compatibility/lib/models/types'
20
- import { UI_E_CompatibilityStatusIcon } from '~/components/common/wizards/common/compatibility/lib/models/enums'
21
-
22
- const props = defineProps<{
23
- text: string
24
- status: UI_T_CompatibilityStatus
25
- }>()
26
-
27
- const localization = computed<UI_I_Localization>(() => useLocal())
28
- const iconStatus = computed<string>(
29
- () => UI_E_CompatibilityStatusIcon[props.status]
30
- )
31
- </script>
32
-
33
- <style lang="scss" scoped>
34
- @import 'assets/scss/common/mixins';
35
- .compatibility {
36
- padding-top: 10px;
37
-
38
- &__content {
39
- align-items: self-start;
40
- border: 1px solid #000;
41
- padding-top: 5px;
42
- padding-left: 5px;
43
- overflow: auto;
44
- min-height: 75px;
45
- }
46
- &__message {
47
- @include flex($align: center);
48
- .icon {
49
- margin-right: 5px;
50
- }
51
- }
52
- }
53
- </style>
1
+ <template>
2
+ <div class="compatibility">
3
+ <p class="compatibility__title">
4
+ {{ localization.inventorySummary.compatibility }}
5
+ </p>
6
+ <div class="flex-align-center compatibility__content">
7
+ <template v-if="props.text">
8
+ <div class="compatibility__message">
9
+ <div v-show="iconStatus" :class="['icon', iconStatus]" />
10
+ <span>{{ props.text }}</span>
11
+ </div>
12
+ </template>
13
+ </div>
14
+ </div>
15
+ </template>
16
+
17
+ <script lang="ts" setup>
18
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
19
+ import type { UI_T_CompatibilityStatus } from '~/components/common/wizards/common/compatibility/lib/models/types'
20
+ import { UI_E_CompatibilityStatusIcon } from '~/components/common/wizards/common/compatibility/lib/models/enums'
21
+
22
+ const props = defineProps<{
23
+ text: string
24
+ status: UI_T_CompatibilityStatus
25
+ }>()
26
+
27
+ const localization = computed<UI_I_Localization>(() => useLocal())
28
+ const iconStatus = computed<string>(
29
+ () => UI_E_CompatibilityStatusIcon[props.status]
30
+ )
31
+ </script>
32
+
33
+ <style lang="scss" scoped>
34
+ @import 'assets/scss/common/mixins';
35
+ .compatibility {
36
+ padding-top: 10px;
37
+
38
+ &__content {
39
+ align-items: self-start;
40
+ border: 1px solid #000;
41
+ padding-top: 5px;
42
+ padding-left: 5px;
43
+ overflow: auto;
44
+ min-height: 75px;
45
+ }
46
+ &__message {
47
+ @include flex($align: center);
48
+ .icon {
49
+ margin-right: 5px;
50
+ }
51
+ }
52
+ }
53
+ </style>