bfg-common 1.4.735 → 1.4.799

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 (1207) hide show
  1. package/.eslintrc.js +21 -21
  2. package/.idea/inspectionProfiles/Project_Default.xml +50 -50
  3. package/.idea/modules.xml +7 -7
  4. package/.idea/prettier.xml +5 -5
  5. package/.idea/uikit.iml +11 -11
  6. package/.idea/vcs.xml +5 -5
  7. package/.prettierrc +4 -4
  8. package/PROJECT_STRUCTURE.md +42 -42
  9. package/README.md +42 -42
  10. package/assets/img/icons/icon-hcs.svg +3 -3
  11. package/assets/img/icons/icon-life-m-dark.svg +3 -3
  12. package/assets/img/icons/icon-life-m-light.svg +3 -3
  13. package/assets/img/icons/icon-ro-dark.svg +1 -1
  14. package/assets/img/icons/icon-ro-light.svg +2 -2
  15. package/assets/img/icons/icons-sprite-dark-1.svg +437 -437
  16. package/assets/img/icons/icons-sprite-dark-2.svg +347 -347
  17. package/assets/img/icons/icons-sprite-dark-4.svg +259 -259
  18. package/assets/img/icons/icons-sprite-dark-6.svg +94 -94
  19. package/assets/img/icons/icons-sprite-light-1.svg +437 -437
  20. package/assets/img/icons/icons-sprite-light-2.svg +347 -347
  21. package/assets/img/icons/icons-sprite-light-4.svg +259 -259
  22. package/assets/img/icons/icons-sprite-light-6.svg +94 -94
  23. package/assets/img/icons/info.svg +8 -8
  24. package/assets/img/icons/vc.svg +52 -52
  25. package/assets/img/logo copy.svg +50 -50
  26. package/assets/img/logo.svg +51 -51
  27. package/assets/localization/local_be.json +2914 -2913
  28. package/assets/localization/local_en.json +2918 -2917
  29. package/assets/localization/local_hy.json +2918 -2917
  30. package/assets/localization/local_kk.json +2917 -2916
  31. package/assets/localization/local_ru.json +2919 -2918
  32. package/assets/localization/local_zh.json +2916 -2915
  33. package/assets/scss/clarity/clr-ui.min.css +8 -8
  34. package/assets/scss/clarity/local_ar.json +2916 -2916
  35. package/assets/scss/common/animations.scss +28 -28
  36. package/assets/scss/common/global.scss +191 -191
  37. package/assets/scss/common/icons/icons-1.scss +262 -262
  38. package/assets/scss/common/icons/icons-2.scss +264 -264
  39. package/assets/scss/common/icons/icons-3.scss +250 -250
  40. package/assets/scss/common/icons/icons-4.scss +279 -279
  41. package/assets/scss/common/icons/icons-5.scss +449 -449
  42. package/assets/scss/common/icons/icons-6.scss +156 -156
  43. package/assets/scss/common/icons/icons.scss +16 -16
  44. package/assets/scss/common/icons/lib-icons.scss +32 -32
  45. package/assets/scss/common/mixins.scss +39 -39
  46. package/assets/scss/common/normalize.scss +361 -361
  47. package/assets/scss/common/theme.scss +329 -329
  48. package/assets/scss/common/utilities.scss +20 -20
  49. package/assets/scss/common/variables.scss +44 -44
  50. package/assets/scss/components/auth.scss +198 -198
  51. package/assets/scss/main.scss +15 -15
  52. package/components/atoms/DiagramIcon.vue +400 -400
  53. package/components/atoms/TheIcon.vue +3249 -3249
  54. package/components/atoms/TheIcon2.vue +1368 -1368
  55. package/components/atoms/TheIcon3.vue +50 -50
  56. package/components/atoms/TheIconOld.vue +2444 -2444
  57. package/components/atoms/alert/Alert.vue +96 -96
  58. package/components/atoms/alert/Notification.vue +171 -171
  59. package/components/atoms/alert/lib/Alert.spec.ts +38 -38
  60. package/components/atoms/alert/lib/Notification.spec.ts +34 -34
  61. package/components/atoms/alert/lib/models/enums.ts +12 -12
  62. package/components/atoms/alert/lib/models/interfaces.ts +27 -27
  63. package/components/atoms/alert/lib/models/types.ts +11 -11
  64. package/components/atoms/autocomplete/Autocomplete.vue +242 -242
  65. package/components/atoms/collapse/CollapseNav.vue +164 -164
  66. package/components/atoms/collapse/CollapseNavItem.vue +218 -218
  67. package/components/atoms/collapse/lib/models/interfaces.ts +11 -11
  68. package/components/atoms/comboDropdownMenu/ComboDropdownMenu.vue +357 -357
  69. package/components/atoms/comboDropdownMenu/lib/models/interfaces.ts +26 -26
  70. package/components/atoms/combobox/Combobox.vue +152 -152
  71. package/components/atoms/datepicker/Datepicker.vue +639 -639
  72. package/components/atoms/datepicker/lib/config/allShortMonths.ts +103 -103
  73. package/components/atoms/datepicker/lib/config/datepicker.ts +46 -46
  74. package/components/atoms/datepicker/lib/models/interfaces.ts +9 -9
  75. package/components/atoms/dropdown/Portlet.vue +114 -114
  76. package/components/atoms/dropdown/dropdown/Dropdown.vue +156 -156
  77. package/components/atoms/dropdown/dropdown/lib/models/interfaces.ts +9 -9
  78. package/components/atoms/dropdown/lib/Portlet.spec.ts +26 -26
  79. package/components/atoms/dropdown/tree/Tree.vue +137 -137
  80. package/components/atoms/dropdown/tree/lib/models/interfaces.ts +11 -11
  81. package/components/atoms/input/Search.vue +16 -16
  82. package/components/atoms/lib/models/interfaces.ts +14 -14
  83. package/components/atoms/list/SelectList.vue +63 -63
  84. package/components/atoms/list/SimpleList.vue +29 -29
  85. package/components/atoms/list/dragDropList/DragDropList.vue +139 -139
  86. package/components/atoms/list/dragDropList/lib/config/events.ts +4 -4
  87. package/components/atoms/loader/BarLoader.vue +27 -27
  88. package/components/atoms/loader/Loader.vue +30 -30
  89. package/components/atoms/loader/PreLoader.vue +38 -38
  90. package/components/atoms/loader/lib/Preloader.spec.ts +24 -24
  91. package/components/atoms/modal/Modal.vue +248 -248
  92. package/components/atoms/modal/bySteps/BySteps.vue +253 -253
  93. package/components/atoms/modal/bySteps/lib/BySteps.spec.ts +66 -66
  94. package/components/atoms/modal/byStepsSecond/ByStepsSecond.vue +184 -184
  95. package/components/atoms/modal/lib/Modal.spec.ts +55 -55
  96. package/components/atoms/nav/NavBar.vue +139 -139
  97. package/components/atoms/nav/VerticalNavBar.vue +90 -90
  98. package/components/atoms/nav/lib/NavBar.spec.ts +34 -34
  99. package/components/atoms/nav/lib/models/interfaces.ts +6 -6
  100. package/components/atoms/notificationBar/NotificationBar.vue +178 -178
  101. package/components/atoms/notificationBar/lib/models/enums.ts +13 -13
  102. package/components/atoms/notificationBar/lib/models/interfaces.ts +6 -6
  103. package/components/atoms/notificationBar/lib/models/types.ts +1 -1
  104. package/components/atoms/perPage/PerPage.vue +53 -53
  105. package/components/atoms/popover/Popover.vue +60 -60
  106. package/components/atoms/popup/SimplePopup.vue +91 -91
  107. package/components/atoms/select/TheSelect.vue +177 -186
  108. package/components/atoms/select/lib/models/interfaces.ts +5 -5
  109. package/components/atoms/stack/StackBlock.vue +185 -185
  110. package/components/atoms/stack/StackContent.vue +63 -63
  111. package/components/atoms/step/VerticalStep.vue +105 -105
  112. package/components/atoms/step/lib/VerticalStep.spec.ts +68 -68
  113. package/components/atoms/step/lib/models/verticalStepItem.ts +7 -7
  114. package/components/atoms/switch/Switch.vue +111 -111
  115. package/components/atoms/table/compact/Compact.vue +526 -526
  116. package/components/atoms/table/compact/lib/models/interfaces.ts +10 -10
  117. package/components/atoms/table/dataGrid/DataGrid.vue +1696 -1696
  118. package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +222 -222
  119. package/components/atoms/table/dataGrid/DataGridPage.vue +197 -197
  120. package/components/atoms/table/dataGrid/DataGridPagination.vue +89 -89
  121. package/components/atoms/table/dataGrid/lib/DataGrid.spec.ts +61 -61
  122. package/components/atoms/table/dataGrid/lib/config/itemsPerPage.ts +20 -20
  123. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +91 -91
  124. package/components/atoms/table/dataGrid/lib/models/interfaces.ts +41 -41
  125. package/components/atoms/table/dataGrid/lib/models/types.ts +5 -5
  126. package/components/atoms/table/dataGrid/lib/utils/constructDataTable.ts +36 -36
  127. package/components/atoms/table/dataGrid/lib/utils/export.ts +15 -15
  128. package/components/atoms/table/info/Info.vue +61 -61
  129. package/components/atoms/table/info/lib/models/interfaces.ts +9 -9
  130. package/components/atoms/table/simpleEvent/SimpleEvent.vue +98 -98
  131. package/components/atoms/table/simpleEvent/lib/models/interfaces.ts +9 -9
  132. package/components/atoms/table/simpleInfo/SimpleInfo.vue +73 -73
  133. package/components/atoms/table/simpleInfo/lib/models/interfaces.ts +5 -5
  134. package/components/atoms/table/simpleTable/SimpleTable.vue +300 -300
  135. package/components/atoms/table/simpleTable/lib/models/interfaces.ts +12 -12
  136. package/components/atoms/tabs/Tabs.vue +214 -214
  137. package/components/atoms/tabs/VerticalTabs.vue +88 -88
  138. package/components/atoms/tabs/lib/models/interfaces.ts +5 -5
  139. package/components/atoms/tabs/lib/models/types.ts +1 -1
  140. package/components/atoms/tooltip/Signpost.vue +227 -227
  141. package/components/atoms/tooltip/Text.vue +37 -37
  142. package/components/atoms/tooltip/Tooltip.vue +57 -57
  143. package/components/atoms/tooltip/TooltipError.vue +113 -113
  144. package/components/atoms/tooltip/lib/models/interfaces.ts +4 -4
  145. package/components/atoms/wizard/Wizard.vue +341 -341
  146. package/components/atoms/wizard/lib/models/enums.ts +8 -8
  147. package/components/atoms/wizard/lib/models/interfaces.ts +59 -59
  148. package/components/atoms/wizard/lib/utils/utils.ts +954 -954
  149. package/components/atoms/wizard/step/Step.vue +95 -95
  150. package/components/common/BadBrowser.vue +118 -118
  151. package/components/common/accordion/Accordion.vue +177 -177
  152. package/components/common/accordion/Recursion.vue +218 -218
  153. package/components/common/accordion/lib/models/enums.ts +5 -5
  154. package/components/common/accordion/lib/models/interfaces.ts +16 -16
  155. package/components/common/accordion/lib/models/types.ts +1 -1
  156. package/components/common/accordion/lib/utils/accordion.ts +31 -31
  157. package/components/common/adapterManager/AdapterManager.vue +828 -828
  158. package/components/common/adapterManager/AddAdapterModal.vue +561 -561
  159. package/components/common/adapterManager/AddAdapterWarningModal.vue +82 -82
  160. package/components/common/adapterManager/NoActiveAdaptersModal.vue +61 -61
  161. package/components/common/adapterManager/NoConnectedActiveAdaptersModal.vue +61 -61
  162. package/components/common/adapterManager/lib/config/index.ts +19 -19
  163. package/components/common/adapterManager/ui/NoSelectedAdapter.vue +39 -39
  164. package/components/common/adapterManager/ui/SecondTitle.vue +37 -37
  165. package/components/common/adapterManager/ui/actions/ActionsBar.vue +95 -95
  166. package/components/common/adapterManager/ui/actions/AddAdapterButton.vue +30 -30
  167. package/components/common/adapterManager/ui/actions/MoveDownAdapterButton.vue +35 -35
  168. package/components/common/adapterManager/ui/actions/MoveUpAdapterButton.vue +35 -35
  169. package/components/common/adapterManager/ui/actions/RemoveAdapterButton.vue +37 -37
  170. package/components/common/adapterManager/ui/actions/VerticalSeparator.vue +10 -10
  171. package/components/common/adapterManager/ui/table/Adapters.vue +92 -92
  172. package/components/common/adapterManager/ui/table/Header.vue +93 -93
  173. package/components/common/adapterManager/ui/table/Table.vue +162 -162
  174. package/components/common/adapterManager/ui/table/lib/models/types.ts +1 -1
  175. package/components/common/browse/Browse.vue +165 -165
  176. package/components/common/browse/BrowseNew.vue +237 -237
  177. package/components/common/browse/BrowseOld.vue +217 -217
  178. package/components/common/browse/blocks/Container.vue +194 -194
  179. package/components/common/browse/blocks/TitleNew.vue +145 -145
  180. package/components/common/browse/blocks/TitleOld.vue +91 -91
  181. package/components/common/browse/blocks/contents/Files.vue +37 -37
  182. package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
  183. package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +96 -96
  184. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  185. package/components/common/browse/blocks/info/Date.vue +36 -36
  186. package/components/common/browse/blocks/info/Size.vue +30 -30
  187. package/components/common/browse/blocks/info/Text.vue +29 -29
  188. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  189. package/components/common/browse/lib/models/interfaces.ts +5 -5
  190. package/components/common/{monitor/advanced/tools/chartOptionsModal → chartOptionsModal}/counters/timespan/form/Form.vue +17 -12
  191. package/components/common/{pages/hardwareHealth/historyTestimony/tools/chartOptionsModal → chartOptionsModal}/counters/timespan/form/lib/config/dateForm.ts +1 -0
  192. package/components/common/context/Context.vue +99 -99
  193. package/components/common/context/lib/Context.spec.ts +20 -20
  194. package/components/common/context/lib/ContextRecursion.spec.ts +55 -55
  195. package/components/common/context/lib/models/interfaces.ts +30 -30
  196. package/components/common/context/recursion/Recursion.vue +86 -86
  197. package/components/common/context/recursion/RecursionNew.vue +211 -211
  198. package/components/common/context/recursion/RecursionOld.vue +213 -213
  199. package/components/common/context/recursion/lib/models/interfaces.ts +2 -2
  200. package/components/common/countdownTimer/CountdownTimer.vue +50 -50
  201. package/components/common/details/DetailsItem.vue +109 -109
  202. package/components/common/details/DetailsList.vue +23 -23
  203. package/components/common/details/lib/models/interfaces.ts +11 -11
  204. package/components/common/diagramMain/Diagram.vue +377 -377
  205. package/components/common/diagramMain/DiagramMain.vue +893 -893
  206. package/components/common/diagramMain/Header.vue +211 -211
  207. package/components/common/diagramMain/adapter/Adapter.vue +123 -123
  208. package/components/common/diagramMain/adapter/AdapterItem.vue +432 -432
  209. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  210. package/components/common/diagramMain/adapter/Contents.vue +207 -207
  211. package/components/common/diagramMain/adapter/Lines.vue +81 -81
  212. package/components/common/diagramMain/adapter/block/Block.vue +27 -27
  213. package/components/common/diagramMain/adapter/block/BlockNew.vue +58 -58
  214. package/components/common/diagramMain/adapter/block/BlockOld.vue +50 -50
  215. package/components/common/diagramMain/adapter/secondBlock/SecondBlock.vue +27 -27
  216. package/components/common/diagramMain/adapter/secondBlock/SecondBlockNew.vue +60 -60
  217. package/components/common/diagramMain/adapter/secondBlock/SecondBlockOld.vue +51 -51
  218. package/components/common/diagramMain/highlights/Highlights.vue +151 -151
  219. package/components/common/diagramMain/highlights/HighlightsNew.vue +124 -124
  220. package/components/common/diagramMain/highlights/HighlightsOld.vue +107 -107
  221. package/components/common/diagramMain/lib/config/index.ts +81 -81
  222. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  223. package/components/common/diagramMain/lib/config/positions.ts +194 -194
  224. package/components/common/diagramMain/lib/models/enums.ts +44 -44
  225. package/components/common/diagramMain/lib/models/interfaces.ts +753 -753
  226. package/components/common/diagramMain/lib/models/types.ts +21 -21
  227. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  228. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +330 -330
  229. package/components/common/diagramMain/modals/Modals.vue +451 -451
  230. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  231. package/components/common/diagramMain/modals/editSettings/EditSettings.vue +497 -497
  232. package/components/common/diagramMain/modals/editSettings/EditSettingsModal.vue +812 -812
  233. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  234. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  235. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  236. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  237. package/components/common/diagramMain/modals/editSettings/tabs/TrafficShaping.vue +398 -398
  238. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  239. package/components/common/diagramMain/modals/editSettings/tabs/port/PortProperties.vue +205 -205
  240. package/components/common/diagramMain/modals/lib/config/adapterModal.ts +144 -144
  241. package/components/common/diagramMain/modals/lib/config/diagramConfig.ts +23 -23
  242. package/components/common/diagramMain/modals/lib/config/index.ts +55 -55
  243. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  244. package/components/common/diagramMain/modals/lib/config/networkModal.ts +390 -390
  245. package/components/common/diagramMain/modals/lib/config/portModal.ts +245 -245
  246. package/components/common/diagramMain/modals/lib/config/switchModal.ts +242 -242
  247. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +46 -46
  248. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  249. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  250. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  251. package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +542 -542
  252. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  253. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  254. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  255. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/VmkernelAdapterReadyComplete.vue +49 -49
  256. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  257. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  258. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  259. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  260. package/components/common/diagramMain/modals/remove/RemoveModal.vue +79 -79
  261. package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +95 -95
  262. package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +230 -230
  263. package/components/common/diagramMain/modals/viewSettings/info/Info.vue +55 -55
  264. package/components/common/diagramMain/modals/viewSettings/info/InfoNew.vue +156 -156
  265. package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +123 -123
  266. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +35 -35
  267. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +199 -199
  268. package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +190 -190
  269. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModal.vue +83 -83
  270. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalNew.vue +68 -68
  271. package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalOld.vue +90 -90
  272. package/components/common/diagramMain/network/Contents.vue +491 -491
  273. package/components/common/diagramMain/network/Lines.vue +107 -107
  274. package/components/common/diagramMain/network/Network.vue +141 -141
  275. package/components/common/diagramMain/network/block/Block.vue +37 -37
  276. package/components/common/diagramMain/network/block/BlockNew.vue +68 -68
  277. package/components/common/diagramMain/network/block/BlockOld.vue +64 -64
  278. package/components/common/diagramMain/network/noNetwork/NoNetwork.vue +12 -12
  279. package/components/common/diagramMain/network/noNetwork/NoNetworkNew.vue +89 -89
  280. package/components/common/diagramMain/network/noNetwork/NoNetworkOld.vue +61 -61
  281. package/components/common/diagramMain/network/secondBlock/SecondBlock.vue +41 -41
  282. package/components/common/diagramMain/network/secondBlock/SecondBlockNew.vue +64 -64
  283. package/components/common/diagramMain/network/secondBlock/SecondBlockOld.vue +60 -60
  284. package/components/common/diagramMain/port/Port.vue +574 -574
  285. package/components/common/diagramMain/port/Ports.vue +47 -47
  286. package/components/common/diagramMain/switch/Switch.vue +180 -180
  287. package/components/common/diagramMain/switch/SwitchSelected.vue +111 -111
  288. package/components/common/feedback/Buttons.vue +229 -229
  289. package/components/common/feedback/Feedback.vue +268 -268
  290. package/components/common/feedback/Message.vue +518 -518
  291. package/components/common/feedback/VisitPortal.vue +62 -62
  292. package/components/common/feedback/lib/config/drawingPanel.ts +31 -31
  293. package/components/common/feedback/lib/config/feedbackTabs.ts +26 -26
  294. package/components/common/feedback/lib/models/interfaces.ts +20 -20
  295. package/components/common/feedback/lib/models/types.ts +1 -1
  296. package/components/common/graph/Graph.vue +110 -110
  297. package/components/common/graph/lib/utils/renderGraph.ts +389 -389
  298. package/components/common/headline/Headline.vue +32 -32
  299. package/components/common/help/navbar/left/Left.vue +165 -165
  300. package/components/common/help/navbar/left/lib/models/interfaces.ts +6 -6
  301. package/components/common/help/navbar/left/lib/utils/constructAccordion.ts +27 -27
  302. package/components/common/help/navbar/right/Right.vue +149 -149
  303. package/components/common/help/navbar/right/lib/models/interfaces.ts +5 -5
  304. package/components/common/layout/theHeader/TheHeader.vue +169 -169
  305. package/components/common/layout/theHeader/TheHeaderNew.vue +314 -314
  306. package/components/common/layout/theHeader/TheHeaderOld.vue +250 -250
  307. package/components/common/layout/theHeader/ThemeSwitch.vue +66 -66
  308. package/components/common/layout/theHeader/feedback/Feedback.vue +109 -109
  309. package/components/common/layout/theHeader/feedback/FeedbackOld.vue +73 -73
  310. package/components/common/layout/theHeader/feedback/lib/config/sendFeedback.ts +17 -17
  311. package/components/common/layout/theHeader/feedback/new/New.vue +192 -192
  312. package/components/common/layout/theHeader/feedback/new/additionalDetails/AdditionalDetails.vue +566 -566
  313. package/components/common/layout/theHeader/feedback/new/additionalDetails/Headline.vue +87 -87
  314. package/components/common/layout/theHeader/feedback/new/description/Description.vue +58 -58
  315. package/components/common/layout/theHeader/feedback/new/email/Email.vue +43 -43
  316. package/components/common/layout/theHeader/feedback/new/lib/models/interfaces.ts +4 -4
  317. package/components/common/layout/theHeader/feedback/new/subtitle/Subtitle.vue +86 -86
  318. package/components/common/layout/theHeader/feedback/new/tabs/Tabs.vue +95 -95
  319. package/components/common/layout/theHeader/feedback/new/tabs/lib/config/tabs.ts +25 -25
  320. package/components/common/layout/theHeader/feedback/new/tabs/lib/models/enums.ts +6 -6
  321. package/components/common/layout/theHeader/feedback/new/tabs/lib/models/types.ts +1 -1
  322. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  323. package/components/common/layout/theHeader/helpMenu/HelpMenu.vue +43 -43
  324. package/components/common/layout/theHeader/helpMenu/aboutNew/AboutNew.vue +103 -103
  325. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +85 -85
  326. package/components/common/layout/theHeader/helpMenu/helpMenuNew/HelpMenuNew.vue +195 -195
  327. package/components/common/layout/theHeader/helpMenu/helpMenuNew/lib/config/dropMenu.ts +28 -28
  328. package/components/common/layout/theHeader/helpMenu/helpMenuOld/HelpMenuOld.vue +69 -69
  329. package/components/common/layout/theHeader/helpMenu/helpMenuOld/lib/config/dropMenu.ts +22 -22
  330. package/components/common/layout/theHeader/helpMenu/helpMenuOld/lib/models/types.ts +1 -1
  331. package/components/common/layout/theHeader/lib/models/enums.ts +10 -10
  332. package/components/common/layout/theHeader/lib/models/types.ts +5 -5
  333. package/components/common/layout/theHeader/lib/utils/localization.ts +32 -32
  334. package/components/common/layout/theHeader/modals/Reconnect.vue +98 -98
  335. package/components/common/layout/theHeader/modals/RedirectLogin.vue +60 -60
  336. package/components/common/layout/theHeader/userMenu/UserMenu.vue +101 -101
  337. package/components/common/layout/theHeader/userMenu/lib/models/interfaces.ts +32 -32
  338. package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePassword.vue +90 -90
  339. package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePasswordNew.vue +175 -175
  340. package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePasswordOld.vue +179 -179
  341. package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/config/form.ts +31 -31
  342. package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/models/interfaces.ts +23 -23
  343. package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/utils.ts +28 -28
  344. package/components/common/layout/theHeader/userMenu/modals/preferences/Preferences.vue +70 -70
  345. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesNew.vue +93 -93
  346. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesOld.vue +122 -122
  347. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguage.vue +113 -113
  348. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguageNew.vue +89 -89
  349. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguageOld.vue +93 -93
  350. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/config/radioOptions.ts +22 -22
  351. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/models/enums.ts +9 -9
  352. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/models/interfaces.ts +11 -11
  353. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/models/types.ts +1 -1
  354. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsole.vue +42 -42
  355. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsoleNew.vue +52 -52
  356. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsoleOld.vue +48 -48
  357. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/lib/config/consoleOptions.ts +30 -30
  358. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/lib/models/interfaces.ts +5 -5
  359. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/Inventory.vue +32 -32
  360. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/InventoryNew.vue +35 -35
  361. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/InventoryOld.vue +31 -31
  362. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/config/preferencesTabs.ts +49 -49
  363. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +1 -1
  364. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormat.vue +54 -54
  365. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormatNew.vue +52 -52
  366. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormatOld.vue +45 -45
  367. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/config/formatOptions.ts +27 -27
  368. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types.ts +1 -1
  369. package/components/common/layout/theHeader/userMenu/modals/preferences/view/View.vue +45 -45
  370. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewNew.vue +33 -33
  371. package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
  372. package/components/common/layout/theHeader/userMenu/userMenuNew/UserMenuNew.vue +170 -170
  373. package/components/common/layout/theHeader/userMenu/userMenuNew/lib/config/dropMenu.ts +28 -28
  374. package/components/common/layout/theHeader/userMenu/userMenuOld/UserMenuOld.vue +36 -36
  375. package/components/common/layout/theHeader/userMenu/userMenuOld/lib/config/dropMenu.ts +36 -36
  376. package/components/common/layout/theHeader/userMenu/userMenuOld/lib/models/types.ts +5 -5
  377. package/components/common/lib/config/states.ts +160 -160
  378. package/components/common/mainNavigationPanel/MainNavigationPanel.vue +150 -150
  379. package/components/common/mainNavigationPanel/MainNavigationPanelNew.vue +327 -327
  380. package/components/common/mainNavigationPanel/MainNavigationPanelOld.vue +300 -300
  381. package/components/common/mainNavigationPanel/lib/models/interfaces.ts +7 -7
  382. package/components/common/mainNavigationPanel/lib/models/types.ts +1 -1
  383. package/components/common/modals/Rename.vue +175 -175
  384. package/components/common/modals/confirmByInput/ConfirmByInput.vue +206 -206
  385. package/components/common/modals/confirmation/Confirmation.vue +74 -74
  386. package/components/common/modals/confirmation/ConfirmationNew.vue +37 -37
  387. package/components/common/modals/confirmation/ConfirmationOld.vue +110 -110
  388. package/components/common/modals/lib/config/defaultForm.ts +18 -18
  389. package/components/common/modals/lib/config/renameLabelWidth.ts +3 -3
  390. package/components/common/modals/lib/models/interfaces.ts +5 -5
  391. package/components/common/modals/unsavedChanges/UnsavedChanges.vue +56 -56
  392. package/components/common/monitor/advanced/Advanced.vue +244 -239
  393. package/components/common/monitor/advanced/GraphView.vue +180 -180
  394. package/components/common/monitor/advanced/lib/models/interfaces.ts +9 -9
  395. package/components/common/monitor/advanced/lib/models/types.ts +1 -1
  396. package/components/common/monitor/advanced/table/Table.vue +93 -93
  397. package/components/common/monitor/advanced/table/lib/config/performanceDatatable.ts +129 -129
  398. package/components/common/monitor/advanced/table/lib/models/interfaces.ts +12 -12
  399. package/components/common/monitor/advanced/table/lib/models/types.ts +10 -10
  400. package/components/common/monitor/advanced/tools/Tools.vue +447 -440
  401. package/components/common/monitor/advanced/tools/chartOptionsModal/ChartOptionsModal.vue +511 -504
  402. package/components/common/monitor/advanced/tools/chartOptionsModal/Notification.vue +34 -34
  403. package/components/common/monitor/advanced/tools/chartOptionsModal/actions/Actions.vue +157 -157
  404. package/components/common/monitor/advanced/tools/chartOptionsModal/actions/lib/utils/optionsActions.ts +25 -25
  405. package/components/common/monitor/advanced/tools/chartOptionsModal/actions/saveOptionsModal/SaveOptionsModal.vue +81 -81
  406. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/Counters.vue +108 -106
  407. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/Table.vue +144 -144
  408. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/tableConfig.ts +89 -89
  409. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +1040 -1040
  410. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/models/interfaces.ts +30 -30
  411. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/models/types.ts +5 -5
  412. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/Timespan.vue +3 -1
  413. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/Object.vue +299 -299
  414. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/lib/config/objectTable.ts +57 -57
  415. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/lib/models/interfaces.ts +4 -4
  416. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/lib/models/types.ts +1 -1
  417. package/components/common/monitor/advanced/tools/chartOptionsModal/lib/models/interfaces.ts +19 -19
  418. package/components/common/monitor/advanced/tools/chartOptionsModal/lib/models/types.ts +3 -3
  419. package/components/common/monitor/advanced/tools/chartOptionsModal/lib/utils/checkSubmit.ts +19 -19
  420. package/components/common/monitor/advanced/tools/chartOptionsModal/metrics/Metrics.vue +42 -42
  421. package/components/common/monitor/advanced/tools/chartOptionsModal/metrics/lib/config/optionsMetrics.ts +173 -173
  422. package/components/common/monitor/advanced/tools/lib/config/advancedToolbar.ts +130 -130
  423. package/components/common/monitor/advanced/tools/lib/models/interfaces.ts +4 -4
  424. package/components/common/monitor/advanced/tools/lib/utils/countCores.ts +7 -7
  425. package/components/common/monitor/lib/config/getValidDateByOption.ts +76 -76
  426. package/components/common/monitor/lib/models/interfaces.ts +24 -24
  427. package/components/common/monitor/overview/Overview.vue +228 -228
  428. package/components/common/monitor/overview/filters/Filters.vue +235 -232
  429. package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModal.vue +250 -240
  430. package/components/common/monitor/overview/filters/customIntervalModal/lib/config/dateChecker.ts +62 -52
  431. package/components/common/monitor/overview/filters/lib/config/filterOptions.ts +100 -100
  432. package/components/common/monitor/overview/filters/lib/models/interfaces.ts +10 -10
  433. package/components/common/monitor/overview/filters/lib/models/types.ts +15 -15
  434. package/components/common/monitor/resourceAllocation/lib/models/interfaces.ts +13 -13
  435. package/components/common/monitor/resourceAllocation/resourceAllocation.vue +196 -196
  436. package/components/common/pages/hardwareHealth/HardwareHealth.vue +213 -206
  437. package/components/common/pages/hardwareHealth/historyTestimony/Graph.vue +7 -2
  438. package/components/common/pages/hardwareHealth/historyTestimony/lib/config/containerSizes.ts +1 -1
  439. package/components/common/pages/hardwareHealth/historyTestimony/lib/models/interfaces.ts +20 -20
  440. package/components/common/pages/hardwareHealth/historyTestimony/tools/Tools.vue +11 -4
  441. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/ChartOptionsModal.vue +494 -487
  442. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/Notification.vue +30 -30
  443. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/actions/Actions.vue +157 -157
  444. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/actions/SaveOptionsModal.vue +81 -81
  445. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/actions/lib/utils/optionsActions.ts +25 -25
  446. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/Counters.vue +6 -6
  447. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/table/Table.vue +174 -174
  448. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/table/lib/config/tableConfig.ts +89 -89
  449. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/table/lib/models/types.ts +5 -5
  450. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/timespan/Timespan.vue +7 -7
  451. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/lib/config/optionsMetrics.ts +17 -17
  452. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/lib/models/interfaces.ts +15 -15
  453. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/lib/models/types.ts +1 -1
  454. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/metrics/Metrics.vue +31 -31
  455. package/components/common/pages/hardwareHealth/historyTestimony/tools/lib/config/toolbar.ts +82 -82
  456. package/components/common/pages/hardwareHealth/historyTestimony/tools/lib/models/interfaces.ts +9 -9
  457. package/components/common/pages/hardwareHealth/lib/config/status.ts +13 -13
  458. package/components/common/pages/hardwareHealth/lib/config/tabsPannel.ts +39 -39
  459. package/components/common/pages/hardwareHealth/lib/models/enums.ts +8 -8
  460. package/components/common/pages/hardwareHealth/lib/models/interfaces.ts +6 -6
  461. package/components/common/pages/hardwareHealth/lib/models/types.ts +5 -5
  462. package/components/common/pages/hardwareHealth/tableView/TableView.vue +194 -194
  463. package/components/common/pages/hardwareHealth/tableView/lib/config/alertWarningTable.ts +109 -109
  464. package/components/common/pages/hardwareHealth/tableView/lib/config/historyTestimonyTable.ts +137 -137
  465. package/components/common/pages/hardwareHealth/tableView/lib/config/sensorTable.ts +133 -133
  466. package/components/common/pages/hardwareHealth/tableView/lib/config/storageSensorTable.ts +88 -88
  467. package/components/common/pages/hardwareHealth/tableView/lib/config/systemLogTable.ts +72 -72
  468. package/components/common/pages/hardwareHealth/tableView/lib/config/tableKeys.ts +22 -22
  469. package/components/common/pages/hardwareHealth/tableView/lib/models/interfaces.ts +29 -29
  470. package/components/common/pages/hardwareHealth/tableView/lib/models/types.ts +26 -26
  471. package/components/common/pages/hardwareHealth/tableView/modal/SensorWarning.vue +63 -63
  472. package/components/common/pages/hardwareHealth/toolsPanel/ToolsPanel.vue +51 -51
  473. package/components/common/pages/hardwareHealth/toolsPanel/lib/config/actionsPanel.ts +34 -34
  474. package/components/common/pages/hardwareHealth/toolsPanel/lib/models/types.ts +4 -4
  475. package/components/common/pages/home/Card.vue +63 -63
  476. package/components/common/pages/home/StatusContent.vue +49 -49
  477. package/components/common/pages/home/headline/Headline.vue +44 -44
  478. package/components/common/pages/home/headline/HeadlineNew.vue +71 -71
  479. package/components/common/pages/home/headline/HeadlineOld.vue +37 -37
  480. package/components/common/pages/home/lib/config/configResourceMeterBlock.ts +21 -21
  481. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  482. package/components/common/pages/home/lib/models/types.ts +12 -12
  483. package/components/common/pages/home/resource/Resource.vue +29 -29
  484. package/components/common/pages/home/resource/ResourceNew.vue +63 -63
  485. package/components/common/pages/home/resource/ResourceOld.vue +116 -116
  486. package/components/common/pages/home/resource/lib/models/interfaces.ts +11 -11
  487. package/components/common/pages/home/resource/lib/utils/resourceMeter.ts +49 -49
  488. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  489. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  490. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  491. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  492. package/components/common/pages/home/widgets/hosts/HostsNew.vue +100 -100
  493. package/components/common/pages/home/widgets/hosts/HostsOld.vue +25 -25
  494. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  495. package/components/common/pages/home/widgets/services/Services.vue +27 -27
  496. package/components/common/pages/home/widgets/services/ServicesNew.vue +123 -123
  497. package/components/common/pages/home/widgets/services/ServicesOld.vue +35 -35
  498. package/components/common/pages/home/widgets/services/lib/config/config.ts +108 -108
  499. package/components/common/pages/home/widgets/services/lib/models/enums.ts +13 -13
  500. package/components/common/pages/home/widgets/services/table/Table.vue +80 -80
  501. package/components/common/pages/home/widgets/services/table/lib/config/config.ts +62 -62
  502. package/components/common/pages/home/widgets/services/table/lib/models/types.ts +6 -6
  503. package/components/common/pages/home/widgets/skeleton/totalQuantitiesItem.vue +82 -82
  504. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  505. package/components/common/pages/home/widgets/vms/VmsNew.vue +101 -101
  506. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  507. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  508. package/components/common/pages/home/widgets/warnings/Warnings.vue +27 -27
  509. package/components/common/pages/home/widgets/warnings/WarningsNew.vue +104 -104
  510. package/components/common/pages/home/widgets/warnings/WarningsOld.vue +39 -39
  511. package/components/common/pages/home/widgets/warnings/lib/config/config.ts +96 -96
  512. package/components/common/pages/home/widgets/warnings/table/Table.vue +114 -114
  513. package/components/common/pages/home/widgets/warnings/table/lib/config/config.ts +73 -73
  514. package/components/common/pages/home/widgets/warnings/table/lib/models/enums.ts +11 -11
  515. package/components/common/pages/home/widgets/warnings/table/lib/models/interfaces.ts +19 -19
  516. package/components/common/pages/home/widgets/warnings/table/lib/models/types.ts +15 -15
  517. package/components/common/pages/scheduledTasks/modals/common/frequency/Frequency.vue +58 -58
  518. package/components/common/pages/scheduledTasks/modals/common/frequency/afterStartup/AfterStartup.vue +82 -82
  519. package/components/common/pages/scheduledTasks/modals/common/frequency/end/End.vue +103 -103
  520. package/components/common/pages/scheduledTasks/modals/common/frequency/end/lib/config/endOptions.ts +17 -17
  521. package/components/common/pages/scheduledTasks/modals/common/frequency/interval/Interval.vue +100 -100
  522. package/components/common/pages/scheduledTasks/modals/common/frequency/lib/config/frequencyOptions.ts +38 -38
  523. package/components/common/pages/scheduledTasks/modals/common/frequency/lib/models/types.ts +7 -7
  524. package/components/common/pages/scheduledTasks/modals/common/frequency/lib/utils.ts +111 -111
  525. package/components/common/pages/scheduledTasks/modals/common/frequency/on/On.vue +232 -232
  526. package/components/common/pages/scheduledTasks/modals/common/frequency/on/lib/config/options.ts +64 -64
  527. package/components/common/pages/scheduledTasks/modals/common/frequency/on/lib/models/types.ts +12 -12
  528. package/components/common/pages/scheduledTasks/modals/common/frequency/on/selectWeek/SelectWeek.vue +68 -68
  529. package/components/common/pages/scheduledTasks/modals/common/frequency/on/selectWeek/lib/config/weekOptions.ts +55 -55
  530. package/components/common/pages/scheduledTasks/modals/common/frequency/on/selectWeek/lib/models/interfaces.ts +6 -6
  531. package/components/common/pages/scheduledTasks/modals/common/frequency/startOn/StartOn.vue +86 -86
  532. package/components/common/pages/scheduledTasks/modals/common/newTaskForm/NewTaskForm.vue +289 -289
  533. package/components/common/pages/scheduledTasks/modals/common/newTaskForm/lib/models/interfaces.ts +3 -3
  534. package/components/common/pages/scheduledTasks/modals/common/newTaskForm/lib/utils.ts +67 -67
  535. package/components/common/pages/scheduledTasks/modals/lib/config/createScheduledTask.ts +23 -23
  536. package/components/common/pages/scheduledTasks/modals/lib/models/interfaces.ts +21 -21
  537. package/components/common/pages/scheduledTasks/modals/lib/utils.ts +7 -7
  538. package/components/common/pages/shortcuts/Shortcuts.vue +67 -67
  539. package/components/common/pages/shortcuts/block/Block.vue +35 -35
  540. package/components/common/pages/shortcuts/block/BlockNew.vue +80 -80
  541. package/components/common/pages/shortcuts/block/BlockOld.vue +55 -55
  542. package/components/common/pages/shortcuts/category/Category.vue +26 -26
  543. package/components/common/pages/shortcuts/category/CategoryNew.vue +41 -41
  544. package/components/common/pages/shortcuts/category/CategoryOld.vue +41 -41
  545. package/components/common/pages/shortcuts/lib/models/interfaces.ts +12 -12
  546. package/components/common/pages/tasks/Tasks.vue +95 -104
  547. package/components/common/pages/tasks/table/Table.vue +258 -257
  548. package/components/common/pages/tasks/table/errorInfo/ErrorInfo.vue +90 -94
  549. package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +168 -168
  550. package/components/common/pages/tasks/table/lib/config/config.ts +269 -269
  551. package/components/common/pages/tasks/table/lib/models/enums.ts +13 -13
  552. package/components/common/perPage/PerPage.vue +52 -52
  553. package/components/common/portlets/customAttributes/Portlet.vue +657 -657
  554. package/components/common/portlets/customAttributes/lib/config/config.ts +138 -138
  555. package/components/common/portlets/customAttributes/lib/models/interfaces.ts +5 -5
  556. package/components/common/portlets/tag/CreateCategory.vue +276 -276
  557. package/components/common/portlets/tag/Portlet.vue +424 -424
  558. package/components/common/portlets/tag/TagAddNew.vue +629 -629
  559. package/components/common/portlets/tag/lib/config/config.ts +201 -201
  560. package/components/common/portlets/tag/lib/models/interfaces.ts +27 -27
  561. package/components/common/portlets/tag/lib/models/types.ts +15 -15
  562. package/components/common/readyToComplete/ReadyToComplete.vue +15 -15
  563. package/components/common/recursionTree/RecursionTree.vue +223 -223
  564. package/components/common/recursionTree/lib/models/interfaces.ts +23 -23
  565. package/components/common/resource/lib/models/interfaces.ts +9 -9
  566. package/components/common/resource/lib/models/types.ts +1 -1
  567. package/components/common/resource/lib/utils.ts +44 -44
  568. package/components/common/resource/progressBlock/ProgressBlock.vue +142 -142
  569. package/components/common/resource/simple/Simple.vue +58 -58
  570. package/components/common/resource/simple/lib/models/enums.ts +6 -6
  571. package/components/common/select/button/ButtonDropdown.vue +108 -108
  572. package/components/common/select/button/lib/models/interfaces.ts +7 -7
  573. package/components/common/select/input/Input.vue +78 -78
  574. package/components/common/select/input/lib/models/interfaces.ts +6 -6
  575. package/components/common/select/radio/RadioGroup.vue +128 -128
  576. package/components/common/select/radio/lib/models/interfaces.ts +9 -9
  577. package/components/common/selectLanguage/SelectLanguage.vue +130 -130
  578. package/components/common/selectLanguage/lib/config/config.ts +39 -39
  579. package/components/common/selectLanguage/lib/utils/utils.ts +5 -5
  580. package/components/common/spiceConsole/Drawer.vue +370 -370
  581. package/components/common/spiceConsole/SpiceConsole.vue +84 -84
  582. package/components/common/spiceConsole/keyboard/Keyboard.vue +403 -403
  583. package/components/common/spiceConsole/keyboard/lib/config/keyboardRows.ts +966 -966
  584. package/components/common/spiceConsole/keyboard/lib/models/interfaces.ts +18 -18
  585. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  586. package/components/common/spiceConsole/lib/models/types.ts +1 -1
  587. package/components/common/spiceConsole/lib/utils/getDeviceType.ts +35 -35
  588. package/components/common/split/horizontal/Horizontal.vue +70 -70
  589. package/components/common/split/horizontal/HorizontalNew.vue +358 -358
  590. package/components/common/split/horizontal/HorizontalOld.vue +307 -307
  591. package/components/common/split/horizontal/lib/models/interfaces.ts +5 -5
  592. package/components/common/split/vertical/Vertical.vue +160 -160
  593. package/components/common/split/vertical/VerticalNew.vue +121 -121
  594. package/components/common/split/vertical/VerticalOld.vue +108 -108
  595. package/components/common/split/vertical/lib/models/interfaces.ts +3 -3
  596. package/components/common/summary/notification/Notification.vue +28 -28
  597. package/components/common/summary/notification/NotificationNew.vue +135 -135
  598. package/components/common/summary/notification/NotificationOld.vue +46 -46
  599. package/components/common/tools/Actions.vue +172 -172
  600. package/components/common/tools/lib/models/interfaces.ts +7 -7
  601. package/components/common/tools/viewSettings/ViewSettings.vue +86 -86
  602. package/components/common/tools/viewSettings/lib/models/interfaces.ts +9 -9
  603. package/components/common/vm/actions/add/Add.vue +616 -618
  604. package/components/common/vm/actions/add/FolderTreeView.vue +83 -83
  605. package/components/common/vm/actions/add/lib/config/steps.ts +145 -145
  606. package/components/common/vm/actions/add/lib/utils.ts +103 -103
  607. package/components/common/vm/actions/clone/Clone.vue +634 -636
  608. package/components/common/vm/actions/clone/lib/config/steps.ts +129 -129
  609. package/components/common/vm/actions/clone/lib/models/interfaces.ts +16 -16
  610. package/components/common/vm/actions/clone/lib/utils.ts +43 -43
  611. package/components/common/vm/actions/clone/select/options/Options.vue +71 -71
  612. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +267 -270
  613. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +269 -271
  614. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +158 -160
  615. package/components/common/vm/actions/common/customizeHardware/lib/config/navItems.ts +36 -36
  616. package/components/common/vm/actions/common/customizeHardware/lib/models/interfaces.ts +7 -7
  617. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +685 -693
  618. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +402 -405
  619. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +267 -269
  620. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  621. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/lib/models/interfaces.ts +8 -8
  622. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +97 -97
  623. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +117 -117
  624. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusOld.vue +109 -109
  625. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/lib/config/options.ts +20 -20
  626. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +228 -228
  627. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +161 -161
  628. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +165 -165
  629. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/lib/config/fileTypes.ts +9 -9
  630. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/lib/config/options.ts +11 -11
  631. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/lib/models/types.ts +1 -1
  632. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  633. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  634. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  635. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  636. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +192 -192
  637. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuOld.vue +174 -174
  638. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Hv.vue +99 -99
  639. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Iommu.vue +55 -55
  640. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Pc.vue +55 -55
  641. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Sa.vue +106 -106
  642. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocket.vue +86 -86
  643. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocketNew.vue +68 -68
  644. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocketOld.vue +63 -63
  645. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/hotPlug/HotPlug.vue +40 -40
  646. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/hotPlug/HotPlugNew.vue +31 -31
  647. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/hotPlug/HotPlugOld.vue +38 -38
  648. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/lib/config/cpuOptions.ts +21 -21
  649. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/maxCpu/MaxCpu.vue +94 -94
  650. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/maxCpu/MaxCpuNew.vue +40 -40
  651. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/maxCpu/MaxCpuOld.vue +51 -51
  652. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/Model.vue +121 -121
  653. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +207 -207
  654. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelOld.vue +171 -171
  655. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
  656. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/SharesNew.vue +58 -58
  657. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/SharesOld.vue +76 -76
  658. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  659. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/Tooltip.vue +21 -21
  660. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +110 -110
  661. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipOld.vue +59 -59
  662. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/binaryOptions.ts +12 -12
  663. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/dropdownItems.ts +147 -149
  664. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces.ts +118 -118
  665. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types.ts +4 -4
  666. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  667. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/LimitNew.vue +70 -70
  668. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/LimitOld.vue +75 -75
  669. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/lib/config/options.ts +29 -29
  670. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +288 -288
  671. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +156 -156
  672. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryOld.vue +155 -155
  673. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlug.vue +29 -29
  674. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlugNew.vue +30 -30
  675. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlugOld.vue +43 -43
  676. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/lib/config/memoryOptions.ts +35 -35
  677. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +351 -351
  678. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +229 -229
  679. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +241 -241
  680. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/Cache.vue +55 -55
  681. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/CacheNew.vue +40 -40
  682. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/CacheOld.vue +57 -57
  683. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/lib/config/options.ts +7 -7
  684. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/File.vue +22 -22
  685. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileNew.vue +36 -36
  686. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileOld.vue +24 -24
  687. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIops.vue +103 -103
  688. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIopsNew.vue +66 -66
  689. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIopsOld.vue +89 -89
  690. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/lib/config/options.ts +28 -28
  691. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +161 -161
  692. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/StorageModal.vue +52 -52
  693. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/StorageModalNew.vue +74 -74
  694. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/StorageModalOld.vue +52 -52
  695. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSize.vue +23 -23
  696. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeNew.vue +37 -37
  697. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeOld.vue +25 -25
  698. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/Mode.vue +65 -65
  699. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeNew.vue +46 -46
  700. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  701. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/lib/config/options.ts +18 -18
  702. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/Provisioning.vue +61 -61
  703. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/ProvisioningNew.vue +44 -44
  704. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/ProvisioningOld.vue +58 -58
  705. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/lib/config/options.ts +15 -15
  706. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/Sharing.vue +63 -63
  707. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +44 -44
  708. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingOld.vue +58 -58
  709. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/lib/config/options.ts +12 -12
  710. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +281 -281
  711. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +124 -124
  712. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkOld.vue +131 -131
  713. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/AdapterType.vue +60 -60
  714. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/AdapterTypeNew.vue +53 -53
  715. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/AdapterTypeOld.vue +60 -60
  716. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/lib/config/options.ts +9 -9
  717. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/Location.vue +71 -71
  718. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  719. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  720. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +74 -74
  721. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -95
  722. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  723. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +69 -69
  724. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  725. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/lib/config/options.ts +11 -11
  726. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +142 -184
  727. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceNew.vue +85 -111
  728. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceOld.vue +91 -117
  729. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIo.vue +33 -33
  730. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +35 -35
  731. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +37 -37
  732. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +33 -40
  733. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +48 -48
  734. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +35 -35
  735. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/lib/config/options.ts +10 -10
  736. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/lib/config/options.ts +7 -14
  737. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  738. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  739. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  740. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +26 -26
  741. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +30 -30
  742. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +31 -31
  743. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelection.vue +35 -35
  744. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelectionNew.vue +46 -46
  745. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelectionOld.vue +46 -46
  746. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbController.vue +58 -58
  747. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +56 -56
  748. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerOld.vue +61 -61
  749. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/lib/config/options.ts +6 -6
  750. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  751. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  752. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherOld.vue +32 -32
  753. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevices.vue +15 -15
  754. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +33 -33
  755. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesOld.vue +21 -21
  756. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/Reservation.vue +196 -196
  757. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationNew.vue +98 -98
  758. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationOld.vue +96 -96
  759. package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/lib/config/options.ts +33 -33
  760. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/Graphics.vue +50 -50
  761. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +131 -131
  762. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +104 -104
  763. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  764. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/lib/config/options.ts +11 -11
  765. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/Model.vue +34 -34
  766. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/ModelNew.vue +44 -44
  767. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/ModelOld.vue +44 -44
  768. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/lib/config/options.ts +10 -10
  769. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +57 -57
  770. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplaysNew.vue +49 -49
  771. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplaysOld.vue +56 -56
  772. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/lib/config/options.ts +14 -14
  773. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemory.vue +105 -105
  774. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  775. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryOld.vue +60 -60
  776. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  777. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  778. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +96 -96
  779. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptions.vue +100 -100
  780. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  781. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsOld.vue +80 -80
  782. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/Secure.vue +50 -50
  783. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  784. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/DelayNew.vue +35 -35
  785. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/DelayOld.vue +41 -41
  786. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/lib/config/config.ts +14 -14
  787. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  788. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +42 -42
  789. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareOld.vue +56 -56
  790. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/lib/config/config.ts +11 -11
  791. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/Menu.vue +20 -20
  792. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  793. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuOld.vue +36 -36
  794. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  795. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  796. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderOld.vue +60 -60
  797. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/lib/models/interfaces.ts +9 -9
  798. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +77 -77
  799. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +141 -141
  800. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +137 -137
  801. package/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces.ts +34 -34
  802. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  803. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/Old.vue +139 -139
  804. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/PlaybackCompression.vue +52 -52
  805. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/PowerControl.vue +50 -50
  806. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/RemoteConsoleOptions.vue +172 -172
  807. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPaste.vue +26 -26
  808. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  809. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteOld.vue +41 -41
  810. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransfer.vue +26 -26
  811. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  812. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferOld.vue +41 -41
  813. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharing.vue +20 -20
  814. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  815. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingOld.vue +37 -37
  816. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/imgCompression/ImgCompression.vue +85 -85
  817. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/imgCompression/lib/config/config.ts +14 -14
  818. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/jpegCompression/JpegCompression.vue +85 -85
  819. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/jpegCompression/lib/config/config.ts +12 -12
  820. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  821. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +39 -39
  822. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +43 -43
  823. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/lib/config/config.ts +6 -6
  824. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/mouseMode/MouseMode.vue +57 -57
  825. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/mouseMode/lib/config/config.ts +11 -11
  826. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  827. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  828. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  829. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/lib/models/interfaces.ts +5 -5
  830. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/lib/utils.ts +12 -12
  831. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/sharePolicy/SharePolicy.vue +56 -56
  832. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/sharePolicy/lib/config/config.ts +11 -11
  833. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/streamingMode/StreamingMode.vue +85 -85
  834. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/streamingMode/lib/config/config.ts +12 -12
  835. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/type/Type.vue +85 -85
  836. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/type/lib/config/config.ts +7 -7
  837. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  838. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +38 -38
  839. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  840. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/lib/config/config.ts +14 -14
  841. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/zlibCompression/ZlibCompression.vue +85 -85
  842. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/zlibCompression/lib/config/config.ts +12 -12
  843. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/Tools.vue +49 -49
  844. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +39 -39
  845. package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsOld.vue +48 -48
  846. package/components/common/vm/actions/common/lib/config/capabilities.ts +346 -346
  847. package/components/common/vm/actions/common/lib/models/enums.ts +123 -123
  848. package/components/common/vm/actions/common/lib/models/interfaces.ts +149 -149
  849. package/components/common/vm/actions/common/lib/models/types.ts +65 -65
  850. package/components/common/vm/actions/common/lib/utils/capabilities.ts +51 -51
  851. package/components/common/vm/actions/common/select/compatibility/Compatibility.vue +155 -155
  852. package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +164 -164
  853. package/components/common/vm/actions/common/select/computeResource/TreeView.vue +124 -124
  854. package/components/common/vm/actions/common/select/computeResource/lib/ComputeResource.spec.ts +479 -479
  855. package/components/common/vm/actions/common/select/createType/CreateType.vue +61 -61
  856. package/components/common/vm/actions/common/select/createType/lib/config/items.ts +26 -26
  857. package/components/common/vm/actions/common/select/lib/models/interfaces.ts +34 -34
  858. package/components/common/vm/actions/common/select/lib/models/types.ts +27 -27
  859. package/components/common/vm/actions/common/select/name/Name.vue +236 -236
  860. package/components/common/vm/actions/common/select/os/os.vue +232 -232
  861. package/components/common/vm/actions/common/select/storage/Storage.vue +130 -130
  862. package/components/common/vm/actions/common/select/storage/StorageOld.vue +129 -129
  863. package/components/common/vm/actions/common/select/storage/lib/config/config.ts +193 -193
  864. package/components/common/vm/actions/common/select/storage/lib/models/types.ts +15 -15
  865. package/components/common/vm/actions/common/select/storage/new/New.vue +159 -159
  866. package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +173 -173
  867. package/components/common/vm/actions/confirm/Confirm.vue +32 -32
  868. package/components/common/vm/actions/editSettings/EditSettings.vue +232 -235
  869. package/components/common/vm/actions/editSettings/EditSettingsOld.vue +183 -185
  870. package/components/common/vm/actions/editSettings/lib/config/modal.ts +9 -9
  871. package/components/common/vm/actions/editSettings/lib/models/types.ts +23 -23
  872. package/components/common/vm/actions/editSettings/lib/utils.ts +45 -45
  873. package/components/common/vm/actions/editSettings/new/New.vue +177 -179
  874. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  875. package/components/common/vm/actions/lib/models/interfaces.ts +6 -6
  876. package/components/common/vm/actions/lib/models/types.ts +11 -11
  877. package/components/common/vm/actions/lib/utils.ts +246 -246
  878. package/components/common/vm/lib/models/interfaces.ts +9 -9
  879. package/components/common/vm/lib/utils/powerActions.ts +55 -55
  880. package/components/common/weekSelect/WeekSelect.vue +143 -143
  881. package/components/common/weekSelect/lib/config/options.ts +10 -10
  882. package/components/common/weekSelect/lib/models/interfaces.ts +6 -6
  883. package/components/common/wizards/datastore/add/Add.vue +307 -307
  884. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  885. package/components/common/wizards/datastore/add/lib/models/enums.ts +5 -5
  886. package/components/common/wizards/datastore/add/lib/models/interfaces.ts +19 -19
  887. package/components/common/wizards/datastore/add/lib/models/types.ts +7 -7
  888. package/components/common/wizards/datastore/add/lib/utils.ts +63 -63
  889. package/components/common/wizards/datastore/add/lib/validations.ts +169 -169
  890. package/components/common/wizards/datastore/add/local/Local.vue +45 -45
  891. package/components/common/wizards/datastore/add/local/createName/CreateName.vue +116 -116
  892. package/components/common/wizards/datastore/add/nfs/Nfs.vue +63 -63
  893. package/components/common/wizards/datastore/add/nfs/_kerberosAuthentication/KerberosAuthentication.vue +55 -55
  894. package/components/common/wizards/datastore/add/nfs/_kerberosAuthentication/lib/config/radioOptions.ts +27 -27
  895. package/components/common/wizards/datastore/add/nfs/accessibility/Accessibility.vue +63 -63
  896. package/components/common/wizards/datastore/add/nfs/accessibility/lib/config/tabsPannel.ts +24 -24
  897. package/components/common/wizards/datastore/add/nfs/accessibility/lib/models/interfaces.ts +9 -9
  898. package/components/common/wizards/datastore/add/nfs/accessibility/lib/models/types.ts +5 -5
  899. package/components/common/wizards/datastore/add/nfs/accessibility/tablesView/TablesView.vue +84 -84
  900. package/components/common/wizards/datastore/add/nfs/accessibility/tablesView/lib/config/compatibleTable.ts +62 -62
  901. package/components/common/wizards/datastore/add/nfs/accessibility/tablesView/lib/config/incompatibleTable.ts +68 -68
  902. package/components/common/wizards/datastore/add/nfs/accessibility/tablesView/lib/config/tableKeys.ts +15 -15
  903. package/components/common/wizards/datastore/add/nfs/accessibility/tablesView/lib/models/interfaces.ts +11 -11
  904. package/components/common/wizards/datastore/add/nfs/configuration/Configuration.vue +237 -237
  905. package/components/common/wizards/datastore/add/nfs/configuration/_serversList/DeletePopover.vue +100 -100
  906. package/components/common/wizards/datastore/add/nfs/configuration/_serversList/ServersList.vue +123 -123
  907. package/components/common/wizards/datastore/add/nfs/configuration/_serversList/lib/config/serversListConfig.ts +40 -40
  908. package/components/common/wizards/datastore/add/nfs/configuration/_serversList/lib/config/tableKeys.ts +3 -3
  909. package/components/common/wizards/datastore/add/nfs/configuration/_serversList/lib/models/interfaces.ts +3 -3
  910. package/components/common/wizards/datastore/add/nfs/configuration/_serversList/lib/models/types.ts +1 -1
  911. package/components/common/wizards/datastore/add/nfs/configuration/lib/models/interfaces.ts +5 -5
  912. package/components/common/wizards/datastore/add/nfs/version/Version.vue +26 -26
  913. package/components/common/wizards/datastore/add/nfs/version/lib/config/versionOptions.ts +22 -22
  914. package/components/common/wizards/datastore/add/readyComplete/ReadyComplete.vue +88 -88
  915. package/components/common/wizards/datastore/add/readyComplete/lib/config/propertiesDetails.ts +140 -140
  916. package/components/common/wizards/datastore/add/sharedStorm/SharedStorm.vue +78 -78
  917. package/components/common/wizards/datastore/add/sharedStorm/_version/Version.vue +28 -28
  918. package/components/common/wizards/datastore/add/sharedStorm/_version/lib/config/versionOptions.ts +21 -21
  919. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/DeviceSelection.vue +276 -276
  920. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/lib/config/selectOptions.ts +23 -23
  921. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/lib/models/interfaces.ts +26 -26
  922. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/lib/models/types.ts +1 -1
  923. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/table/Table.vue +133 -133
  924. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/table/lib/config/lunDiskTable.ts +84 -84
  925. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/table/lib/config/tableKeys.ts +11 -11
  926. package/components/common/wizards/datastore/add/sharedStorm/deviceSelection/table/lib/models/types.ts +9 -9
  927. package/components/common/wizards/datastore/add/sharedStorm/partitionConfiguration/PartitionConfiguration.vue +236 -236
  928. package/components/common/wizards/datastore/add/sharedStorm/partitionConfiguration/graphicTooltip/graphicTooltip.vue +64 -64
  929. package/components/common/wizards/datastore/add/sharedStorm/partitionConfiguration/lib/config/selectOptions.ts +46 -46
  930. package/components/common/wizards/datastore/add/sharedStorm/partitionConfiguration/sizeGraphic/sizeGraphic.vue +225 -225
  931. package/components/common/wizards/datastore/add/types/Types.vue +83 -83
  932. package/components/common/wizards/datastore/add/types/lib/config/typeOptions.ts +41 -41
  933. package/components/common/wizards/network/add/Add.vue +1086 -1086
  934. package/components/common/wizards/network/add/lib/config/config.ts +36 -36
  935. package/components/common/wizards/network/add/lib/config/initialData.ts +62 -62
  936. package/components/common/wizards/network/add/lib/config/portPropertiesStep.ts +43 -43
  937. package/components/common/wizards/network/add/lib/config/selectSwitch.ts +19 -19
  938. package/components/common/wizards/network/add/lib/config/sendData.ts +141 -141
  939. package/components/common/wizards/network/add/lib/config/steps.ts +497 -497
  940. package/components/common/wizards/network/add/lib/models/enums.ts +17 -17
  941. package/components/common/wizards/network/add/lib/models/interfaces.ts +249 -249
  942. package/components/common/wizards/network/add/lib/models/types.ts +14 -14
  943. package/components/common/wizards/network/add/lib/utils/utils.ts +4 -4
  944. package/components/common/wizards/network/add/mappers/mappers.ts +192 -192
  945. package/components/common/wizards/network/add/modals/SelectNetwork.vue +173 -173
  946. package/components/common/wizards/network/add/modals/SelectStandardSwitch.vue +138 -138
  947. package/components/common/wizards/network/add/modals/SelectSwitch.vue +131 -131
  948. package/components/common/wizards/network/add/steps/ConnectionSettings.vue +154 -154
  949. package/components/common/wizards/network/add/steps/CreateStandardSwitch.vue +91 -91
  950. package/components/common/wizards/network/add/steps/IpFourSettings.vue +305 -305
  951. package/components/common/wizards/network/add/steps/PhysicalAdapter.vue +13 -13
  952. package/components/common/wizards/network/add/steps/PortProperties.vue +407 -407
  953. package/components/common/wizards/network/add/steps/ReadyComplete.vue +20 -20
  954. package/components/common/wizards/network/add/steps/SelectConnectionType.vue +99 -99
  955. package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +467 -467
  956. package/components/common/wizards/network/add/validations/common.ts +26 -26
  957. package/components/common/wizards/network/add/validations/connectionSettings.ts +70 -70
  958. package/components/common/wizards/network/add/validations/createStandardSwitch.ts +59 -59
  959. package/components/common/wizards/network/add/validations/ipFourSettings.ts +182 -182
  960. package/components/common/wizards/network/add/validations/networkValidation.ts +77 -77
  961. package/components/common/wizards/network/add/validations/physicalAdapter.ts +70 -70
  962. package/components/common/wizards/network/add/validations/portProperties.ts +83 -83
  963. package/components/common/wizards/network/add/validations/targetDevice.ts +109 -109
  964. package/components/common/wizards/network/add/validations/validations.ts +43 -43
  965. package/components/common/wizards/vm/common/computeResource/TreeView.vue +58 -58
  966. package/components/common/wizards/vm/common/tooltip/Tooltip.vue +84 -84
  967. package/components/common/wizards/vm/common/validation/compatibility/Compatibility.vue +62 -62
  968. package/components/common/wizards/vm/common/validation/lib/models/enums.ts +5 -5
  969. package/components/common/wizards/vm/migrate/Migrate.vue +288 -288
  970. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +210 -210
  971. package/components/common/wizards/vm/migrate/lib/config/steps.ts +109 -109
  972. package/components/common/wizards/vm/migrate/lib/models/enums.ts +6 -6
  973. package/components/common/wizards/vm/migrate/lib/models/interfaces.ts +35 -35
  974. package/components/common/wizards/vm/migrate/lib/validations.ts +57 -57
  975. package/components/common/wizards/vm/migrate/select/computeResource/ComputeResource.vue +188 -188
  976. package/components/common/wizards/vm/migrate/select/computeResource/lib/config/tabsPannel.ts +28 -28
  977. package/components/common/wizards/vm/migrate/select/computeResource/lib/models/enums.ts +6 -6
  978. package/components/common/wizards/vm/migrate/select/computeResource/lib/models/interfaces.ts +31 -31
  979. package/components/common/wizards/vm/migrate/select/computeResource/lib/models/types.ts +12 -12
  980. package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +134 -134
  981. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/clusterTable.ts +113 -113
  982. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/hostTable.ts +124 -124
  983. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/resourcePoolTable.ts +115 -115
  984. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/tableKeys.ts +65 -65
  985. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/vappsTable.ts +68 -68
  986. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/models/interfaces.ts +50 -50
  987. package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/models/types.ts +60 -60
  988. package/components/common/wizards/vm/migrate/select/network/Network.vue +100 -100
  989. package/components/common/wizards/vm/migrate/select/network/lib/models/interfaces.ts +4 -4
  990. package/components/common/wizards/vm/migrate/select/network/table/network/Network.vue +127 -127
  991. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +88 -88
  992. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/basicTable.ts +70 -70
  993. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/tableKeys.ts +13 -13
  994. package/components/common/wizards/vm/migrate/select/network/table/network/lib/models/interfaces.ts +12 -12
  995. package/components/common/wizards/vm/migrate/select/network/table/network/lib/models/types.ts +21 -21
  996. package/components/common/wizards/vm/migrate/select/network/table/useAt/UseAt.vue +54 -54
  997. package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/config/tableKeys.ts +7 -7
  998. package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/config/useAtTable.ts +47 -47
  999. package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/models/interfaces.ts +1 -1
  1000. package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/models/types.ts +5 -5
  1001. package/components/common/wizards/vm/migrate/select/priority/Priority.vue +25 -25
  1002. package/components/common/wizards/vm/migrate/select/priority/lib/config/typeOptions.ts +21 -21
  1003. package/components/common/wizards/vm/migrate/select/priority/lib/models/types.ts +1 -1
  1004. package/components/common/wizards/vm/migrate/select/storage/Storage.vue +174 -174
  1005. package/components/common/wizards/vm/migrate/select/storage/configure/batch/Batch.vue +68 -68
  1006. package/components/common/wizards/vm/migrate/select/storage/configure/batch/config/virtualDiskFormat.ts +30 -30
  1007. package/components/common/wizards/vm/migrate/select/storage/configure/batch/table/Table.vue +128 -128
  1008. package/components/common/wizards/vm/migrate/select/storage/configure/batch/table/lib/config/datastoreTable.ts +177 -177
  1009. package/components/common/wizards/vm/migrate/select/storage/configure/batch/table/lib/models/types.ts +15 -15
  1010. package/components/common/wizards/vm/migrate/select/storage/configure/disk/Disk.vue +68 -68
  1011. package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/Table.vue +74 -74
  1012. package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/config/diskTable.ts +136 -136
  1013. package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/config/tableKeys.ts +15 -15
  1014. package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/models/interfaces.ts +29 -29
  1015. package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/models/types.ts +13 -13
  1016. package/components/common/wizards/vm/migrate/select/storage/lib/config/tabsPannel.ts +20 -20
  1017. package/components/common/wizards/vm/migrate/select/storage/lib/models/enums.ts +6 -6
  1018. package/components/common/wizards/vm/migrate/select/storage/lib/models/types.ts +9 -9
  1019. package/components/common/wizards/vm/migrate/select/storage/policy/Policy.vue +84 -84
  1020. package/components/common/wizards/vm/migrate/select/storage/selectedPerDisk/SelectedPerDisk.vue +80 -80
  1021. package/components/common/wizards/vm/migrate/select/targetServer/lib/config/tabsPannel.ts +18 -18
  1022. package/components/common/wizards/vm/migrate/select/targetServer/lib/models/types.ts +1 -1
  1023. package/components/common/wizards/vm/migrate/select/targetServer/new/New.vue +261 -261
  1024. package/components/common/wizards/vm/migrate/select/targetServer/new/lib/models/interfaces.ts +11 -11
  1025. package/components/common/wizards/vm/migrate/select/targetServer/saved/Saved.vue +27 -27
  1026. package/components/common/wizards/vm/migrate/select/targetServer/targetServer.vue +51 -51
  1027. package/components/common/wizards/vm/migrate/select/type/Type.vue +27 -27
  1028. package/components/common/wizards/vm/migrate/select/type/lib/config/typeOptions.ts +41 -41
  1029. package/components/common/wizards/vm/migrate/select/type/lib/models/interfaces.ts +5 -5
  1030. package/components/common/wizards/vm/migrate/select/type/lib/models/types.ts +5 -5
  1031. package/components/content/Hint.vue +24 -24
  1032. package/components/lib/models/interfaces.ts +14 -14
  1033. package/composables/deepCopy.ts +21 -21
  1034. package/composables/productNameLocal.ts +30 -30
  1035. package/composables/useAppVersion.ts +21 -21
  1036. package/composables/useDiff.ts +15 -15
  1037. package/composables/useEnvLanguage.ts +23 -23
  1038. package/composables/useLocal.ts +49 -49
  1039. package/composables/useLocalStorage.ts +45 -45
  1040. package/composables/useThrottle.ts +32 -32
  1041. package/composables/useUniqueId.ts +5 -5
  1042. package/eslint/index.js +15 -15
  1043. package/eslint/no-import-type.js +17 -17
  1044. package/eslint/no-invalid-type-prefix.js +32 -32
  1045. package/layouts/auth.vue +32 -32
  1046. package/lib/config/regExp.ts +17 -17
  1047. package/lib/models/composables/useAppVersion/interfaces.ts +5 -5
  1048. package/lib/models/composables/useMyFetch/interfaces.ts +25 -25
  1049. package/lib/models/composables/useMyFetch/types.ts +1 -1
  1050. package/lib/models/enums.ts +35 -35
  1051. package/lib/models/interfaces.ts +69 -69
  1052. package/lib/models/plugins/date/interfaces.ts +5 -5
  1053. package/lib/models/plugins/date/types.ts +1 -1
  1054. package/lib/models/plugins/validation/interfaces.ts +21 -21
  1055. package/lib/models/plugins/validation/types.ts +1 -1
  1056. package/lib/models/store/host/interfaces.ts +38 -38
  1057. package/lib/models/store/interfaces.ts +43 -43
  1058. package/lib/models/store/network/interfaces.ts +13 -13
  1059. package/lib/models/store/storage/interfaces.ts +32 -32
  1060. package/lib/models/store/tasks/enums.ts +34 -34
  1061. package/lib/models/store/tasks/interfaces.ts +126 -126
  1062. package/lib/models/store/tasks/types.ts +2 -2
  1063. package/lib/models/store/types.ts +43 -43
  1064. package/lib/models/store/vm/interfaces.ts +241 -241
  1065. package/lib/models/table/interfaces.ts +56 -56
  1066. package/lib/models/table/types.ts +1 -1
  1067. package/lib/models/types.ts +55 -55
  1068. package/lib/utils/base64.ts +34 -34
  1069. package/lib/utils/contentBuild.ts +34 -34
  1070. package/lib/utils/notification.ts +22 -22
  1071. package/lib/utils/sendTask.ts +73 -73
  1072. package/lib/utils/token.ts +34 -34
  1073. package/lib/utils/utils.ts +22 -22
  1074. package/minify.js +146 -146
  1075. package/modules/fixContentBuild/index.ts +91 -91
  1076. package/modules/fixContentBuild/lib/utils/methods.ts +115 -115
  1077. package/modules/fixSpiceConsoleBuild/index.ts +28 -28
  1078. package/modules/replaceEnv/index.ts +40 -40
  1079. package/modules/setLastUpdateTime/index.ts +36 -36
  1080. package/modules/setLastUpdateTime/lib/utils/methods.ts +31 -31
  1081. package/nuxt.config.ts +8 -8
  1082. package/package.json +42 -42
  1083. package/plugins/binary.ts +164 -164
  1084. package/plugins/date.ts +233 -233
  1085. package/plugins/recursion.ts +311 -311
  1086. package/plugins/spice-console/spice.console.ts +147 -147
  1087. package/plugins/text.ts +48 -48
  1088. package/plugins/validation.ts +172 -172
  1089. package/public/spice-console/application/WorkerProcess.js +3350 -3350
  1090. package/public/spice-console/application/WorkerProcess_back.js +3144 -3144
  1091. package/public/spice-console/application/WorkerProcess_meta.js +3103 -3103
  1092. package/public/spice-console/application/WorkerProcess_reverse.js +3214 -3214
  1093. package/public/spice-console/application/agent.js +178 -178
  1094. package/public/spice-console/application/application.js +641 -641
  1095. package/public/spice-console/application/checkActivity.js +50 -50
  1096. package/public/spice-console/application/clientgui.js +849 -849
  1097. package/public/spice-console/application/clipboard/clipboarddataparser.js +92 -92
  1098. package/public/spice-console/application/clipboard/local/localClipboard.js +110 -110
  1099. package/public/spice-console/application/clipboard.js +82 -82
  1100. package/public/spice-console/application/codec.js +264 -264
  1101. package/public/spice-console/application/imagecache.js +81 -81
  1102. package/public/spice-console/application/inputmanager.js +270 -270
  1103. package/public/spice-console/application/packetfactory.js +206 -206
  1104. package/public/spice-console/application/packetfilter.js +103 -103
  1105. package/public/spice-console/application/packetprocess.js +75 -75
  1106. package/public/spice-console/application/rasteroperation.js +118 -118
  1107. package/public/spice-console/application/spiceconnection.js +197 -197
  1108. package/public/spice-console/application/stream.js +67 -67
  1109. package/public/spice-console/application/virtualmouse.js +109 -109
  1110. package/public/spice-console/keymaps/keyevent.js +36 -36
  1111. package/public/spice-console/keymaps/keymap.js +229 -229
  1112. package/public/spice-console/keymaps/keymapes.js +375 -375
  1113. package/public/spice-console/keymaps/keymapesObj.js +317 -317
  1114. package/public/spice-console/keymaps/keymapus.js +317 -317
  1115. package/public/spice-console/keymaps/scanCodeObjModifier.js +65 -65
  1116. package/public/spice-console/keymaps/scanCodeObjProvider.js +60 -60
  1117. package/public/spice-console/lib/AsyncConsumer.js +204 -204
  1118. package/public/spice-console/lib/AsyncWorker.js +60 -60
  1119. package/public/spice-console/lib/CollisionDetector.js +27 -27
  1120. package/public/spice-console/lib/DataLogger.js +197 -197
  1121. package/public/spice-console/lib/GenericObjectPool.js +152 -152
  1122. package/public/spice-console/lib/GlobalPool.js +114 -114
  1123. package/public/spice-console/lib/ImageUncompressor.js +138 -138
  1124. package/public/spice-console/lib/IntegrationBenchmark.js +64 -64
  1125. package/public/spice-console/lib/PacketWorkerIdentifier.js +107 -107
  1126. package/public/spice-console/lib/SyncAsyncHandler.js +46 -46
  1127. package/public/spice-console/lib/base64.js +298 -298
  1128. package/public/spice-console/lib/biginteger.js +1640 -1640
  1129. package/public/spice-console/lib/bowser.js +276 -276
  1130. package/public/spice-console/lib/decoder/dixie.js +7930 -7930
  1131. package/public/spice-console/lib/decoder/jmuxer.js +2815 -2815
  1132. package/public/spice-console/lib/displayRouter.js +83 -83
  1133. package/public/spice-console/lib/encrypt.js +191 -191
  1134. package/public/spice-console/lib/flipper.js +39 -39
  1135. package/public/spice-console/lib/graphic.js +1230 -1230
  1136. package/public/spice-console/lib/graphicdebug.js +223 -223
  1137. package/public/spice-console/lib/images/bitmap.js +203 -203
  1138. package/public/spice-console/lib/images/jsquic_family.js +83 -83
  1139. package/public/spice-console/lib/images/jsquic_rgba.js +342 -342
  1140. package/public/spice-console/lib/images/jsquic_uncompress.js +529 -529
  1141. package/public/spice-console/lib/images/lz.js +717 -717
  1142. package/public/spice-console/lib/images/png.js +275 -275
  1143. package/public/spice-console/lib/jgestures.min.js +43 -43
  1144. package/public/spice-console/lib/jquery-2.0.3.js +8829 -8829
  1145. package/public/spice-console/lib/jquery-mousewheel.js +83 -83
  1146. package/public/spice-console/lib/jquery-visibility.min.js +1 -1
  1147. package/public/spice-console/lib/jsbn.js +578 -578
  1148. package/public/spice-console/lib/jsbn2.js +675 -675
  1149. package/public/spice-console/lib/lodash.4.0.0.min.js +136 -136
  1150. package/public/spice-console/lib/modernizr.js +39 -39
  1151. package/public/spice-console/lib/pixastic.js +3244 -3244
  1152. package/public/spice-console/lib/prettyprint.js +794 -794
  1153. package/public/spice-console/lib/prng4.js +64 -64
  1154. package/public/spice-console/lib/queue.js +259 -259
  1155. package/public/spice-console/lib/rasterEngine.js +995 -995
  1156. package/public/spice-console/lib/rng.js +87 -87
  1157. package/public/spice-console/lib/runqueue.js +103 -103
  1158. package/public/spice-console/lib/sha1.js +124 -124
  1159. package/public/spice-console/lib/stuckkeyshandler.js +122 -122
  1160. package/public/spice-console/lib/timelapsedetector.js +62 -62
  1161. package/public/spice-console/lib/utils.js +327 -327
  1162. package/public/spice-console/lib/virtualjoystick.js +370 -370
  1163. package/public/spice-console/network/busconnection.js +195 -195
  1164. package/public/spice-console/network/clusternodechooser.js +49 -49
  1165. package/public/spice-console/network/connectioncontrol.js +60 -60
  1166. package/public/spice-console/network/packetcontroller.js +62 -62
  1167. package/public/spice-console/network/packetextractor.js +73 -73
  1168. package/public/spice-console/network/packetlinkfactory.js +64 -64
  1169. package/public/spice-console/network/packetreassembler.js +77 -77
  1170. package/public/spice-console/network/reassemblerfactory.js +39 -39
  1171. package/public/spice-console/network/sizedefiner.js +86 -86
  1172. package/public/spice-console/network/socket.js +120 -120
  1173. package/public/spice-console/network/socketqueue.js +95 -95
  1174. package/public/spice-console/network/spicechannel.js +383 -383
  1175. package/public/spice-console/network/websocketwrapper.js +75 -75
  1176. package/public/spice-console/process/busprocess.js +309 -309
  1177. package/public/spice-console/process/cursorprocess.js +111 -111
  1178. package/public/spice-console/process/displaypreprocess.js +152 -152
  1179. package/public/spice-console/process/displayprocess.js +210 -210
  1180. package/public/spice-console/process/inputprocess.js +203 -203
  1181. package/public/spice-console/process/mainprocess.js +78 -78
  1182. package/public/spice-console/process/playbackprocess.js +233 -233
  1183. package/public/spice-console/run.js +187 -187
  1184. package/public/spice-console/spiceobjects/generated/protocol.js +538 -538
  1185. package/public/spice-console/spiceobjects/spiceobjects.js +3488 -3488
  1186. package/public/spice-console/swcanvas/swcanvas.js +82 -82
  1187. package/public/spice-console/tools/generate.php +269 -269
  1188. package/public/spice-console/tools/generateKeyboardLayout.php +63 -63
  1189. package/public/spice-console/tools/generateSpiceObject.php +81 -81
  1190. package/store/main/actions.ts +8 -8
  1191. package/store/main/getters.ts +7 -7
  1192. package/store/main/lib/interfaces.ts +15 -15
  1193. package/store/main/mutations.ts +7 -7
  1194. package/store/main/state.ts +7 -7
  1195. package/store/main/store.ts +12 -12
  1196. package/store/storage/device/lib/models/interfaces.ts +26 -26
  1197. package/store/tasks/actions.ts +133 -133
  1198. package/store/tasks/getters.ts +25 -25
  1199. package/store/tasks/lib/models/interfaces.ts +18 -18
  1200. package/store/tasks/mappers/recentTasks.ts +64 -64
  1201. package/store/tasks/mappers/tasks.ts +44 -44
  1202. package/store/tasks/mutations.ts +58 -58
  1203. package/store/tasks/state.ts +16 -16
  1204. package/store/tasks/store.ts +12 -12
  1205. package/tsconfig.json +4 -4
  1206. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/form/lib/config/dateForm.ts +0 -114
  1207. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/timespan/form/Form.vue +0 -539
@@ -1,1696 +1,1696 @@
1
- <template>
2
- <div class="relative" style="display: flex">
3
- <div
4
- :id="outerWrapper"
5
- :class="[
6
- 'datagrid-outer-wrapper',
7
- {
8
- 'datagrid-outer-wrapper-opened-info': isShowHiddenInfo,
9
- },
10
- ]"
11
- >
12
- <div class="datagrid-inner-wrapper">
13
- <div
14
- v-if="props.isMainFilter"
15
- class="main-filter-content flex-justify-end"
16
- >
17
- <atoms-the-icon class="filter-icon" name="filter" />
18
- <input
19
- :id="`${props.testId}-main-filter-input`"
20
- v-model.trim="mainFilter"
21
- :data-id="`${props.testId}-main-filter-input`"
22
- :placeholder="props.mainFilterPlaceholder"
23
- type="text"
24
- @input="emits('main-filter', mainFilter)"
25
- />
26
- </div>
27
- <div
28
- :class="[
29
- 'datagrid',
30
- {
31
- 'datagrid-opened-info': isShowHiddenInfo,
32
- },
33
- ]"
34
- >
35
- <div :id="tableWrapperId" class="datagrid-table-wrapper">
36
- <div class="datagrid-table" :data-id="props.testId">
37
- <div class="datagrid-header">
38
- <div class="datagrid-row">
39
- <div class="datagrid-row-master datagrid-row-flex">
40
- <div
41
- v-if="props.type || $slots.toggleBlock"
42
- class="datagrid-row-sticky"
43
- >
44
- <div
45
- v-if="props.type"
46
- :id="expandableCaret"
47
- class="datagrid-column datagrid-expandable-caret datagrid-fixed-column flex-align-center flex-justify-center"
48
- >
49
- <template v-if="props.type === 'checkbox'">
50
- <div
51
- class="clr-checkbox-wrapper flex-align-center flex-justify-center w-100"
52
- >
53
- <input
54
- :id="`${props.testId}-${inputId}-all`"
55
- v-model="selectedAll"
56
- :data-id="`${props.testId}-filter-all`"
57
- type="checkbox"
58
- class="checkbox-btn"
59
- :value="-1"
60
- @change="changeAll"
61
- />
62
- <label
63
- :for="`${props.testId}-${inputId}-all`"
64
- class="clr-control-label"
65
- />
66
- </div>
67
- <div class="datagrid-column-separator"></div>
68
- </template>
69
- </div>
70
- <div
71
- v-if="$slots.toggleBlock"
72
- class="datagrid-toggle-block datagrid-column datagrid-fixed-width"
73
- >
74
- <div class="datagrid-column-flex">
75
- <div class="datagrid-column-separator">
76
- <span class="clr-sr-only" />
77
- <div class="datagrid-column-resize-tracker" />
78
- </div>
79
- </div>
80
- </div>
81
- </div>
82
- <div class="datagrid-row-scrollable">
83
- <div
84
- v-for="(item, key) in headItemsPresent"
85
- :key="key"
86
- :style="{
87
- width: columnsWidth[key][0],
88
- minWidth: columnsWidth[key][1],
89
- }"
90
- class="datagrid-column datagrid-fixed-width"
91
- >
92
- <div class="datagrid-column-flex">
93
- <button
94
- :id="`${props.testId}-sort-column-${key}`"
95
- :data-id="`${item.testId}-sort-column`"
96
- :class="[
97
- 'datagrid-column-title',
98
- {
99
- 'default text-decoration-none':
100
- !item.sortColumn,
101
- },
102
- ]"
103
- @click="sortTable(item.sortColumn)"
104
- >
105
- <slot :key="key" name="th" :item="item">
106
- <span
107
- :title="item.text"
108
- :style="{
109
- width:
110
- columnsWidth[key][0]?.slice(0, -2) -
111
- (item.hasFilter ? 65 : 40) +
112
- 'px',
113
- }"
114
- class="title-column"
115
- >
116
- {{ item.text }}
117
- </span>
118
- </slot>
119
- <span
120
- v-if="item.sortColumn"
121
- class="sort-arrow-wrap"
122
- >
123
- <atoms-the-icon
124
- v-show="sortInfo[0] === item.sortColumn"
125
- :class="['sort-arrow', { down: sortInfo[1] }]"
126
- name="sort-arrow"
127
- />
128
- </span>
129
- </button>
130
- <button
131
- v-if="item.hasFilter"
132
- :id="`${props.testId}-filter-icon-${key}`"
133
- :data-id="`${item.testId}-filter-icon`"
134
- class="datagrid-filter-toggle clr-anchor clr-smart-open-close"
135
- @click="filterShow[key] = !filterShow[key]"
136
- >
137
- <atoms-the-icon
138
- v-if="filterTerm[key]"
139
- class="filter-icon"
140
- name="filter-solid"
141
- style="fill: #0079b8"
142
- />
143
- <atoms-the-icon
144
- v-else
145
- class="filter-icon"
146
- name="filter"
147
- />
148
- </button>
149
- <atoms-popup-simple-popup
150
- v-model="filterShow[key]"
151
- :test-id="`${props.testId}-filter`"
152
- top="100%"
153
- :left="key === 0 ? '0' : ''"
154
- :right="key !== 0 ? '0' : ''"
155
- >
156
- <input
157
- :id="`${props.testId}-filter-input-${key}`"
158
- v-model="filterTerm[key]"
159
- :data-id="`${item.testId}-filter-input`"
160
- type="text"
161
- @input="filtering"
162
- />
163
- </atoms-popup-simple-popup>
164
- <div
165
- v-show="
166
- !isShowHiddenInfo ||
167
- (isShowHiddenInfo && key === 0)
168
- "
169
- :class="[
170
- 'datagrid-column-separator',
171
- {
172
- 'double-arrow-separator':
173
- key === 0 && props.withInfo,
174
- },
175
- ]"
176
- @mousedown="setGrab(key, $event)"
177
- >
178
- <button
179
- :id="`${props.testId}-resize-tracker-${key}`"
180
- class="datagrid-column-handle drag-handle draggable"
181
- />
182
- <span class="clr-sr-only" />
183
- <div class="datagrid-column-resize-tracker" />
184
- </div>
185
- </div>
186
- </div>
187
- </div>
188
- </div>
189
- </div>
190
- </div>
191
-
192
- <template v-if="bodyItemsPresent.length">
193
- <div
194
- v-for="(item, key) in bodyItemsPresent"
195
- :key="item.id"
196
- :class="[
197
- 'datagrid-body-row datagrid-row animation',
198
- {
199
- 'datagrid-selected active': checkIsSelectedRow(
200
- item[0].id
201
- ),
202
- 'datagrid-selected-info':
203
- props.withInfo &&
204
- isShowHiddenInfo &&
205
- checkIsSelectedRow(item[0].id),
206
- },
207
- ]"
208
- :[props.rowAttributeIdName]="item[0].dataId"
209
- >
210
- <div>
211
- <div
212
- :data-id="`${item[0].testId}-select-row`"
213
- class="datagrid-row-master datagrid-row-flex"
214
- @click.stop="selectRowById(item[0])"
215
- >
216
- <div
217
- v-if="props.type || $slots.toggleBlock"
218
- class="datagrid-row-sticky"
219
- @click.stop
220
- >
221
- <div
222
- :id="expandableCaret"
223
- :class="[
224
- 'datagrid-expandable-caret flex-justify-center datagrid-cell',
225
- {
226
- 'datagrid-fixed-column': !props.withInfo,
227
- 'datagrid-fixed-column-without-separator':
228
- props.withInfo,
229
- },
230
- ]"
231
- >
232
- <!--TODO refactoring (duplicate)-->
233
- <div
234
- v-if="$slots.toggleBlock && !props.type"
235
- class="datagrid-cell datagrid-fixed-width"
236
- >
237
- <div
238
- v-if="item[0]?.isShowToggleIcon ?? true"
239
- class="flex-align-center"
240
- >
241
- <button
242
- :id="`${props.testId}-toggle-icon-${key}`"
243
- :data-id="`${item[0].testId}-toggle-button`"
244
- class="datagrid-expandable-caret-button reset-btn"
245
- @click="toggle(key)"
246
- >
247
- <atoms-the-icon
248
- :class="[
249
- 'datagrid-expandable-caret-icon',
250
- { toggle: toggedItems[key] },
251
- ]"
252
- name="angle"
253
- />
254
- </button>
255
- </div>
256
- </div>
257
- <slot
258
- v-if="props.type"
259
- :key="key"
260
- name="type"
261
- :item="item"
262
- >
263
- <div
264
- :class="
265
- item[0]?.disabled && 'clr-form-control-disabled'
266
- "
267
- >
268
- <div
269
- :class="`clr-${props.type}-wrapper flex-justify-center flex-align-center`"
270
- >
271
- <input
272
- :id="`${props.testId}-${inputId}-${item[0].id}`"
273
- :key="item[0].id"
274
- v-model="selectedRowLocal"
275
- :data-id="`${item[0].testId}-row-selection-input`"
276
- :type="props.type"
277
- :class="`${props.type}-btn`"
278
- :value="item[0].id"
279
- :disabled="item[0]?.disabled || false"
280
- name="selected-store"
281
- @change="
282
- changeSelectedRow($event, item[0].id)
283
- "
284
- />
285
- <label
286
- :for="`${props.testId}-${inputId}-${item[0].id}`"
287
- class="clr-control-label"
288
- />
289
- </div>
290
- </div>
291
- </slot>
292
- </div>
293
- <!--TODO refactoring (duplicate)-->
294
- <div
295
- v-if="$slots.toggleBlock && props.type"
296
- class="datagrid-cell datagrid-fixed-width"
297
- >
298
- <div class="flex-align-center">
299
- <button
300
- :id="`${props.testId}-toggle-icon-${key}`"
301
- :data-id="`${item[0].testId}-toggle-row-button`"
302
- class="datagrid-expandable-caret-button reset-btn"
303
- @click="toggle(key)"
304
- >
305
- <atoms-the-icon
306
- :class="[
307
- 'datagrid-expandable-caret-icon',
308
- { toggle: toggedItems[key] },
309
- ]"
310
- name="angle"
311
- />
312
- </button>
313
- </div>
314
- </div>
315
- </div>
316
- <div class="datagrid-row-scrollable">
317
- <div class="datagrid-scrolling-cells">
318
- <div
319
- v-for="(item2, key2) in item"
320
- v-show="
321
- !isShowHiddenInfo ||
322
- item2.key === 'col1' ||
323
- item2.key === 'icon'
324
- "
325
- :key="key2"
326
- :style="{
327
- width: columnsWidth[key2][0],
328
- minWidth: columnsWidth[key2][1],
329
- }"
330
- :class="[
331
- 'datagrid-cell datagrid-fixed-width',
332
- {
333
- 'hidden-text-triangle':
334
- isShowHiddenInfo &&
335
- item2.data?.name === 'hidden-text-triangle',
336
- },
337
- ]"
338
- >
339
- <div
340
- :class="[
341
- 'flex-align-center h-100',
342
- {
343
- 'double-arrow-width':
344
- item2.data?.name === 'doubleArrows',
345
- },
346
- ]"
347
- >
348
- <div
349
- v-if="item2.data?.name === 'doubleArrows'"
350
- :id="`show-info-${item[0].data.id}`"
351
- :data-id="`${item[0].testId}-double-arrow`"
352
- :class="[
353
- 'double-arrow-wrap',
354
- {
355
- 'arrow-selected':
356
- isShowHiddenInfo &&
357
- item2.id === props.selectedRow,
358
- },
359
- ]"
360
- @click.prevent.stop="
361
- doubleArrowClick(item2, item)
362
- "
363
- >
364
- <atoms-the-icon
365
- v-if="item2.data?.name === 'doubleArrows'"
366
- name="doubleArrows"
367
- :class="[
368
- 'double-arrow',
369
- {
370
- 'arrow-selected':
371
- isShowHiddenInfo &&
372
- item2.id === props.selectedRow,
373
- },
374
- ]"
375
- />
376
- </div>
377
- <span
378
- v-if="item2.text && item2.data?.iconClassName"
379
- class="vertical-divider"
380
- />
381
- <slot :name="item2.key" :item="item2">
382
- <span class="text-ellipsis" :title="item2.text"
383
- >{{ item2.text }}
384
- </span>
385
- </slot>
386
- </div>
387
- </div>
388
- </div>
389
- <div
390
- v-show="toggedItems[key]"
391
- class="datagrid-row-flex datagrid-row-detail datagrid-container"
392
- >
393
- <slot name="toggleBlock" :item="item" />
394
- </div>
395
- </div>
396
- </div>
397
- </div>
398
- </div>
399
- </template>
400
- <template v-else>
401
- <div class="datagrid-placeholder-container">
402
- <div class="datagrid-placeholder datagrid-empty">
403
- <div class="datagrid-placeholder-image"></div>
404
-
405
- <span>No items found</span>
406
- </div>
407
- </div>
408
- </template>
409
- </div>
410
- </div>
411
- </div>
412
-
413
- <div
414
- v-if="!hideFooter"
415
- :class="[
416
- 'datagrid-footer',
417
- {
418
- 'datagrid-footer-opened-info': isShowHiddenInfo,
419
- },
420
- ]"
421
- >
422
- <div
423
- v-if="props.type === 'checkbox' && props.selectedRow?.length"
424
- class="clr-form-control-disabled"
425
- >
426
- <div class="clr-checkbox-wrapper">
427
- <input
428
- :id="`${props.testId}-check-all`"
429
- :data-id="`${props.testId}-check-all`"
430
- type="checkbox"
431
- checked
432
- />
433
- <label class="clr-control-label">
434
- {{ props.selectedRow?.length }}
435
- </label>
436
- </div>
437
- </div>
438
- <div class="datagrid-footer-description flex-align-center">
439
- <atoms-table-data-grid-column-switch
440
- v-if="columnKeysLocal"
441
- v-model:column-keys="columnKeysLocal"
442
- :test-id="`${props.testId}-footer-description`"
443
- class="switch-icon"
444
- />
445
-
446
- <template v-if="props.isShowExport && bodyItemsPresent.length">
447
- <common-select-button-dropdown
448
- v-if="props.selectedRow?.length"
449
- :heading="localization.common.export"
450
- :items="exportItems"
451
- :test-id="`${props.testId}-export-btn`"
452
- class="properties__actions"
453
- is-top
454
- @click="onExport"
455
- />
456
- <button
457
- v-else
458
- class="export-link dropdown-toggle btn btn-sm btn-link"
459
- @click="onExportAll"
460
- >
461
- {{ localization.common.export }}
462
- </button>
463
- </template>
464
-
465
- <div v-if="$slots.action" class="datagrid-footer__action">
466
- <slot name="action" />
467
- </div>
468
- </div>
469
-
470
- <atoms-table-data-grid-pagination
471
- :test-id="props.testId"
472
- :page-size="props.pageSize"
473
- :page="props.page"
474
- :options="mergeOptions"
475
- :total-items="props.totalItems"
476
- :total-pages="props.totalPages"
477
- :hide-pagination="props.hidePagination"
478
- :hide-page-size="props.hidePageSize"
479
- :show-page-info="props.showPageInfo"
480
- :page-items-count="props.bodyItems.length"
481
- :is-show-hidden-info="isShowHiddenInfo"
482
- @change-page-size="changePageSize"
483
- @change-page="changePage"
484
- />
485
- </div>
486
-
487
- <atoms-loader
488
- v-show="props.loading"
489
- class="datagrid-spinner"
490
- :test-id="`${props.testId}-spinner`"
491
- />
492
- </div>
493
- </div>
494
- <div
495
- v-if="isShowInfo"
496
- id="hidden-features"
497
- :class="[
498
- 'hidden-features',
499
- {
500
- 'show-hidden-info': isShowHiddenInfo,
501
- },
502
- ]"
503
- >
504
- <!-- <div class="header">-->
505
- <!-- <slot name="hiddenInfoHeader" :item="showedInfoCol" />-->
506
- <!-- <button-->
507
- <!-- :id="`${props.testId}-hidden-info-toggle-icon-${showedInfoRow?.key}-${showedInfoRow?.data.name}`"-->
508
- <!-- :data-id="`${props.testId}-hidden-info-toggle-icon`"-->
509
- <!-- class="signpost-action close"-->
510
- <!-- @click="isShowHiddenInfo = false"-->
511
- <!-- >-->
512
- <!-- <atoms-the-icon class="close-icon" name="close" />-->
513
- <!-- </button>-->
514
- <!-- </div>-->
515
- <!-- <slot name="hiddenInfoBody" />-->
516
- <button
517
- :id="`${props.testId}-hidden-info-toggle-icon-${showedInfoRow?.key}-${showedInfoRow?.data.name}`"
518
- :data-id="`${props.testId}-hidden-info-toggle-icon`"
519
- class="signpost-action close"
520
- @click="isShowHiddenInfo = false"
521
- >
522
- <atoms-the-icon class="close-icon" name="close" />
523
- </button>
524
- <slot name="hiddenInfo" :item="showedInfoCol" />
525
- </div>
526
- </div>
527
- </template>
528
-
529
- <script setup lang="ts">
530
- import type {
531
- UI_I_HTMLSelectElement,
532
- UI_I_Localization,
533
- } from '~/lib/models/interfaces'
534
- import type {
535
- UI_I_HeadItem,
536
- UI_I_BodyItem,
537
- UI_I_ColumnKey,
538
- } from '~/components/atoms/table/dataGrid/lib/models/interfaces'
539
- import type {
540
- UI_T_ColumnKeys,
541
- UI_T_DataGridType,
542
- UI_T_SelectedRow,
543
- } from '~/components/atoms/table/dataGrid/lib/models/types'
544
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
545
- import type { UI_I_DropdownButtonItem } from '~/components/common/select/button/lib/models/interfaces'
546
- import { itemsPerPage } from '~/components/atoms/table/dataGrid/lib/config/itemsPerPage'
547
- import { exportItemsFunc } from '~/components/atoms/table/dataGrid/lib/config/settingsTable'
548
- import { generateCsvAndDownload } from '~/components/atoms/table/dataGrid/lib/utils/export'
549
-
550
- const props = withDefaults(
551
- defineProps<{
552
- headItems: UI_I_HeadItem[]
553
- bodyItems: UI_I_BodyItem[][]
554
- pageSize: number
555
- page: number
556
- totalItems: number
557
- totalPages: number
558
- loading?: boolean
559
- columnKeys?: UI_I_ColumnKey[]
560
- selectedRow?: UI_T_SelectedRow
561
- type?: UI_T_DataGridType
562
- itemsPerPage?: UI_I_OptionItem[]
563
- offSelectByRow?: boolean
564
- hidePageSize?: boolean
565
- showPageInfo?: boolean
566
- serverOff?: boolean
567
- fillWidth?: boolean
568
- hideFooter?: boolean
569
- hidePagination?: boolean
570
- testId?: string
571
- withInfo?: boolean
572
- rowAttributeIdName?: string
573
- isMainFilter?: boolean
574
- mainFilterPlaceholder?: string
575
- isShowExport?: boolean
576
- }>(),
577
- {
578
- columnKeys: undefined,
579
- selectedRow: undefined,
580
- type: undefined,
581
- itemsPerPage: undefined,
582
- fillWidth: true,
583
- testId: 'ui-data-grid',
584
- withInfo: false,
585
- rowAttributeIdName: 'data-id',
586
- isShowExport: false,
587
- }
588
- )
589
-
590
- const emits = defineEmits<{
591
- (event: 'update:column-keys', value: UI_T_ColumnKeys): void
592
- (event: 'update:selected-row', value: UI_T_SelectedRow): void
593
- (event: 'update:page-size', value: number): void
594
- (event: 'update:page', value: number): void
595
- (event: 'main-filter', value: string): void
596
- (event: 'filtering', value: string[][]): void
597
- (event: 'sorting', value: [string, boolean]): void
598
- (event: 'change', value: any): void
599
- (event: 'row-detail', value: number): void
600
- }>()
601
-
602
- const localization = computed<UI_I_Localization>(() => useLocal())
603
-
604
- const mainFilter = ref<string>('')
605
-
606
- const mergeOptions = computed<UI_I_OptionItem[]>(
607
- () => props.itemsPerPage || itemsPerPage
608
- )
609
-
610
- const inputId = ref<string>(`radio-input-${useUniqueId()}`)
611
-
612
- const columnKeysLocal = computed<UI_T_ColumnKeys>({
613
- get() {
614
- return props.columnKeys
615
- },
616
- set(newValue) {
617
- emits('update:column-keys', newValue)
618
- },
619
- })
620
-
621
- const selectedAll = ref<boolean>(false)
622
- const changeAll = (e: UI_I_HTMLSelectElement): void => {
623
- const newSelectedRow: (number | string)[] = []
624
- if (e.target.checked) {
625
- bodyItemsPresent.value.forEach((row) => {
626
- if (row[0]?.disabled) return
627
-
628
- newSelectedRow.push(row[0].id)
629
- })
630
- }
631
-
632
- emits('update:selected-row', newSelectedRow)
633
- }
634
-
635
- const selectedRowLocal = ref<UI_T_SelectedRow>([])
636
- const isShowHiddenInfo = ref<boolean>(false)
637
- const tableWrapperId = `table-wrapper-${useUniqueId()}`
638
- let memoryWidth = '0'
639
-
640
- const showedInfoRow = ref<UI_I_BodyItem | null>(null)
641
- const showedInfoCol = ref<UI_I_BodyItem[] | null>(null)
642
-
643
- const isShowInfo = computed(
644
- () =>
645
- showedInfoRow.value &&
646
- showedInfoRow.value.id === props.selectedRow &&
647
- !showedInfoRow.value.data?.text &&
648
- isShowHiddenInfo.value
649
- )
650
-
651
- const setShowedInfoData = (
652
- item: UI_I_BodyItem | null,
653
- items: UI_I_BodyItem[] | null,
654
- reset: boolean = false
655
- ): void => {
656
- showedInfoRow.value = item
657
- showedInfoCol.value = items
658
-
659
- reset && (isShowHiddenInfo.value = false)
660
- item && selectRowById(item)
661
- reset && (isShowHiddenInfo.value = true)
662
- }
663
-
664
- const doubleArrowClick = (
665
- item: UI_I_BodyItem,
666
- items: UI_I_BodyItem[]
667
- ): void => {
668
- if (!isShowHiddenInfo.value) {
669
- setShowedInfoData(item, items)
670
- } else {
671
- if (showedInfoRow.value?.id !== item.id) {
672
- setShowedInfoData(item, items, true)
673
-
674
- return
675
- } else {
676
- setShowedInfoData(null, null)
677
- }
678
- }
679
-
680
- isShowHiddenInfo.value = !isShowHiddenInfo.value
681
- }
682
-
683
- watch(
684
- () => props.selectedRow,
685
- (newValue) => {
686
- if (newValue === undefined) return
687
-
688
- if (Array.isArray(newValue) && !newValue.length) selectedAll.value = false
689
-
690
- selectedRowLocal.value = newValue
691
- },
692
- { immediate: true }
693
- )
694
- const selectRowById = (item: UI_I_BodyItem): void => {
695
- const { id, disabled } = item
696
-
697
- if (props.offSelectByRow || isShowHiddenInfo.value || disabled) return
698
-
699
- if (props.type === 'checkbox' && Array.isArray(selectedRowLocal.value)) {
700
- const has = selectedRowLocal.value.includes(id)
701
- if (has) {
702
- selectedRowLocal.value = selectedRowLocal.value.filter(
703
- (rowId: string | number) => rowId !== id
704
- )
705
- } else {
706
- selectedRowLocal.value.push(id)
707
- }
708
-
709
- emits('change', selectedRowLocal.value)
710
- emits('update:selected-row', selectedRowLocal.value)
711
-
712
- changeSelectedAll(!has)
713
- return
714
- }
715
-
716
- emits('change', id)
717
- emits('update:selected-row', id)
718
- }
719
- const changeSelectedRow = (
720
- e: UI_I_HTMLSelectElement,
721
- id: number | string
722
- ): void => {
723
- if (props.type === 'checkbox' && Array.isArray(selectedRowLocal.value)) {
724
- const newSelectedRow = [...selectedRowLocal.value]
725
- emits('change', newSelectedRow)
726
- emits('update:selected-row', newSelectedRow)
727
-
728
- changeSelectedAll(e.target.checked)
729
- return
730
- }
731
-
732
- emits('change', id)
733
- emits('update:selected-row', id)
734
- }
735
- const changeSelectedAll = (checked: boolean): void => {
736
- if (props.type === 'checkbox' && Array.isArray(selectedRowLocal.value)) {
737
- const newSelectedRow = [...selectedRowLocal.value]
738
-
739
- if (!checked) {
740
- selectedAll.value = false
741
- } else if (newSelectedRow.length === bodyItemsPresent.value.length) {
742
- selectedAll.value = true
743
- }
744
- }
745
- }
746
-
747
- const checkIsSelectedRow = (id: number | string): boolean => {
748
- if (props.type === 'checkbox' && Array.isArray(props.selectedRow)) {
749
- return props.selectedRow.includes(id)
750
- }
751
- return props.selectedRow === id
752
- }
753
-
754
- // Sorting
755
- const sortInfo = ref<[string, boolean]>(['', true])
756
- const sortedColumnIndex = computed<number>(() => {
757
- let index = -1
758
- headItemsPresent.value.forEach((item, key) => {
759
- if (item.sortColumn === sortInfo.value[0]) index = key
760
- })
761
-
762
- return index
763
- })
764
- const sortTable = (sortName: string): void => {
765
- if (!sortName) return
766
-
767
- emits('update:selected-row', selectedRowLocal.value)
768
-
769
- if (sortInfo.value[0] === sortName) {
770
- sortInfo.value[1] = !sortInfo.value[1]
771
-
772
- emits('sorting', sortInfo.value)
773
- return
774
- }
775
- sortInfo.value[0] = sortName
776
- sortInfo.value[1] = true
777
-
778
- emits('sorting', sortInfo.value)
779
- }
780
-
781
- // Filtering
782
- const filterShow = ref<boolean[]>([])
783
- const filterTerm = ref<string[]>([])
784
- const filtering = (): void => {
785
- const filter: string[][] = []
786
- headItemsPresent.value.forEach((item, key) => {
787
- if (filterTerm.value[key]) filter.push([item.key, filterTerm.value[key]])
788
- })
789
-
790
- emits('filtering', filter)
791
- }
792
-
793
- // Pagination
794
- const changePageSize = (value: number): void => {
795
- emits('update:page-size', value)
796
- }
797
- const changePage = (value: number): void => {
798
- emits('update:selected-row', [])
799
- emits('update:page', value)
800
- }
801
-
802
- const headItemsPresent = computed<UI_I_HeadItem[]>(() => {
803
- if (!columnKeysLocal.value) {
804
- return props.headItems
805
- }
806
-
807
- return props.headItems.filter((item, key) => {
808
- return columnKeysLocal.value?.find(
809
- (item2, key2) => item2.key === item.key && key === key2
810
- )?.show
811
- })
812
- })
813
-
814
- const bodyItemsPresent = computed<UI_I_BodyItem[][]>(() => {
815
- let items: UI_I_BodyItem[][] = props.bodyItems
816
-
817
- // Filtering by column
818
- if (columnKeysLocal.value) {
819
- items = items.map((arr) => {
820
- arr = arr.filter((item, key) => {
821
- return columnKeysLocal.value?.find(
822
- (item2, key2) => item2.key === item.key && key === key2
823
- )?.show
824
- })
825
- return arr
826
- })
827
- }
828
-
829
- if (props.serverOff) {
830
- // Sorting
831
- if (sortInfo.value[0] !== '') {
832
- items = useDeepCopy(items).sort(
833
- (a: UI_I_BodyItem[], b: UI_I_BodyItem[]) => {
834
- let first = a[sortedColumnIndex.value].text.toString().toLowerCase()
835
- let second = b[sortedColumnIndex.value].text.toString().toLowerCase()
836
-
837
- const sortValueA = a[sortedColumnIndex.value]?.data?.sortValue
838
- const sortValueB = b[sortedColumnIndex.value]?.data?.sortValue
839
- if (sortValueA || sortValueA === 0) {
840
- first = sortValueA
841
- }
842
- if (sortValueB || sortValueB === 0) {
843
- second = sortValueB
844
- }
845
-
846
- if (sortInfo.value[1]) {
847
- return first > second ? 1 : first < second ? -1 : 0
848
- } else {
849
- return first < second ? 1 : first > second ? -1 : 0
850
- }
851
- }
852
- )
853
- }
854
- // Filtering
855
- const hasFilter = headItemsPresent.value.some(
856
- (_, key) => filterTerm.value[key]
857
- )
858
- if (hasFilter) {
859
- items = items.filter((row) => {
860
- // 0 - начальное значение
861
- // 1 - найден элемент
862
- // -1 - ненайден элемент
863
- let hasItem = 0
864
- headItemsPresent.value.forEach((item, key) => {
865
- if (!filterTerm.value[key]) return
866
- const term = filterTerm.value[key].toLowerCase()
867
-
868
- row.forEach((col) => {
869
- if (
870
- col.key === item.key &&
871
- typeof col.text === 'string' &&
872
- hasItem != -1
873
- ) {
874
- hasItem = col.text.toLowerCase().includes(term) ? 1 : -1
875
- }
876
- })
877
- })
878
-
879
- return hasItem === 1
880
- })
881
- }
882
- }
883
-
884
- return items
885
- })
886
-
887
- const toggedItems = ref<boolean[]>([])
888
-
889
- const toggle = (key: number): void => {
890
- toggedItems.value[key] = !toggedItems.value[key]
891
- if (!toggedItems.value[key]) return
892
- emits('row-detail', key)
893
- }
894
-
895
- const outerWrapper = `datagrid-outer-wrapper${useUniqueId()}`
896
- const expandableCaret = `datagrid-expandable-caret${useUniqueId()}`
897
-
898
- // Resize
899
- let helper = false
900
- let setColumnWidth = (): void => {
901
- if (!helper) {
902
- columnsWidth.value = []
903
- headItemsPresent.value.forEach((item) => {
904
- columnsWidth.value.push([
905
- item.width, // width
906
- item.width, // min-width
907
- ])
908
- })
909
-
910
- helper = true
911
- setTimeout(() => setColumnWidth(), 0)
912
- return
913
- }
914
- // Не продолжаем, чтобы ширина калонок была так как заданно в headItemsPresent
915
- if (!props.fillWidth) return
916
-
917
- // PC-672
918
- // const dataGridWidth = document.getElementById(outerWrapper)?.clientWidth || 0
919
- // const leftColumnWidth =
920
- // document.getElementById(expandableCaret)?.clientWidth || 0
921
- // const bordersWidth = 2
922
- // const columnWidth =
923
- // (dataGridWidth - leftColumnWidth - bordersWidth) /
924
- // headItemsPresent.value.length
925
-
926
- headItemsPresent.value.forEach((item) => {
927
- columnsWidth.value.push([
928
- // `${columnWidth}px`, // width
929
- item.width, // width
930
- item.width, // min-width
931
- ])
932
- })
933
- }
934
- setColumnWidth = useThrottle(setColumnWidth)
935
-
936
- const columnsWidth = ref<[string, string][]>([])
937
- watch(
938
- bodyItemsPresent,
939
- (newValue: UI_I_BodyItem[][]) => {
940
- newValue.forEach(() => {
941
- toggedItems.value.push(false)
942
- })
943
- setColumnWidth()
944
- },
945
- {
946
- immediate: true,
947
- deep: true,
948
- }
949
- )
950
-
951
- watch(
952
- headItemsPresent,
953
- (newValue: UI_I_HeadItem[]) => {
954
- filterShow.value = newValue.map(() => false)
955
- filterTerm.value = newValue.map(() => '')
956
- },
957
- {
958
- immediate: true,
959
- deep: true,
960
- }
961
- )
962
-
963
- const grabColumn = ref<number>(-1)
964
- const grabStartX = ref<number>(0)
965
- const setGrab = (key: number, e: MouseEvent): void => {
966
- if (props.withInfo && key === 0) return
967
-
968
- if (!isShowHiddenInfo.value) {
969
- grabColumn.value = key
970
- const currentWidth = parseInt(columnsWidth.value[grabColumn.value][0])
971
- grabStartX.value = e.clientX - currentWidth
972
- }
973
- }
974
-
975
- const isDrag = ref<boolean>(false)
976
-
977
- const mouseup = (): void => {
978
- if (grabColumn.value === -1) {
979
- return
980
- }
981
-
982
- grabColumn.value = -1
983
- isDrag.value = false
984
- }
985
-
986
- let resizeObserve: ResizeObserver
987
- let mousemove = (e: MouseEvent): void => {
988
- if (grabColumn.value === -1) return
989
-
990
- e.preventDefault()
991
- isDrag.value = true
992
- resizeObserve.disconnect()
993
-
994
- const minWidth = parseInt(columnsWidth.value[grabColumn.value][1])
995
- const changeX = Math.max(e.clientX - grabStartX.value, minWidth)
996
-
997
- columnsWidth.value[grabColumn.value] = [`${changeX}px`, `${minWidth}px`]
998
- }
999
- mousemove = useThrottle(mousemove)
1000
-
1001
- const setResizeObserve = (): void => {
1002
- const el = document.getElementById(outerWrapper)
1003
-
1004
- if (!el) {
1005
- setTimeout(setResizeObserve, 0)
1006
- return
1007
- }
1008
-
1009
- resizeObserve = new ResizeObserver(setColumnWidth)
1010
- resizeObserve.observe(el)
1011
- }
1012
-
1013
- let resizeObserveWithInfo: ResizeObserver
1014
-
1015
- const setColumnWidthWithInfo = (ent: ResizeObserverEntry[]): void => {
1016
- if (isShowHiddenInfo.value) {
1017
- memoryWidth = columnsWidth.value[1][0]
1018
- columnsWidth.value[1][0] = `${ent[0].contentBoxSize[0].inlineSize - 86}px`
1019
- } else {
1020
- columnsWidth.value[1][0] = memoryWidth
1021
- }
1022
- }
1023
-
1024
- const setResizeObserveWithInfo = (): void => {
1025
- const el = document.querySelector('.datagrid')
1026
-
1027
- if (!el) {
1028
- setTimeout(setResizeObserveWithInfo, 0)
1029
- return
1030
- }
1031
-
1032
- resizeObserveWithInfo = new ResizeObserver(setColumnWidthWithInfo)
1033
- resizeObserveWithInfo.observe(el)
1034
- }
1035
-
1036
- // Export
1037
- const exportItems = computed<UI_I_DropdownButtonItem[]>(
1038
- () => exportItemsFunc(
1039
- localization.value,
1040
- bodyItemsPresent.value.length || 0,
1041
- props.selectedRow?.length || 0
1042
- )
1043
- )
1044
- const onExport = (type: '0' | '1'): void => {
1045
- switch (type) {
1046
- case '0':
1047
- onExportAll()
1048
- break
1049
- case '1':
1050
- exportSelected()
1051
- }
1052
- }
1053
- const onExportAll = (): void => {
1054
- const rows = document.querySelectorAll(
1055
- `#${tableWrapperId} .datagrid-row-scrollable`
1056
- ) as NodeListOf<HTMLElement>
1057
- generateCsvAndDownload(Array.from(rows))
1058
- }
1059
- const exportSelected = (): void => {
1060
- const header = document.querySelectorAll(
1061
- `#${tableWrapperId} .datagrid-row-scrollable`
1062
- )[0] as HTMLElement
1063
- const rows = document.querySelectorAll(
1064
- `#${tableWrapperId} .datagrid-selected`
1065
- ) as NodeListOf<HTMLElement>
1066
- generateCsvAndDownload([header, ...Array.from(rows)])
1067
- }
1068
-
1069
- onMounted(() => {
1070
- window.addEventListener('mousemove', mousemove)
1071
- window.addEventListener('mouseup', mouseup)
1072
-
1073
- if (props.withInfo) {
1074
- setResizeObserveWithInfo()
1075
- }
1076
-
1077
- setResizeObserve()
1078
- })
1079
- onUnmounted(() => {
1080
- window.removeEventListener('mouseup', mouseup)
1081
- window.removeEventListener('mousemove', mousemove)
1082
- })
1083
- </script>
1084
-
1085
- <style scoped lang="scss">
1086
- @import '~/assets/scss/common/mixins';
1087
- .datagrid-outer-wrapper {
1088
- @include flex($dir: row);
1089
- //padding-top: 12px;
1090
- flex-grow: 1;
1091
- overflow: auto;
1092
-
1093
- &.datagrid-outer-wrapper-opened-info {
1094
- width: 35%;
1095
- min-width: 195px;
1096
- }
1097
-
1098
- & * {
1099
- box-sizing: border-box;
1100
- }
1101
-
1102
- & svg {
1103
- fill: var(--table-color);
1104
- }
1105
-
1106
- .datagrid-inner-wrapper {
1107
- @include flex($dir: column);
1108
- flex-grow: 1;
1109
- overflow: auto;
1110
-
1111
- .main-filter-content {
1112
- align-items: center;
1113
-
1114
- .filter-icon {
1115
- width: 16px;
1116
- height: 16px;
1117
- margin-right: 10px;
1118
- }
1119
- }
1120
- .datagrid {
1121
- overflow: auto;
1122
- flex: 1 1 auto;
1123
- border-radius: 0.125rem 0.125rem 0 0;
1124
- background-color: var(--block-view-bg-color);
1125
- border-color: var(--global-border-color);
1126
- margin-top: 0;
1127
-
1128
- &.datagrid-opened-info {
1129
- border-radius: 0.125rem 0 0 0;
1130
- overflow-x: hidden;
1131
- }
1132
-
1133
- .datagrid-table-wrapper {
1134
- min-width: max-content;
1135
- display: flex;
1136
- flex: 1 1 auto;
1137
- min-height: 100%;
1138
-
1139
- .datagrid-table {
1140
- @include flex($dir: column);
1141
- flex: 1 1 auto;
1142
- align-content: flex-start;
1143
- position: relative;
1144
-
1145
- .datagrid-header {
1146
- position: sticky;
1147
- top: 0;
1148
- z-index: 501;
1149
- width: auto;
1150
-
1151
- .datagrid-row-scrollable {
1152
- flex-direction: row;
1153
-
1154
- .datagrid-column-separator {
1155
- user-select: none;
1156
-
1157
- &::after {
1158
- cursor: col-resize;
1159
- }
1160
- &.double-arrow-separator .datagrid-column-handle {
1161
- cursor: unset;
1162
- }
1163
- &.double-arrow-separator::after {
1164
- cursor: unset;
1165
- }
1166
- }
1167
- }
1168
-
1169
- .datagrid-row {
1170
- color: var(--table-color);
1171
- background-color: var(--block-view-bg-color);
1172
-
1173
- &.datagrid-selected {
1174
- background-color: var(--row-selected-bg-color);
1175
- border-bottom: 1px solid var(--global-border-color);
1176
-
1177
- & :deep(*) {
1178
- color: var(--table-active-color);
1179
- }
1180
- }
1181
-
1182
- .datagrid-column {
1183
- background-color: var(--block-view-bg-color);
1184
- border-bottom: 1px solid var(--global-border-color);
1185
- padding: 6px 12px 5px;
1186
- position: relative;
1187
- //flex: 1 1 auto;
1188
-
1189
- &:last-child {
1190
- flex: 1 1 auto;
1191
- }
1192
-
1193
- &.datagrid-toggle-block {
1194
- width: 38px;
1195
- min-width: 38px;
1196
-
1197
- &::after {
1198
- content: '';
1199
- width: 0.05rem;
1200
- height: calc(100% - 0.5rem);
1201
- position: absolute;
1202
- right: 0;
1203
- top: 0.25rem;
1204
- background-color: var(--global-border-color);
1205
- }
1206
-
1207
- .datagrid-column-separator {
1208
- cursor: default;
1209
-
1210
- &::after {
1211
- cursor: default;
1212
- }
1213
- }
1214
- }
1215
- }
1216
-
1217
- .datagrid-column-title {
1218
- align-self: auto;
1219
- color: var(--table-color);
1220
- background-color: var(--block-view-bg-color);
1221
- border-bottom-color: var(--global-border-color);
1222
- font-size: 11px;
1223
- @include flex($align: center);
1224
- display: flex;
1225
- flex-direction: row;
1226
- justify-content: flex-start;
1227
- align-items: center;
1228
- //line-height: 24px;
1229
- line-height: normal;
1230
-
1231
- .title-column {
1232
- font-weight: bold;
1233
- font-size: 11px;
1234
- overflow: hidden;
1235
- text-wrap: none;
1236
- text-overflow: ellipsis;
1237
- }
1238
-
1239
- .sort-arrow-wrap {
1240
- margin-left: auto;
1241
- height: 14px;
1242
- width: 14px;
1243
- min-height: 14px;
1244
- min-width: 14px;
1245
- vertical-align: middle;
1246
-
1247
- .sort-arrow {
1248
- &.down {
1249
- transform: rotate(180deg);
1250
- }
1251
- }
1252
- }
1253
- .title-icon {
1254
- width: 24px;
1255
- height: 24px;
1256
- }
1257
- }
1258
-
1259
- .datagrid-filter-toggle {
1260
- background: unset;
1261
- margin-top: -4px;
1262
- align-self: center;
1263
-
1264
- .filter-icon {
1265
- width: 16px;
1266
- height: 16px;
1267
- }
1268
- }
1269
- }
1270
- }
1271
-
1272
- .datagrid-placeholder-container {
1273
- .datagrid-placeholder.datagrid-empty {
1274
- background: var(--block-view-bg-color);
1275
- }
1276
- span {
1277
- font-size: 16px;
1278
- color: var(--global-font-color4);
1279
- }
1280
- }
1281
-
1282
- .datagrid-row {
1283
- width: 100%;
1284
- min-width: max-content;
1285
- border-top: none;
1286
- color: var(--table-color);
1287
- background-color: var(--block-view-bg-color);
1288
- border-bottom: 1px solid var(--global-border-color);
1289
-
1290
- &.datagrid-selected {
1291
- & :deep(*) {
1292
- color: var(--table-active-color);
1293
- }
1294
-
1295
- .datagrid-cell {
1296
- background-color: var(--row-selected-bg-color);
1297
- border-bottom: 1px solid var(--global-border-color);
1298
- position: relative;
1299
- line-height: 1rem;
1300
- }
1301
-
1302
- .datagrid-row-detail {
1303
- background-color: var(--row-selected-bg-color);
1304
- border-bottom: 1px solid var(--global-border-color);
1305
- }
1306
- }
1307
-
1308
- .datagrid-cell {
1309
- min-width: 38px;
1310
- min-height: 28px;
1311
- padding: 2px 12px 3px 12px;
1312
- position: relative;
1313
-
1314
- &:has(.double-arrow-wrap) {
1315
- padding-left: 4px;
1316
- }
1317
-
1318
- &:has(.double-arrow-wrap)::after {
1319
- content: '';
1320
- width: 0.5px;
1321
- height: calc(100% - 6px);
1322
- position: absolute;
1323
- right: 2px;
1324
- top: 3px;
1325
- background-color: var(--global-border-color);
1326
- }
1327
-
1328
- &:last-child {
1329
- flex: 1 1 auto;
1330
- }
1331
-
1332
- button {
1333
- height: 0.9rem;
1334
- width: 0.9rem;
1335
-
1336
- .arrow-icon {
1337
- width: 16px;
1338
- height: 16px;
1339
- transform: rotate(90deg);
1340
- }
1341
- }
1342
-
1343
- .datagrid-cell-icon {
1344
- display: inline-block;
1345
- width: 16px;
1346
- height: 16px;
1347
- }
1348
-
1349
- .datagrid-expandable-caret-button {
1350
- cursor: pointer;
1351
- width: 100%;
1352
-
1353
- .datagrid-expandable-caret-icon {
1354
- width: 16px;
1355
- height: 16px;
1356
- transform: rotate(90deg);
1357
- fill: var(--table-caret-color);
1358
-
1359
- &.toggle {
1360
- transform: rotate(180deg);
1361
- }
1362
- }
1363
- }
1364
- }
1365
-
1366
- &.datagrid-selected-info {
1367
- width: 100%;
1368
- min-width: max-content;
1369
- border-top: none;
1370
- color: var(--table-color);
1371
- background-color: var(--block-view-bg-color);
1372
-
1373
- .datagrid-cell {
1374
- position: relative;
1375
-
1376
- &.hidden-text-triangle::after {
1377
- content: '';
1378
- position: absolute;
1379
- transform: rotate(225deg);
1380
- border-bottom: 15px solid transparent;
1381
- border-right: 15px solid var(--global-bg-color);
1382
- bottom: 26%;
1383
- right: -16px;
1384
- z-index: 1000;
1385
- }
1386
-
1387
- &.hidden-text-triangle::before {
1388
- content: '';
1389
- transform: rotate(-135deg);
1390
- position: absolute;
1391
- border-bottom: 16px solid transparent;
1392
- border-right: 16px solid var(--global-border-color);
1393
- bottom: 23%;
1394
- right: -17px;
1395
- z-index: 999;
1396
- }
1397
- }
1398
- }
1399
- }
1400
-
1401
- .datagrid-row-sticky {
1402
- @include flex($w: nowrap);
1403
- position: sticky;
1404
- left: 0;
1405
- z-index: 500;
1406
- background-color: var(--block-view-bg-color);
1407
-
1408
- .datagrid-column {
1409
- color: var(--table-color);
1410
- background-color: var(--block-view-bg-color);
1411
- border-bottom-color: var(--global-border-color);
1412
- text-align: left;
1413
- display: flex;
1414
- flex: 1 1 auto;
1415
- vertical-align: top;
1416
- border: none;
1417
-
1418
- &.datagrid-expandable-caret {
1419
- .datagrid-column-separator {
1420
- display: block;
1421
-
1422
- &::after {
1423
- top: 0;
1424
- height: 18px;
1425
- }
1426
- }
1427
-
1428
- .radio-btn {
1429
- width: 16px;
1430
- height: 16px;
1431
- }
1432
- }
1433
-
1434
- .datagrid-column-separator {
1435
- position: relative;
1436
- //left: 0.6rem;
1437
- flex: 0 0 auto;
1438
- width: 0.05rem;
1439
- order: 100;
1440
- margin-left: auto;
1441
- height: 100%;
1442
- }
1443
- }
1444
-
1445
- .datagrid-fixed-column-without-separator {
1446
- background-color: var(--block-view-bg-color);
1447
-
1448
- &::after {
1449
- background-color: transparent;
1450
- }
1451
- }
1452
-
1453
- .datagrid-fixed-column {
1454
- background-color: var(--block-view-bg-color);
1455
-
1456
- //&::after {
1457
- // content: '';
1458
- // width: 0.05rem;
1459
- // height: calc(100% - 0.5rem);
1460
- // position: absolute;
1461
- // right: 0;
1462
- // top: 0.25rem;
1463
- // background-color: var(--global-border-color);
1464
- //}
1465
-
1466
- .clr-form-control-disabled {
1467
- .clr-checkbox-wrapper {
1468
- label {
1469
- cursor: not-allowed;
1470
- }
1471
- }
1472
- }
1473
- }
1474
-
1475
- .datagrid-fixed-width {
1476
- &::after {
1477
- content: '';
1478
- width: 0.05rem;
1479
- height: calc(100% - 0.5rem);
1480
- position: absolute;
1481
- right: 0;
1482
- top: 0.25rem;
1483
- background-color: var(--global-border-color);
1484
- }
1485
- }
1486
- }
1487
-
1488
- .datagrid-row-scrollable {
1489
- @include flex($ff: row nowrap);
1490
- flex: 1 1 auto;
1491
-
1492
- .datagrid-scrolling-cells {
1493
- @include flex($ff: row nowrap);
1494
- flex: 1 1 auto;
1495
- }
1496
- }
1497
- .datagrid-body-row {
1498
- .datagrid-row-scrollable {
1499
- @include flex($ff: column nowrap);
1500
-
1501
- .datagrid-row-detail {
1502
- flex: 1;
1503
- }
1504
- }
1505
-
1506
- &:not(.datagrid-selected):hover {
1507
- border-bottom: 1px solid var(--table-hover-row-border-color);
1508
- background-color: var(--table-hover-row-background-color);
1509
- color: var(--table-hover-row-color);
1510
-
1511
- .datagrid-fixed-column {
1512
- background-color: var(--table-hover-row-background-color);
1513
- }
1514
- .datagrid-cell {
1515
- background-color: var(--table-hover-row-background-color);
1516
- }
1517
- }
1518
- }
1519
- }
1520
- }
1521
- }
1522
-
1523
- .datagrid-footer {
1524
- flex: 0 0 auto;
1525
- @include flex($ff: row nowrap, $just: space-between, $align: stretch);
1526
- font-size: 0.55rem;
1527
- background-color: var(--block-view-bg-color);
1528
- border: 0.05rem solid var(--global-border-color);
1529
- border-top: none;
1530
- border-radius: 0 0 0.15rem 0.15rem;
1531
- padding: 0 0.6rem;
1532
- height: 28px;
1533
-
1534
- &.datagrid-footer-opened-info {
1535
- border-radius: 0 0 0 0.15rem;
1536
- flex-direction: row-reverse;
1537
- }
1538
-
1539
- .clr-form-control-disabled {
1540
- opacity: 1;
1541
-
1542
- .clr-checkbox-wrapper {
1543
- label {
1544
- color: #8c8c8c;
1545
- margin-right: 9px;
1546
- padding-left: 22px;
1547
- &:before {
1548
- position: absolute;
1549
- top: 4px;
1550
- left: 0;
1551
- content: '';
1552
- display: inline-block;
1553
- height: 16px;
1554
- width: 16px;
1555
- border: none;
1556
- border-radius: 3px;
1557
- background-color: var(--table-checkbox-color);
1558
- }
1559
-
1560
- &:after {
1561
- position: absolute;
1562
- content: '';
1563
- display: inline-block;
1564
- height: 5px;
1565
- width: 8px;
1566
- border-left: 2px solid #fff;
1567
- border-bottom: 2px solid #fff;
1568
- top: 4px;
1569
- left: 4px;
1570
- transform: translateY(4px) rotate(-45deg);
1571
- }
1572
- }
1573
- }
1574
- }
1575
- }
1576
-
1577
- .datagrid-spinner {
1578
- top: 0.6rem;
1579
- height: calc(100% - 0.6rem);
1580
- }
1581
-
1582
- .datagrid-footer-description {
1583
- flex: 1 1 auto;
1584
-
1585
- :deep(svg) {
1586
- fill: var(--table-switch-color);
1587
- }
1588
- }
1589
-
1590
- .clr-radio-wrapper,
1591
- .clr-checkbox-wrapper {
1592
- height: 18px;
1593
- }
1594
-
1595
- .clr-radio-wrapper label,
1596
- .clr-checkbox-wrapper label {
1597
- padding-left: 16px;
1598
- }
1599
- }
1600
- }
1601
- //.vertical-divider {
1602
- // width: 1px;
1603
- // height: 22px;
1604
- // background: #bbb;
1605
- // margin: 2px 2px 0 -5px;
1606
- //}
1607
-
1608
- .hidden-features {
1609
- padding: 9px 14px;
1610
- background-color: var(--global-bg-color);
1611
- color: var(--global-font-color2);
1612
- border: 1px solid var(--global-border-color);
1613
- border-left: none;
1614
- overflow-y: auto;
1615
- overflow-x: hidden;
1616
- width: 65%;
1617
-
1618
- //.header {
1619
- // display: flex;
1620
- // align-items: center;
1621
- // justify-content: space-between;
1622
- // background-color: inherit;
1623
- //
1624
- // h3 {
1625
- // font-size: 1rem;
1626
- // color: var(--global-font-color2) !important;
1627
- // line-height: 1.7rem;
1628
- // }
1629
- button {
1630
- position: absolute;
1631
- top: 24px;
1632
- right: 24px;
1633
- line-height: 24px;
1634
-
1635
- .close-icon {
1636
- //margin-left: 10px;
1637
- width: 24px;
1638
- height: 24px;
1639
- }
1640
- }
1641
- //}
1642
- }
1643
- .double-arrow-width {
1644
- width: 25px;
1645
- }
1646
- .double-arrow-wrap {
1647
- width: 30px;
1648
- height: 20px;
1649
- padding-top: 1px;
1650
- padding-left: 5px;
1651
- cursor: pointer;
1652
- background-color: transparent;
1653
-
1654
- .double-arrow {
1655
- background-color: transparent;
1656
- transform: rotate(90deg);
1657
- width: 16px;
1658
- height: 16px;
1659
- }
1660
-
1661
- .double-arrow.arrow-selected {
1662
- transform: rotate(-90deg) !important;
1663
- background-color: #0079b8;
1664
- }
1665
- }
1666
- .double-arrow-wrap.arrow-selected {
1667
- background-color: #0079b8;
1668
- border-radius: 3px;
1669
- }
1670
- </style>
1671
-
1672
- <style>
1673
- :root {
1674
- --table-color: #565656;
1675
- --table-active-color: #fff;
1676
- --table-checkbox-color: #454545;
1677
- --table-caret-color: #454545;
1678
- --table-switch-color: #575757;
1679
- --table-hover-row-border-color: #666;
1680
- --table-hover-row-background-color: #e8e8e8;
1681
- --table-hover-row-color: #454545;
1682
- --table-spinner-bg-color: #ffffff99;
1683
- }
1684
-
1685
- :root.dark-theme {
1686
- --table-color: #fff;
1687
- --table-active-color: #565656;
1688
- --table-checkbox-color: #49aeda;
1689
- --table-caret-color: #ffffff;
1690
- --table-switch-color: #b3b3b3;
1691
- --table-hover-row-border-color: #fff;
1692
- --table-hover-row-background-color: #324f61;
1693
- --table-hover-row-color: #e9ecef;
1694
- --table-spinner-bg-color: rgba(0, 0, 0, 0.5);
1695
- }
1696
- </style>
1
+ <template>
2
+ <div class="relative" style="display: flex">
3
+ <div
4
+ :id="outerWrapper"
5
+ :class="[
6
+ 'datagrid-outer-wrapper',
7
+ {
8
+ 'datagrid-outer-wrapper-opened-info': isShowHiddenInfo,
9
+ },
10
+ ]"
11
+ >
12
+ <div class="datagrid-inner-wrapper">
13
+ <div
14
+ v-if="props.isMainFilter"
15
+ class="main-filter-content flex-justify-end"
16
+ >
17
+ <atoms-the-icon class="filter-icon" name="filter" />
18
+ <input
19
+ :id="`${props.testId}-main-filter-input`"
20
+ v-model.trim="mainFilter"
21
+ :data-id="`${props.testId}-main-filter-input`"
22
+ :placeholder="props.mainFilterPlaceholder"
23
+ type="text"
24
+ @input="emits('main-filter', mainFilter)"
25
+ />
26
+ </div>
27
+ <div
28
+ :class="[
29
+ 'datagrid',
30
+ {
31
+ 'datagrid-opened-info': isShowHiddenInfo,
32
+ },
33
+ ]"
34
+ >
35
+ <div :id="tableWrapperId" class="datagrid-table-wrapper">
36
+ <div class="datagrid-table" :data-id="props.testId">
37
+ <div class="datagrid-header">
38
+ <div class="datagrid-row">
39
+ <div class="datagrid-row-master datagrid-row-flex">
40
+ <div
41
+ v-if="props.type || $slots.toggleBlock"
42
+ class="datagrid-row-sticky"
43
+ >
44
+ <div
45
+ v-if="props.type"
46
+ :id="expandableCaret"
47
+ class="datagrid-column datagrid-expandable-caret datagrid-fixed-column flex-align-center flex-justify-center"
48
+ >
49
+ <template v-if="props.type === 'checkbox'">
50
+ <div
51
+ class="clr-checkbox-wrapper flex-align-center flex-justify-center w-100"
52
+ >
53
+ <input
54
+ :id="`${props.testId}-${inputId}-all`"
55
+ v-model="selectedAll"
56
+ :data-id="`${props.testId}-filter-all`"
57
+ type="checkbox"
58
+ class="checkbox-btn"
59
+ :value="-1"
60
+ @change="changeAll"
61
+ />
62
+ <label
63
+ :for="`${props.testId}-${inputId}-all`"
64
+ class="clr-control-label"
65
+ />
66
+ </div>
67
+ <div class="datagrid-column-separator"></div>
68
+ </template>
69
+ </div>
70
+ <div
71
+ v-if="$slots.toggleBlock"
72
+ class="datagrid-toggle-block datagrid-column datagrid-fixed-width"
73
+ >
74
+ <div class="datagrid-column-flex">
75
+ <div class="datagrid-column-separator">
76
+ <span class="clr-sr-only" />
77
+ <div class="datagrid-column-resize-tracker" />
78
+ </div>
79
+ </div>
80
+ </div>
81
+ </div>
82
+ <div class="datagrid-row-scrollable">
83
+ <div
84
+ v-for="(item, key) in headItemsPresent"
85
+ :key="key"
86
+ :style="{
87
+ width: columnsWidth[key][0],
88
+ minWidth: columnsWidth[key][1],
89
+ }"
90
+ class="datagrid-column datagrid-fixed-width"
91
+ >
92
+ <div class="datagrid-column-flex">
93
+ <button
94
+ :id="`${props.testId}-sort-column-${key}`"
95
+ :data-id="`${item.testId}-sort-column`"
96
+ :class="[
97
+ 'datagrid-column-title',
98
+ {
99
+ 'default text-decoration-none':
100
+ !item.sortColumn,
101
+ },
102
+ ]"
103
+ @click="sortTable(item.sortColumn)"
104
+ >
105
+ <slot :key="key" name="th" :item="item">
106
+ <span
107
+ :title="item.text"
108
+ :style="{
109
+ width:
110
+ columnsWidth[key][0]?.slice(0, -2) -
111
+ (item.hasFilter ? 65 : 40) +
112
+ 'px',
113
+ }"
114
+ class="title-column"
115
+ >
116
+ {{ item.text }}
117
+ </span>
118
+ </slot>
119
+ <span
120
+ v-if="item.sortColumn"
121
+ class="sort-arrow-wrap"
122
+ >
123
+ <atoms-the-icon
124
+ v-show="sortInfo[0] === item.sortColumn"
125
+ :class="['sort-arrow', { down: sortInfo[1] }]"
126
+ name="sort-arrow"
127
+ />
128
+ </span>
129
+ </button>
130
+ <button
131
+ v-if="item.hasFilter"
132
+ :id="`${props.testId}-filter-icon-${key}`"
133
+ :data-id="`${item.testId}-filter-icon`"
134
+ class="datagrid-filter-toggle clr-anchor clr-smart-open-close"
135
+ @click="filterShow[key] = !filterShow[key]"
136
+ >
137
+ <atoms-the-icon
138
+ v-if="filterTerm[key]"
139
+ class="filter-icon"
140
+ name="filter-solid"
141
+ style="fill: #0079b8"
142
+ />
143
+ <atoms-the-icon
144
+ v-else
145
+ class="filter-icon"
146
+ name="filter"
147
+ />
148
+ </button>
149
+ <atoms-popup-simple-popup
150
+ v-model="filterShow[key]"
151
+ :test-id="`${props.testId}-filter`"
152
+ top="100%"
153
+ :left="key === 0 ? '0' : ''"
154
+ :right="key !== 0 ? '0' : ''"
155
+ >
156
+ <input
157
+ :id="`${props.testId}-filter-input-${key}`"
158
+ v-model="filterTerm[key]"
159
+ :data-id="`${item.testId}-filter-input`"
160
+ type="text"
161
+ @input="filtering"
162
+ />
163
+ </atoms-popup-simple-popup>
164
+ <div
165
+ v-show="
166
+ !isShowHiddenInfo ||
167
+ (isShowHiddenInfo && key === 0)
168
+ "
169
+ :class="[
170
+ 'datagrid-column-separator',
171
+ {
172
+ 'double-arrow-separator':
173
+ key === 0 && props.withInfo,
174
+ },
175
+ ]"
176
+ @mousedown="setGrab(key, $event)"
177
+ >
178
+ <button
179
+ :id="`${props.testId}-resize-tracker-${key}`"
180
+ class="datagrid-column-handle drag-handle draggable"
181
+ />
182
+ <span class="clr-sr-only" />
183
+ <div class="datagrid-column-resize-tracker" />
184
+ </div>
185
+ </div>
186
+ </div>
187
+ </div>
188
+ </div>
189
+ </div>
190
+ </div>
191
+
192
+ <template v-if="bodyItemsPresent.length">
193
+ <div
194
+ v-for="(item, key) in bodyItemsPresent"
195
+ :key="item.id"
196
+ :class="[
197
+ 'datagrid-body-row datagrid-row animation',
198
+ {
199
+ 'datagrid-selected active': checkIsSelectedRow(
200
+ item[0].id
201
+ ),
202
+ 'datagrid-selected-info':
203
+ props.withInfo &&
204
+ isShowHiddenInfo &&
205
+ checkIsSelectedRow(item[0].id),
206
+ },
207
+ ]"
208
+ :[props.rowAttributeIdName]="item[0].dataId"
209
+ >
210
+ <div>
211
+ <div
212
+ :data-id="`${item[0].testId}-select-row`"
213
+ class="datagrid-row-master datagrid-row-flex"
214
+ @click.stop="selectRowById(item[0])"
215
+ >
216
+ <div
217
+ v-if="props.type || $slots.toggleBlock"
218
+ class="datagrid-row-sticky"
219
+ @click.stop
220
+ >
221
+ <div
222
+ :id="expandableCaret"
223
+ :class="[
224
+ 'datagrid-expandable-caret flex-justify-center datagrid-cell',
225
+ {
226
+ 'datagrid-fixed-column': !props.withInfo,
227
+ 'datagrid-fixed-column-without-separator':
228
+ props.withInfo,
229
+ },
230
+ ]"
231
+ >
232
+ <!--TODO refactoring (duplicate)-->
233
+ <div
234
+ v-if="$slots.toggleBlock && !props.type"
235
+ class="datagrid-cell datagrid-fixed-width"
236
+ >
237
+ <div
238
+ v-if="item[0]?.isShowToggleIcon ?? true"
239
+ class="flex-align-center"
240
+ >
241
+ <button
242
+ :id="`${props.testId}-toggle-icon-${key}`"
243
+ :data-id="`${item[0].testId}-toggle-button`"
244
+ class="datagrid-expandable-caret-button reset-btn"
245
+ @click="toggle(key)"
246
+ >
247
+ <atoms-the-icon
248
+ :class="[
249
+ 'datagrid-expandable-caret-icon',
250
+ { toggle: toggedItems[key] },
251
+ ]"
252
+ name="angle"
253
+ />
254
+ </button>
255
+ </div>
256
+ </div>
257
+ <slot
258
+ v-if="props.type"
259
+ :key="key"
260
+ name="type"
261
+ :item="item"
262
+ >
263
+ <div
264
+ :class="
265
+ item[0]?.disabled && 'clr-form-control-disabled'
266
+ "
267
+ >
268
+ <div
269
+ :class="`clr-${props.type}-wrapper flex-justify-center flex-align-center`"
270
+ >
271
+ <input
272
+ :id="`${props.testId}-${inputId}-${item[0].id}`"
273
+ :key="item[0].id"
274
+ v-model="selectedRowLocal"
275
+ :data-id="`${item[0].testId}-row-selection-input`"
276
+ :type="props.type"
277
+ :class="`${props.type}-btn`"
278
+ :value="item[0].id"
279
+ :disabled="item[0]?.disabled || false"
280
+ name="selected-store"
281
+ @change="
282
+ changeSelectedRow($event, item[0].id)
283
+ "
284
+ />
285
+ <label
286
+ :for="`${props.testId}-${inputId}-${item[0].id}`"
287
+ class="clr-control-label"
288
+ />
289
+ </div>
290
+ </div>
291
+ </slot>
292
+ </div>
293
+ <!--TODO refactoring (duplicate)-->
294
+ <div
295
+ v-if="$slots.toggleBlock && props.type"
296
+ class="datagrid-cell datagrid-fixed-width"
297
+ >
298
+ <div class="flex-align-center">
299
+ <button
300
+ :id="`${props.testId}-toggle-icon-${key}`"
301
+ :data-id="`${item[0].testId}-toggle-row-button`"
302
+ class="datagrid-expandable-caret-button reset-btn"
303
+ @click="toggle(key)"
304
+ >
305
+ <atoms-the-icon
306
+ :class="[
307
+ 'datagrid-expandable-caret-icon',
308
+ { toggle: toggedItems[key] },
309
+ ]"
310
+ name="angle"
311
+ />
312
+ </button>
313
+ </div>
314
+ </div>
315
+ </div>
316
+ <div class="datagrid-row-scrollable">
317
+ <div class="datagrid-scrolling-cells">
318
+ <div
319
+ v-for="(item2, key2) in item"
320
+ v-show="
321
+ !isShowHiddenInfo ||
322
+ item2.key === 'col1' ||
323
+ item2.key === 'icon'
324
+ "
325
+ :key="key2"
326
+ :style="{
327
+ width: columnsWidth[key2][0],
328
+ minWidth: columnsWidth[key2][1],
329
+ }"
330
+ :class="[
331
+ 'datagrid-cell datagrid-fixed-width',
332
+ {
333
+ 'hidden-text-triangle':
334
+ isShowHiddenInfo &&
335
+ item2.data?.name === 'hidden-text-triangle',
336
+ },
337
+ ]"
338
+ >
339
+ <div
340
+ :class="[
341
+ 'flex-align-center h-100',
342
+ {
343
+ 'double-arrow-width':
344
+ item2.data?.name === 'doubleArrows',
345
+ },
346
+ ]"
347
+ >
348
+ <div
349
+ v-if="item2.data?.name === 'doubleArrows'"
350
+ :id="`show-info-${item[0].data.id}`"
351
+ :data-id="`${item[0].testId}-double-arrow`"
352
+ :class="[
353
+ 'double-arrow-wrap',
354
+ {
355
+ 'arrow-selected':
356
+ isShowHiddenInfo &&
357
+ item2.id === props.selectedRow,
358
+ },
359
+ ]"
360
+ @click.prevent.stop="
361
+ doubleArrowClick(item2, item)
362
+ "
363
+ >
364
+ <atoms-the-icon
365
+ v-if="item2.data?.name === 'doubleArrows'"
366
+ name="doubleArrows"
367
+ :class="[
368
+ 'double-arrow',
369
+ {
370
+ 'arrow-selected':
371
+ isShowHiddenInfo &&
372
+ item2.id === props.selectedRow,
373
+ },
374
+ ]"
375
+ />
376
+ </div>
377
+ <span
378
+ v-if="item2.text && item2.data?.iconClassName"
379
+ class="vertical-divider"
380
+ />
381
+ <slot :name="item2.key" :item="item2">
382
+ <span class="text-ellipsis" :title="item2.text"
383
+ >{{ item2.text }}
384
+ </span>
385
+ </slot>
386
+ </div>
387
+ </div>
388
+ </div>
389
+ <div
390
+ v-show="toggedItems[key]"
391
+ class="datagrid-row-flex datagrid-row-detail datagrid-container"
392
+ >
393
+ <slot name="toggleBlock" :item="item" />
394
+ </div>
395
+ </div>
396
+ </div>
397
+ </div>
398
+ </div>
399
+ </template>
400
+ <template v-else>
401
+ <div class="datagrid-placeholder-container">
402
+ <div class="datagrid-placeholder datagrid-empty">
403
+ <div class="datagrid-placeholder-image"></div>
404
+
405
+ <span>No items found</span>
406
+ </div>
407
+ </div>
408
+ </template>
409
+ </div>
410
+ </div>
411
+ </div>
412
+
413
+ <div
414
+ v-if="!hideFooter"
415
+ :class="[
416
+ 'datagrid-footer',
417
+ {
418
+ 'datagrid-footer-opened-info': isShowHiddenInfo,
419
+ },
420
+ ]"
421
+ >
422
+ <div
423
+ v-if="props.type === 'checkbox' && props.selectedRow?.length"
424
+ class="clr-form-control-disabled"
425
+ >
426
+ <div class="clr-checkbox-wrapper">
427
+ <input
428
+ :id="`${props.testId}-check-all`"
429
+ :data-id="`${props.testId}-check-all`"
430
+ type="checkbox"
431
+ checked
432
+ />
433
+ <label class="clr-control-label">
434
+ {{ props.selectedRow?.length }}
435
+ </label>
436
+ </div>
437
+ </div>
438
+ <div class="datagrid-footer-description flex-align-center">
439
+ <atoms-table-data-grid-column-switch
440
+ v-if="columnKeysLocal"
441
+ v-model:column-keys="columnKeysLocal"
442
+ :test-id="`${props.testId}-footer-description`"
443
+ class="switch-icon"
444
+ />
445
+
446
+ <template v-if="props.isShowExport && bodyItemsPresent.length">
447
+ <common-select-button-dropdown
448
+ v-if="props.selectedRow?.length"
449
+ :heading="localization.common.export"
450
+ :items="exportItems"
451
+ :test-id="`${props.testId}-export-btn`"
452
+ class="properties__actions"
453
+ is-top
454
+ @click="onExport"
455
+ />
456
+ <button
457
+ v-else
458
+ class="export-link dropdown-toggle btn btn-sm btn-link"
459
+ @click="onExportAll"
460
+ >
461
+ {{ localization.common.export }}
462
+ </button>
463
+ </template>
464
+
465
+ <div v-if="$slots.action" class="datagrid-footer__action">
466
+ <slot name="action" />
467
+ </div>
468
+ </div>
469
+
470
+ <atoms-table-data-grid-pagination
471
+ :test-id="props.testId"
472
+ :page-size="props.pageSize"
473
+ :page="props.page"
474
+ :options="mergeOptions"
475
+ :total-items="props.totalItems"
476
+ :total-pages="props.totalPages"
477
+ :hide-pagination="props.hidePagination"
478
+ :hide-page-size="props.hidePageSize"
479
+ :show-page-info="props.showPageInfo"
480
+ :page-items-count="props.bodyItems.length"
481
+ :is-show-hidden-info="isShowHiddenInfo"
482
+ @change-page-size="changePageSize"
483
+ @change-page="changePage"
484
+ />
485
+ </div>
486
+
487
+ <atoms-loader
488
+ v-show="props.loading"
489
+ class="datagrid-spinner"
490
+ :test-id="`${props.testId}-spinner`"
491
+ />
492
+ </div>
493
+ </div>
494
+ <div
495
+ v-if="isShowInfo"
496
+ id="hidden-features"
497
+ :class="[
498
+ 'hidden-features',
499
+ {
500
+ 'show-hidden-info': isShowHiddenInfo,
501
+ },
502
+ ]"
503
+ >
504
+ <!-- <div class="header">-->
505
+ <!-- <slot name="hiddenInfoHeader" :item="showedInfoCol" />-->
506
+ <!-- <button-->
507
+ <!-- :id="`${props.testId}-hidden-info-toggle-icon-${showedInfoRow?.key}-${showedInfoRow?.data.name}`"-->
508
+ <!-- :data-id="`${props.testId}-hidden-info-toggle-icon`"-->
509
+ <!-- class="signpost-action close"-->
510
+ <!-- @click="isShowHiddenInfo = false"-->
511
+ <!-- >-->
512
+ <!-- <atoms-the-icon class="close-icon" name="close" />-->
513
+ <!-- </button>-->
514
+ <!-- </div>-->
515
+ <!-- <slot name="hiddenInfoBody" />-->
516
+ <button
517
+ :id="`${props.testId}-hidden-info-toggle-icon-${showedInfoRow?.key}-${showedInfoRow?.data.name}`"
518
+ :data-id="`${props.testId}-hidden-info-toggle-icon`"
519
+ class="signpost-action close"
520
+ @click="isShowHiddenInfo = false"
521
+ >
522
+ <atoms-the-icon class="close-icon" name="close" />
523
+ </button>
524
+ <slot name="hiddenInfo" :item="showedInfoCol" />
525
+ </div>
526
+ </div>
527
+ </template>
528
+
529
+ <script setup lang="ts">
530
+ import type {
531
+ UI_I_HTMLSelectElement,
532
+ UI_I_Localization,
533
+ } from '~/lib/models/interfaces'
534
+ import type {
535
+ UI_I_HeadItem,
536
+ UI_I_BodyItem,
537
+ UI_I_ColumnKey,
538
+ } from '~/components/atoms/table/dataGrid/lib/models/interfaces'
539
+ import type {
540
+ UI_T_ColumnKeys,
541
+ UI_T_DataGridType,
542
+ UI_T_SelectedRow,
543
+ } from '~/components/atoms/table/dataGrid/lib/models/types'
544
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
545
+ import type { UI_I_DropdownButtonItem } from '~/components/common/select/button/lib/models/interfaces'
546
+ import { itemsPerPage } from '~/components/atoms/table/dataGrid/lib/config/itemsPerPage'
547
+ import { exportItemsFunc } from '~/components/atoms/table/dataGrid/lib/config/settingsTable'
548
+ import { generateCsvAndDownload } from '~/components/atoms/table/dataGrid/lib/utils/export'
549
+
550
+ const props = withDefaults(
551
+ defineProps<{
552
+ headItems: UI_I_HeadItem[]
553
+ bodyItems: UI_I_BodyItem[][]
554
+ pageSize: number
555
+ page: number
556
+ totalItems: number
557
+ totalPages: number
558
+ loading?: boolean
559
+ columnKeys?: UI_I_ColumnKey[]
560
+ selectedRow?: UI_T_SelectedRow
561
+ type?: UI_T_DataGridType
562
+ itemsPerPage?: UI_I_OptionItem[]
563
+ offSelectByRow?: boolean
564
+ hidePageSize?: boolean
565
+ showPageInfo?: boolean
566
+ serverOff?: boolean
567
+ fillWidth?: boolean
568
+ hideFooter?: boolean
569
+ hidePagination?: boolean
570
+ testId?: string
571
+ withInfo?: boolean
572
+ rowAttributeIdName?: string
573
+ isMainFilter?: boolean
574
+ mainFilterPlaceholder?: string
575
+ isShowExport?: boolean
576
+ }>(),
577
+ {
578
+ columnKeys: undefined,
579
+ selectedRow: undefined,
580
+ type: undefined,
581
+ itemsPerPage: undefined,
582
+ fillWidth: true,
583
+ testId: 'ui-data-grid',
584
+ withInfo: false,
585
+ rowAttributeIdName: 'data-id',
586
+ isShowExport: false,
587
+ }
588
+ )
589
+
590
+ const emits = defineEmits<{
591
+ (event: 'update:column-keys', value: UI_T_ColumnKeys): void
592
+ (event: 'update:selected-row', value: UI_T_SelectedRow): void
593
+ (event: 'update:page-size', value: number): void
594
+ (event: 'update:page', value: number): void
595
+ (event: 'main-filter', value: string): void
596
+ (event: 'filtering', value: string[][]): void
597
+ (event: 'sorting', value: [string, boolean]): void
598
+ (event: 'change', value: any): void
599
+ (event: 'row-detail', value: number): void
600
+ }>()
601
+
602
+ const localization = computed<UI_I_Localization>(() => useLocal())
603
+
604
+ const mainFilter = ref<string>('')
605
+
606
+ const mergeOptions = computed<UI_I_OptionItem[]>(
607
+ () => props.itemsPerPage || itemsPerPage
608
+ )
609
+
610
+ const inputId = ref<string>(`radio-input-${useUniqueId()}`)
611
+
612
+ const columnKeysLocal = computed<UI_T_ColumnKeys>({
613
+ get() {
614
+ return props.columnKeys
615
+ },
616
+ set(newValue) {
617
+ emits('update:column-keys', newValue)
618
+ },
619
+ })
620
+
621
+ const selectedAll = ref<boolean>(false)
622
+ const changeAll = (e: UI_I_HTMLSelectElement): void => {
623
+ const newSelectedRow: (number | string)[] = []
624
+ if (e.target.checked) {
625
+ bodyItemsPresent.value.forEach((row) => {
626
+ if (row[0]?.disabled) return
627
+
628
+ newSelectedRow.push(row[0].id)
629
+ })
630
+ }
631
+
632
+ emits('update:selected-row', newSelectedRow)
633
+ }
634
+
635
+ const selectedRowLocal = ref<UI_T_SelectedRow>([])
636
+ const isShowHiddenInfo = ref<boolean>(false)
637
+ const tableWrapperId = `table-wrapper-${useUniqueId()}`
638
+ let memoryWidth = '0'
639
+
640
+ const showedInfoRow = ref<UI_I_BodyItem | null>(null)
641
+ const showedInfoCol = ref<UI_I_BodyItem[] | null>(null)
642
+
643
+ const isShowInfo = computed(
644
+ () =>
645
+ showedInfoRow.value &&
646
+ showedInfoRow.value.id === props.selectedRow &&
647
+ !showedInfoRow.value.data?.text &&
648
+ isShowHiddenInfo.value
649
+ )
650
+
651
+ const setShowedInfoData = (
652
+ item: UI_I_BodyItem | null,
653
+ items: UI_I_BodyItem[] | null,
654
+ reset: boolean = false
655
+ ): void => {
656
+ showedInfoRow.value = item
657
+ showedInfoCol.value = items
658
+
659
+ reset && (isShowHiddenInfo.value = false)
660
+ item && selectRowById(item)
661
+ reset && (isShowHiddenInfo.value = true)
662
+ }
663
+
664
+ const doubleArrowClick = (
665
+ item: UI_I_BodyItem,
666
+ items: UI_I_BodyItem[]
667
+ ): void => {
668
+ if (!isShowHiddenInfo.value) {
669
+ setShowedInfoData(item, items)
670
+ } else {
671
+ if (showedInfoRow.value?.id !== item.id) {
672
+ setShowedInfoData(item, items, true)
673
+
674
+ return
675
+ } else {
676
+ setShowedInfoData(null, null)
677
+ }
678
+ }
679
+
680
+ isShowHiddenInfo.value = !isShowHiddenInfo.value
681
+ }
682
+
683
+ watch(
684
+ () => props.selectedRow,
685
+ (newValue) => {
686
+ if (newValue === undefined) return
687
+
688
+ if (Array.isArray(newValue) && !newValue.length) selectedAll.value = false
689
+
690
+ selectedRowLocal.value = newValue
691
+ },
692
+ { immediate: true }
693
+ )
694
+ const selectRowById = (item: UI_I_BodyItem): void => {
695
+ const { id, disabled } = item
696
+
697
+ if (props.offSelectByRow || isShowHiddenInfo.value || disabled) return
698
+
699
+ if (props.type === 'checkbox' && Array.isArray(selectedRowLocal.value)) {
700
+ const has = selectedRowLocal.value.includes(id)
701
+ if (has) {
702
+ selectedRowLocal.value = selectedRowLocal.value.filter(
703
+ (rowId: string | number) => rowId !== id
704
+ )
705
+ } else {
706
+ selectedRowLocal.value.push(id)
707
+ }
708
+
709
+ emits('change', selectedRowLocal.value)
710
+ emits('update:selected-row', selectedRowLocal.value)
711
+
712
+ changeSelectedAll(!has)
713
+ return
714
+ }
715
+
716
+ emits('change', id)
717
+ emits('update:selected-row', id)
718
+ }
719
+ const changeSelectedRow = (
720
+ e: UI_I_HTMLSelectElement,
721
+ id: number | string
722
+ ): void => {
723
+ if (props.type === 'checkbox' && Array.isArray(selectedRowLocal.value)) {
724
+ const newSelectedRow = [...selectedRowLocal.value]
725
+ emits('change', newSelectedRow)
726
+ emits('update:selected-row', newSelectedRow)
727
+
728
+ changeSelectedAll(e.target.checked)
729
+ return
730
+ }
731
+
732
+ emits('change', id)
733
+ emits('update:selected-row', id)
734
+ }
735
+ const changeSelectedAll = (checked: boolean): void => {
736
+ if (props.type === 'checkbox' && Array.isArray(selectedRowLocal.value)) {
737
+ const newSelectedRow = [...selectedRowLocal.value]
738
+
739
+ if (!checked) {
740
+ selectedAll.value = false
741
+ } else if (newSelectedRow.length === bodyItemsPresent.value.length) {
742
+ selectedAll.value = true
743
+ }
744
+ }
745
+ }
746
+
747
+ const checkIsSelectedRow = (id: number | string): boolean => {
748
+ if (props.type === 'checkbox' && Array.isArray(props.selectedRow)) {
749
+ return props.selectedRow.includes(id)
750
+ }
751
+ return props.selectedRow === id
752
+ }
753
+
754
+ // Sorting
755
+ const sortInfo = ref<[string, boolean]>(['', true])
756
+ const sortedColumnIndex = computed<number>(() => {
757
+ let index = -1
758
+ headItemsPresent.value.forEach((item, key) => {
759
+ if (item.sortColumn === sortInfo.value[0]) index = key
760
+ })
761
+
762
+ return index
763
+ })
764
+ const sortTable = (sortName: string): void => {
765
+ if (!sortName) return
766
+
767
+ emits('update:selected-row', selectedRowLocal.value)
768
+
769
+ if (sortInfo.value[0] === sortName) {
770
+ sortInfo.value[1] = !sortInfo.value[1]
771
+
772
+ emits('sorting', sortInfo.value)
773
+ return
774
+ }
775
+ sortInfo.value[0] = sortName
776
+ sortInfo.value[1] = true
777
+
778
+ emits('sorting', sortInfo.value)
779
+ }
780
+
781
+ // Filtering
782
+ const filterShow = ref<boolean[]>([])
783
+ const filterTerm = ref<string[]>([])
784
+ const filtering = (): void => {
785
+ const filter: string[][] = []
786
+ headItemsPresent.value.forEach((item, key) => {
787
+ if (filterTerm.value[key]) filter.push([item.key, filterTerm.value[key]])
788
+ })
789
+
790
+ emits('filtering', filter)
791
+ }
792
+
793
+ // Pagination
794
+ const changePageSize = (value: number): void => {
795
+ emits('update:page-size', value)
796
+ }
797
+ const changePage = (value: number): void => {
798
+ emits('update:selected-row', [])
799
+ emits('update:page', value)
800
+ }
801
+
802
+ const headItemsPresent = computed<UI_I_HeadItem[]>(() => {
803
+ if (!columnKeysLocal.value) {
804
+ return props.headItems
805
+ }
806
+
807
+ return props.headItems.filter((item, key) => {
808
+ return columnKeysLocal.value?.find(
809
+ (item2, key2) => item2.key === item.key && key === key2
810
+ )?.show
811
+ })
812
+ })
813
+
814
+ const bodyItemsPresent = computed<UI_I_BodyItem[][]>(() => {
815
+ let items: UI_I_BodyItem[][] = props.bodyItems
816
+
817
+ // Filtering by column
818
+ if (columnKeysLocal.value) {
819
+ items = items.map((arr) => {
820
+ arr = arr.filter((item, key) => {
821
+ return columnKeysLocal.value?.find(
822
+ (item2, key2) => item2.key === item.key && key === key2
823
+ )?.show
824
+ })
825
+ return arr
826
+ })
827
+ }
828
+
829
+ if (props.serverOff) {
830
+ // Sorting
831
+ if (sortInfo.value[0] !== '') {
832
+ items = useDeepCopy(items).sort(
833
+ (a: UI_I_BodyItem[], b: UI_I_BodyItem[]) => {
834
+ let first = a[sortedColumnIndex.value].text.toString().toLowerCase()
835
+ let second = b[sortedColumnIndex.value].text.toString().toLowerCase()
836
+
837
+ const sortValueA = a[sortedColumnIndex.value]?.data?.sortValue
838
+ const sortValueB = b[sortedColumnIndex.value]?.data?.sortValue
839
+ if (sortValueA || sortValueA === 0) {
840
+ first = sortValueA
841
+ }
842
+ if (sortValueB || sortValueB === 0) {
843
+ second = sortValueB
844
+ }
845
+
846
+ if (sortInfo.value[1]) {
847
+ return first > second ? 1 : first < second ? -1 : 0
848
+ } else {
849
+ return first < second ? 1 : first > second ? -1 : 0
850
+ }
851
+ }
852
+ )
853
+ }
854
+ // Filtering
855
+ const hasFilter = headItemsPresent.value.some(
856
+ (_, key) => filterTerm.value[key]
857
+ )
858
+ if (hasFilter) {
859
+ items = items.filter((row) => {
860
+ // 0 - начальное значение
861
+ // 1 - найден элемент
862
+ // -1 - ненайден элемент
863
+ let hasItem = 0
864
+ headItemsPresent.value.forEach((item, key) => {
865
+ if (!filterTerm.value[key]) return
866
+ const term = filterTerm.value[key].toLowerCase()
867
+
868
+ row.forEach((col) => {
869
+ if (
870
+ col.key === item.key &&
871
+ typeof col.text === 'string' &&
872
+ hasItem != -1
873
+ ) {
874
+ hasItem = col.text.toLowerCase().includes(term) ? 1 : -1
875
+ }
876
+ })
877
+ })
878
+
879
+ return hasItem === 1
880
+ })
881
+ }
882
+ }
883
+
884
+ return items
885
+ })
886
+
887
+ const toggedItems = ref<boolean[]>([])
888
+
889
+ const toggle = (key: number): void => {
890
+ toggedItems.value[key] = !toggedItems.value[key]
891
+ if (!toggedItems.value[key]) return
892
+ emits('row-detail', key)
893
+ }
894
+
895
+ const outerWrapper = `datagrid-outer-wrapper${useUniqueId()}`
896
+ const expandableCaret = `datagrid-expandable-caret${useUniqueId()}`
897
+
898
+ // Resize
899
+ let helper = false
900
+ let setColumnWidth = (): void => {
901
+ if (!helper) {
902
+ columnsWidth.value = []
903
+ headItemsPresent.value.forEach((item) => {
904
+ columnsWidth.value.push([
905
+ item.width, // width
906
+ item.width, // min-width
907
+ ])
908
+ })
909
+
910
+ helper = true
911
+ setTimeout(() => setColumnWidth(), 0)
912
+ return
913
+ }
914
+ // Не продолжаем, чтобы ширина калонок была так как заданно в headItemsPresent
915
+ if (!props.fillWidth) return
916
+
917
+ // PC-672
918
+ // const dataGridWidth = document.getElementById(outerWrapper)?.clientWidth || 0
919
+ // const leftColumnWidth =
920
+ // document.getElementById(expandableCaret)?.clientWidth || 0
921
+ // const bordersWidth = 2
922
+ // const columnWidth =
923
+ // (dataGridWidth - leftColumnWidth - bordersWidth) /
924
+ // headItemsPresent.value.length
925
+
926
+ headItemsPresent.value.forEach((item) => {
927
+ columnsWidth.value.push([
928
+ // `${columnWidth}px`, // width
929
+ item.width, // width
930
+ item.width, // min-width
931
+ ])
932
+ })
933
+ }
934
+ setColumnWidth = useThrottle(setColumnWidth)
935
+
936
+ const columnsWidth = ref<[string, string][]>([])
937
+ watch(
938
+ bodyItemsPresent,
939
+ (newValue: UI_I_BodyItem[][]) => {
940
+ newValue.forEach(() => {
941
+ toggedItems.value.push(false)
942
+ })
943
+ setColumnWidth()
944
+ },
945
+ {
946
+ immediate: true,
947
+ deep: true,
948
+ }
949
+ )
950
+
951
+ watch(
952
+ headItemsPresent,
953
+ (newValue: UI_I_HeadItem[]) => {
954
+ filterShow.value = newValue.map(() => false)
955
+ filterTerm.value = newValue.map(() => '')
956
+ },
957
+ {
958
+ immediate: true,
959
+ deep: true,
960
+ }
961
+ )
962
+
963
+ const grabColumn = ref<number>(-1)
964
+ const grabStartX = ref<number>(0)
965
+ const setGrab = (key: number, e: MouseEvent): void => {
966
+ if (props.withInfo && key === 0) return
967
+
968
+ if (!isShowHiddenInfo.value) {
969
+ grabColumn.value = key
970
+ const currentWidth = parseInt(columnsWidth.value[grabColumn.value][0])
971
+ grabStartX.value = e.clientX - currentWidth
972
+ }
973
+ }
974
+
975
+ const isDrag = ref<boolean>(false)
976
+
977
+ const mouseup = (): void => {
978
+ if (grabColumn.value === -1) {
979
+ return
980
+ }
981
+
982
+ grabColumn.value = -1
983
+ isDrag.value = false
984
+ }
985
+
986
+ let resizeObserve: ResizeObserver
987
+ let mousemove = (e: MouseEvent): void => {
988
+ if (grabColumn.value === -1) return
989
+
990
+ e.preventDefault()
991
+ isDrag.value = true
992
+ resizeObserve.disconnect()
993
+
994
+ const minWidth = parseInt(columnsWidth.value[grabColumn.value][1])
995
+ const changeX = Math.max(e.clientX - grabStartX.value, minWidth)
996
+
997
+ columnsWidth.value[grabColumn.value] = [`${changeX}px`, `${minWidth}px`]
998
+ }
999
+ mousemove = useThrottle(mousemove)
1000
+
1001
+ const setResizeObserve = (): void => {
1002
+ const el = document.getElementById(outerWrapper)
1003
+
1004
+ if (!el) {
1005
+ setTimeout(setResizeObserve, 0)
1006
+ return
1007
+ }
1008
+
1009
+ resizeObserve = new ResizeObserver(setColumnWidth)
1010
+ resizeObserve.observe(el)
1011
+ }
1012
+
1013
+ let resizeObserveWithInfo: ResizeObserver
1014
+
1015
+ const setColumnWidthWithInfo = (ent: ResizeObserverEntry[]): void => {
1016
+ if (isShowHiddenInfo.value) {
1017
+ memoryWidth = columnsWidth.value[1][0]
1018
+ columnsWidth.value[1][0] = `${ent[0].contentBoxSize[0].inlineSize - 86}px`
1019
+ } else {
1020
+ columnsWidth.value[1][0] = memoryWidth
1021
+ }
1022
+ }
1023
+
1024
+ const setResizeObserveWithInfo = (): void => {
1025
+ const el = document.querySelector('.datagrid')
1026
+
1027
+ if (!el) {
1028
+ setTimeout(setResizeObserveWithInfo, 0)
1029
+ return
1030
+ }
1031
+
1032
+ resizeObserveWithInfo = new ResizeObserver(setColumnWidthWithInfo)
1033
+ resizeObserveWithInfo.observe(el)
1034
+ }
1035
+
1036
+ // Export
1037
+ const exportItems = computed<UI_I_DropdownButtonItem[]>(
1038
+ () => exportItemsFunc(
1039
+ localization.value,
1040
+ bodyItemsPresent.value.length || 0,
1041
+ props.selectedRow?.length || 0
1042
+ )
1043
+ )
1044
+ const onExport = (type: '0' | '1'): void => {
1045
+ switch (type) {
1046
+ case '0':
1047
+ onExportAll()
1048
+ break
1049
+ case '1':
1050
+ exportSelected()
1051
+ }
1052
+ }
1053
+ const onExportAll = (): void => {
1054
+ const rows = document.querySelectorAll(
1055
+ `#${tableWrapperId} .datagrid-row-scrollable`
1056
+ ) as NodeListOf<HTMLElement>
1057
+ generateCsvAndDownload(Array.from(rows))
1058
+ }
1059
+ const exportSelected = (): void => {
1060
+ const header = document.querySelectorAll(
1061
+ `#${tableWrapperId} .datagrid-row-scrollable`
1062
+ )[0] as HTMLElement
1063
+ const rows = document.querySelectorAll(
1064
+ `#${tableWrapperId} .datagrid-selected`
1065
+ ) as NodeListOf<HTMLElement>
1066
+ generateCsvAndDownload([header, ...Array.from(rows)])
1067
+ }
1068
+
1069
+ onMounted(() => {
1070
+ window.addEventListener('mousemove', mousemove)
1071
+ window.addEventListener('mouseup', mouseup)
1072
+
1073
+ if (props.withInfo) {
1074
+ setResizeObserveWithInfo()
1075
+ }
1076
+
1077
+ setResizeObserve()
1078
+ })
1079
+ onUnmounted(() => {
1080
+ window.removeEventListener('mouseup', mouseup)
1081
+ window.removeEventListener('mousemove', mousemove)
1082
+ })
1083
+ </script>
1084
+
1085
+ <style scoped lang="scss">
1086
+ @import '~/assets/scss/common/mixins';
1087
+ .datagrid-outer-wrapper {
1088
+ @include flex($dir: row);
1089
+ //padding-top: 12px;
1090
+ flex-grow: 1;
1091
+ overflow: auto;
1092
+
1093
+ &.datagrid-outer-wrapper-opened-info {
1094
+ width: 35%;
1095
+ min-width: 195px;
1096
+ }
1097
+
1098
+ & * {
1099
+ box-sizing: border-box;
1100
+ }
1101
+
1102
+ & svg {
1103
+ fill: var(--table-color);
1104
+ }
1105
+
1106
+ .datagrid-inner-wrapper {
1107
+ @include flex($dir: column);
1108
+ flex-grow: 1;
1109
+ overflow: auto;
1110
+
1111
+ .main-filter-content {
1112
+ align-items: center;
1113
+
1114
+ .filter-icon {
1115
+ width: 16px;
1116
+ height: 16px;
1117
+ margin-right: 10px;
1118
+ }
1119
+ }
1120
+ .datagrid {
1121
+ overflow: auto;
1122
+ flex: 1 1 auto;
1123
+ border-radius: 0.125rem 0.125rem 0 0;
1124
+ background-color: var(--block-view-bg-color);
1125
+ border-color: var(--global-border-color);
1126
+ margin-top: 0;
1127
+
1128
+ &.datagrid-opened-info {
1129
+ border-radius: 0.125rem 0 0 0;
1130
+ overflow-x: hidden;
1131
+ }
1132
+
1133
+ .datagrid-table-wrapper {
1134
+ min-width: max-content;
1135
+ display: flex;
1136
+ flex: 1 1 auto;
1137
+ min-height: 100%;
1138
+
1139
+ .datagrid-table {
1140
+ @include flex($dir: column);
1141
+ flex: 1 1 auto;
1142
+ align-content: flex-start;
1143
+ position: relative;
1144
+
1145
+ .datagrid-header {
1146
+ position: sticky;
1147
+ top: 0;
1148
+ z-index: 501;
1149
+ width: auto;
1150
+
1151
+ .datagrid-row-scrollable {
1152
+ flex-direction: row;
1153
+
1154
+ .datagrid-column-separator {
1155
+ user-select: none;
1156
+
1157
+ &::after {
1158
+ cursor: col-resize;
1159
+ }
1160
+ &.double-arrow-separator .datagrid-column-handle {
1161
+ cursor: unset;
1162
+ }
1163
+ &.double-arrow-separator::after {
1164
+ cursor: unset;
1165
+ }
1166
+ }
1167
+ }
1168
+
1169
+ .datagrid-row {
1170
+ color: var(--table-color);
1171
+ background-color: var(--block-view-bg-color);
1172
+
1173
+ &.datagrid-selected {
1174
+ background-color: var(--row-selected-bg-color);
1175
+ border-bottom: 1px solid var(--global-border-color);
1176
+
1177
+ & :deep(*) {
1178
+ color: var(--table-active-color);
1179
+ }
1180
+ }
1181
+
1182
+ .datagrid-column {
1183
+ background-color: var(--block-view-bg-color);
1184
+ border-bottom: 1px solid var(--global-border-color);
1185
+ padding: 6px 12px 5px;
1186
+ position: relative;
1187
+ //flex: 1 1 auto;
1188
+
1189
+ &:last-child {
1190
+ flex: 1 1 auto;
1191
+ }
1192
+
1193
+ &.datagrid-toggle-block {
1194
+ width: 38px;
1195
+ min-width: 38px;
1196
+
1197
+ &::after {
1198
+ content: '';
1199
+ width: 0.05rem;
1200
+ height: calc(100% - 0.5rem);
1201
+ position: absolute;
1202
+ right: 0;
1203
+ top: 0.25rem;
1204
+ background-color: var(--global-border-color);
1205
+ }
1206
+
1207
+ .datagrid-column-separator {
1208
+ cursor: default;
1209
+
1210
+ &::after {
1211
+ cursor: default;
1212
+ }
1213
+ }
1214
+ }
1215
+ }
1216
+
1217
+ .datagrid-column-title {
1218
+ align-self: auto;
1219
+ color: var(--table-color);
1220
+ background-color: var(--block-view-bg-color);
1221
+ border-bottom-color: var(--global-border-color);
1222
+ font-size: 11px;
1223
+ @include flex($align: center);
1224
+ display: flex;
1225
+ flex-direction: row;
1226
+ justify-content: flex-start;
1227
+ align-items: center;
1228
+ //line-height: 24px;
1229
+ line-height: normal;
1230
+
1231
+ .title-column {
1232
+ font-weight: bold;
1233
+ font-size: 11px;
1234
+ overflow: hidden;
1235
+ text-wrap: none;
1236
+ text-overflow: ellipsis;
1237
+ }
1238
+
1239
+ .sort-arrow-wrap {
1240
+ margin-left: auto;
1241
+ height: 14px;
1242
+ width: 14px;
1243
+ min-height: 14px;
1244
+ min-width: 14px;
1245
+ vertical-align: middle;
1246
+
1247
+ .sort-arrow {
1248
+ &.down {
1249
+ transform: rotate(180deg);
1250
+ }
1251
+ }
1252
+ }
1253
+ .title-icon {
1254
+ width: 24px;
1255
+ height: 24px;
1256
+ }
1257
+ }
1258
+
1259
+ .datagrid-filter-toggle {
1260
+ background: unset;
1261
+ margin-top: -4px;
1262
+ align-self: center;
1263
+
1264
+ .filter-icon {
1265
+ width: 16px;
1266
+ height: 16px;
1267
+ }
1268
+ }
1269
+ }
1270
+ }
1271
+
1272
+ .datagrid-placeholder-container {
1273
+ .datagrid-placeholder.datagrid-empty {
1274
+ background: var(--block-view-bg-color);
1275
+ }
1276
+ span {
1277
+ font-size: 16px;
1278
+ color: var(--global-font-color4);
1279
+ }
1280
+ }
1281
+
1282
+ .datagrid-row {
1283
+ width: 100%;
1284
+ min-width: max-content;
1285
+ border-top: none;
1286
+ color: var(--table-color);
1287
+ background-color: var(--block-view-bg-color);
1288
+ border-bottom: 1px solid var(--global-border-color);
1289
+
1290
+ &.datagrid-selected {
1291
+ & :deep(*) {
1292
+ color: var(--table-active-color);
1293
+ }
1294
+
1295
+ .datagrid-cell {
1296
+ background-color: var(--row-selected-bg-color);
1297
+ border-bottom: 1px solid var(--global-border-color);
1298
+ position: relative;
1299
+ line-height: 1rem;
1300
+ }
1301
+
1302
+ .datagrid-row-detail {
1303
+ background-color: var(--row-selected-bg-color);
1304
+ border-bottom: 1px solid var(--global-border-color);
1305
+ }
1306
+ }
1307
+
1308
+ .datagrid-cell {
1309
+ min-width: 38px;
1310
+ min-height: 28px;
1311
+ padding: 2px 12px 3px 12px;
1312
+ position: relative;
1313
+
1314
+ &:has(.double-arrow-wrap) {
1315
+ padding-left: 4px;
1316
+ }
1317
+
1318
+ &:has(.double-arrow-wrap)::after {
1319
+ content: '';
1320
+ width: 0.5px;
1321
+ height: calc(100% - 6px);
1322
+ position: absolute;
1323
+ right: 2px;
1324
+ top: 3px;
1325
+ background-color: var(--global-border-color);
1326
+ }
1327
+
1328
+ &:last-child {
1329
+ flex: 1 1 auto;
1330
+ }
1331
+
1332
+ button {
1333
+ height: 0.9rem;
1334
+ width: 0.9rem;
1335
+
1336
+ .arrow-icon {
1337
+ width: 16px;
1338
+ height: 16px;
1339
+ transform: rotate(90deg);
1340
+ }
1341
+ }
1342
+
1343
+ .datagrid-cell-icon {
1344
+ display: inline-block;
1345
+ width: 16px;
1346
+ height: 16px;
1347
+ }
1348
+
1349
+ .datagrid-expandable-caret-button {
1350
+ cursor: pointer;
1351
+ width: 100%;
1352
+
1353
+ .datagrid-expandable-caret-icon {
1354
+ width: 16px;
1355
+ height: 16px;
1356
+ transform: rotate(90deg);
1357
+ fill: var(--table-caret-color);
1358
+
1359
+ &.toggle {
1360
+ transform: rotate(180deg);
1361
+ }
1362
+ }
1363
+ }
1364
+ }
1365
+
1366
+ &.datagrid-selected-info {
1367
+ width: 100%;
1368
+ min-width: max-content;
1369
+ border-top: none;
1370
+ color: var(--table-color);
1371
+ background-color: var(--block-view-bg-color);
1372
+
1373
+ .datagrid-cell {
1374
+ position: relative;
1375
+
1376
+ &.hidden-text-triangle::after {
1377
+ content: '';
1378
+ position: absolute;
1379
+ transform: rotate(225deg);
1380
+ border-bottom: 15px solid transparent;
1381
+ border-right: 15px solid var(--global-bg-color);
1382
+ bottom: 26%;
1383
+ right: -16px;
1384
+ z-index: 1000;
1385
+ }
1386
+
1387
+ &.hidden-text-triangle::before {
1388
+ content: '';
1389
+ transform: rotate(-135deg);
1390
+ position: absolute;
1391
+ border-bottom: 16px solid transparent;
1392
+ border-right: 16px solid var(--global-border-color);
1393
+ bottom: 23%;
1394
+ right: -17px;
1395
+ z-index: 999;
1396
+ }
1397
+ }
1398
+ }
1399
+ }
1400
+
1401
+ .datagrid-row-sticky {
1402
+ @include flex($w: nowrap);
1403
+ position: sticky;
1404
+ left: 0;
1405
+ z-index: 500;
1406
+ background-color: var(--block-view-bg-color);
1407
+
1408
+ .datagrid-column {
1409
+ color: var(--table-color);
1410
+ background-color: var(--block-view-bg-color);
1411
+ border-bottom-color: var(--global-border-color);
1412
+ text-align: left;
1413
+ display: flex;
1414
+ flex: 1 1 auto;
1415
+ vertical-align: top;
1416
+ border: none;
1417
+
1418
+ &.datagrid-expandable-caret {
1419
+ .datagrid-column-separator {
1420
+ display: block;
1421
+
1422
+ &::after {
1423
+ top: 0;
1424
+ height: 18px;
1425
+ }
1426
+ }
1427
+
1428
+ .radio-btn {
1429
+ width: 16px;
1430
+ height: 16px;
1431
+ }
1432
+ }
1433
+
1434
+ .datagrid-column-separator {
1435
+ position: relative;
1436
+ //left: 0.6rem;
1437
+ flex: 0 0 auto;
1438
+ width: 0.05rem;
1439
+ order: 100;
1440
+ margin-left: auto;
1441
+ height: 100%;
1442
+ }
1443
+ }
1444
+
1445
+ .datagrid-fixed-column-without-separator {
1446
+ background-color: var(--block-view-bg-color);
1447
+
1448
+ &::after {
1449
+ background-color: transparent;
1450
+ }
1451
+ }
1452
+
1453
+ .datagrid-fixed-column {
1454
+ background-color: var(--block-view-bg-color);
1455
+
1456
+ //&::after {
1457
+ // content: '';
1458
+ // width: 0.05rem;
1459
+ // height: calc(100% - 0.5rem);
1460
+ // position: absolute;
1461
+ // right: 0;
1462
+ // top: 0.25rem;
1463
+ // background-color: var(--global-border-color);
1464
+ //}
1465
+
1466
+ .clr-form-control-disabled {
1467
+ .clr-checkbox-wrapper {
1468
+ label {
1469
+ cursor: not-allowed;
1470
+ }
1471
+ }
1472
+ }
1473
+ }
1474
+
1475
+ .datagrid-fixed-width {
1476
+ &::after {
1477
+ content: '';
1478
+ width: 0.05rem;
1479
+ height: calc(100% - 0.5rem);
1480
+ position: absolute;
1481
+ right: 0;
1482
+ top: 0.25rem;
1483
+ background-color: var(--global-border-color);
1484
+ }
1485
+ }
1486
+ }
1487
+
1488
+ .datagrid-row-scrollable {
1489
+ @include flex($ff: row nowrap);
1490
+ flex: 1 1 auto;
1491
+
1492
+ .datagrid-scrolling-cells {
1493
+ @include flex($ff: row nowrap);
1494
+ flex: 1 1 auto;
1495
+ }
1496
+ }
1497
+ .datagrid-body-row {
1498
+ .datagrid-row-scrollable {
1499
+ @include flex($ff: column nowrap);
1500
+
1501
+ .datagrid-row-detail {
1502
+ flex: 1;
1503
+ }
1504
+ }
1505
+
1506
+ &:not(.datagrid-selected):hover {
1507
+ border-bottom: 1px solid var(--table-hover-row-border-color);
1508
+ background-color: var(--table-hover-row-background-color);
1509
+ color: var(--table-hover-row-color);
1510
+
1511
+ .datagrid-fixed-column {
1512
+ background-color: var(--table-hover-row-background-color);
1513
+ }
1514
+ .datagrid-cell {
1515
+ background-color: var(--table-hover-row-background-color);
1516
+ }
1517
+ }
1518
+ }
1519
+ }
1520
+ }
1521
+ }
1522
+
1523
+ .datagrid-footer {
1524
+ flex: 0 0 auto;
1525
+ @include flex($ff: row nowrap, $just: space-between, $align: stretch);
1526
+ font-size: 0.55rem;
1527
+ background-color: var(--block-view-bg-color);
1528
+ border: 0.05rem solid var(--global-border-color);
1529
+ border-top: none;
1530
+ border-radius: 0 0 0.15rem 0.15rem;
1531
+ padding: 0 0.6rem;
1532
+ height: 28px;
1533
+
1534
+ &.datagrid-footer-opened-info {
1535
+ border-radius: 0 0 0 0.15rem;
1536
+ flex-direction: row-reverse;
1537
+ }
1538
+
1539
+ .clr-form-control-disabled {
1540
+ opacity: 1;
1541
+
1542
+ .clr-checkbox-wrapper {
1543
+ label {
1544
+ color: #8c8c8c;
1545
+ margin-right: 9px;
1546
+ padding-left: 22px;
1547
+ &:before {
1548
+ position: absolute;
1549
+ top: 4px;
1550
+ left: 0;
1551
+ content: '';
1552
+ display: inline-block;
1553
+ height: 16px;
1554
+ width: 16px;
1555
+ border: none;
1556
+ border-radius: 3px;
1557
+ background-color: var(--table-checkbox-color);
1558
+ }
1559
+
1560
+ &:after {
1561
+ position: absolute;
1562
+ content: '';
1563
+ display: inline-block;
1564
+ height: 5px;
1565
+ width: 8px;
1566
+ border-left: 2px solid #fff;
1567
+ border-bottom: 2px solid #fff;
1568
+ top: 4px;
1569
+ left: 4px;
1570
+ transform: translateY(4px) rotate(-45deg);
1571
+ }
1572
+ }
1573
+ }
1574
+ }
1575
+ }
1576
+
1577
+ .datagrid-spinner {
1578
+ top: 0.6rem;
1579
+ height: calc(100% - 0.6rem);
1580
+ }
1581
+
1582
+ .datagrid-footer-description {
1583
+ flex: 1 1 auto;
1584
+
1585
+ :deep(svg) {
1586
+ fill: var(--table-switch-color);
1587
+ }
1588
+ }
1589
+
1590
+ .clr-radio-wrapper,
1591
+ .clr-checkbox-wrapper {
1592
+ height: 18px;
1593
+ }
1594
+
1595
+ .clr-radio-wrapper label,
1596
+ .clr-checkbox-wrapper label {
1597
+ padding-left: 16px;
1598
+ }
1599
+ }
1600
+ }
1601
+ //.vertical-divider {
1602
+ // width: 1px;
1603
+ // height: 22px;
1604
+ // background: #bbb;
1605
+ // margin: 2px 2px 0 -5px;
1606
+ //}
1607
+
1608
+ .hidden-features {
1609
+ padding: 9px 14px;
1610
+ background-color: var(--global-bg-color);
1611
+ color: var(--global-font-color2);
1612
+ border: 1px solid var(--global-border-color);
1613
+ border-left: none;
1614
+ overflow-y: auto;
1615
+ overflow-x: hidden;
1616
+ width: 65%;
1617
+
1618
+ //.header {
1619
+ // display: flex;
1620
+ // align-items: center;
1621
+ // justify-content: space-between;
1622
+ // background-color: inherit;
1623
+ //
1624
+ // h3 {
1625
+ // font-size: 1rem;
1626
+ // color: var(--global-font-color2) !important;
1627
+ // line-height: 1.7rem;
1628
+ // }
1629
+ button {
1630
+ position: absolute;
1631
+ top: 24px;
1632
+ right: 24px;
1633
+ line-height: 24px;
1634
+
1635
+ .close-icon {
1636
+ //margin-left: 10px;
1637
+ width: 24px;
1638
+ height: 24px;
1639
+ }
1640
+ }
1641
+ //}
1642
+ }
1643
+ .double-arrow-width {
1644
+ width: 25px;
1645
+ }
1646
+ .double-arrow-wrap {
1647
+ width: 30px;
1648
+ height: 20px;
1649
+ padding-top: 1px;
1650
+ padding-left: 5px;
1651
+ cursor: pointer;
1652
+ background-color: transparent;
1653
+
1654
+ .double-arrow {
1655
+ background-color: transparent;
1656
+ transform: rotate(90deg);
1657
+ width: 16px;
1658
+ height: 16px;
1659
+ }
1660
+
1661
+ .double-arrow.arrow-selected {
1662
+ transform: rotate(-90deg) !important;
1663
+ background-color: #0079b8;
1664
+ }
1665
+ }
1666
+ .double-arrow-wrap.arrow-selected {
1667
+ background-color: #0079b8;
1668
+ border-radius: 3px;
1669
+ }
1670
+ </style>
1671
+
1672
+ <style>
1673
+ :root {
1674
+ --table-color: #565656;
1675
+ --table-active-color: #fff;
1676
+ --table-checkbox-color: #454545;
1677
+ --table-caret-color: #454545;
1678
+ --table-switch-color: #575757;
1679
+ --table-hover-row-border-color: #666;
1680
+ --table-hover-row-background-color: #e8e8e8;
1681
+ --table-hover-row-color: #454545;
1682
+ --table-spinner-bg-color: #ffffff99;
1683
+ }
1684
+
1685
+ :root.dark-theme {
1686
+ --table-color: #fff;
1687
+ --table-active-color: #565656;
1688
+ --table-checkbox-color: #49aeda;
1689
+ --table-caret-color: #ffffff;
1690
+ --table-switch-color: #b3b3b3;
1691
+ --table-hover-row-border-color: #fff;
1692
+ --table-hover-row-background-color: #324f61;
1693
+ --table-hover-row-color: #e9ecef;
1694
+ --table-spinner-bg-color: rgba(0, 0, 0, 0.5);
1695
+ }
1696
+ </style>