bfg-common 1.5.645 → 1.5.647

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 (87) 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/portModal.ts +251 -251
  16. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  17. package/components/common/diagramMain/port/Port.vue +580 -580
  18. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  19. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  20. package/components/common/pages/backups/DetailView.vue +52 -52
  21. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  22. package/components/common/pages/backups/modals/Modals.vue +243 -243
  23. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  24. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  25. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  26. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  27. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  28. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  29. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  30. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  31. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  32. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  33. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  34. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  35. package/components/common/select/radio/RadioGroup.vue +137 -137
  36. package/components/common/spiceConsole/Drawer.vue +420 -420
  37. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  38. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  39. package/components/common/tools/Actions.vue +207 -207
  40. package/components/common/treeView/TreeView.vue +52 -52
  41. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  42. package/components/common/vm/actions/clone/new/New.vue +437 -437
  43. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  44. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  45. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  46. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  47. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  48. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  49. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  50. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  51. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  52. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  53. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  54. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  55. package/components/common/wizards/common/compatibility/New.vue +99 -99
  56. package/components/common/wizards/common/compatibility/Old.vue +53 -53
  57. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  58. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  59. package/components/common/wizards/common/steps/name/New.vue +221 -221
  60. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  61. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  62. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  63. package/components/common/wizards/datastore/add/Add.vue +228 -228
  64. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  65. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  66. package/composables/useAppVersion.ts +21 -21
  67. package/composables/useLocal.ts +6 -6
  68. package/composables/useLocalCommon.ts +39 -39
  69. package/package.json +2 -2
  70. package/plugins/console.ts +21 -21
  71. package/plugins/mouse.ts +21 -21
  72. package/plugins/panelStates.ts +70 -70
  73. package/plugins/text.ts +59 -59
  74. package/public/spice-console/application/clientgui.js +854 -854
  75. package/public/spice-console/application/packetfactory.js +211 -211
  76. package/public/spice-console/application/virtualmouse.js +147 -147
  77. package/public/spice-console/lib/images/bitmap.js +203 -203
  78. package/public/spice-console/network/spicechannel.js +440 -440
  79. package/public/spice-console/process/cursorprocess.js +128 -128
  80. package/public/spice-console/process/inputprocess.js +227 -227
  81. package/public/spice-console/process/mainprocess.js +212 -212
  82. package/public/spice-console/run.js +210 -210
  83. package/store/main/mutations.ts +7 -7
  84. package/store/main/state.ts +7 -7
  85. package/store/tasks/actions.ts +165 -165
  86. package/store/tasks/mappers/recentTasks.ts +123 -123
  87. 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>