bfg-common 1.5.429 → 1.5.431
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.
- package/.eslintrc.js +21 -21
- package/.idea/inspectionProfiles/Project_Default.xml +51 -51
- package/.idea/modules.xml +7 -7
- package/.idea/prettier.xml +5 -5
- package/.idea/uikit.iml +11 -11
- package/.idea/vcs.xml +5 -5
- package/.prettierrc +4 -4
- package/CODE_STYLE.md +109 -109
- package/PROJECT_STRUCTURE.md +130 -130
- package/README.md +42 -42
- package/assets/img/icons/icon-hcs.svg +3 -3
- package/assets/img/icons/icon-life-m-dark.svg +3 -3
- package/assets/img/icons/icon-life-m-light.svg +3 -3
- package/assets/img/icons/icon-ro-dark.svg +1 -1
- package/assets/img/icons/icon-ro-light.svg +2 -2
- package/assets/img/icons/icons-sprite-dark-1.svg +456 -456
- package/assets/img/icons/icons-sprite-dark-2.svg +347 -347
- package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
- package/assets/img/icons/icons-sprite-dark-4.svg +264 -264
- package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
- package/assets/img/icons/icons-sprite-dark-6.svg +114 -114
- package/assets/img/icons/icons-sprite-light-1.svg +456 -456
- package/assets/img/icons/icons-sprite-light-2.svg +347 -347
- package/assets/img/icons/icons-sprite-light-3.svg +227 -227
- package/assets/img/icons/icons-sprite-light-4.svg +264 -264
- package/assets/img/icons/icons-sprite-light-5.svg +488 -488
- package/assets/img/icons/icons-sprite-light-6.svg +114 -114
- package/assets/img/icons/info.svg +8 -8
- package/assets/img/icons/vc.svg +52 -52
- package/assets/img/logo copy.svg +50 -50
- package/assets/img/logo.svg +51 -51
- package/assets/localization/local_be.json +3519 -3519
- package/assets/localization/local_en.json +3523 -3523
- package/assets/localization/local_hy.json +3523 -3523
- package/assets/localization/local_kk.json +3522 -3522
- package/assets/localization/local_ru.json +3522 -3522
- package/assets/localization/local_zh.json +3520 -3520
- package/assets/scss/clarity/clr-ui.min.css +8 -8
- package/assets/scss/clarity/local_ar.json +2924 -2924
- package/assets/scss/common/animations.scss +28 -28
- package/assets/scss/common/global.scss +193 -193
- package/assets/scss/common/icons/icons-1.scss +280 -280
- package/assets/scss/common/icons/icons-2.scss +264 -264
- package/assets/scss/common/icons/icons-3.scss +250 -250
- package/assets/scss/common/icons/icons-4.scss +279 -279
- package/assets/scss/common/icons/icons-5.scss +449 -449
- package/assets/scss/common/icons/icons-6.scss +174 -174
- package/assets/scss/common/icons/icons.scss +16 -16
- package/assets/scss/common/icons/lib-icons.scss +32 -32
- package/assets/scss/common/mixins.scss +39 -39
- package/assets/scss/common/normalize.scss +348 -348
- package/assets/scss/common/theme.scss +812 -812
- package/assets/scss/common/utilities.scss +20 -20
- package/assets/scss/common/variables.scss +44 -44
- package/assets/scss/components/auth.scss +201 -201
- package/assets/scss/main.scss +15 -15
- package/components/atoms/DiagramIcon.vue +400 -400
- package/components/atoms/TheIcon.vue +3338 -3338
- package/components/atoms/TheIcon2.vue +1368 -1368
- package/components/atoms/TheIcon3.vue +50 -50
- package/components/atoms/TheIconOld.vue +2444 -2444
- package/components/atoms/alert/Alert.vue +87 -87
- package/components/atoms/alert/Notification.vue +169 -169
- package/components/atoms/alert/lib/Alert.spec.ts +38 -38
- package/components/atoms/alert/lib/Notification.spec.ts +34 -34
- package/components/atoms/alert/lib/models/enums.ts +12 -12
- package/components/atoms/alert/lib/models/interfaces.ts +27 -27
- package/components/atoms/alert/lib/models/types.ts +11 -11
- package/components/atoms/autocomplete/Autocomplete.vue +361 -361
- package/components/atoms/collapse/CollapseNav.vue +170 -170
- package/components/atoms/collapse/CollapseNavItem.vue +218 -218
- package/components/atoms/collapse/lib/models/interfaces.ts +14 -14
- package/components/atoms/comboDropdownMenu/ComboDropdownMenu.vue +357 -357
- package/components/atoms/comboDropdownMenu/lib/models/interfaces.ts +26 -26
- package/components/atoms/combobox/Combobox.vue +162 -162
- package/components/atoms/datepicker/Datepicker.vue +639 -639
- package/components/atoms/datepicker/lib/config/allShortMonths.ts +103 -103
- package/components/atoms/datepicker/lib/config/datepicker.ts +46 -46
- package/components/atoms/datepicker/lib/models/interfaces.ts +9 -9
- package/components/atoms/dropdown/Portlet.vue +105 -105
- package/components/atoms/dropdown/dropdown/Dropdown.vue +168 -168
- package/components/atoms/dropdown/dropdown/lib/models/interfaces.ts +9 -9
- package/components/atoms/dropdown/lib/Portlet.spec.ts +26 -26
- package/components/atoms/dropdown/tree/Tree.vue +137 -137
- package/components/atoms/dropdown/tree/lib/models/interfaces.ts +11 -11
- package/components/atoms/input/Search.vue +16 -16
- package/components/atoms/lib/models/interfaces.ts +14 -14
- package/components/atoms/list/SelectList.vue +63 -63
- package/components/atoms/list/SimpleList.vue +29 -29
- package/components/atoms/list/dragDropList/DragDropList.vue +149 -149
- package/components/atoms/list/dragDropList/lib/config/events.ts +4 -4
- package/components/atoms/loader/BarLoader.vue +27 -27
- package/components/atoms/loader/Loader.vue +30 -30
- package/components/atoms/loader/PreLoader.vue +38 -38
- package/components/atoms/loader/lib/Preloader.spec.ts +24 -24
- package/components/atoms/modal/Modal.vue +247 -247
- package/components/atoms/modal/bySteps/BySteps.vue +255 -255
- package/components/atoms/modal/bySteps/lib/BySteps.spec.ts +66 -66
- package/components/atoms/modal/byStepsSecond/ByStepsSecond.vue +175 -175
- package/components/atoms/modal/lib/Modal.spec.ts +55 -55
- package/components/atoms/nav/NavBar.vue +164 -164
- package/components/atoms/nav/VerticalNavBar.vue +79 -79
- package/components/atoms/nav/lib/NavBar.spec.ts +34 -34
- package/components/atoms/nav/lib/models/interfaces.ts +6 -6
- package/components/atoms/notificationBar/NotificationBar.vue +178 -178
- package/components/atoms/notificationBar/lib/models/enums.ts +13 -13
- package/components/atoms/notificationBar/lib/models/interfaces.ts +6 -6
- package/components/atoms/notificationBar/lib/models/types.ts +1 -1
- package/components/atoms/perPage/PerPage.vue +58 -58
- package/components/atoms/popover/Popover.vue +58 -58
- package/components/atoms/popover/lib/models/interfaces.ts +4 -4
- package/components/atoms/popup/SimplePopup.vue +86 -86
- package/components/atoms/select/TheSelect.vue +187 -187
- package/components/atoms/select/lib/models/interfaces.ts +5 -5
- package/components/atoms/stack/StackBlock.vue +190 -190
- package/components/atoms/stack/StackContent.vue +63 -63
- package/components/atoms/step/VerticalStep.vue +105 -105
- package/components/atoms/step/lib/VerticalStep.spec.ts +68 -68
- package/components/atoms/step/lib/models/verticalStepItem.ts +5 -5
- package/components/atoms/switch/Switch.vue +97 -97
- package/components/atoms/table/compact/Compact.vue +508 -508
- package/components/atoms/table/compact/lib/models/interfaces.ts +10 -10
- package/components/atoms/table/dataGrid/DataGrid.vue +1694 -1694
- package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +277 -277
- package/components/atoms/table/dataGrid/DataGridPage.vue +195 -195
- package/components/atoms/table/dataGrid/DataGridPagination.vue +92 -92
- package/components/atoms/table/dataGrid/lib/DataGrid.spec.ts +61 -61
- package/components/atoms/table/dataGrid/lib/config/itemsPerPage.ts +20 -20
- package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
- package/components/atoms/table/dataGrid/lib/models/interfaces.ts +41 -41
- package/components/atoms/table/dataGrid/lib/models/types.ts +5 -5
- package/components/atoms/table/dataGrid/lib/utils/constructDataTable.ts +36 -36
- package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
- package/components/atoms/table/info/Info.vue +71 -71
- package/components/atoms/table/info/lib/models/interfaces.ts +11 -11
- package/components/atoms/table/simpleEvent/SimpleEvent.vue +89 -89
- package/components/atoms/table/simpleEvent/lib/models/interfaces.ts +9 -9
- package/components/atoms/table/simpleInfo/SimpleInfo.vue +78 -78
- package/components/atoms/table/simpleInfo/lib/models/interfaces.ts +5 -5
- package/components/atoms/table/simpleTable/SimpleTable.vue +288 -288
- package/components/atoms/table/simpleTable/lib/models/interfaces.ts +12 -12
- package/components/atoms/tabs/Tabs.vue +220 -220
- package/components/atoms/tabs/VerticalTabs.vue +95 -95
- package/components/atoms/tabs/lib/models/interfaces.ts +7 -7
- package/components/atoms/tabs/lib/models/types.ts +1 -1
- package/components/atoms/tooltip/Signpost.vue +215 -215
- package/components/atoms/tooltip/Text.vue +37 -37
- package/components/atoms/tooltip/Tooltip.vue +57 -57
- package/components/atoms/tooltip/TooltipError.vue +119 -119
- package/components/atoms/tooltip/lib/models/interfaces.ts +4 -4
- package/components/atoms/wizard/Wizard.vue +342 -342
- package/components/atoms/wizard/step/Step.vue +95 -95
- package/components/common/BadBrowser.vue +118 -118
- package/components/common/accordion/Accordion.vue +177 -177
- package/components/common/accordion/Recursion.vue +225 -225
- package/components/common/accordion/lib/models/enums.ts +5 -5
- package/components/common/accordion/lib/models/interfaces.ts +18 -18
- package/components/common/accordion/lib/models/types.ts +1 -1
- package/components/common/accordion/lib/utils/accordion.ts +31 -31
- package/components/common/adapterManager/AdapterManager.vue +829 -829
- package/components/common/adapterManager/AddAdapterModal.vue +561 -561
- package/components/common/adapterManager/AddAdapterWarningModal.vue +82 -82
- package/components/common/adapterManager/NoActiveAdaptersModal.vue +61 -61
- package/components/common/adapterManager/NoConnectedActiveAdaptersModal.vue +61 -61
- package/components/common/adapterManager/lib/config/index.ts +19 -19
- package/components/common/adapterManager/ui/NoSelectedAdapter.vue +38 -38
- package/components/common/adapterManager/ui/SecondTitle.vue +36 -36
- package/components/common/adapterManager/ui/actions/ActionsBar.vue +95 -95
- package/components/common/adapterManager/ui/actions/AddAdapterButton.vue +34 -34
- package/components/common/adapterManager/ui/actions/MoveDownAdapterButton.vue +39 -39
- package/components/common/adapterManager/ui/actions/MoveUpAdapterButton.vue +39 -39
- package/components/common/adapterManager/ui/actions/RemoveAdapterButton.vue +41 -41
- package/components/common/adapterManager/ui/actions/VerticalSeparator.vue +10 -10
- package/components/common/adapterManager/ui/table/Adapters.vue +92 -92
- package/components/common/adapterManager/ui/table/Header.vue +96 -96
- package/components/common/adapterManager/ui/table/Table.vue +162 -162
- package/components/common/adapterManager/ui/table/lib/models/types.ts +1 -1
- package/components/common/backup/storage/actions/add/Add.vue +248 -248
- package/components/common/backup/storage/actions/add/New.vue +298 -298
- package/components/common/backup/storage/actions/add/Old.vue +120 -120
- package/components/common/backup/storage/actions/add/lib/config/createDatastore.ts +16 -16
- package/components/common/backup/storage/actions/add/lib/config/steps.ts +168 -168
- package/components/common/backup/storage/actions/add/lib/models/interfaces.ts +23 -23
- package/components/common/backup/storage/actions/add/lib/models/types.ts +2 -2
- package/components/common/backup/storage/actions/add/lib/utils.ts +30 -30
- package/components/common/backup/storage/actions/add/lib/validations.ts +242 -242
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibility.vue +57 -57
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibilityNew.vue +51 -51
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/HostAccessibilityOld.vue +59 -59
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/lib/config/tabsPannel.ts +30 -30
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/lib/models/types.ts +3 -3
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/Table.vue +39 -39
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/lib/models/interfaces.ts +11 -11
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/new/New.vue +119 -119
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/new/lib/config/compatibleTable.ts +80 -80
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/old/Old.vue +90 -90
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/old/lib/config/compatibleTable.ts +58 -58
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/old/lib/config/incompatibleTable.ts +68 -68
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/old/lib/config/tableKeys.ts +15 -15
- package/components/common/backup/storage/actions/add/steps/hostAccessibility/table/old/lib/models/types.ts +6 -6
- package/components/common/backup/storage/actions/add/steps/name/Name.vue +47 -47
- package/components/common/backup/storage/actions/add/steps/name/New.vue +112 -112
- package/components/common/backup/storage/actions/add/steps/name/Old.vue +119 -119
- package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigure.vue +48 -48
- package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigureNew.vue +280 -280
- package/components/common/backup/storage/actions/add/steps/nameAndConfigure/NameAndConfigureOld.vue +325 -325
- package/components/common/backup/storage/actions/add/steps/nameAndConfigure/lib/models/interfaces.ts +7 -7
- package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyComplete.vue +45 -45
- package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyCompleteNew.vue +164 -164
- package/components/common/backup/storage/actions/add/steps/readyComplete/ReadyCompleteOld.vue +92 -92
- package/components/common/backup/storage/actions/add/steps/readyComplete/lib/config/propertiesDetails.ts +243 -243
- package/components/common/backup/storage/actions/add/steps/typeMode/TypeMode.vue +32 -32
- package/components/common/backup/storage/actions/add/steps/typeMode/TypeModeNew.vue +119 -119
- package/components/common/backup/storage/actions/add/steps/typeMode/TypeModeOld.vue +66 -66
- package/components/common/backup/storage/actions/add/steps/typeMode/lib/config/typeOptions.ts +39 -39
- package/components/common/backup/storage/actions/delete/Delete.vue +64 -64
- package/components/common/backup/storage/actions/delete/lib/models/interfaces.ts +4 -4
- package/components/common/browse/Browse.vue +179 -179
- package/components/common/browse/BrowseNew.vue +308 -308
- package/components/common/browse/BrowseOld.vue +224 -224
- package/components/common/browse/blocks/Container.vue +235 -235
- package/components/common/browse/blocks/TitleNew.vue +146 -146
- package/components/common/browse/blocks/TitleOld.vue +91 -91
- package/components/common/browse/blocks/contents/Files.vue +37 -37
- package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
- package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +95 -95
- package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
- package/components/common/browse/blocks/info/Date.vue +37 -37
- package/components/common/browse/blocks/info/Size.vue +30 -30
- package/components/common/browse/blocks/info/Text.vue +29 -29
- package/components/common/chartOptionsModal/counters/timespan/form/Form.vue +290 -290
- package/components/common/chartOptionsModal/counters/timespan/form/FormNew.vue +261 -261
- package/components/common/chartOptionsModal/counters/timespan/form/FormOld.vue +372 -372
- package/components/common/chartOptionsModal/counters/timespan/form/lib/config/dateForm.ts +116 -116
- package/components/common/context/Context.vue +111 -111
- package/components/common/context/lib/Context.spec.ts +20 -20
- package/components/common/context/lib/ContextRecursion.spec.ts +55 -55
- package/components/common/context/lib/models/interfaces.ts +33 -33
- package/components/common/context/recursion/Recursion.vue +92 -92
- package/components/common/context/recursion/RecursionNew.vue +283 -283
- package/components/common/context/recursion/RecursionOld.vue +221 -221
- package/components/common/context/recursion/lib/models/interfaces.ts +2 -2
- package/components/common/countdownTimer/CountdownTimer.vue +50 -50
- package/components/common/details/DetailsItem.vue +109 -109
- package/components/common/details/DetailsList.vue +23 -23
- package/components/common/details/lib/models/interfaces.ts +12 -12
- package/components/common/diagramMain/Diagram.vue +377 -377
- package/components/common/diagramMain/DiagramMain.vue +900 -900
- package/components/common/diagramMain/Header.vue +219 -219
- package/components/common/diagramMain/adapter/Adapter.vue +123 -123
- package/components/common/diagramMain/adapter/AdapterItem.vue +438 -438
- package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
- package/components/common/diagramMain/adapter/Contents.vue +212 -212
- package/components/common/diagramMain/adapter/Lines.vue +81 -81
- package/components/common/diagramMain/adapter/block/Block.vue +27 -27
- package/components/common/diagramMain/adapter/block/BlockNew.vue +58 -58
- package/components/common/diagramMain/adapter/block/BlockOld.vue +50 -50
- package/components/common/diagramMain/adapter/secondBlock/SecondBlock.vue +27 -27
- package/components/common/diagramMain/adapter/secondBlock/SecondBlockNew.vue +60 -60
- package/components/common/diagramMain/adapter/secondBlock/SecondBlockOld.vue +51 -51
- package/components/common/diagramMain/highlights/Highlights.vue +151 -151
- package/components/common/diagramMain/highlights/HighlightsNew.vue +124 -124
- package/components/common/diagramMain/highlights/HighlightsOld.vue +107 -107
- package/components/common/diagramMain/lib/config/index.ts +81 -81
- package/components/common/diagramMain/lib/config/positions.ts +194 -194
- package/components/common/diagramMain/lib/models/enums.ts +44 -44
- package/components/common/diagramMain/lib/models/interfaces.ts +755 -755
- package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +330 -330
- package/components/common/diagramMain/modals/Modals.vue +452 -452
- package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +43 -43
- package/components/common/diagramMain/modals/editSettings/EditSettings.vue +497 -497
- package/components/common/diagramMain/modals/editSettings/EditSettingsModal.vue +789 -789
- package/components/common/diagramMain/modals/editSettings/lib/models/interfaces.ts +21 -21
- package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +215 -215
- package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +190 -190
- package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +164 -164
- package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
- package/components/common/diagramMain/modals/editSettings/tabs/TrafficShaping.vue +399 -399
- package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +351 -351
- package/components/common/diagramMain/modals/editSettings/tabs/port/PortProperties.vue +206 -206
- package/components/common/diagramMain/modals/lib/config/adapterModal.ts +144 -144
- package/components/common/diagramMain/modals/lib/config/diagramConfig.ts +25 -25
- package/components/common/diagramMain/modals/lib/config/index.ts +55 -55
- package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
- package/components/common/diagramMain/modals/lib/config/networkModal.ts +398 -398
- package/components/common/diagramMain/modals/lib/config/portModal.ts +251 -251
- package/components/common/diagramMain/modals/lib/config/switchModal.ts +242 -242
- package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
- package/components/common/diagramMain/modals/migrateVmkernelAdapter/MigrateVmkernelAdapter.vue +541 -541
- package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
- package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
- package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
- package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/VmkernelAdapterReadyComplete.vue +49 -49
- package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
- package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
- package/components/common/diagramMain/modals/remove/RemoveModal.vue +74 -74
- package/components/common/diagramMain/modals/remove/RemoveModalNew.vue +95 -95
- package/components/common/diagramMain/modals/remove/RemoveModalOld.vue +230 -230
- package/components/common/diagramMain/modals/viewSettings/info/Info.vue +55 -55
- package/components/common/diagramMain/modals/viewSettings/info/InfoNew.vue +157 -157
- package/components/common/diagramMain/modals/viewSettings/info/InfoOld.vue +125 -125
- package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettings.vue +36 -36
- package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsNew.vue +208 -208
- package/components/common/diagramMain/modals/viewSettings/viewSettings/ViewSettingsOld.vue +203 -203
- package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModal.vue +60 -60
- package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalNew.vue +50 -50
- package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/ViewSettingsModalOld.vue +70 -70
- package/components/common/diagramMain/modals/viewSettings/viewSettingsModal/lib/models/interfaces.ts +48 -48
- package/components/common/diagramMain/network/Contents.vue +497 -497
- package/components/common/diagramMain/network/Lines.vue +107 -107
- package/components/common/diagramMain/network/Network.vue +141 -141
- package/components/common/diagramMain/network/block/Block.vue +37 -37
- package/components/common/diagramMain/network/block/BlockNew.vue +68 -68
- package/components/common/diagramMain/network/block/BlockOld.vue +64 -64
- package/components/common/diagramMain/network/noNetwork/NoNetwork.vue +12 -12
- package/components/common/diagramMain/network/noNetwork/NoNetworkNew.vue +89 -89
- package/components/common/diagramMain/network/noNetwork/NoNetworkOld.vue +61 -61
- package/components/common/diagramMain/network/secondBlock/SecondBlock.vue +41 -41
- package/components/common/diagramMain/network/secondBlock/SecondBlockNew.vue +64 -64
- package/components/common/diagramMain/network/secondBlock/SecondBlockOld.vue +60 -60
- package/components/common/diagramMain/port/Port.vue +580 -580
- package/components/common/diagramMain/switch/Switch.vue +180 -180
- package/components/common/diagramMain/switch/SwitchSelected.vue +111 -111
- package/components/common/feedback/Buttons.vue +209 -209
- package/components/common/feedback/Feedback.vue +279 -279
- package/components/common/feedback/Message.vue +511 -511
- package/components/common/feedback/VisitPortal.vue +61 -61
- package/components/common/feedback/lib/config/drawingPanel.ts +32 -32
- package/components/common/feedback/lib/config/feedbackTabs.ts +27 -27
- package/components/common/feedback/lib/models/interfaces.ts +20 -20
- package/components/common/feedback/lib/models/types.ts +1 -1
- package/components/common/graph/Graph.vue +127 -127
- package/components/common/graph/GraphOld.vue +61 -61
- package/components/common/graph/graphNew/GraphNew.vue +178 -178
- package/components/common/graph/graphNew/lib/models/enums.ts +9 -9
- package/components/common/graph/lib/utils/renderGraph.ts +388 -388
- package/components/common/headline/Headline.vue +32 -32
- package/components/common/help/navbar/left/Left.vue +165 -165
- package/components/common/help/navbar/left/lib/models/interfaces.ts +6 -6
- package/components/common/help/navbar/left/lib/utils/constructAccordion.ts +27 -27
- package/components/common/help/navbar/right/Right.vue +149 -149
- package/components/common/help/navbar/right/lib/models/interfaces.ts +5 -5
- package/components/common/layout/theHeader/TheHeader.vue +169 -169
- package/components/common/layout/theHeader/TheHeaderNew.vue +303 -303
- package/components/common/layout/theHeader/TheHeaderOld.vue +250 -250
- package/components/common/layout/theHeader/ThemeSwitch.vue +66 -66
- package/components/common/layout/theHeader/feedback/Feedback.vue +109 -109
- package/components/common/layout/theHeader/feedback/FeedbackOld.vue +63 -63
- package/components/common/layout/theHeader/feedback/lib/config/sendFeedback.ts +17 -17
- package/components/common/layout/theHeader/feedback/new/New.vue +209 -209
- package/components/common/layout/theHeader/feedback/new/additionalDetails/AdditionalDetails.vue +595 -595
- package/components/common/layout/theHeader/feedback/new/additionalDetails/Headline.vue +38 -38
- package/components/common/layout/theHeader/feedback/new/description/Description.vue +59 -59
- package/components/common/layout/theHeader/feedback/new/email/Email.vue +43 -43
- package/components/common/layout/theHeader/feedback/new/lib/models/interfaces.ts +4 -4
- package/components/common/layout/theHeader/feedback/new/subtitle/Subtitle.vue +38 -38
- package/components/common/layout/theHeader/feedback/new/tabs/Tabs.vue +80 -80
- package/components/common/layout/theHeader/feedback/new/tabs/lib/config/tabs.ts +25 -25
- package/components/common/layout/theHeader/feedback/new/tabs/lib/models/enums.ts +6 -6
- package/components/common/layout/theHeader/feedback/new/tabs/lib/models/types.ts +1 -1
- package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
- package/components/common/layout/theHeader/helpMenu/HelpMenu.vue +43 -43
- package/components/common/layout/theHeader/helpMenu/aboutNew/AboutNew.vue +99 -99
- package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +80 -80
- package/components/common/layout/theHeader/helpMenu/helpMenuNew/HelpMenuNew.vue +195 -195
- package/components/common/layout/theHeader/helpMenu/helpMenuNew/lib/config/dropMenu.ts +28 -28
- package/components/common/layout/theHeader/helpMenu/helpMenuOld/HelpMenuOld.vue +59 -59
- package/components/common/layout/theHeader/helpMenu/helpMenuOld/lib/config/dropMenu.ts +22 -22
- package/components/common/layout/theHeader/helpMenu/helpMenuOld/lib/models/types.ts +1 -1
- package/components/common/layout/theHeader/lib/models/enums.ts +10 -10
- package/components/common/layout/theHeader/lib/models/types.ts +5 -5
- package/components/common/layout/theHeader/lib/utils/localization.ts +32 -32
- package/components/common/layout/theHeader/modals/Reconnect.vue +98 -98
- package/components/common/layout/theHeader/modals/RedirectLogin.vue +60 -60
- package/components/common/layout/theHeader/userMenu/UserMenu.vue +101 -101
- package/components/common/layout/theHeader/userMenu/lib/models/interfaces.ts +32 -32
- package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePassword.vue +90 -90
- package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePasswordNew.vue +189 -189
- package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePasswordOld.vue +179 -179
- package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/config/form.ts +31 -31
- package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/models/interfaces.ts +23 -23
- package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/utils.ts +28 -28
- package/components/common/layout/theHeader/userMenu/modals/preferences/Preferences.vue +70 -70
- package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesNew.vue +93 -93
- package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesOld.vue +130 -130
- package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguage.vue +113 -113
- package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguageNew.vue +89 -89
- package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguageOld.vue +90 -90
- package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/config/radioOptions.ts +22 -22
- package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/models/enums.ts +9 -9
- package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/models/interfaces.ts +11 -11
- package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/lib/models/types.ts +1 -1
- package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsole.vue +42 -42
- package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsoleNew.vue +53 -53
- package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsoleOld.vue +49 -49
- package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/lib/config/consoleOptions.ts +30 -30
- package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/lib/models/interfaces.ts +5 -5
- package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/Inventory.vue +32 -32
- package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/InventoryNew.vue +35 -35
- package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/InventoryOld.vue +31 -31
- package/components/common/layout/theHeader/userMenu/modals/preferences/lib/config/preferencesTabs.ts +49 -49
- package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +1 -1
- package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormat.vue +54 -54
- package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormatNew.vue +52 -52
- package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormatOld.vue +45 -45
- package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/config/formatOptions.ts +27 -27
- package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/lib/models/types.ts +1 -1
- package/components/common/layout/theHeader/userMenu/modals/preferences/view/View.vue +45 -45
- package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewNew.vue +33 -33
- package/components/common/layout/theHeader/userMenu/modals/preferences/view/ViewOld.vue +112 -112
- package/components/common/layout/theHeader/userMenu/userMenuNew/UserMenuNew.vue +170 -170
- package/components/common/layout/theHeader/userMenu/userMenuNew/lib/config/dropMenu.ts +28 -28
- package/components/common/layout/theHeader/userMenu/userMenuOld/UserMenuOld.vue +36 -36
- package/components/common/layout/theHeader/userMenu/userMenuOld/lib/config/dropMenu.ts +36 -36
- package/components/common/layout/theHeader/userMenu/userMenuOld/lib/models/types.ts +5 -5
- package/components/common/lib/config/states.ts +160 -160
- package/components/common/mainNavigationPanel/MainNavigationPanel.vue +151 -151
- package/components/common/mainNavigationPanel/MainNavigationPanelNew.vue +301 -301
- package/components/common/mainNavigationPanel/MainNavigationPanelOld.vue +299 -299
- package/components/common/mainNavigationPanel/lib/models/interfaces.ts +9 -9
- package/components/common/mainNavigationPanel/lib/models/types.ts +1 -1
- package/components/common/modals/Rename.vue +180 -180
- package/components/common/modals/confirmByInput/ConfirmByInput.vue +85 -85
- package/components/common/modals/confirmByInput/ConfirmByInputNew.vue +103 -103
- package/components/common/modals/confirmByInput/ConfirmByInputOld.vue +209 -209
- package/components/common/modals/confirmation/Confirmation.vue +79 -79
- package/components/common/modals/confirmation/ConfirmationNew.vue +77 -77
- package/components/common/modals/confirmation/ConfirmationOld.vue +111 -111
- package/components/common/modals/lib/config/defaultForm.ts +18 -18
- package/components/common/modals/lib/config/renameLabelWidth.ts +3 -3
- package/components/common/modals/lib/models/interfaces.ts +5 -5
- package/components/common/modals/unsavedChanges/UnsavedChanges.vue +48 -48
- package/components/common/monitor/advanced/Advanced.vue +203 -203
- package/components/common/monitor/advanced/AdvancedNew.vue +191 -191
- package/components/common/monitor/advanced/AdvancedOld.vue +220 -220
- package/components/common/monitor/advanced/graphView/GraphView.vue +145 -145
- package/components/common/monitor/advanced/graphView/GraphViewNew.vue +36 -36
- package/components/common/monitor/advanced/graphView/GraphViewOld.vue +56 -56
- package/components/common/monitor/advanced/lib/models/interfaces.ts +9 -9
- package/components/common/monitor/advanced/lib/models/types.ts +1 -1
- package/components/common/monitor/advanced/table/Table.vue +31 -31
- package/components/common/monitor/advanced/table/lib/models/interfaces.ts +12 -12
- package/components/common/monitor/advanced/table/lib/models/types.ts +10 -10
- package/components/common/monitor/advanced/table/tableNew/TableNew.vue +92 -92
- package/components/common/monitor/advanced/table/tableNew/lib/config/options.ts +139 -139
- package/components/common/monitor/advanced/table/tableNew/lib/utils/constructBody.ts +27 -27
- package/components/common/monitor/advanced/table/tableOld/TableOld.vue +93 -93
- package/components/common/monitor/advanced/table/tableOld/lib/config/performanceDatatable.ts +129 -129
- package/components/common/monitor/advanced/tools/Tools.vue +309 -309
- package/components/common/monitor/advanced/tools/ToolsNew.vue +222 -222
- package/components/common/monitor/advanced/tools/ToolsOld.vue +315 -315
- package/components/common/monitor/advanced/tools/chartOptionsModal/ChartOptionsModal.vue +549 -549
- package/components/common/monitor/advanced/tools/chartOptionsModal/ChartOptionsModalNew.vue +204 -204
- package/components/common/monitor/advanced/tools/chartOptionsModal/ChartOptionsModalOld.vue +189 -189
- package/components/common/monitor/advanced/tools/chartOptionsModal/Notification.vue +27 -27
- package/components/common/monitor/advanced/tools/chartOptionsModal/NotificationNew.vue +22 -22
- package/components/common/monitor/advanced/tools/chartOptionsModal/NotificationOld.vue +27 -27
- package/components/common/monitor/advanced/tools/chartOptionsModal/actions/Actions.vue +106 -106
- package/components/common/monitor/advanced/tools/chartOptionsModal/actions/ActionsNew.vue +165 -165
- package/components/common/monitor/advanced/tools/chartOptionsModal/actions/ActionsOld.vue +114 -114
- package/components/common/monitor/advanced/tools/chartOptionsModal/actions/lib/utils/optionsActions.ts +32 -32
- package/components/common/monitor/advanced/tools/chartOptionsModal/actions/saveOptionsModal/SaveOptionsModal.vue +81 -81
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/Counters.vue +146 -146
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/CountersNew.vue +139 -139
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/CountersOld.vue +114 -114
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/Table.vue +105 -105
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +1040 -1040
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/models/interfaces.ts +30 -30
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/tableNew/TableNew.vue +48 -48
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/tableNew/config/options.ts +19 -19
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/tableNew/config/tableData.ts +71 -71
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/tableNew/utils/constructTable.ts +29 -29
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/tableOld/TableOld.vue +85 -85
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/tableOld/lib/config/tableConfig.ts +89 -89
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/tableOld/lib/models/types.ts +5 -5
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/Timespan.vue +138 -138
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/TimespanNew.vue +188 -188
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/TimespanOld.vue +95 -95
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/Object.vue +294 -294
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/lib/config/objectTable.ts +64 -64
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/lib/models/interfaces.ts +4 -4
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/lib/models/types.ts +1 -1
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/objectNew/ObjectNew.vue +62 -62
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/objectNew/lib/config/options.ts +25 -25
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/objectNew/lib/config/tableData.ts +47 -47
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/objectNew/lib/utils/constructTable.ts +22 -22
- package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/object/objectOld/ObjectOld.vue +84 -84
- package/components/common/monitor/advanced/tools/chartOptionsModal/lib/models/interfaces.ts +19 -19
- package/components/common/monitor/advanced/tools/chartOptionsModal/lib/models/types.ts +3 -3
- package/components/common/monitor/advanced/tools/chartOptionsModal/lib/utils/checkSubmit.ts +19 -19
- package/components/common/monitor/advanced/tools/chartOptionsModal/metrics/Metrics.vue +30 -30
- package/components/common/monitor/advanced/tools/chartOptionsModal/metrics/MetricsNew.vue +121 -121
- package/components/common/monitor/advanced/tools/chartOptionsModal/metrics/MetricsOld.vue +32 -32
- package/components/common/monitor/advanced/tools/chartOptionsModal/metrics/lib/config/optionsMetrics.ts +173 -173
- package/components/common/monitor/advanced/tools/lib/config/advancedToolbar.ts +146 -146
- package/components/common/monitor/advanced/tools/lib/models/interfaces.ts +4 -4
- package/components/common/monitor/advanced/tools/lib/utils/countCores.ts +7 -7
- package/components/common/monitor/lib/config/getValidDateByOption.ts +76 -76
- package/components/common/monitor/lib/models/interfaces.ts +24 -24
- package/components/common/monitor/overview/Overview.vue +141 -141
- package/components/common/monitor/overview/OverviewNew.vue +120 -120
- package/components/common/monitor/overview/OverviewOld.vue +130 -130
- package/components/common/monitor/overview/filters/Filters.vue +174 -174
- package/components/common/monitor/overview/filters/FiltersNew.vue +171 -171
- package/components/common/monitor/overview/filters/FiltersOld.vue +153 -153
- package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModal.vue +173 -173
- package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModalOld.vue +161 -161
- package/components/common/monitor/overview/filters/customIntervalModal/customIntervalModalNew/CustomIntervalModalNew.vue +230 -230
- package/components/common/monitor/overview/filters/customIntervalModal/customIntervalModalNew/lib/utils/date.ts +11 -11
- package/components/common/monitor/overview/filters/customIntervalModal/lib/config/dateChecker.ts +62 -62
- package/components/common/monitor/overview/filters/lib/config/filterOptions.ts +100 -100
- package/components/common/monitor/overview/filters/lib/models/interfaces.ts +10 -10
- package/components/common/monitor/overview/filters/lib/models/types.ts +15 -15
- package/components/common/monitor/resourceAllocation/lib/models/interfaces.ts +13 -13
- package/components/common/monitor/resourceAllocation/resourceAllocation.vue +196 -196
- package/components/common/pages/backups/Backups.vue +102 -102
- package/components/common/pages/backups/DetailView.vue +52 -52
- package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
- package/components/common/pages/backups/lib/models/types.ts +7 -7
- package/components/common/pages/backups/lib/utils/getBackupOrBackupStorageId.ts +25 -25
- package/components/common/pages/backups/modals/Modals.vue +240 -240
- package/components/common/pages/backups/modals/createBackup/CreateBackup.vue +5 -2
- package/components/common/pages/backups/modals/createBackup/configuration/Configuration.vue +29 -29
- package/components/common/pages/backups/modals/createBackup/configuration/backupWindow/BackupWindow.vue +26 -26
- package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/MaxBandwidth.vue +66 -66
- package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
- package/components/common/pages/backups/modals/createBackup/configuration/strategy/Strategy.vue +35 -35
- package/components/common/pages/backups/modals/createBackup/datastores/Datastores.vue +59 -59
- package/components/common/pages/backups/modals/createBackup/datastores/tableView/TableView.vue +95 -95
- package/components/common/pages/backups/modals/createBackup/datastores/tableView/lib/config/keys.ts +14 -14
- package/components/common/pages/backups/modals/createBackup/datastores/tableView/lib/config/table.ts +119 -119
- package/components/common/pages/backups/modals/createBackup/datastores/tableView/lib/models/types.ts +10 -10
- package/components/common/pages/backups/modals/createBackup/disks/Disks.vue +28 -28
- package/components/common/pages/backups/modals/createBackup/disks/tableView/TableView.vue +108 -108
- package/components/common/pages/backups/modals/createBackup/disks/tableView/lib/config/keys.ts +12 -12
- package/components/common/pages/backups/modals/createBackup/disks/tableView/lib/config/table.ts +117 -117
- package/components/common/pages/backups/modals/createBackup/disks/tableView/lib/models/types.ts +10 -10
- package/components/common/pages/backups/modals/createBackup/general/General.vue +135 -135
- package/components/common/pages/backups/modals/createBackup/lib/config/steps.ts +117 -117
- package/components/common/pages/backups/modals/createBackup/lib/config/strategyOptions.ts +12 -12
- package/components/common/pages/backups/modals/createBackup/lib/models/interfaces.ts +8 -8
- package/components/common/pages/backups/modals/createBackup/readyToComplete/ReadyToComplete.vue +15 -15
- package/components/common/pages/backups/modals/deleteBackup/DeleteBackup.vue +52 -52
- package/components/common/pages/backups/modals/lib/config/createBackup.ts +16 -16
- package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
- package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
- package/components/common/pages/backups/modals/restore/Restore.vue +417 -417
- package/components/common/pages/backups/modals/restore/disks/Disks.vue +27 -27
- package/components/common/pages/backups/modals/restore/disks/tableView/TableView.vue +102 -102
- package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/keys.ts +14 -14
- package/components/common/pages/backups/modals/restore/disks/tableView/lib/config/table.ts +117 -117
- package/components/common/pages/backups/modals/restore/disks/tableView/lib/models/types.ts +10 -10
- package/components/common/pages/backups/modals/restore/lib/config/restoreCodes.ts +4 -4
- package/components/common/pages/backups/modals/restore/lib/config/steps.ts +108 -108
- package/components/common/pages/backups/modals/restore/name/Name.vue +160 -160
- package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
- package/components/common/pages/backups/modals/restore/networks/Networks.vue +67 -67
- package/components/common/pages/backups/modals/restore/networks/table/Table.vue +214 -214
- package/components/common/pages/backups/modals/restore/networks/table/adapterType/AdapterType.vue +32 -32
- package/components/common/pages/backups/modals/restore/networks/table/adapterType/lib/config/options.ts +8 -8
- package/components/common/pages/backups/modals/restore/networks/table/lib/config/networkTable.ts +75 -75
- package/components/common/pages/backups/modals/restore/networks/table/lib/config/tableKeys.ts +10 -10
- package/components/common/pages/backups/modals/restore/networks/table/lib/models/types.ts +6 -6
- package/components/common/pages/backups/modals/restore/types/Types.vue +60 -60
- package/components/common/pages/backups/modals/restore/types/lib/config/descriptions.ts +7 -7
- package/components/common/pages/backups/modals/restore/types/lib/config/typeOptions.ts +25 -25
- package/components/common/pages/backups/tools/Tools.vue +75 -75
- package/components/common/pages/backups/tools/lib/config/tabs.ts +36 -36
- package/components/common/pages/hardwareHealth/HardwareHealth.vue +214 -214
- package/components/common/pages/hardwareHealth/historyTestimony/Graph.vue +459 -459
- package/components/common/pages/hardwareHealth/historyTestimony/lib/config/containerSizes.ts +1 -1
- package/components/common/pages/hardwareHealth/historyTestimony/lib/models/interfaces.ts +20 -20
- package/components/common/pages/hardwareHealth/historyTestimony/tools/Tools.vue +389 -389
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/ChartOptionsModal.vue +502 -502
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/Notification.vue +30 -30
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/actions/Actions.vue +157 -157
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/actions/SaveOptionsModal.vue +81 -81
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/actions/lib/utils/optionsActions.ts +25 -25
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/Counters.vue +94 -94
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/table/Table.vue +174 -174
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/table/lib/config/tableConfig.ts +89 -89
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/table/lib/models/types.ts +5 -5
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/timespan/Timespan.vue +66 -66
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/lib/config/optionsMetrics.ts +17 -17
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/lib/models/interfaces.ts +15 -15
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/lib/models/types.ts +1 -1
- package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/metrics/Metrics.vue +31 -31
- package/components/common/pages/hardwareHealth/historyTestimony/tools/lib/config/toolbar.ts +82 -82
- package/components/common/pages/hardwareHealth/historyTestimony/tools/lib/models/interfaces.ts +9 -9
- package/components/common/pages/hardwareHealth/lib/config/status.ts +13 -13
- package/components/common/pages/hardwareHealth/lib/config/tabsPannel.ts +39 -39
- package/components/common/pages/hardwareHealth/lib/models/enums.ts +8 -8
- package/components/common/pages/hardwareHealth/lib/models/interfaces.ts +6 -6
- package/components/common/pages/hardwareHealth/lib/models/types.ts +5 -5
- package/components/common/pages/hardwareHealth/tableView/TableView.vue +194 -194
- package/components/common/pages/hardwareHealth/tableView/lib/config/alertWarningTable.ts +109 -109
- package/components/common/pages/hardwareHealth/tableView/lib/config/historyTestimonyTable.ts +137 -137
- package/components/common/pages/hardwareHealth/tableView/lib/config/sensorTable.ts +153 -153
- package/components/common/pages/hardwareHealth/tableView/lib/config/storageSensorTable.ts +93 -93
- package/components/common/pages/hardwareHealth/tableView/lib/config/systemLogTable.ts +72 -72
- package/components/common/pages/hardwareHealth/tableView/lib/config/tableKeys.ts +22 -22
- package/components/common/pages/hardwareHealth/tableView/lib/models/interfaces.ts +29 -29
- package/components/common/pages/hardwareHealth/tableView/lib/models/types.ts +26 -26
- package/components/common/pages/hardwareHealth/tableView/modal/SensorWarning.vue +63 -63
- package/components/common/pages/hardwareHealth/toolsPanel/ToolsPanel.vue +51 -51
- package/components/common/pages/hardwareHealth/toolsPanel/lib/config/actionsPanel.ts +34 -34
- package/components/common/pages/hardwareHealth/toolsPanel/lib/models/types.ts +4 -4
- package/components/common/pages/home/Card.vue +63 -63
- package/components/common/pages/home/StatusContent.vue +52 -52
- package/components/common/pages/home/headline/Headline.vue +35 -35
- package/components/common/pages/home/headline/HeadlineNew.vue +99 -99
- package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
- package/components/common/pages/home/lib/config/configResourceMeterBlock.ts +35 -35
- package/components/common/pages/home/lib/models/interfaces.ts +48 -48
- package/components/common/pages/home/lib/models/types.ts +12 -12
- package/components/common/pages/home/resource/Resource.vue +29 -29
- package/components/common/pages/home/resource/ResourceNew.vue +63 -63
- package/components/common/pages/home/resource/ResourceOld.vue +122 -122
- package/components/common/pages/home/resource/lib/models/interfaces.ts +14 -14
- package/components/common/pages/home/resource/lib/utils/resourceMeter.ts +52 -52
- package/components/common/pages/home/widgets/Widgets.vue +54 -54
- package/components/common/pages/home/widgets/WidgetsNew.vue +93 -93
- package/components/common/pages/home/widgets/WidgetsOld.vue +41 -41
- package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
- package/components/common/pages/home/widgets/hosts/HostsNew.vue +100 -100
- package/components/common/pages/home/widgets/hosts/HostsOld.vue +25 -25
- package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
- package/components/common/pages/home/widgets/services/Services.vue +27 -27
- package/components/common/pages/home/widgets/services/ServicesNew.vue +145 -145
- package/components/common/pages/home/widgets/services/ServicesOld.vue +35 -35
- package/components/common/pages/home/widgets/services/lib/config/config.ts +130 -130
- package/components/common/pages/home/widgets/services/lib/models/enums.ts +20 -20
- package/components/common/pages/home/widgets/services/table/Table.vue +80 -80
- package/components/common/pages/home/widgets/services/table/lib/config/config.ts +62 -62
- package/components/common/pages/home/widgets/services/table/lib/models/types.ts +6 -6
- package/components/common/pages/home/widgets/skeleton/totalQuantitiesItem.vue +82 -82
- package/components/common/pages/home/widgets/vms/Vms.vue +35 -35
- package/components/common/pages/home/widgets/vms/VmsNew.vue +107 -107
- package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
- package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
- package/components/common/pages/home/widgets/warnings/Warnings.vue +27 -27
- package/components/common/pages/home/widgets/warnings/WarningsNew.vue +104 -104
- package/components/common/pages/home/widgets/warnings/WarningsOld.vue +39 -39
- package/components/common/pages/home/widgets/warnings/lib/config/config.ts +96 -96
- package/components/common/pages/home/widgets/warnings/table/Table.vue +114 -114
- package/components/common/pages/home/widgets/warnings/table/lib/config/config.ts +73 -73
- package/components/common/pages/home/widgets/warnings/table/lib/models/enums.ts +11 -11
- package/components/common/pages/home/widgets/warnings/table/lib/models/interfaces.ts +19 -19
- package/components/common/pages/home/widgets/warnings/table/lib/models/types.ts +15 -15
- package/components/common/pages/licensing/Licensing.vue +128 -128
- package/components/common/pages/licensing/lib/models/interfaces.ts +21 -21
- package/components/common/pages/licensing/lib/utils/validation.ts +28 -28
- package/components/common/pages/licensing/listView/ListView.vue +50 -50
- package/components/common/pages/licensing/listView/lib/config/list.ts +57 -57
- package/components/common/pages/licensing/listView/lib/models/interfaces.ts +5 -5
- package/components/common/pages/licensing/modals/assign/Assign.vue +247 -247
- package/components/common/pages/licensing/modals/assign/lib/config/tabsPannel.ts +17 -17
- package/components/common/pages/licensing/modals/assign/lib/models/interfaces.ts +4 -4
- package/components/common/pages/licensing/modals/assign/lib/utils/error.ts +24 -24
- package/components/common/pages/licensing/modals/assign/new/New.vue +216 -216
- package/components/common/pages/licensing/modals/assign/tableView/TableView.vue +193 -193
- package/components/common/pages/licensing/modals/assign/tableView/lib/config/table.ts +100 -100
- package/components/common/pages/licensing/modals/assign/tableView/lib/config/tableKeys.ts +10 -10
- package/components/common/pages/licensing/modals/assign/tableView/lib/models/interfaces.ts +9 -9
- package/components/common/pages/licensing/modals/assign/tableView/lib/models/types.ts +8 -8
- package/components/common/pages/packages/Packages.vue +194 -194
- package/components/common/pages/packages/lib/config/actions.ts +59 -59
- package/components/common/pages/packages/lib/models/types.ts +8 -8
- package/components/common/pages/packages/tableView/TableView.vue +120 -120
- package/components/common/pages/packages/tableView/lib/config/configTable.ts +136 -136
- package/components/common/pages/packages/tableView/lib/config/tableKey.ts +14 -14
- package/components/common/pages/packages/tableView/lib/models/types.ts +12 -12
- package/components/common/pages/scheduledTasks/lib/models/interfaces.ts +42 -42
- package/components/common/pages/scheduledTasks/lib/models/types.ts +16 -16
- package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
- package/components/common/pages/scheduledTasks/modals/common/frequency/Frequency.vue +59 -59
- package/components/common/pages/scheduledTasks/modals/common/frequency/afterStartup/AfterStartup.vue +82 -82
- package/components/common/pages/scheduledTasks/modals/common/frequency/end/End.vue +115 -115
- package/components/common/pages/scheduledTasks/modals/common/frequency/end/lib/config/endOptions.ts +17 -17
- package/components/common/pages/scheduledTasks/modals/common/frequency/interval/Interval.vue +102 -102
- package/components/common/pages/scheduledTasks/modals/common/frequency/lib/config/frequencyOptions.ts +38 -38
- package/components/common/pages/scheduledTasks/modals/common/frequency/lib/models/types.ts +7 -7
- package/components/common/pages/scheduledTasks/modals/common/frequency/lib/utils.ts +128 -128
- package/components/common/pages/scheduledTasks/modals/common/frequency/on/On.vue +237 -237
- package/components/common/pages/scheduledTasks/modals/common/frequency/on/lib/config/options.ts +64 -64
- package/components/common/pages/scheduledTasks/modals/common/frequency/on/lib/models/types.ts +12 -12
- package/components/common/pages/scheduledTasks/modals/common/frequency/on/selectWeek/SelectWeek.vue +68 -68
- package/components/common/pages/scheduledTasks/modals/common/frequency/on/selectWeek/lib/config/weekOptions.ts +55 -55
- package/components/common/pages/scheduledTasks/modals/common/frequency/on/selectWeek/lib/models/interfaces.ts +6 -6
- package/components/common/pages/scheduledTasks/modals/common/frequency/startOn/StartOn.vue +88 -88
- package/components/common/pages/scheduledTasks/modals/common/newTaskForm/NewTaskForm.vue +293 -293
- package/components/common/pages/scheduledTasks/modals/common/newTaskForm/lib/models/interfaces.ts +3 -3
- package/components/common/pages/scheduledTasks/modals/common/newTaskForm/lib/utils.ts +67 -67
- package/components/common/pages/scheduledTasks/modals/lib/config/createScheduledTask.ts +23 -23
- package/components/common/pages/scheduledTasks/modals/lib/models/interfaces.ts +21 -21
- package/components/common/pages/scheduledTasks/modals/lib/utils.ts +7 -7
- package/components/common/pages/shortcuts/Shortcuts.vue +67 -67
- package/components/common/pages/shortcuts/block/Block.vue +39 -39
- package/components/common/pages/shortcuts/block/BlockNew.vue +104 -104
- package/components/common/pages/shortcuts/block/BlockOld.vue +73 -73
- package/components/common/pages/shortcuts/category/Category.vue +26 -26
- package/components/common/pages/shortcuts/category/CategoryNew.vue +41 -41
- package/components/common/pages/shortcuts/category/CategoryOld.vue +41 -41
- package/components/common/pages/shortcuts/lib/models/interfaces.ts +13 -13
- package/components/common/pages/tasks/Tasks.vue +122 -122
- package/components/common/pages/tasks/table/Table.vue +352 -352
- package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +197 -197
- package/components/common/pages/tasks/table/lib/config/config.ts +270 -270
- package/components/common/pages/tasks/table/lib/models/enums.ts +13 -13
- package/components/common/perPage/PerPage.vue +52 -52
- package/components/common/portlets/customAttributes/Portlet.vue +658 -658
- package/components/common/portlets/customAttributes/lib/config/config.ts +146 -146
- package/components/common/portlets/customAttributes/lib/models/interfaces.ts +5 -5
- package/components/common/portlets/tag/CreateCategory.vue +265 -265
- package/components/common/portlets/tag/Portlet.vue +444 -444
- package/components/common/portlets/tag/TagAddNew.vue +605 -605
- package/components/common/portlets/tag/lib/config/config.ts +210 -210
- package/components/common/portlets/tag/lib/models/interfaces.ts +27 -27
- package/components/common/portlets/tag/lib/models/types.ts +15 -15
- package/components/common/readyToComplete/New.vue +121 -121
- package/components/common/readyToComplete/Old.vue +15 -15
- package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
- package/components/common/recursionTree/RecursionTree.vue +210 -210
- package/components/common/recursionTree/lib/models/interfaces.ts +27 -27
- package/components/common/resource/lib/models/interfaces.ts +10 -10
- package/components/common/resource/lib/models/types.ts +1 -1
- package/components/common/resource/lib/utils.ts +44 -44
- package/components/common/resource/progressBlock/ProgressBlock.vue +142 -142
- package/components/common/resource/simple/Simple.vue +65 -65
- package/components/common/resource/simple/lib/models/enums.ts +6 -6
- package/components/common/select/button/ButtonDropdown.vue +112 -112
- package/components/common/select/button/lib/models/interfaces.ts +8 -8
- package/components/common/select/input/Input.vue +77 -77
- package/components/common/select/input/lib/models/interfaces.ts +6 -6
- package/components/common/select/radio/RadioGroup.vue +137 -137
- package/components/common/select/radio/lib/models/interfaces.ts +11 -11
- package/components/common/selectLanguage/SelectLanguage.vue +200 -200
- package/components/common/selectLanguage/lib/config/config.ts +40 -40
- package/components/common/selectLanguage/lib/utils/utils.ts +5 -5
- package/components/common/spiceConsole/Drawer.vue +381 -381
- package/components/common/spiceConsole/SpiceConsole.vue +127 -127
- package/components/common/spiceConsole/keyboard/Keyboard.vue +403 -403
- package/components/common/spiceConsole/keyboard/lib/config/keyboardRows.ts +966 -966
- package/components/common/spiceConsole/keyboard/lib/models/interfaces.ts +18 -18
- package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
- package/components/common/spiceConsole/lib/models/types.ts +1 -1
- package/components/common/spiceConsole/lib/utils/getDeviceType.ts +35 -35
- package/components/common/split/horizontal/Horizontal.vue +70 -70
- package/components/common/split/horizontal/HorizontalNew.vue +387 -387
- package/components/common/split/horizontal/HorizontalOld.vue +337 -337
- package/components/common/split/vertical/Vertical.vue +162 -162
- package/components/common/split/vertical/VerticalNew.vue +124 -124
- package/components/common/split/vertical/VerticalOld.vue +111 -111
- package/components/common/split/vertical/lib/models/interfaces.ts +3 -3
- package/components/common/summary/notification/Notification.vue +28 -28
- package/components/common/summary/notification/NotificationNew.vue +135 -135
- package/components/common/summary/notification/NotificationOld.vue +47 -47
- package/components/common/titleBar/titleBarNew/notification/Notification.vue +372 -372
- package/components/common/titleBar/titleBarNew/notification/lib/config/tabsData.ts +47 -47
- package/components/common/titleBar/titleBarNew/notification/lib/models/interfaces.ts +10 -10
- package/components/common/titleBar/titleBarNew/notification/lib/models/types.ts +3 -3
- package/components/common/tools/Actions.vue +207 -207
- package/components/common/tools/lib/models/interfaces.ts +10 -10
- package/components/common/tools/viewSettings/ViewSettings.vue +86 -86
- package/components/common/tools/viewSettings/lib/models/interfaces.ts +9 -9
- package/components/common/tooltip/Help.vue +182 -182
- package/components/common/treeView/TreeView.vue +52 -52
- package/components/common/vm/actions/add/Add.vue +840 -840
- package/components/common/vm/actions/add/New.vue +668 -668
- package/components/common/vm/actions/add/Old.vue +398 -398
- package/components/common/vm/actions/add/folderTreeView/FolderTreeView.vue +72 -72
- package/components/common/vm/actions/add/folderTreeView/New.vue +40 -40
- package/components/common/vm/actions/add/folderTreeView/Old.vue +50 -50
- package/components/common/vm/actions/add/lib/config/steps.ts +319 -319
- package/components/common/vm/actions/add/lib/utils.ts +103 -103
- package/components/common/vm/actions/clone/Clone.vue +841 -841
- package/components/common/vm/actions/clone/lib/config/steps.ts +291 -291
- package/components/common/vm/actions/clone/lib/models/interfaces.ts +6 -6
- package/components/common/vm/actions/clone/lib/utils.ts +43 -43
- package/components/common/vm/actions/clone/toTemplate/ToTemplate.vue +644 -644
- package/components/common/vm/actions/clone/toTemplate/lib/config/steps.ts +118 -118
- package/components/common/vm/actions/clone/toTemplate/lib/models/interfaces.ts +14 -14
- package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +308 -308
- package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +373 -373
- package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +205 -205
- package/components/common/vm/actions/common/customizeHardware/lib/config/navItems.ts +36 -36
- package/components/common/vm/actions/common/customizeHardware/lib/models/interfaces.ts +7 -7
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +722 -722
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +523 -523
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +339 -339
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +232 -232
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/lib/models/interfaces.ts +8 -8
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/Bus.vue +110 -110
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +67 -67
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusOld.vue +114 -114
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/lib/config/options.ts +20 -20
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDrive.vue +239 -239
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +234 -234
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +174 -174
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/lib/config/fileTypes.ts +9 -9
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/lib/config/options.ts +11 -11
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/lib/models/types.ts +1 -1
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +78 -78
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +363 -363
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuNew.vue +248 -248
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/CpuOld.vue +185 -185
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Hv.vue +99 -99
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Iommu.vue +55 -55
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Pc.vue +55 -55
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Sa.vue +106 -106
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocket.vue +86 -86
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocketNew.vue +69 -69
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocketOld.vue +63 -63
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/hotPlug/HotPlug.vue +40 -40
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/hotPlug/HotPlugNew.vue +34 -34
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/hotPlug/HotPlugOld.vue +46 -46
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/lib/config/cpuOptions.ts +21 -21
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/maxCpu/MaxCpu.vue +94 -94
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/maxCpu/MaxCpuNew.vue +41 -41
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/maxCpu/MaxCpuOld.vue +51 -51
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/Model.vue +121 -121
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelNew.vue +130 -130
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/model/ModelOld.vue +169 -169
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/Shares.vue +140 -140
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/SharesNew.vue +65 -65
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/SharesOld.vue +76 -76
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/Tooltip.vue +21 -21
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipNew.vue +155 -155
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/tooltip/TooltipOld.vue +59 -59
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/binaryOptions.ts +12 -12
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/dropdownItems.ts +156 -156
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces.ts +118 -118
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/types.ts +7 -7
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +221 -221
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/LimitNew.vue +75 -75
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/LimitOld.vue +75 -75
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/lib/config/options.ts +29 -29
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +313 -313
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryNew.vue +158 -158
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/MemoryOld.vue +155 -155
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlug.vue +29 -29
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlugNew.vue +35 -35
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/hotPlug/HotPlugOld.vue +42 -42
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/lib/config/memoryOptions.ts +35 -35
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +392 -392
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +327 -327
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +272 -272
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/Cache.vue +63 -63
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/CacheNew.vue +47 -47
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/CacheOld.vue +58 -58
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/cache/lib/config/options.ts +12 -12
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/File.vue +22 -22
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileNew.vue +41 -41
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/file/FileOld.vue +24 -24
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIops.vue +103 -103
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIopsNew.vue +66 -66
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/LimitIopsOld.vue +89 -89
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/limitIops/lib/config/options.ts +31 -31
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/Location.vue +154 -154
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationNew.vue +79 -79
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/LocationOld.vue +85 -85
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/Old.vue +54 -54
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/StorageModal.vue +61 -61
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/new/New.vue +134 -134
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/location/storageModal/new/lib/config/table.ts +15 -15
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSize.vue +23 -23
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeNew.vue +47 -47
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/maximumSize/MaximumSizeOld.vue +24 -24
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/Mode.vue +65 -65
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeNew.vue +48 -48
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +57 -57
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/lib/config/options.ts +18 -18
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/Provisioning.vue +61 -61
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/ProvisioningNew.vue +52 -52
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/ProvisioningOld.vue +58 -58
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/provisioning/lib/config/options.ts +15 -15
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/Sharing.vue +63 -63
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +52 -52
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingOld.vue +58 -58
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/lib/config/options.ts +12 -12
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +293 -293
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +134 -134
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkOld.vue +131 -131
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/AdapterType.vue +60 -60
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/AdapterTypeNew.vue +54 -54
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/AdapterTypeOld.vue +60 -60
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/adapterType/lib/config/options.ts +9 -9
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/Location.vue +71 -71
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +106 -106
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/Table.vue +92 -92
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +94 -94
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +63 -63
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +81 -81
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/lib/config/options.ts +11 -11
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +210 -210
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceNew.vue +94 -94
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceOld.vue +96 -96
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIo.vue +29 -29
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +83 -83
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/lib/config/options.ts +10 -10
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/lib/config/options.ts +14 -14
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +80 -80
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelection.vue +35 -35
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelectionNew.vue +46 -46
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelectionOld.vue +46 -46
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbController.vue +58 -58
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +65 -65
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerOld.vue +61 -61
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/lib/config/options.ts +6 -6
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +36 -36
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherOld.vue +32 -32
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevices.vue +15 -15
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesNew.vue +45 -45
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/inputDevices/InputDevicesOld.vue +21 -21
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/Reservation.vue +197 -197
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationNew.vue +108 -108
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/ReservationOld.vue +104 -104
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/reservation/lib/config/options.ts +33 -33
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/Graphics.vue +50 -50
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCard.vue +162 -162
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +121 -121
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +120 -120
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/lib/config/options.ts +14 -14
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/Model.vue +37 -37
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/ModelNew.vue +44 -44
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/ModelOld.vue +44 -44
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/model/lib/config/options.ts +13 -13
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplays.vue +53 -53
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplaysNew.vue +52 -52
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/numberDisplays/NumberDisplaysOld.vue +56 -56
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemory.vue +107 -107
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +50 -50
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryOld.vue +64 -64
- package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/lib/config/options.ts +2 -2
- package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +163 -163
- package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +138 -138
- package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsOld.vue +120 -120
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptions.vue +110 -110
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +85 -85
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsOld.vue +91 -91
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/Secure.vue +52 -52
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +32 -32
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/DelayNew.vue +41 -41
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/DelayOld.vue +43 -43
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/lib/config/config.ts +14 -14
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +60 -60
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +47 -47
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareOld.vue +58 -58
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/lib/config/config.ts +11 -11
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/Menu.vue +26 -26
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +31 -31
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuOld.vue +41 -41
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +174 -174
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +71 -71
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderOld.vue +63 -63
- package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/lib/models/interfaces.ts +9 -9
- package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptions.vue +101 -101
- package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +161 -161
- package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsOld.vue +158 -158
- package/components/common/vm/actions/common/customizeHardware/vmoptions/lib/models/interfaces.ts +34 -34
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +148 -148
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/Old.vue +141 -141
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/PlaybackCompression.vue +52 -52
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/PowerControl.vue +50 -50
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/RemoteConsoleOptions.vue +178 -178
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPaste.vue +26 -26
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +31 -31
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteOld.vue +41 -41
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransfer.vue +26 -26
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +31 -31
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferOld.vue +41 -41
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharing.vue +20 -20
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +31 -31
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingOld.vue +37 -37
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/imgCompression/ImgCompression.vue +85 -85
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/imgCompression/lib/config/config.ts +14 -14
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/jpegCompression/JpegCompression.vue +85 -85
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/jpegCompression/lib/config/config.ts +12 -12
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +42 -42
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapOld.vue +44 -44
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/lib/config/config.ts +6 -6
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/mouseMode/MouseMode.vue +57 -57
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/mouseMode/lib/config/config.ts +11 -11
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +128 -128
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/lib/models/interfaces.ts +5 -5
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/lib/utils.ts +24 -24
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/sharePolicy/SharePolicy.vue +56 -56
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/sharePolicy/lib/config/config.ts +11 -11
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/streamingMode/StreamingMode.vue +85 -85
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/streamingMode/lib/config/config.ts +12 -12
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/type/Type.vue +85 -85
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/type/lib/config/config.ts +7 -7
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +42 -42
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/lib/config/config.ts +14 -14
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/zlibCompression/ZlibCompression.vue +85 -85
- package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/zlibCompression/lib/config/config.ts +12 -12
- package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/Tools.vue +49 -49
- package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsNew.vue +45 -45
- package/components/common/vm/actions/common/customizeHardware/vmoptions/tools/ToolsOld.vue +57 -57
- package/components/common/vm/actions/common/lib/config/capabilities.ts +361 -361
- package/components/common/vm/actions/common/lib/models/enums.ts +123 -123
- package/components/common/vm/actions/common/lib/models/interfaces.ts +156 -156
- package/components/common/vm/actions/common/lib/models/types.ts +67 -67
- package/components/common/vm/actions/common/lib/utils/capabilities.ts +56 -56
- package/components/common/vm/actions/common/select/compatibility/Compatibility.vue +107 -107
- package/components/common/vm/actions/common/select/compatibility/New.vue +175 -175
- package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
- package/components/common/vm/actions/common/select/computeResource/ComputeResource.vue +143 -143
- package/components/common/vm/actions/common/select/computeResource/New.vue +184 -184
- package/components/common/vm/actions/common/select/computeResource/Old.vue +99 -99
- package/components/common/vm/actions/common/select/computeResource/lib/ComputeResource.spec.ts +479 -479
- package/components/common/vm/actions/common/select/computeResource/treeView/New.vue +51 -51
- package/components/common/vm/actions/common/select/computeResource/treeView/Old.vue +51 -51
- package/components/common/vm/actions/common/select/computeResource/treeView/TreeView.vue +131 -131
- package/components/common/vm/actions/common/select/createType/CreateType.vue +38 -38
- package/components/common/vm/actions/common/select/createType/New.vue +103 -103
- package/components/common/vm/actions/common/select/createType/Old.vue +70 -70
- package/components/common/vm/actions/common/select/createType/lib/config/items.ts +48 -48
- package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
- package/components/common/vm/actions/common/select/lib/models/interfaces.ts +34 -34
- package/components/common/vm/actions/common/select/lib/models/types.ts +27 -27
- package/components/common/vm/actions/common/select/name/Name.vue +182 -182
- package/components/common/vm/actions/common/select/name/New.vue +232 -232
- package/components/common/vm/actions/common/select/name/Old.vue +122 -122
- package/components/common/vm/actions/common/select/options/New.vue +183 -183
- package/components/common/vm/actions/common/select/options/Old.vue +75 -75
- package/components/common/vm/actions/common/select/options/Options.vue +38 -38
- package/components/common/vm/actions/common/select/os/New.vue +129 -129
- package/components/common/vm/actions/common/select/os/Old.vue +152 -152
- package/components/common/vm/actions/common/select/os/Os.vue +139 -139
- package/components/common/vm/actions/common/select/storage/Old.vue +132 -132
- package/components/common/vm/actions/common/select/storage/Storage.vue +164 -164
- package/components/common/vm/actions/common/select/storage/lib/config/config.ts +206 -206
- package/components/common/vm/actions/common/select/storage/lib/models/types.ts +15 -15
- package/components/common/vm/actions/common/select/storage/new/New.vue +310 -310
- package/components/common/vm/actions/common/select/storage/new/lib/config/table.ts +337 -337
- package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
- package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
- package/components/common/vm/actions/common/select/template/Template.vue +70 -70
- package/components/common/vm/actions/common/select/template/new/New.vue +42 -42
- package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
- package/components/common/vm/actions/common/select/template/treeView/New.vue +89 -89
- package/components/common/vm/actions/common/select/template/treeView/Old.vue +50 -50
- package/components/common/vm/actions/common/select/template/treeView/TreeView.vue +80 -80
- package/components/common/vm/actions/confirm/Confirm.vue +37 -37
- package/components/common/vm/actions/editSettings/EditSettings.vue +252 -252
- package/components/common/vm/actions/editSettings/EditSettingsOld.vue +200 -200
- package/components/common/vm/actions/editSettings/lib/config/modal.ts +12 -12
- package/components/common/vm/actions/editSettings/lib/models/types.ts +23 -23
- package/components/common/vm/actions/editSettings/lib/utils.ts +42 -42
- package/components/common/vm/actions/editSettings/new/New.vue +201 -201
- package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
- package/components/common/vm/actions/lib/models/interfaces.ts +40 -40
- package/components/common/vm/actions/lib/models/types.ts +11 -11
- package/components/common/vm/actions/lib/utils.ts +239 -239
- package/components/common/vm/lib/models/interfaces.ts +9 -9
- package/components/common/vm/lib/utils/powerActions.ts +55 -55
- package/components/common/vmt/actions/add/Add.vue +548 -548
- package/components/common/vmt/actions/add/New.vue +346 -347
- package/components/common/vmt/actions/add/Old.vue +304 -304
- package/components/common/vmt/actions/add/lib/config/steps.ts +107 -107
- package/components/common/vmt/actions/add/lib/models/interfaces.ts +23 -23
- package/components/common/weekSelect/WeekSelect.vue +143 -143
- package/components/common/weekSelect/lib/config/options.ts +10 -10
- package/components/common/weekSelect/lib/models/interfaces.ts +6 -6
- package/components/common/wizards/datastore/add/Add.vue +224 -224
- package/components/common/wizards/datastore/add/New.vue +259 -259
- package/components/common/wizards/datastore/add/Old.vue +129 -129
- package/components/common/wizards/datastore/add/lib/config/createDatastore.ts +16 -16
- package/components/common/wizards/datastore/add/lib/config/steps.ts +175 -175
- package/components/common/wizards/datastore/add/lib/models/enums.ts +5 -5
- package/components/common/wizards/datastore/add/lib/models/interfaces.ts +22 -22
- package/components/common/wizards/datastore/add/lib/models/types.ts +7 -7
- package/components/common/wizards/datastore/add/lib/utils.ts +63 -63
- package/components/common/wizards/datastore/add/lib/validations.ts +199 -199
- package/components/common/wizards/datastore/add/steps/_kerberosAuthentication/KerberosAuthentication.vue +56 -56
- package/components/common/wizards/datastore/add/steps/_kerberosAuthentication/lib/config/radioOptions.ts +27 -27
- package/components/common/wizards/datastore/add/steps/_local/Local.vue +46 -46
- package/components/common/wizards/datastore/add/steps/_local/createName/CreateName.vue +116 -116
- package/components/common/wizards/datastore/add/steps/_nfsVersion/NfsVersion.vue +24 -24
- package/components/common/wizards/datastore/add/steps/_nfsVersion/lib/config/versionOptions.ts +23 -23
- package/components/common/wizards/datastore/add/steps/_partitionConfiguration/PartitionConfiguration.vue +245 -245
- package/components/common/wizards/datastore/add/steps/_partitionConfiguration/graphicTooltip/graphicTooltip.vue +64 -64
- package/components/common/wizards/datastore/add/steps/_partitionConfiguration/lib/config/selectOptions.ts +46 -46
- package/components/common/wizards/datastore/add/steps/_partitionConfiguration/sizeGraphic/sizeGraphic.vue +225 -225
- package/components/common/wizards/datastore/add/steps/_vmfsVersion/Version.vue +29 -29
- package/components/common/wizards/datastore/add/steps/_vmfsVersion/lib/config/versionOptions.ts +21 -21
- package/components/common/wizards/datastore/add/steps/hostAccessibility/HostAccessibility.vue +59 -59
- package/components/common/wizards/datastore/add/steps/hostAccessibility/HostAccessibilityNew.vue +53 -53
- package/components/common/wizards/datastore/add/steps/hostAccessibility/HostAccessibilityOld.vue +55 -55
- package/components/common/wizards/datastore/add/steps/hostAccessibility/lib/config/tabsPannel.ts +30 -30
- package/components/common/wizards/datastore/add/steps/hostAccessibility/lib/models/types.ts +3 -3
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/Table.vue +39 -39
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/lib/models/interfaces.ts +11 -11
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/new/New.vue +113 -113
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/new/lib/config/compatibleTable.ts +83 -83
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/old/Old.vue +90 -90
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/old/lib/config/compatibleTable.ts +58 -58
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/old/lib/config/incompatibleTable.ts +68 -68
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/old/lib/config/tableKeys.ts +15 -15
- package/components/common/wizards/datastore/add/steps/hostAccessibility/table/old/lib/models/types.ts +6 -6
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigure.vue +50 -49
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureNew.vue +232 -232
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/NameAndConfigureOld.vue +230 -230
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/DeletePopover.vue +99 -99
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/ServersList.vue +129 -129
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/lib/config/serversListConfig.ts +43 -43
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/lib/config/tableKeys.ts +3 -3
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/lib/models/interfaces.ts +3 -3
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/_serversList/lib/models/types.ts +1 -1
- package/components/common/wizards/datastore/add/steps/nameAndConfigure/lib/models/interfaces.ts +5 -5
- package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDevice.vue +148 -148
- package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +227 -227
- package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceOld.vue +226 -226
- package/components/common/wizards/datastore/add/steps/nameAndDevice/lib/config/selectOptions.ts +13 -13
- package/components/common/wizards/datastore/add/steps/nameAndDevice/lib/models/interfaces.ts +16 -16
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/Table.vue +73 -73
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/lib/models/interfaces.ts +15 -15
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/new/New.vue +171 -171
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/new/lib/config/lunDiskTable.ts +185 -185
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/new/lib/models/enums.ts +16 -16
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/old/Old.vue +99 -99
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/old/lib/config/lunDiskTable.ts +84 -84
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/old/lib/config/tableKeys.ts +11 -11
- package/components/common/wizards/datastore/add/steps/nameAndDevice/table/old/lib/models/types.ts +9 -9
- package/components/common/wizards/datastore/add/steps/readyComplete/ReadyComplete.vue +44 -44
- package/components/common/wizards/datastore/add/steps/readyComplete/ReadyCompleteNew.vue +164 -164
- package/components/common/wizards/datastore/add/steps/readyComplete/ReadyCompleteOld.vue +103 -103
- package/components/common/wizards/datastore/add/steps/readyComplete/lib/config/propertiesDetails.ts +160 -160
- package/components/common/wizards/datastore/add/steps/typeMode/TypeMode.vue +35 -35
- package/components/common/wizards/datastore/add/steps/typeMode/TypeModeNew.vue +101 -101
- package/components/common/wizards/datastore/add/steps/typeMode/TypeModeOld.vue +71 -71
- package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
- package/components/common/wizards/network/add/Add.vue +1088 -1088
- package/components/common/wizards/network/add/lib/config/config.ts +36 -36
- package/components/common/wizards/network/add/lib/config/initialData.ts +62 -62
- package/components/common/wizards/network/add/lib/config/portPropertiesStep.ts +43 -43
- package/components/common/wizards/network/add/lib/config/selectSwitch.ts +19 -19
- package/components/common/wizards/network/add/lib/config/sendData.ts +141 -141
- package/components/common/wizards/network/add/lib/config/steps.ts +497 -497
- package/components/common/wizards/network/add/lib/models/enums.ts +17 -17
- package/components/common/wizards/network/add/lib/models/interfaces.ts +249 -249
- package/components/common/wizards/network/add/lib/models/types.ts +14 -14
- package/components/common/wizards/network/add/lib/utils/utils.ts +4 -4
- package/components/common/wizards/network/add/mappers/mappers.ts +192 -192
- package/components/common/wizards/network/add/modals/SelectNetwork.vue +177 -177
- package/components/common/wizards/network/add/modals/SelectStandardSwitch.vue +143 -143
- package/components/common/wizards/network/add/modals/SelectSwitch.vue +136 -136
- package/components/common/wizards/network/add/steps/ConnectionSettings.vue +154 -154
- package/components/common/wizards/network/add/steps/CreateStandardSwitch.vue +91 -91
- package/components/common/wizards/network/add/steps/IpFourSettings.vue +309 -309
- package/components/common/wizards/network/add/steps/PhysicalAdapter.vue +13 -13
- package/components/common/wizards/network/add/steps/PortProperties.vue +411 -411
- package/components/common/wizards/network/add/steps/ReadyComplete.vue +20 -20
- package/components/common/wizards/network/add/steps/SelectConnectionType.vue +112 -112
- package/components/common/wizards/network/add/steps/SelectedTargetDevice.vue +467 -467
- package/components/common/wizards/network/add/validations/common.ts +26 -26
- package/components/common/wizards/network/add/validations/connectionSettings.ts +70 -70
- package/components/common/wizards/network/add/validations/createStandardSwitch.ts +59 -59
- package/components/common/wizards/network/add/validations/ipFourSettings.ts +182 -182
- package/components/common/wizards/network/add/validations/networkValidation.ts +77 -77
- package/components/common/wizards/network/add/validations/physicalAdapter.ts +70 -70
- package/components/common/wizards/network/add/validations/portProperties.ts +83 -83
- package/components/common/wizards/network/add/validations/targetDevice.ts +109 -109
- package/components/common/wizards/network/add/validations/validations.ts +43 -43
- package/components/common/wizards/vm/common/computeResource/TreeView.vue +58 -58
- package/components/common/wizards/vm/common/tooltip/Tooltip.vue +84 -84
- package/components/common/wizards/vm/common/validation/compatibility/Compatibility.vue +62 -62
- package/components/common/wizards/vm/common/validation/lib/models/enums.ts +5 -5
- package/components/common/wizards/vm/migrate/Migrate.vue +353 -353
- package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +221 -221
- package/components/common/wizards/vm/migrate/lib/config/steps.ts +157 -157
- package/components/common/wizards/vm/migrate/lib/models/enums.ts +12 -12
- package/components/common/wizards/vm/migrate/lib/models/interfaces.ts +35 -35
- package/components/common/wizards/vm/migrate/lib/validations.ts +68 -68
- package/components/common/wizards/vm/migrate/select/computeResource/ComputeResource.vue +195 -195
- package/components/common/wizards/vm/migrate/select/computeResource/lib/config/tabsPannel.ts +39 -39
- package/components/common/wizards/vm/migrate/select/computeResource/lib/models/enums.ts +6 -6
- package/components/common/wizards/vm/migrate/select/computeResource/lib/models/interfaces.ts +31 -31
- package/components/common/wizards/vm/migrate/select/computeResource/lib/models/types.ts +12 -12
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/TableView.vue +138 -138
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/clusterTable.ts +113 -113
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/hostTable.ts +124 -124
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/resourcePoolTable.ts +115 -115
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/tableKeys.ts +65 -65
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/config/vappsTable.ts +68 -68
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/models/interfaces.ts +50 -50
- package/components/common/wizards/vm/migrate/select/computeResource/tableView/lib/models/types.ts +60 -60
- package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
- package/components/common/wizards/vm/migrate/select/network/lib/models/interfaces.ts +4 -4
- package/components/common/wizards/vm/migrate/select/network/table/network/Network.vue +150 -150
- package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
- package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/basicTable.ts +70 -70
- package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/tableKeys.ts +13 -13
- package/components/common/wizards/vm/migrate/select/network/table/network/lib/models/interfaces.ts +12 -12
- package/components/common/wizards/vm/migrate/select/network/table/network/lib/models/types.ts +21 -21
- package/components/common/wizards/vm/migrate/select/network/table/useAt/UseAt.vue +54 -54
- package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/config/tableKeys.ts +7 -7
- package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/config/useAtTable.ts +47 -47
- package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/models/interfaces.ts +1 -1
- package/components/common/wizards/vm/migrate/select/network/table/useAt/lib/models/types.ts +5 -5
- package/components/common/wizards/vm/migrate/select/priority/Priority.vue +43 -43
- package/components/common/wizards/vm/migrate/select/priority/lib/config/typeOptions.ts +28 -28
- package/components/common/wizards/vm/migrate/select/priority/lib/models/types.ts +1 -1
- package/components/common/wizards/vm/migrate/select/storage/Storage.vue +174 -174
- package/components/common/wizards/vm/migrate/select/storage/configure/batch/Batch.vue +68 -68
- package/components/common/wizards/vm/migrate/select/storage/configure/batch/config/virtualDiskFormat.ts +31 -31
- package/components/common/wizards/vm/migrate/select/storage/configure/batch/table/Table.vue +128 -128
- package/components/common/wizards/vm/migrate/select/storage/configure/batch/table/lib/config/datastoreTable.ts +177 -177
- package/components/common/wizards/vm/migrate/select/storage/configure/batch/table/lib/models/types.ts +15 -15
- package/components/common/wizards/vm/migrate/select/storage/configure/disk/Disk.vue +68 -68
- package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/Table.vue +74 -74
- package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/config/diskTable.ts +136 -136
- package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/config/tableKeys.ts +15 -15
- package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/models/interfaces.ts +29 -29
- package/components/common/wizards/vm/migrate/select/storage/configure/disk/table/lib/models/types.ts +13 -13
- package/components/common/wizards/vm/migrate/select/storage/lib/config/tabsPannel.ts +21 -21
- package/components/common/wizards/vm/migrate/select/storage/lib/models/enums.ts +6 -6
- package/components/common/wizards/vm/migrate/select/storage/lib/models/types.ts +9 -9
- package/components/common/wizards/vm/migrate/select/storage/policy/Policy.vue +84 -84
- package/components/common/wizards/vm/migrate/select/storage/selectedPerDisk/SelectedPerDisk.vue +80 -80
- package/components/common/wizards/vm/migrate/select/targetServer/lib/config/tabsPannel.ts +19 -19
- package/components/common/wizards/vm/migrate/select/targetServer/lib/models/types.ts +1 -1
- package/components/common/wizards/vm/migrate/select/targetServer/new/New.vue +258 -258
- package/components/common/wizards/vm/migrate/select/targetServer/new/lib/models/interfaces.ts +11 -11
- package/components/common/wizards/vm/migrate/select/targetServer/saved/Saved.vue +27 -27
- package/components/common/wizards/vm/migrate/select/targetServer/targetServer.vue +51 -51
- package/components/common/wizards/vm/migrate/select/type/Type.vue +27 -27
- package/components/common/wizards/vm/migrate/select/type/lib/config/typeOptions.ts +45 -45
- package/components/common/wizards/vm/migrate/select/type/lib/models/interfaces.ts +6 -6
- package/components/common/wizards/vm/migrate/select/type/lib/models/types.ts +5 -5
- package/components/common/wizards/vm/migrate/vmOrigin/VmOrigin.vue +94 -94
- package/components/common/wizards/vm/migrate/vmOrigin/lib/models/interfaces.ts +20 -20
- package/components/common/wizards/vm/migrate/vmOrigin/lib/utils/constructItems.ts +74 -74
- package/components/content/Hint.vue +24 -24
- package/components/lib/models/interfaces.ts +14 -14
- package/composables/deepCopy.ts +21 -21
- package/composables/productNameLocal.ts +30 -30
- package/composables/useAppVersion.ts +21 -21
- package/composables/useDiff.ts +15 -15
- package/composables/useEnvLanguage.ts +23 -23
- package/composables/useLocal.ts +51 -51
- package/composables/useLocalStorage.ts +45 -45
- package/composables/useThrottle.ts +32 -32
- package/composables/useUniqueId.ts +5 -5
- package/eslint/index.js +15 -15
- package/eslint/no-import-type.js +17 -17
- package/eslint/no-invalid-type-prefix.js +32 -32
- package/layouts/auth.vue +32 -32
- package/lib/config/regExp.ts +18 -18
- package/lib/config/uiTable.ts +20 -20
- package/lib/models/composables/useAppVersion/interfaces.ts +5 -5
- package/lib/models/composables/useMyFetch/interfaces.ts +25 -25
- package/lib/models/composables/useMyFetch/types.ts +1 -1
- package/lib/models/enums.ts +35 -35
- package/lib/models/interfaces.ts +91 -91
- package/lib/models/plugins/date/interfaces.ts +5 -5
- package/lib/models/plugins/date/types.ts +1 -1
- package/lib/models/plugins/panelStates/interfaces.ts +5 -5
- package/lib/models/plugins/validation/interfaces.ts +21 -21
- package/lib/models/plugins/validation/types.ts +1 -1
- package/lib/models/store/host/interfaces.ts +38 -38
- package/lib/models/store/interfaces.ts +45 -45
- package/lib/models/store/network/interfaces.ts +13 -13
- package/lib/models/store/storage/interfaces.ts +32 -32
- package/lib/models/store/tasks/enums.ts +34 -34
- package/lib/models/store/tasks/interfaces.ts +137 -137
- package/lib/models/store/tasks/types.ts +2 -2
- package/lib/models/store/types.ts +43 -43
- package/lib/models/store/vm/interfaces.ts +397 -397
- package/lib/models/table/interfaces.ts +57 -57
- package/lib/models/table/types.ts +1 -1
- package/lib/models/types.ts +58 -58
- package/lib/utils/base64.ts +34 -34
- package/lib/utils/contentBuild.ts +34 -34
- package/lib/utils/date.ts +12 -12
- package/lib/utils/notification.ts +22 -22
- package/lib/utils/sendTask.ts +73 -73
- package/lib/utils/token.ts +34 -34
- package/lib/utils/utils.ts +60 -60
- package/minify.js +146 -146
- package/modules/fixContentBuild/index.ts +91 -91
- package/modules/fixContentBuild/lib/utils/methods.ts +115 -115
- package/modules/fixSpiceConsoleBuild/index.ts +28 -28
- package/modules/replaceEnv/index.ts +40 -40
- package/modules/setLastUpdateTime/index.ts +36 -36
- package/modules/setLastUpdateTime/lib/utils/methods.ts +31 -31
- package/nuxt.config.ts +8 -8
- package/package.json +2 -2
- package/plugins/binary.ts +164 -164
- package/plugins/console.ts +22 -22
- package/plugins/cron.ts +75 -75
- package/plugins/date.ts +233 -233
- package/plugins/directives.ts +74 -74
- package/plugins/helpers.ts +18 -18
- package/plugins/number.ts +18 -18
- package/plugins/panelStates.ts +70 -70
- package/plugins/recursion.ts +388 -388
- package/plugins/spice-console/spice.console.ts +147 -147
- package/plugins/text.ts +59 -59
- package/plugins/time.ts +17 -17
- package/plugins/validation.ts +178 -178
- package/public/spice-console/application/WorkerProcess.js +3350 -3350
- package/public/spice-console/application/WorkerProcess_back.js +3144 -3144
- package/public/spice-console/application/WorkerProcess_meta.js +3103 -3103
- package/public/spice-console/application/WorkerProcess_reverse.js +3214 -3214
- package/public/spice-console/application/agent.js +178 -178
- package/public/spice-console/application/application.js +641 -641
- package/public/spice-console/application/checkActivity.js +50 -50
- package/public/spice-console/application/clientgui.js +849 -849
- package/public/spice-console/application/clipboard/clipboarddataparser.js +92 -92
- package/public/spice-console/application/clipboard/local/localClipboard.js +110 -110
- package/public/spice-console/application/clipboard.js +82 -82
- package/public/spice-console/application/codec.js +264 -264
- package/public/spice-console/application/imagecache.js +81 -81
- package/public/spice-console/application/inputmanager.js +270 -270
- package/public/spice-console/application/packetfactory.js +206 -206
- package/public/spice-console/application/packetfilter.js +103 -103
- package/public/spice-console/application/packetprocess.js +75 -75
- package/public/spice-console/application/rasteroperation.js +118 -118
- package/public/spice-console/application/spiceconnection.js +197 -197
- package/public/spice-console/application/stream.js +67 -67
- package/public/spice-console/application/virtualmouse.js +109 -109
- package/public/spice-console/keymaps/keyevent.js +36 -36
- package/public/spice-console/keymaps/keymap.js +229 -229
- package/public/spice-console/keymaps/keymapes.js +375 -375
- package/public/spice-console/keymaps/keymapesObj.js +317 -317
- package/public/spice-console/keymaps/keymapus.js +317 -317
- package/public/spice-console/keymaps/scanCodeObjModifier.js +65 -65
- package/public/spice-console/keymaps/scanCodeObjProvider.js +60 -60
- package/public/spice-console/lib/AsyncConsumer.js +204 -204
- package/public/spice-console/lib/AsyncWorker.js +60 -60
- package/public/spice-console/lib/CollisionDetector.js +27 -27
- package/public/spice-console/lib/DataLogger.js +197 -197
- package/public/spice-console/lib/GenericObjectPool.js +152 -152
- package/public/spice-console/lib/GlobalPool.js +114 -114
- package/public/spice-console/lib/ImageUncompressor.js +138 -138
- package/public/spice-console/lib/IntegrationBenchmark.js +64 -64
- package/public/spice-console/lib/PacketWorkerIdentifier.js +107 -107
- package/public/spice-console/lib/SyncAsyncHandler.js +46 -46
- package/public/spice-console/lib/base64.js +298 -298
- package/public/spice-console/lib/biginteger.js +1640 -1640
- package/public/spice-console/lib/bowser.js +276 -276
- package/public/spice-console/lib/decoder/dixie.js +7930 -7930
- package/public/spice-console/lib/decoder/jmuxer.js +2815 -2815
- package/public/spice-console/lib/displayRouter.js +83 -83
- package/public/spice-console/lib/encrypt.js +191 -191
- package/public/spice-console/lib/flipper.js +39 -39
- package/public/spice-console/lib/graphic.js +1230 -1230
- package/public/spice-console/lib/graphicdebug.js +223 -223
- package/public/spice-console/lib/images/bitmap.js +203 -203
- package/public/spice-console/lib/images/jsquic_family.js +83 -83
- package/public/spice-console/lib/images/jsquic_rgba.js +342 -342
- package/public/spice-console/lib/images/jsquic_uncompress.js +529 -529
- package/public/spice-console/lib/images/lz.js +717 -717
- package/public/spice-console/lib/images/png.js +275 -275
- package/public/spice-console/lib/jgestures.min.js +43 -43
- package/public/spice-console/lib/jquery-2.0.3.js +8829 -8829
- package/public/spice-console/lib/jquery-mousewheel.js +83 -83
- package/public/spice-console/lib/jquery-visibility.min.js +1 -1
- package/public/spice-console/lib/jsbn.js +578 -578
- package/public/spice-console/lib/jsbn2.js +675 -675
- package/public/spice-console/lib/lodash.4.0.0.min.js +136 -136
- package/public/spice-console/lib/modernizr.js +39 -39
- package/public/spice-console/lib/pixastic.js +3244 -3244
- package/public/spice-console/lib/prettyprint.js +794 -794
- package/public/spice-console/lib/prng4.js +64 -64
- package/public/spice-console/lib/queue.js +259 -259
- package/public/spice-console/lib/rasterEngine.js +1024 -1024
- package/public/spice-console/lib/rng.js +87 -87
- package/public/spice-console/lib/runqueue.js +103 -103
- package/public/spice-console/lib/sha1.js +124 -124
- package/public/spice-console/lib/stuckkeyshandler.js +122 -122
- package/public/spice-console/lib/timelapsedetector.js +62 -62
- package/public/spice-console/lib/utils.js +327 -327
- package/public/spice-console/lib/virtualjoystick.js +370 -370
- package/public/spice-console/network/busconnection.js +195 -195
- package/public/spice-console/network/clusternodechooser.js +49 -49
- package/public/spice-console/network/connectioncontrol.js +60 -60
- package/public/spice-console/network/packetcontroller.js +62 -62
- package/public/spice-console/network/packetextractor.js +73 -73
- package/public/spice-console/network/packetlinkfactory.js +64 -64
- package/public/spice-console/network/packetreassembler.js +77 -77
- package/public/spice-console/network/reassemblerfactory.js +39 -39
- package/public/spice-console/network/sizedefiner.js +86 -86
- package/public/spice-console/network/socket.js +120 -120
- package/public/spice-console/network/socketqueue.js +95 -95
- package/public/spice-console/network/spicechannel.js +390 -390
- package/public/spice-console/network/websocketwrapper.js +75 -75
- package/public/spice-console/process/busprocess.js +309 -309
- package/public/spice-console/process/cursorprocess.js +111 -111
- package/public/spice-console/process/displaypreprocess.js +152 -152
- package/public/spice-console/process/displayprocess.js +210 -210
- package/public/spice-console/process/inputprocess.js +203 -203
- package/public/spice-console/process/mainprocess.js +78 -78
- package/public/spice-console/process/playbackprocess.js +233 -233
- package/public/spice-console/run.js +187 -187
- package/public/spice-console/spiceobjects/generated/protocol.js +538 -538
- package/public/spice-console/spiceobjects/spiceobjects.js +3488 -3488
- package/public/spice-console/swcanvas/swcanvas.js +82 -82
- package/public/spice-console/tools/generate.php +269 -269
- package/public/spice-console/tools/generateKeyboardLayout.php +63 -63
- package/public/spice-console/tools/generateSpiceObject.php +81 -81
- package/store/main/actions.ts +8 -8
- package/store/main/getters.ts +7 -7
- package/store/main/lib/interfaces.ts +15 -15
- package/store/main/mutations.ts +7 -7
- package/store/main/state.ts +7 -7
- package/store/main/store.ts +12 -12
- package/store/storage/device/lib/models/interfaces.ts +26 -26
- package/store/tasks/actions.ts +134 -134
- package/store/tasks/getters.ts +25 -25
- package/store/tasks/lib/models/enums.ts +9 -9
- package/store/tasks/lib/models/interfaces.ts +18 -18
- package/store/tasks/mappers/recentTasks.ts +90 -90
- package/store/tasks/mappers/tasks.ts +45 -45
- package/store/tasks/mutations.ts +58 -58
- package/store/tasks/state.ts +16 -16
- package/store/tasks/store.ts +12 -12
- package/tsconfig.json +4 -4
- package/components/atoms/wizard/lib/models/enums.ts +0 -8
- package/components/atoms/wizard/lib/models/interfaces.ts +0 -59
- package/components/atoms/wizard/lib/utils/utils.ts +0 -954
@@ -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>
|