bfg-common 1.5.419 → 1.5.421

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