bfg-common 1.5.43 → 1.5.45

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 (185) 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/scss/common/normalize.scss +339 -339
  7. package/components/atoms/TheIcon3.vue +50 -50
  8. package/components/atoms/collapse/CollapseNav.vue +165 -165
  9. package/components/atoms/dropdown/dropdown/Dropdown.vue +168 -168
  10. package/components/atoms/modal/bySteps/BySteps.vue +253 -253
  11. package/components/atoms/perPage/PerPage.vue +58 -58
  12. package/components/atoms/stack/StackBlock.vue +185 -185
  13. package/components/atoms/table/dataGrid/DataGrid.vue +1 -1
  14. package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +222 -222
  15. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  16. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  17. package/components/atoms/tabs/VerticalTabs.vue +105 -105
  18. package/components/atoms/tooltip/Signpost.vue +227 -227
  19. package/components/common/accordion/Recursion.vue +222 -222
  20. package/components/common/browse/BrowseNew.vue +237 -237
  21. package/components/common/browse/BrowseOld.vue +217 -217
  22. package/components/common/browse/blocks/contents/Files.vue +37 -37
  23. package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
  24. package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +96 -96
  25. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  26. package/components/common/context/Context.vue +111 -111
  27. package/components/common/context/lib/models/interfaces.ts +31 -31
  28. package/components/common/context/recursion/Recursion.vue +87 -87
  29. package/components/common/context/recursion/RecursionNew.vue +238 -238
  30. package/components/common/context/recursion/RecursionOld.vue +228 -228
  31. package/components/common/details/DetailsItem.vue +109 -109
  32. package/components/common/diagramMain/DiagramMain.vue +897 -897
  33. package/components/common/diagramMain/Header.vue +214 -214
  34. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  35. package/components/common/layout/theHeader/helpMenu/aboutNew/AboutNew.vue +103 -103
  36. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  37. package/components/common/mainNavigationPanel/MainNavigationPanelNew.vue +336 -336
  38. package/components/common/mainNavigationPanel/MainNavigationPanelOld.vue +311 -311
  39. package/components/common/modals/unsavedChanges/UnsavedChanges.vue +56 -56
  40. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  41. package/components/common/pages/home/StatusContent.vue +49 -49
  42. package/components/common/pages/home/headline/Headline.vue +45 -45
  43. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  44. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  45. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  46. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  47. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  48. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  49. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  50. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  51. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  52. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  53. package/components/common/pages/licensing/Licensing.vue +128 -0
  54. package/components/common/pages/licensing/lib/models/interfaces.ts +22 -0
  55. package/components/common/pages/licensing/lib/utils/validation.ts +29 -0
  56. package/components/common/pages/licensing/listView/ListView.vue +50 -0
  57. package/components/common/pages/licensing/listView/lib/config/list.ts +57 -0
  58. package/components/common/pages/licensing/listView/lib/models/interfaces.ts +5 -0
  59. package/components/common/pages/licensing/modals/assign/Assign.vue +247 -0
  60. package/components/common/pages/licensing/modals/assign/lib/config/tabsPannel.ts +17 -0
  61. package/components/common/pages/licensing/modals/assign/lib/models/interfaces.ts +5 -0
  62. package/components/common/pages/licensing/modals/assign/lib/utils/error.ts +25 -0
  63. package/components/common/pages/licensing/modals/assign/new/New.vue +216 -0
  64. package/components/common/pages/licensing/modals/assign/tableView/TableView.vue +193 -0
  65. package/components/common/pages/licensing/modals/assign/tableView/lib/config/table.ts +100 -0
  66. package/components/common/pages/licensing/modals/assign/tableView/lib/config/tableKeys.ts +10 -0
  67. package/components/common/pages/licensing/modals/assign/tableView/lib/models/interfaces.ts +9 -0
  68. package/components/common/pages/licensing/modals/assign/tableView/lib/models/types.ts +8 -0
  69. package/components/common/pages/packages/Packages.vue +208 -208
  70. package/components/common/pages/shortcuts/block/BlockNew.vue +96 -96
  71. package/components/common/pages/shortcuts/block/BlockOld.vue +68 -68
  72. package/components/common/portlets/customAttributes/Portlet.vue +667 -667
  73. package/components/common/portlets/tag/Portlet.vue +433 -433
  74. package/components/common/recursionTree/RecursionTree.vue +223 -223
  75. package/components/common/select/button/ButtonDropdown.vue +108 -108
  76. package/components/common/spiceConsole/Drawer.vue +370 -370
  77. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  78. package/components/common/split/horizontal/HorizontalNew.vue +376 -376
  79. package/components/common/split/horizontal/HorizontalOld.vue +337 -337
  80. package/components/common/split/vertical/Vertical.vue +160 -160
  81. package/components/common/tools/Actions.vue +188 -188
  82. package/components/common/vm/actions/add/Add.vue +774 -774
  83. package/components/common/vm/actions/add/lib/config/steps.ts +247 -247
  84. package/components/common/vm/actions/clone/Clone.vue +798 -798
  85. package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
  86. package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +634 -634
  87. package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +116 -116
  88. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +275 -275
  89. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +274 -274
  90. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +177 -177
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +698 -698
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +410 -410
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +319 -319
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +99 -99
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +117 -117
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +232 -232
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +164 -164
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +168 -168
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  102. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  103. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  104. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  105. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  106. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  107. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +368 -368
  108. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +232 -232
  109. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +250 -250
  110. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  111. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +44 -44
  112. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +286 -286
  113. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +124 -124
  114. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -95
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +69 -69
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +84 -84
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  126. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  127. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  128. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  129. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
  130. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +81 -81
  131. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  132. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +56 -56
  133. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  134. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  135. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +104 -104
  136. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  137. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  138. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  139. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  140. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  141. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  142. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  143. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +42 -42
  144. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  145. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  146. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  147. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +141 -141
  148. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  149. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  150. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  151. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  152. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  153. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +39 -39
  154. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  155. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  156. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  157. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  158. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +38 -38
  159. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  160. package/components/common/vm/actions/common/lib/utils/capabilities.ts +52 -52
  161. package/components/common/vm/actions/common/select/createType/CreateType.vue +74 -74
  162. package/components/common/vm/actions/common/select/storage/Storage.vue +130 -130
  163. package/components/common/vm/actions/common/select/storage/StorageOld.vue +129 -129
  164. package/components/common/vm/actions/common/select/template/Template.vue +65 -65
  165. package/components/common/vm/actions/common/select/template/TemplateTreeView.vue +88 -88
  166. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  167. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  168. package/components/common/wizards/datastore/add/nfs/accessibility/Accessibility.vue +60 -60
  169. package/components/common/wizards/datastore/add/readyComplete/ReadyComplete.vue +92 -92
  170. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +105 -105
  171. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  172. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  173. package/components/common/wizards/vm/migrate/select/network/table/network/Network.vue +150 -150
  174. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  175. package/components/common/wizards/vm/migrate/select/priority/Priority.vue +43 -43
  176. package/composables/productNameLocal.ts +30 -30
  177. package/composables/useAppVersion.ts +21 -21
  178. package/package.json +1 -1
  179. package/plugins/date.ts +233 -233
  180. package/plugins/directives.ts +24 -24
  181. package/public/spice-console/lib/images/bitmap.js +203 -203
  182. package/public/spice-console/network/spicechannel.js +383 -383
  183. package/store/main/mutations.ts +7 -7
  184. package/store/main/state.ts +7 -7
  185. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,433 +1,433 @@
1
- <template>
2
- <div>
3
- <ui-portlet
4
- class="tags"
5
- test-id="tags-portlet"
6
- :title="portletTitle"
7
- :dragged="props.dragged"
8
- :dragged-any="props.draggedAny"
9
- :is-open="props.isOpen"
10
- :portlet-id="props.portletId"
11
- :is-loading="props.isLoading"
12
- @toggle="onTogglePortlet"
13
- >
14
- <template #portletBody="{ isLoadingBody }">
15
- <ui-data-table
16
- test-id="tags-portlet-table"
17
- :data="data"
18
- :options="options"
19
- server-off
20
- :default-layout="false"
21
- size="sm"
22
- :loading="isLoadingBody"
23
- :skeleton="skeletonData"
24
- >
25
- <!-- :loading="loading"-->
26
- <template #icon="{ item }">
27
- <div class="actions-dropdown-button-container">
28
- <span
29
- :id="`actions-tags-${item.data.row}`"
30
- :class="[
31
- 'icon-container',
32
- {
33
- selected: isShow[`action-tags-${item.data.row}`],
34
- },
35
- ]"
36
- @click="onShowActions(item.data.row)"
37
- >
38
- <ui-icon :name="item.data.icon" width="16" height="16" />
39
- </span>
40
- <ui-popup-window
41
- v-model="isShow[`action-tags-${item.data.row}`]"
42
- :elem-id="`actions-tags-${item.data.row}`"
43
- width="fit-content"
44
- left
45
- bottom
46
- >
47
- <div class="edit-actions-container">
48
- <div
49
- class="action"
50
- data-id="view-tag-details-action"
51
- @click="onShowDetails(item.data.row)"
52
- >
53
- <ui-icon name="view-details" width="16" height="16" />
54
- <span>{{ localization.common.viewDetails }}</span>
55
- </div>
56
- <div
57
- v-development="true"
58
- class="action-remove"
59
- data-id="show-remove-tag-dialog-action"
60
- @click="onShowRemoveDialog(item.data.row)"
61
- >
62
- <ui-icon name="delete" width="16" height="16" />
63
- <span>{{ localization.common.remove }}</span>
64
- </div>
65
- </div>
66
- </ui-popup-window>
67
- </div>
68
- </template>
69
- </ui-data-table>
70
- </template>
71
- <template #portletFooter="{ isLoadingFooter }">
72
- <div class="footer">
73
- <ui-button
74
- v-if="!isLoadingFooter"
75
- v-development="true"
76
- test-id="show-assign-new-tag-modal"
77
- variant="text"
78
- is-without-height
79
- is-without-sizes
80
- @click="onShowAssignModal"
81
- >
82
- {{ localization.common.assignNew }}...
83
- </ui-button>
84
- <ui-portlet-skeleton-footer v-else />
85
- </div>
86
- </template>
87
- </ui-portlet>
88
-
89
- <ui-popup
90
- v-if="isShowRemoveDialog"
91
- test-id="remove-tag-dialog"
92
- icon-name="info-status"
93
- :texts="removeTagDialogTexts"
94
- :message="removeTagMessage"
95
- :title="localization.common.removeTag"
96
- @hide="onHideRemoveDialog"
97
- @submit="onRemoveTag"
98
- />
99
-
100
- <common-portlets-tag-add-new
101
- v-if="isShowModal"
102
- :is-show-modal="isShowModal"
103
- :assign-data="assignData"
104
- :selected-item-name="props.selectedItemName"
105
- @add-new-tag="onAddNewTag"
106
- @create-category="onCreateCategory"
107
- @cancel="onHideAssignModal"
108
- @assign="onAssignSelectedTags"
109
- />
110
- </div>
111
- </template>
112
-
113
- <script setup lang="ts">
114
- import type {
115
- UI_I_ArbitraryObject,
116
- UI_I_Localization,
117
- } from '~/lib/models/interfaces'
118
- import type {
119
- UI_I_DataTable,
120
- UI_I_DataTableOptions,
121
- UI_I_DataTableHeader,
122
- UI_I_DataTableBody,
123
- } from '~/node_modules/bfg-uikit/components/ui/dataTable/models/interfaces'
124
- import type { UI_I_ModalTexts } from '~/node_modules/bfg-uikit/components/ui/modal/models/interfaces'
125
- import type { UI_I_CreateCategoryData } from '~/components/common/portlets/tag/lib/models/interfaces'
126
- import {
127
- tagTableHeaderOptions,
128
- tagTableHeaderDataFunc,
129
- tagsAssignBodyItemsTemporary,
130
- skeletonData,
131
- } from '~/components/common/portlets/tag/lib/config/config'
132
-
133
- const props = defineProps<{
134
- portletId: string
135
- dragged?: boolean
136
- isOpen?: boolean
137
- draggedAny?: boolean
138
- selectedItemName: string
139
- bodyItems: UI_I_DataTableBody[]
140
- isLoading: boolean
141
- }>()
142
-
143
- const localization = computed<UI_I_Localization>(() => useLocal())
144
-
145
- const isShow = ref<UI_I_ArbitraryObject<boolean>>({})
146
- const isShowModal = ref<boolean>(false)
147
- const onShowAssignModal = (): void => {
148
- isShowModal.value = true
149
- }
150
-
151
- const onHideAssignModal = (): void => {
152
- isShowModal.value = false
153
- }
154
- const onShowActions = (id: number): void => {
155
- isShow.value[`action-tags-${id}`] = !isShow.value[`action-tags-${id}`]
156
- }
157
- const onShowDetails = (_id: number): void => {
158
- navigateTo('/tags-attributes/tags')
159
- }
160
-
161
- const isShowRemoveDialog = ref<boolean>(false)
162
-
163
- const onHideRemoveDialog = (): void => {
164
- isShowRemoveDialog.value = false
165
- }
166
- const tagIdForRemove = ref<number>(0)
167
- const tagNameForRemove = computed<string>(
168
- () =>
169
- (tagsBodyItems.value.find(
170
- (row: UI_I_DataTableBody) => row.row === tagIdForRemove.value
171
- )?.data[0]?.text || '') as string
172
- )
173
-
174
- const removeTagMessage = computed<string>(() =>
175
- localization.value.common.removeTagDialog
176
- .replace?.('{tagName}', tagNameForRemove.value)
177
- .replace('{selectedItemName}', props.selectedItemName)
178
- )
179
- const onShowRemoveDialog = (id: number): void => {
180
- tagIdForRemove.value = id
181
- isShowRemoveDialog.value = true
182
- }
183
-
184
- const removeTagDialogTexts = computed<UI_I_ModalTexts>(() => ({
185
- button1: localization.value.common.cancel,
186
- button2: localization.value.common.remove,
187
- }))
188
-
189
- const onRemoveTag = (): void => {
190
- onHideRemoveDialog()
191
-
192
- const removeItem = tagsBodyItems.value.find(
193
- (row) => row.row === tagIdForRemove.value
194
- )
195
- if (!removeItem) return
196
-
197
- emits('remove-tag', removeItem)
198
- tagsBodyItems.value = tagsBodyItems.value.filter(
199
- (row) => row.row !== tagIdForRemove.value
200
- )
201
- }
202
-
203
- const options: UI_I_DataTableOptions = {
204
- ...tagTableHeaderOptions,
205
- isSelectable: false,
206
- }
207
-
208
- const tagsHeadItems = computed<UI_I_DataTableHeader[]>(() =>
209
- tagTableHeaderDataFunc(localization.value)
210
- )
211
- // const tagsBodyItems = computed<UI_I_TableBodyItem[][]>(() => {
212
- // return $store.getters['inventory/getTags'] || []
213
- // })
214
-
215
- // const { $store } = useNuxtApp()
216
-
217
- const tagsBodyItems = ref<UI_I_DataTableBody[]>([])
218
-
219
- watch(
220
- () => props.bodyItems,
221
- (newValue: UI_I_DataTableBody[]) => {
222
- tagsBodyItems.value = newValue
223
- },
224
- { deep: true, immediate: true }
225
- )
226
-
227
- const tagsAssignBodyItems = ref<UI_I_DataTableBody[]>(
228
- useDeepCopy(tagsAssignBodyItemsTemporary)
229
- )
230
-
231
- const data = computed<UI_I_DataTable>(() => ({
232
- id: 'tags',
233
- selectedRows: [],
234
- isAllSelected: false,
235
- title: '',
236
- subTitle: '',
237
- header: tagsHeadItems.value,
238
- body: tagsBodyItems.value,
239
- }))
240
-
241
- const assignData = computed<UI_I_DataTable>(() => ({
242
- id: 'tags-assign',
243
- selectedRows: [],
244
- isAllSelected: false,
245
- title: '',
246
- subTitle: '',
247
- header: tagsHeadItems.value,
248
- body: tagsAssignBodyItems.value,
249
- }))
250
-
251
- // const showTagModal = (): void => {
252
- // isShowTagModal.value = true
253
- // }
254
-
255
- // const routeParams = useRoute().params
256
- // const routeId: string = routeParams?.id.toString()
257
- // const routeType: string = routeParams?.type.toString()
258
- // const getTags = async (): Promise<void> => {
259
- // const payload: I_GetTagsPayload = {
260
- // id: routeId,
261
- // type: `${routeType}s`,
262
- // }
263
- //
264
- // return await $store.dispatch('inventory/A_GET_TAGS', payload)
265
- // }
266
- // getTags()
267
-
268
- const onAddNewTag = (newTag: UI_I_DataTableBody): void => {
269
- tagsAssignBodyItems.value.push(newTag)
270
- emits('create-new-tag', newTag)
271
- }
272
-
273
- const onAssignSelectedTags = async (
274
- data: UI_I_DataTableBody[]
275
- ): Promise<void> => {
276
- if (data.length > 0) {
277
- const sortedIds = tagsBodyItems.value
278
- .map((row: UI_I_DataTableBody) => Number(row.row))
279
- .sort()
280
- let lastId = sortedIds[sortedIds.length - 1]
281
- lastId = lastId === undefined ? -1 : lastId
282
-
283
- const selectedNewTags = data.map((row, index) => {
284
- return {
285
- ...row,
286
- row: lastId + index + 1,
287
- isSelected: false,
288
- data: [
289
- row.data[0],
290
- row.data[1],
291
- row.data[2],
292
- {
293
- ...row.data[3],
294
- key: 'icon',
295
- data: {
296
- icon: 'vertical-dotes',
297
- row: lastId + index + 1,
298
- },
299
- },
300
- ],
301
- }
302
- })
303
-
304
- const addedTagsName = selectedNewTags.map((row) => row.data[0].text)
305
-
306
- tagsAssignBodyItems.value = tagsAssignBodyItems.value.filter(
307
- (row: UI_I_DataTableBody) => !addedTagsName.includes(row.data[0].text)
308
- )
309
-
310
- tagsBodyItems.value = [...tagsBodyItems.value, ...selectedNewTags]
311
- emits('assign-new-tags', selectedNewTags)
312
- }
313
- onHideAssignModal()
314
- // const tags = data.map((row) => {
315
- // return {
316
- // name: row[0].text,
317
- // description: row[1].text,
318
- // category: 'none',
319
- // }
320
- // })
321
- // const payload: I_UpdateTagsPayload = {
322
- // tags,
323
- // id: routeId,
324
- // type: `${routeType}s`,
325
- // }
326
- // hideTagModal()
327
- // await $store.dispatch('inventory/A_UPDATE_TAGS', payload)
328
- //
329
- // globalRefresh()
330
- }
331
-
332
- const portletTitle = computed<string>(
333
- () =>
334
- localization.value.common.assignedTags +
335
- (tagsBodyItems.value.length ? ` (${tagsBodyItems.value.length})` : '')
336
- )
337
- // const globalRefresh = (): void => {
338
- // $store.dispatch('main/A_GLOBAL_REFRESH', null)
339
- // }
340
-
341
- const onCreateCategory = (data: UI_I_CreateCategoryData): void => {
342
- emits('create-category', data)
343
- }
344
-
345
- const emits = defineEmits<{
346
- (event: 'toggle-portlet', id: string): void
347
- (event: 'create-category', value: UI_I_CreateCategoryData): void
348
- (event: 'create-new-tag', value: UI_I_DataTableBody): void
349
- (event: 'assign-new-tags', value: UI_I_DataTableBody[]): void
350
- (event: 'remove-tag', value: UI_I_DataTableBody): void
351
- }>()
352
-
353
- const onTogglePortlet = (id: string): void => {
354
- emits('toggle-portlet', id)
355
- }
356
- </script>
357
-
358
- <style scoped lang="scss">
359
- .icon-container {
360
- width: 16px;
361
- height: 16px;
362
- display: block;
363
- cursor: pointer;
364
- color: var(--table-actions-icon);
365
-
366
- &:hover,
367
- &.selected {
368
- color: var(--table-actions-icon-hover);
369
- }
370
- }
371
-
372
- .action-remove {
373
- display: flex;
374
- align-items: center;
375
- column-gap: 8px;
376
-
377
- height: 32px;
378
- border-radius: 4px;
379
- padding: 8px;
380
- color: var(--table-actions-remove);
381
- cursor: pointer;
382
-
383
- font-size: 13px;
384
- font-weight: 500;
385
- line-height: 15.73px;
386
-
387
- &:hover {
388
- background: var(--table-actions-bg-hover);
389
- }
390
- }
391
-
392
- .action {
393
- display: flex;
394
- align-items: center;
395
- column-gap: 8px;
396
-
397
- height: 32px;
398
- border-radius: 4px;
399
- padding: 8px;
400
- color: var(--table-actions-view);
401
- margin-bottom: 8px;
402
- cursor: pointer;
403
-
404
- font-size: 13px;
405
- font-weight: 500;
406
- line-height: 15.73px;
407
-
408
- &:hover {
409
- background: var(--table-actions-bg-hover);
410
- }
411
- }
412
-
413
- .footer {
414
- padding: 0 16px 8px;
415
-
416
- :deep(button.ui-btn) {
417
- line-height: 16px;
418
- margin-bottom: 11px;
419
- margin-left: 6px;
420
- width: fit-content;
421
- }
422
- }
423
-
424
- .actions-dropdown-button-container {
425
- display: flex;
426
- justify-content: flex-end;
427
- width: 100%;
428
- }
429
-
430
- .edit-actions-container {
431
- padding: 8px;
432
- }
433
- </style>
1
+ <template>
2
+ <div>
3
+ <ui-portlet
4
+ class="tags"
5
+ test-id="tags-portlet"
6
+ :title="portletTitle"
7
+ :dragged="props.dragged"
8
+ :dragged-any="props.draggedAny"
9
+ :is-open="props.isOpen"
10
+ :portlet-id="props.portletId"
11
+ :is-loading="props.isLoading"
12
+ @toggle="onTogglePortlet"
13
+ >
14
+ <template #portletBody="{ isLoadingBody }">
15
+ <ui-data-table
16
+ test-id="tags-portlet-table"
17
+ :data="data"
18
+ :options="options"
19
+ server-off
20
+ :default-layout="false"
21
+ size="sm"
22
+ :loading="isLoadingBody"
23
+ :skeleton="skeletonData"
24
+ >
25
+ <!-- :loading="loading"-->
26
+ <template #icon="{ item }">
27
+ <div class="actions-dropdown-button-container">
28
+ <span
29
+ :id="`actions-tags-${item.data.row}`"
30
+ :class="[
31
+ 'icon-container',
32
+ {
33
+ selected: isShow[`action-tags-${item.data.row}`],
34
+ },
35
+ ]"
36
+ @click="onShowActions(item.data.row)"
37
+ >
38
+ <ui-icon :name="item.data.icon" width="16" height="16" />
39
+ </span>
40
+ <ui-popup-window
41
+ v-model="isShow[`action-tags-${item.data.row}`]"
42
+ :elem-id="`actions-tags-${item.data.row}`"
43
+ width="fit-content"
44
+ left
45
+ bottom
46
+ >
47
+ <div class="edit-actions-container">
48
+ <div
49
+ class="action"
50
+ data-id="view-tag-details-action"
51
+ @click="onShowDetails(item.data.row)"
52
+ >
53
+ <ui-icon name="view-details" width="16" height="16" />
54
+ <span>{{ localization.common.viewDetails }}</span>
55
+ </div>
56
+ <div
57
+ v-development="true"
58
+ class="action-remove"
59
+ data-id="show-remove-tag-dialog-action"
60
+ @click="onShowRemoveDialog(item.data.row)"
61
+ >
62
+ <ui-icon name="delete" width="16" height="16" />
63
+ <span>{{ localization.common.remove }}</span>
64
+ </div>
65
+ </div>
66
+ </ui-popup-window>
67
+ </div>
68
+ </template>
69
+ </ui-data-table>
70
+ </template>
71
+ <template #portletFooter="{ isLoadingFooter }">
72
+ <div class="footer">
73
+ <ui-button
74
+ v-if="!isLoadingFooter"
75
+ v-development="true"
76
+ test-id="show-assign-new-tag-modal"
77
+ variant="text"
78
+ is-without-height
79
+ is-without-sizes
80
+ @click="onShowAssignModal"
81
+ >
82
+ {{ localization.common.assignNew }}...
83
+ </ui-button>
84
+ <ui-portlet-skeleton-footer v-else />
85
+ </div>
86
+ </template>
87
+ </ui-portlet>
88
+
89
+ <ui-popup
90
+ v-if="isShowRemoveDialog"
91
+ test-id="remove-tag-dialog"
92
+ icon-name="info-status"
93
+ :texts="removeTagDialogTexts"
94
+ :message="removeTagMessage"
95
+ :title="localization.common.removeTag"
96
+ @hide="onHideRemoveDialog"
97
+ @submit="onRemoveTag"
98
+ />
99
+
100
+ <common-portlets-tag-add-new
101
+ v-if="isShowModal"
102
+ :is-show-modal="isShowModal"
103
+ :assign-data="assignData"
104
+ :selected-item-name="props.selectedItemName"
105
+ @add-new-tag="onAddNewTag"
106
+ @create-category="onCreateCategory"
107
+ @cancel="onHideAssignModal"
108
+ @assign="onAssignSelectedTags"
109
+ />
110
+ </div>
111
+ </template>
112
+
113
+ <script setup lang="ts">
114
+ import type {
115
+ UI_I_ArbitraryObject,
116
+ UI_I_Localization,
117
+ } from '~/lib/models/interfaces'
118
+ import type {
119
+ UI_I_DataTable,
120
+ UI_I_DataTableOptions,
121
+ UI_I_DataTableHeader,
122
+ UI_I_DataTableBody,
123
+ } from '~/node_modules/bfg-uikit/components/ui/dataTable/models/interfaces'
124
+ import type { UI_I_ModalTexts } from '~/node_modules/bfg-uikit/components/ui/modal/models/interfaces'
125
+ import type { UI_I_CreateCategoryData } from '~/components/common/portlets/tag/lib/models/interfaces'
126
+ import {
127
+ tagTableHeaderOptions,
128
+ tagTableHeaderDataFunc,
129
+ tagsAssignBodyItemsTemporary,
130
+ skeletonData,
131
+ } from '~/components/common/portlets/tag/lib/config/config'
132
+
133
+ const props = defineProps<{
134
+ portletId: string
135
+ dragged?: boolean
136
+ isOpen?: boolean
137
+ draggedAny?: boolean
138
+ selectedItemName: string
139
+ bodyItems: UI_I_DataTableBody[]
140
+ isLoading: boolean
141
+ }>()
142
+
143
+ const localization = computed<UI_I_Localization>(() => useLocal())
144
+
145
+ const isShow = ref<UI_I_ArbitraryObject<boolean>>({})
146
+ const isShowModal = ref<boolean>(false)
147
+ const onShowAssignModal = (): void => {
148
+ isShowModal.value = true
149
+ }
150
+
151
+ const onHideAssignModal = (): void => {
152
+ isShowModal.value = false
153
+ }
154
+ const onShowActions = (id: number): void => {
155
+ isShow.value[`action-tags-${id}`] = !isShow.value[`action-tags-${id}`]
156
+ }
157
+ const onShowDetails = (_id: number): void => {
158
+ navigateTo('/tags-attributes/tags')
159
+ }
160
+
161
+ const isShowRemoveDialog = ref<boolean>(false)
162
+
163
+ const onHideRemoveDialog = (): void => {
164
+ isShowRemoveDialog.value = false
165
+ }
166
+ const tagIdForRemove = ref<number>(0)
167
+ const tagNameForRemove = computed<string>(
168
+ () =>
169
+ (tagsBodyItems.value.find(
170
+ (row: UI_I_DataTableBody) => row.row === tagIdForRemove.value
171
+ )?.data[0]?.text || '') as string
172
+ )
173
+
174
+ const removeTagMessage = computed<string>(() =>
175
+ localization.value.common.removeTagDialog
176
+ .replace?.('{tagName}', tagNameForRemove.value)
177
+ .replace('{selectedItemName}', props.selectedItemName)
178
+ )
179
+ const onShowRemoveDialog = (id: number): void => {
180
+ tagIdForRemove.value = id
181
+ isShowRemoveDialog.value = true
182
+ }
183
+
184
+ const removeTagDialogTexts = computed<UI_I_ModalTexts>(() => ({
185
+ button1: localization.value.common.cancel,
186
+ button2: localization.value.common.remove,
187
+ }))
188
+
189
+ const onRemoveTag = (): void => {
190
+ onHideRemoveDialog()
191
+
192
+ const removeItem = tagsBodyItems.value.find(
193
+ (row) => row.row === tagIdForRemove.value
194
+ )
195
+ if (!removeItem) return
196
+
197
+ emits('remove-tag', removeItem)
198
+ tagsBodyItems.value = tagsBodyItems.value.filter(
199
+ (row) => row.row !== tagIdForRemove.value
200
+ )
201
+ }
202
+
203
+ const options: UI_I_DataTableOptions = {
204
+ ...tagTableHeaderOptions,
205
+ isSelectable: false,
206
+ }
207
+
208
+ const tagsHeadItems = computed<UI_I_DataTableHeader[]>(() =>
209
+ tagTableHeaderDataFunc(localization.value)
210
+ )
211
+ // const tagsBodyItems = computed<UI_I_TableBodyItem[][]>(() => {
212
+ // return $store.getters['inventory/getTags'] || []
213
+ // })
214
+
215
+ // const { $store } = useNuxtApp()
216
+
217
+ const tagsBodyItems = ref<UI_I_DataTableBody[]>([])
218
+
219
+ watch(
220
+ () => props.bodyItems,
221
+ (newValue: UI_I_DataTableBody[]) => {
222
+ tagsBodyItems.value = newValue
223
+ },
224
+ { deep: true, immediate: true }
225
+ )
226
+
227
+ const tagsAssignBodyItems = ref<UI_I_DataTableBody[]>(
228
+ useDeepCopy(tagsAssignBodyItemsTemporary)
229
+ )
230
+
231
+ const data = computed<UI_I_DataTable>(() => ({
232
+ id: 'tags',
233
+ selectedRows: [],
234
+ isAllSelected: false,
235
+ title: '',
236
+ subTitle: '',
237
+ header: tagsHeadItems.value,
238
+ body: tagsBodyItems.value,
239
+ }))
240
+
241
+ const assignData = computed<UI_I_DataTable>(() => ({
242
+ id: 'tags-assign',
243
+ selectedRows: [],
244
+ isAllSelected: false,
245
+ title: '',
246
+ subTitle: '',
247
+ header: tagsHeadItems.value,
248
+ body: tagsAssignBodyItems.value,
249
+ }))
250
+
251
+ // const showTagModal = (): void => {
252
+ // isShowTagModal.value = true
253
+ // }
254
+
255
+ // const routeParams = useRoute().params
256
+ // const routeId: string = routeParams?.id.toString()
257
+ // const routeType: string = routeParams?.type.toString()
258
+ // const getTags = async (): Promise<void> => {
259
+ // const payload: I_GetTagsPayload = {
260
+ // id: routeId,
261
+ // type: `${routeType}s`,
262
+ // }
263
+ //
264
+ // return await $store.dispatch('inventory/A_GET_TAGS', payload)
265
+ // }
266
+ // getTags()
267
+
268
+ const onAddNewTag = (newTag: UI_I_DataTableBody): void => {
269
+ tagsAssignBodyItems.value.push(newTag)
270
+ emits('create-new-tag', newTag)
271
+ }
272
+
273
+ const onAssignSelectedTags = async (
274
+ data: UI_I_DataTableBody[]
275
+ ): Promise<void> => {
276
+ if (data.length > 0) {
277
+ const sortedIds = tagsBodyItems.value
278
+ .map((row: UI_I_DataTableBody) => Number(row.row))
279
+ .sort()
280
+ let lastId = sortedIds[sortedIds.length - 1]
281
+ lastId = lastId === undefined ? -1 : lastId
282
+
283
+ const selectedNewTags = data.map((row, index) => {
284
+ return {
285
+ ...row,
286
+ row: lastId + index + 1,
287
+ isSelected: false,
288
+ data: [
289
+ row.data[0],
290
+ row.data[1],
291
+ row.data[2],
292
+ {
293
+ ...row.data[3],
294
+ key: 'icon',
295
+ data: {
296
+ icon: 'vertical-dotes',
297
+ row: lastId + index + 1,
298
+ },
299
+ },
300
+ ],
301
+ }
302
+ })
303
+
304
+ const addedTagsName = selectedNewTags.map((row) => row.data[0].text)
305
+
306
+ tagsAssignBodyItems.value = tagsAssignBodyItems.value.filter(
307
+ (row: UI_I_DataTableBody) => !addedTagsName.includes(row.data[0].text)
308
+ )
309
+
310
+ tagsBodyItems.value = [...tagsBodyItems.value, ...selectedNewTags]
311
+ emits('assign-new-tags', selectedNewTags)
312
+ }
313
+ onHideAssignModal()
314
+ // const tags = data.map((row) => {
315
+ // return {
316
+ // name: row[0].text,
317
+ // description: row[1].text,
318
+ // category: 'none',
319
+ // }
320
+ // })
321
+ // const payload: I_UpdateTagsPayload = {
322
+ // tags,
323
+ // id: routeId,
324
+ // type: `${routeType}s`,
325
+ // }
326
+ // hideTagModal()
327
+ // await $store.dispatch('inventory/A_UPDATE_TAGS', payload)
328
+ //
329
+ // globalRefresh()
330
+ }
331
+
332
+ const portletTitle = computed<string>(
333
+ () =>
334
+ localization.value.common.assignedTags +
335
+ (tagsBodyItems.value.length ? ` (${tagsBodyItems.value.length})` : '')
336
+ )
337
+ // const globalRefresh = (): void => {
338
+ // $store.dispatch('main/A_GLOBAL_REFRESH', null)
339
+ // }
340
+
341
+ const onCreateCategory = (data: UI_I_CreateCategoryData): void => {
342
+ emits('create-category', data)
343
+ }
344
+
345
+ const emits = defineEmits<{
346
+ (event: 'toggle-portlet', id: string): void
347
+ (event: 'create-category', value: UI_I_CreateCategoryData): void
348
+ (event: 'create-new-tag', value: UI_I_DataTableBody): void
349
+ (event: 'assign-new-tags', value: UI_I_DataTableBody[]): void
350
+ (event: 'remove-tag', value: UI_I_DataTableBody): void
351
+ }>()
352
+
353
+ const onTogglePortlet = (id: string): void => {
354
+ emits('toggle-portlet', id)
355
+ }
356
+ </script>
357
+
358
+ <style scoped lang="scss">
359
+ .icon-container {
360
+ width: 16px;
361
+ height: 16px;
362
+ display: block;
363
+ cursor: pointer;
364
+ color: var(--table-actions-icon);
365
+
366
+ &:hover,
367
+ &.selected {
368
+ color: var(--table-actions-icon-hover);
369
+ }
370
+ }
371
+
372
+ .action-remove {
373
+ display: flex;
374
+ align-items: center;
375
+ column-gap: 8px;
376
+
377
+ height: 32px;
378
+ border-radius: 4px;
379
+ padding: 8px;
380
+ color: var(--table-actions-remove);
381
+ cursor: pointer;
382
+
383
+ font-size: 13px;
384
+ font-weight: 500;
385
+ line-height: 15.73px;
386
+
387
+ &:hover {
388
+ background: var(--table-actions-bg-hover);
389
+ }
390
+ }
391
+
392
+ .action {
393
+ display: flex;
394
+ align-items: center;
395
+ column-gap: 8px;
396
+
397
+ height: 32px;
398
+ border-radius: 4px;
399
+ padding: 8px;
400
+ color: var(--table-actions-view);
401
+ margin-bottom: 8px;
402
+ cursor: pointer;
403
+
404
+ font-size: 13px;
405
+ font-weight: 500;
406
+ line-height: 15.73px;
407
+
408
+ &:hover {
409
+ background: var(--table-actions-bg-hover);
410
+ }
411
+ }
412
+
413
+ .footer {
414
+ padding: 0 16px 8px;
415
+
416
+ :deep(button.ui-btn) {
417
+ line-height: 16px;
418
+ margin-bottom: 11px;
419
+ margin-left: 6px;
420
+ width: fit-content;
421
+ }
422
+ }
423
+
424
+ .actions-dropdown-button-container {
425
+ display: flex;
426
+ justify-content: flex-end;
427
+ width: 100%;
428
+ }
429
+
430
+ .edit-actions-container {
431
+ padding: 8px;
432
+ }
433
+ </style>