@demos-europe/demosplan-ui 0.4.12 → 0.4.13
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/.yarn/install-state.gz +0 -0
- package/CHANGELOG.md +10 -0
- package/babel.config.js +9 -9
- package/dist/demosplan-ui.umd.js +1 -1
- package/eslint.config.js +104 -0
- package/jest/shallowMountWithGlobalMocks.js +8 -6
- package/jest.config.js +4 -4
- package/package.json +12 -5
- package/scripts/buildTokens.js +1 -1
- package/scripts/utils/transformTokens.js +2 -2
- package/src/components/DpAccordion/DpAccordion.vue +4 -4
- package/src/components/DpAnonymizeText/DpAnonymizeText.vue +4 -4
- package/src/components/DpBulkEditHeader/DpBulkEditHeader.stories.tsx +1 -1
- package/src/components/DpButton/DpButton.vue +51 -43
- package/src/components/DpButtonIcon/DpButtonIcon.vue +5 -5
- package/src/components/DpButtonRow/DpButtonRow.vue +5 -5
- package/src/components/DpCheckbox/DpCheckbox.vue +2 -2
- package/src/components/DpCheckboxGroup/DpCheckboxGroup.vue +4 -4
- package/src/components/DpColumnSelector/DpColumnSelector.vue +1 -1
- package/src/components/DpContextualHelp/DpContextualHelp.vue +4 -4
- package/src/components/DpDataTable/DpDataTable.vue +53 -49
- package/src/components/DpDataTable/DpResizableColumn.vue +1 -1
- package/src/components/DpDataTable/DpTableHeader.vue +6 -4
- package/src/components/DpDataTable/DpTableRow.vue +1 -1
- package/src/components/DpDataTableExtended/DpDataTableExtended.vue +8 -8
- package/src/components/DpDataTableExtended/DpSelectPageItemCount.vue +2 -2
- package/src/components/DpDatetimePicker/DpDatetimePicker.vue +6 -6
- package/src/components/DpDetails/DpDetails.vue +1 -1
- package/src/components/DpDraggable/DpDraggable.vue +10 -12
- package/src/components/DpEditor/DpEditor.vue +45 -45
- package/src/components/DpEditor/DpResizableImage.vue +6 -6
- package/src/components/DpEditor/DpUploadModal.vue +11 -12
- package/src/components/DpEditor/MentionList.vue +5 -3
- package/src/components/DpEditor/libs/editorObscure.js +2 -2
- package/src/components/DpFlyout/DpFlyout.vue +5 -5
- package/src/components/DpIcon/util/iconConfig.ts +28 -28
- package/src/components/DpInlineNotification/DpInlineNotification.vue +2 -2
- package/src/components/DpLabel/DpLabel.vue +5 -3
- package/src/components/DpModal/DpModal.vue +5 -5
- package/src/components/DpMultiselect/DpMultiselect.vue +23 -25
- package/src/components/DpMultistepNav/DpMultistepNav.vue +2 -2
- package/src/components/DpPager/DpPager.vue +12 -12
- package/src/components/DpResettableInput/DpResettableInput.vue +3 -3
- package/src/components/DpSearchField/DpSearchField.vue +7 -2
- package/src/components/DpSelect/DpSelect.vue +3 -3
- package/src/components/DpSkeletonBox/DpSkeletonBox.vue +1 -1
- package/src/components/DpSlidebar/DpSlidebar.vue +2 -2
- package/src/components/DpSplitButton/DpSplitButton.vue +2 -2
- package/src/components/DpStickyElement/DpStickyElement.vue +1 -1
- package/src/components/DpTabs/DpTabs.vue +1 -1
- package/src/components/DpTextArea/DpTextArea.vue +4 -4
- package/src/components/DpTimePicker/DpTimePicker.vue +14 -14
- package/src/components/DpToggle/DpToggle.vue +1 -1
- package/src/components/DpTooltip/DpTooltip.vue +4 -2
- package/src/components/DpTooltip/utils/tooltip.js +4 -4
- package/src/components/DpTooltipIcon/DpTooltipIcon.vue +2 -2
- package/src/components/DpTransitionExpand/DpTransitionExpand.vue +1 -1
- package/src/components/DpTreeList/DpTreeList.vue +4 -4
- package/src/components/DpTreeList/DpTreeListCheckbox.vue +1 -1
- package/src/components/DpTreeList/DpTreeListNode.vue +12 -12
- package/src/components/DpUploadFiles/DpUpload.vue +2 -2
- package/src/components/DpUploadFiles/DpUploadFiles.vue +10 -10
- package/src/components/DpUploadFiles/DpUploadedFile.vue +6 -6
- package/src/components/DpUploadFiles/DpUploadedFileList.vue +4 -4
- package/src/components/DpVideoPlayer/DpVideoPlayer.vue +7 -7
- package/src/directives/CleanHtml/CleanHtml.js +1 -1
- package/src/directives/Tooltip/Tooltip.js +1 -1
- package/src/lib/ActionMenu.js +48 -48
- package/src/lib/DpApi.js +2 -2
- package/src/lib/FileInfo.js +15 -15
- package/src/lib/validation/utils/assignHandlerForTrigger.js +8 -8
- package/src/lib/validation/utils/assignHandlersForInputs.js +51 -51
- package/src/lib/validation/utils/assignObserver.js +29 -29
- package/src/lib/validation/utils/helpers.js +4 -4
- package/src/lib/validation/utils/validateForm.js +15 -15
- package/src/lib/validation/utils/validateInputField.js +11 -11
- package/src/utils/index.js +2 -2
- package/tokens/dist/js/boxShadow.js +1 -1
- package/tokens/dist/js/breakpoints.js +1 -1
- package/tokens/dist/js/color.brand.js +1 -1
- package/tokens/dist/js/color.data.js +1 -1
- package/tokens/dist/js/color.palette.js +1 -1
- package/tokens/dist/js/color.ui.js +1 -1
- package/tokens/dist/js/fontSize.js +1 -1
- package/tokens/dist/js/rounded.js +1 -1
- package/tokens/dist/js/space.js +1 -1
- package/tokens/dist/js/zIndex.js +1 -1
- package/tokens/dist/scss/_boxShadow.scss +1 -1
- package/tokens/dist/scss/_breakpoints.scss +1 -1
- package/tokens/dist/scss/_color.brand.scss +1 -1
- package/tokens/dist/scss/_color.data.scss +1 -1
- package/tokens/dist/scss/_color.palette.scss +1 -1
- package/tokens/dist/scss/_color.ui.scss +1 -1
- package/tokens/dist/scss/_fontSize.scss +1 -1
- package/tokens/dist/scss/_rounded.scss +1 -1
- package/tokens/dist/scss/_space.scss +1 -1
- package/tokens/dist/scss/_zIndex.scss +1 -1
- package/types/icons.ts +26 -26
- package/coverage/clover.xml +0 -6
- package/coverage/coverage-final.json +0 -1
- package/coverage/lcov-report/base.css +0 -224
- package/coverage/lcov-report/block-navigation.js +0 -87
- package/coverage/lcov-report/components/DpContextualHelp/DpContextualHelp.vue.html +0 -271
- package/coverage/lcov-report/components/DpContextualHelp/index.html +0 -116
- package/coverage/lcov-report/components/DpDataTableExtended/DataTableSearch.js.html +0 -190
- package/coverage/lcov-report/components/DpDataTableExtended/index.html +0 -116
- package/coverage/lcov-report/components/DpEditor/libs/handleWordPaste.js.html +0 -1138
- package/coverage/lcov-report/components/DpEditor/libs/index.html +0 -116
- package/coverage/lcov-report/components/DpIcon/DpIcon.vue.html +0 -256
- package/coverage/lcov-report/components/DpIcon/index.html +0 -131
- package/coverage/lcov-report/components/DpIcon/index.ts.html +0 -91
- package/coverage/lcov-report/components/DpIcon/util/iconVariables.js.html +0 -682
- package/coverage/lcov-report/components/DpIcon/util/index.html +0 -116
- package/coverage/lcov-report/components/DpTooltip/utils/index.html +0 -116
- package/coverage/lcov-report/components/DpTooltip/utils/tooltip.js.html +0 -490
- package/coverage/lcov-report/components/shared/index.html +0 -116
- package/coverage/lcov-report/components/shared/translations.js.html +0 -490
- package/coverage/lcov-report/directives/CleanHtml/CleanHtml.js.html +0 -265
- package/coverage/lcov-report/directives/CleanHtml/index.html +0 -116
- package/coverage/lcov-report/directives/Tooltip/Tooltip.js.html +0 -349
- package/coverage/lcov-report/directives/Tooltip/index.html +0 -116
- package/coverage/lcov-report/directives/index.html +0 -116
- package/coverage/lcov-report/directives/index.js.html +0 -109
- package/coverage/lcov-report/favicon.png +0 -0
- package/coverage/lcov-report/index.html +0 -101
- package/coverage/lcov-report/jest/index.html +0 -116
- package/coverage/lcov-report/jest/shallowMountWithGlobalMocks.js.html +0 -208
- package/coverage/lcov-report/prettify.css +0 -1
- package/coverage/lcov-report/prettify.js +0 -2
- package/coverage/lcov-report/sort-arrow-sprite.png +0 -0
- package/coverage/lcov-report/sorter.js +0 -196
- package/coverage/lcov-report/src/components/DpCheckbox/DpCheckbox.vue.html +0 -424
- package/coverage/lcov-report/src/components/DpCheckbox/index.html +0 -116
- package/coverage/lcov-report/src/components/DpContextualHelp/DpContextualHelp.vue.html +0 -361
- package/coverage/lcov-report/src/components/DpContextualHelp/index.html +0 -131
- package/coverage/lcov-report/src/components/DpContextualHelp/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpDataTableExtended/DataTableSearch.js.html +0 -190
- package/coverage/lcov-report/src/components/DpDataTableExtended/index.html +0 -116
- package/coverage/lcov-report/src/components/DpDraggable/DpDraggable.vue.html +0 -499
- package/coverage/lcov-report/src/components/DpDraggable/index.html +0 -131
- package/coverage/lcov-report/src/components/DpDraggable/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpEditor/libs/handleWordPaste.js.html +0 -1153
- package/coverage/lcov-report/src/components/DpEditor/libs/index.html +0 -116
- package/coverage/lcov-report/src/components/DpIcon/DpIcon.vue.html +0 -256
- package/coverage/lcov-report/src/components/DpIcon/index.html +0 -131
- package/coverage/lcov-report/src/components/DpIcon/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpIcon/util/iconVariables.js.html +0 -706
- package/coverage/lcov-report/src/components/DpIcon/util/index.html +0 -116
- package/coverage/lcov-report/src/components/DpInput/DpInput.vue.html +0 -937
- package/coverage/lcov-report/src/components/DpInput/index.html +0 -131
- package/coverage/lcov-report/src/components/DpInput/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpLabel/DpLabel.vue.html +0 -409
- package/coverage/lcov-report/src/components/DpLabel/index.html +0 -131
- package/coverage/lcov-report/src/components/DpLabel/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpModal/DpModal.vue.html +0 -739
- package/coverage/lcov-report/src/components/DpModal/index.html +0 -131
- package/coverage/lcov-report/src/components/DpModal/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpNotification/DpNotification.vue.html +0 -343
- package/coverage/lcov-report/src/components/DpNotification/index.html +0 -131
- package/coverage/lcov-report/src/components/DpNotification/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpObscure/DpObscure.vue.html +0 -148
- package/coverage/lcov-report/src/components/DpObscure/index.html +0 -131
- package/coverage/lcov-report/src/components/DpObscure/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpSelect/DpSelect.vue.html +0 -559
- package/coverage/lcov-report/src/components/DpSelect/index.html +0 -131
- package/coverage/lcov-report/src/components/DpSelect/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpTooltip/utils/index.html +0 -116
- package/coverage/lcov-report/src/components/DpTooltip/utils/tooltip.js.html +0 -490
- package/coverage/lcov-report/src/components/DpTreeList/DpTreeList.vue.html +0 -1099
- package/coverage/lcov-report/src/components/DpTreeList/DpTreeListCheckbox.vue.html +0 -301
- package/coverage/lcov-report/src/components/DpTreeList/DpTreeListNode.vue.html +0 -1144
- package/coverage/lcov-report/src/components/DpTreeList/DpTreeListToggle.vue.html +0 -382
- package/coverage/lcov-report/src/components/DpTreeList/index.html +0 -161
- package/coverage/lcov-report/src/components/DpTreeList/utils/constants.js.html +0 -100
- package/coverage/lcov-report/src/components/DpTreeList/utils/index.html +0 -116
- package/coverage/lcov-report/src/components/DpUploadFiles/DpUpload.vue.html +0 -979
- package/coverage/lcov-report/src/components/DpUploadFiles/DpUploadFiles.vue.html +0 -970
- package/coverage/lcov-report/src/components/DpUploadFiles/DpUploadedFile.vue.html +0 -340
- package/coverage/lcov-report/src/components/DpUploadFiles/DpUploadedFileList.vue.html +0 -202
- package/coverage/lcov-report/src/components/DpUploadFiles/index.html +0 -176
- package/coverage/lcov-report/src/components/DpUploadFiles/index.ts.html +0 -91
- package/coverage/lcov-report/src/components/DpUploadFiles/utils/UppyTranslations.js.html +0 -151
- package/coverage/lcov-report/src/components/DpUploadFiles/utils/index.html +0 -116
- package/coverage/lcov-report/src/components/shared/index.html +0 -116
- package/coverage/lcov-report/src/components/shared/translations.js.html +0 -508
- package/coverage/lcov-report/src/directives/CleanHtml/CleanHtml.js.html +0 -265
- package/coverage/lcov-report/src/directives/CleanHtml/index.html +0 -116
- package/coverage/lcov-report/src/directives/Tooltip/Tooltip.js.html +0 -349
- package/coverage/lcov-report/src/directives/Tooltip/index.html +0 -116
- package/coverage/lcov-report/src/directives/index.html +0 -116
- package/coverage/lcov-report/src/directives/index.js.html +0 -109
- package/coverage/lcov-report/src/lib/ActionMenu.js.html +0 -610
- package/coverage/lcov-report/src/lib/Detabinator.js.html +0 -304
- package/coverage/lcov-report/src/lib/DpApi.js.html +0 -748
- package/coverage/lcov-report/src/lib/DpConfirm.js.html +0 -118
- package/coverage/lcov-report/src/lib/DpGetCssVariable.js.html +0 -103
- package/coverage/lcov-report/src/lib/FileInfo.js.html +0 -574
- package/coverage/lcov-report/src/lib/HighlightHashLink.js.html +0 -160
- package/coverage/lcov-report/src/lib/MatchMedia.js.html +0 -220
- package/coverage/lcov-report/src/lib/SideNav.js.html +0 -712
- package/coverage/lcov-report/src/lib/Sticky.js.html +0 -223
- package/coverage/lcov-report/src/lib/TableWrapper.js.html +0 -214
- package/coverage/lcov-report/src/lib/index.html +0 -281
- package/coverage/lcov-report/src/lib/index.js.html +0 -190
- package/coverage/lcov-report/src/lib/validation/utils/assignHandlersForInputs.js.html +0 -400
- package/coverage/lcov-report/src/lib/validation/utils/helpers.js.html +0 -523
- package/coverage/lcov-report/src/lib/validation/utils/index.html +0 -236
- package/coverage/lcov-report/src/lib/validation/utils/validateDatepicker.js.html +0 -160
- package/coverage/lcov-report/src/lib/validation/utils/validateEmail.js.html +0 -136
- package/coverage/lcov-report/src/lib/validation/utils/validateFieldset.js.html +0 -163
- package/coverage/lcov-report/src/lib/validation/utils/validateForm.js.html +0 -205
- package/coverage/lcov-report/src/lib/validation/utils/validateInputField.js.html +0 -403
- package/coverage/lcov-report/src/lib/validation/utils/validateMultiselect.js.html +0 -121
- package/coverage/lcov-report/src/lib/validation/utils/validateTiptap.js.html +0 -160
- package/coverage/lcov-report/src/mixins/dpSelectAllMixin.js.html +0 -232
- package/coverage/lcov-report/src/mixins/dpValidateMixin.js.html +0 -460
- package/coverage/lcov-report/src/mixins/index.html +0 -176
- package/coverage/lcov-report/src/mixins/index.js.html +0 -124
- package/coverage/lcov-report/src/mixins/prefixClassMixin/index.html +0 -116
- package/coverage/lcov-report/src/mixins/prefixClassMixin/prefixClassMixin.js.html +0 -121
- package/coverage/lcov-report/src/mixins/sessionStorageMixin.js.html +0 -160
- package/coverage/lcov-report/src/mixins/tableSelectAllItems.js.html +0 -427
- package/coverage/lcov-report/src/shared/index.html +0 -116
- package/coverage/lcov-report/src/shared/index.js.html +0 -103
- package/coverage/lcov-report/src/shared/props/index.html +0 -116
- package/coverage/lcov-report/src/shared/props/props.js.html +0 -310
- package/coverage/lcov-report/src/utils/date.js.html +0 -208
- package/coverage/lcov-report/src/utils/debounce.js.html +0 -163
- package/coverage/lcov-report/src/utils/deepMerge.js.html +0 -175
- package/coverage/lcov-report/src/utils/formatBytes.js.html +0 -133
- package/coverage/lcov-report/src/utils/formatString.js.html +0 -109
- package/coverage/lcov-report/src/utils/fullscreen.js.html +0 -253
- package/coverage/lcov-report/src/utils/getAnimationEventName.js.html +0 -157
- package/coverage/lcov-report/src/utils/getScrollTop.js.html +0 -109
- package/coverage/lcov-report/src/utils/hasOwnProp.js.html +0 -142
- package/coverage/lcov-report/src/utils/hasPermission.js.html +0 -214
- package/coverage/lcov-report/src/utils/index.html +0 -341
- package/coverage/lcov-report/src/utils/index.js.html +0 -217
- package/coverage/lcov-report/src/utils/lengthHint/index.html +0 -116
- package/coverage/lcov-report/src/utils/lengthHint/lengthHint.js.html +0 -268
- package/coverage/lcov-report/src/utils/prefixClass.js.html +0 -199
- package/coverage/lcov-report/src/utils/resistFingerprintingDuckTest.js.html +0 -232
- package/coverage/lcov-report/src/utils/sortAlphabetically.js.html +0 -193
- package/coverage/lcov-report/src/utils/throttle.js.html +0 -145
- package/coverage/lcov-report/src/utils/uniqueArrayByObjectKey.js.html +0 -151
- package/coverage/lcov-report/utils/date.js.html +0 -208
- package/coverage/lcov-report/utils/debounce.js.html +0 -163
- package/coverage/lcov-report/utils/deepMerge.js.html +0 -175
- package/coverage/lcov-report/utils/formatBytes.js.html +0 -133
- package/coverage/lcov-report/utils/fullscreen.js.html +0 -253
- package/coverage/lcov-report/utils/getAnimationEventName.js.html +0 -157
- package/coverage/lcov-report/utils/getScrollTop.js.html +0 -109
- package/coverage/lcov-report/utils/hasOwnProp.js.html +0 -142
- package/coverage/lcov-report/utils/hasPermission.js.html +0 -214
- package/coverage/lcov-report/utils/index.html +0 -326
- package/coverage/lcov-report/utils/index.js.html +0 -211
- package/coverage/lcov-report/utils/lengthHint/index.html +0 -116
- package/coverage/lcov-report/utils/lengthHint/lengthHint.js.html +0 -268
- package/coverage/lcov-report/utils/prefixClass.js.html +0 -199
- package/coverage/lcov-report/utils/resistFingerprintingDuckTest.js.html +0 -232
- package/coverage/lcov-report/utils/sortAlphabetically.js.html +0 -193
- package/coverage/lcov-report/utils/throttle.js.html +0 -145
- package/coverage/lcov-report/utils/uniqueArrayByObjectKey.js.html +0 -151
- package/coverage/lcov.info +0 -0
- package/style/style.css +0 -1002
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<div
|
|
3
|
-
class="c-timepicker inline-block"
|
|
4
3
|
v-on-click-outside="closeFlyout"
|
|
4
|
+
class="c-timepicker inline-block"
|
|
5
5
|
@keydown.esc="closeFlyout"
|
|
6
6
|
@keydown.enter="e => handleEnter(e)">
|
|
7
7
|
<dp-label
|
|
@@ -10,30 +10,30 @@
|
|
|
10
10
|
:text="label" />
|
|
11
11
|
<dp-resettable-input
|
|
12
12
|
v-if="!isMobileDevice"
|
|
13
|
-
:data-cy="dataCy"
|
|
14
13
|
:id="`timeInput:${id}`"
|
|
15
14
|
:ref="`timeInput:${id}`"
|
|
15
|
+
:data-cy="dataCy"
|
|
16
16
|
class="w-8"
|
|
17
17
|
button-variant="small"
|
|
18
18
|
default-value="00:00"
|
|
19
19
|
:input-attributes="{ disabled: disabled, autocomplete: 'off' }"
|
|
20
|
+
pattern="([01]?[0-9]|2[0-3]):[0-5][0-9]"
|
|
21
|
+
:value="currentTime"
|
|
20
22
|
@reset="handleReset"
|
|
21
23
|
@enter="val => handleEnter(val)"
|
|
22
24
|
@focus="handleFocus"
|
|
23
25
|
@blur="handleBlur"
|
|
24
|
-
@input="val => handleInput(val)"
|
|
25
|
-
pattern="([01]?[0-9]|2[0-3]):[0-5][0-9]"
|
|
26
|
-
:value="currentTime" />
|
|
26
|
+
@input="val => handleInput(val)" />
|
|
27
27
|
<dp-input
|
|
28
28
|
v-else
|
|
29
|
-
:data-cy="dataCy"
|
|
30
29
|
:id="`timeInput:${id}`"
|
|
30
|
+
:data-cy="dataCy"
|
|
31
31
|
class="w-8"
|
|
32
32
|
type="time"
|
|
33
33
|
pattern="([01]?[0-9]|2[0-3]):[0-5][0-9]"
|
|
34
34
|
:value="currentTime"
|
|
35
|
-
|
|
36
|
-
|
|
35
|
+
autocomplete="off"
|
|
36
|
+
@input="val => handleInput(val)" />
|
|
37
37
|
|
|
38
38
|
<div
|
|
39
39
|
ref="flyout"
|
|
@@ -45,13 +45,13 @@
|
|
|
45
45
|
v-for="hour in availableHours"
|
|
46
46
|
:key="`${id}:hour:${hour}`"
|
|
47
47
|
class="c-timepicker__flyout-item"
|
|
48
|
-
:class="{'is-selected': currentHour === hour}">
|
|
48
|
+
:class="{ 'is-selected': currentHour === hour }">
|
|
49
49
|
<button
|
|
50
|
-
|
|
50
|
+
:id="`${id}:hour:${hour}`"
|
|
51
51
|
class="btn--blank u-ph-0_125 u-pv-0_125"
|
|
52
52
|
tabindex="0"
|
|
53
53
|
:value="hour"
|
|
54
|
-
|
|
54
|
+
@click.prevent="handleInput(hour, 'hour')">
|
|
55
55
|
{{ hour }}
|
|
56
56
|
</button>
|
|
57
57
|
</li>
|
|
@@ -63,13 +63,13 @@
|
|
|
63
63
|
v-for="minute in availableMinutes"
|
|
64
64
|
:key="`${id}:minute:${minute}`"
|
|
65
65
|
class="c-timepicker__flyout-item"
|
|
66
|
-
:class="{'is-selected': currentMinutes === minute}">
|
|
66
|
+
:class="{ 'is-selected': currentMinutes === minute }">
|
|
67
67
|
<button
|
|
68
|
-
|
|
68
|
+
:id="`${id}:minute:${minute}`"
|
|
69
69
|
tabindex="0"
|
|
70
70
|
class="btn--blank u-ph-0_125 u-pv-0_125"
|
|
71
71
|
:value="minute"
|
|
72
|
-
|
|
72
|
+
@click.prevent="handleInput(minute, 'minute')">
|
|
73
73
|
{{ minute }}
|
|
74
74
|
</button>
|
|
75
75
|
</li>
|
|
@@ -50,8 +50,10 @@ export default {
|
|
|
50
50
|
mounted () {
|
|
51
51
|
this.tooltipHook = this.$el
|
|
52
52
|
|
|
53
|
-
|
|
54
|
-
|
|
53
|
+
/*
|
|
54
|
+
* Check if there is exact one Child DOM-Element in the slot
|
|
55
|
+
* If so, put the tooltip on that element, otherwise on the wrapper
|
|
56
|
+
*/
|
|
55
57
|
if (this.$el.hasChildNodes() && this.$el.childNodes.length === 1 && Object.keys(this.$el.childNodes[0]).length > 0) {
|
|
56
58
|
this.tooltipHook = this.$el.childNodes[0]
|
|
57
59
|
}
|
|
@@ -93,10 +93,10 @@ const createTooltip = async (id, wrapperEl, { place = 'top', container = 'body',
|
|
|
93
93
|
})
|
|
94
94
|
|
|
95
95
|
/*
|
|
96
|
-
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
96
|
+
* Handles the position of the arrow - e.g. if the Tooltip is on the top,
|
|
97
|
+
* we want to place the arrow at the bottom, and so on. `placement` can be
|
|
98
|
+
* 'bottom-start' etc as well, so we have to make sure to only take the first part.
|
|
99
|
+
*/
|
|
100
100
|
const { x: arrowX, y: arrowY } = middlewareData.arrow
|
|
101
101
|
const opposedSide = {
|
|
102
102
|
top: 'bottom',
|
|
@@ -10,8 +10,8 @@
|
|
|
10
10
|
<div class="flex bg-color--white">
|
|
11
11
|
<dp-tree-list-checkbox
|
|
12
12
|
v-if="checkAll"
|
|
13
|
-
name="checkAll"
|
|
14
13
|
v-model="allElementsSelected"
|
|
14
|
+
name="checkAll"
|
|
15
15
|
check-all
|
|
16
16
|
:style="checkboxIndentationStyle" />
|
|
17
17
|
<div class="grow color--grey">
|
|
@@ -21,9 +21,9 @@
|
|
|
21
21
|
v-if="treeData.length > 0"
|
|
22
22
|
class="color--grey"
|
|
23
23
|
data-cy="treeListNodeToggle"
|
|
24
|
-
@input="toggleAll"
|
|
25
24
|
:value="allElementsExpanded"
|
|
26
|
-
toggle-all
|
|
25
|
+
toggle-all
|
|
26
|
+
@input="toggleAll" />
|
|
27
27
|
</div>
|
|
28
28
|
</div>
|
|
29
29
|
|
|
@@ -43,9 +43,9 @@
|
|
|
43
43
|
:opts="opts.draggable">
|
|
44
44
|
<dp-tree-list-node
|
|
45
45
|
v-for="(node, idx) in treeData"
|
|
46
|
-
:data-cy="`treeListNode:${idx}`"
|
|
47
46
|
:ref="`node_${node.id}`"
|
|
48
47
|
:key="node.id"
|
|
48
|
+
:data-cy="`treeListNode:${idx}`"
|
|
49
49
|
:check-branch="branchIdentifier"
|
|
50
50
|
:children="node.children || []"
|
|
51
51
|
:draggable="draggable"
|
|
@@ -1,13 +1,13 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<li
|
|
3
|
-
class="border--top relative"
|
|
4
3
|
:id="nodeId"
|
|
4
|
+
class="border--top relative"
|
|
5
5
|
data-cy="treeListNode">
|
|
6
6
|
<div class="c-treelist__node flex">
|
|
7
7
|
<div
|
|
8
|
+
v-if="isDraggable"
|
|
8
9
|
class="inline-block u-p-0_25 u-pr-0 u-mt-0_125"
|
|
9
|
-
:class="dragHandle"
|
|
10
|
-
v-if="isDraggable">
|
|
10
|
+
:class="dragHandle">
|
|
11
11
|
<dp-icon
|
|
12
12
|
class="c-treelist__drag-handle-icon"
|
|
13
13
|
icon="drag-handle" />
|
|
@@ -22,11 +22,11 @@
|
|
|
22
22
|
class="flex grow items-start"
|
|
23
23
|
:style="indentationStyle">
|
|
24
24
|
<dp-tree-list-toggle
|
|
25
|
-
class="c-treelist__folder text--left u-pv-0_25"
|
|
26
|
-
:class="{'pointer-events-none': 0 === children.length}"
|
|
27
|
-
:icon-class-prop="iconClassFolder"
|
|
28
25
|
v-if="isBranch"
|
|
29
|
-
v-model="isExpanded"
|
|
26
|
+
v-model="isExpanded"
|
|
27
|
+
class="c-treelist__folder text--left u-pv-0_25"
|
|
28
|
+
:class="{ 'pointer-events-none': 0 === children.length }"
|
|
29
|
+
:icon-class-prop="iconClassFolder" />
|
|
30
30
|
<div class="grow u-pl-0 u-p-0_25">
|
|
31
31
|
<slot
|
|
32
32
|
v-if="isBranch"
|
|
@@ -44,12 +44,12 @@
|
|
|
44
44
|
</div>
|
|
45
45
|
</div>
|
|
46
46
|
<dp-tree-list-toggle
|
|
47
|
-
data-cy="treeListChildToggle"
|
|
48
47
|
v-if="isBranch"
|
|
49
|
-
|
|
50
|
-
:disabled="!hasToggle"
|
|
48
|
+
v-model="isExpanded"
|
|
51
49
|
v-tooltip="!hasToggle ? translations.noElementsExisting : ''"
|
|
52
|
-
|
|
50
|
+
data-cy="treeListChildToggle"
|
|
51
|
+
class="self-start"
|
|
52
|
+
:disabled="!hasToggle" />
|
|
53
53
|
<div
|
|
54
54
|
v-else
|
|
55
55
|
class="min-w-4" />
|
|
@@ -71,9 +71,9 @@
|
|
|
71
71
|
<dp-tree-list-node
|
|
72
72
|
v-for="(child, idx) in children"
|
|
73
73
|
v-show="true === isExpanded"
|
|
74
|
-
:data-cy="`treeListChild:${idx}`"
|
|
75
74
|
:ref="`node_${child.id}`"
|
|
76
75
|
:key="child.id"
|
|
76
|
+
:data-cy="`treeListChild:${idx}`"
|
|
77
77
|
:check-branch="checkBranch"
|
|
78
78
|
:children="child.children || []"
|
|
79
79
|
:handle-change="handleChange"
|
|
@@ -26,9 +26,9 @@
|
|
|
26
26
|
|
|
27
27
|
--><dp-uploaded-file-list
|
|
28
28
|
v-if="uploadedFiles.length > 0"
|
|
29
|
-
@file-remove="handleRemove"
|
|
30
29
|
:class="[prefixClass('layout__item u-1-of-1-palm'), prefixClass(sideBySide ? 'u-1-of-2' : 'u-1-of-1 u-mt')]"
|
|
31
|
-
:files="uploadedFiles"
|
|
30
|
+
:files="uploadedFiles"
|
|
31
|
+
@file-remove="handleRemove" />
|
|
32
32
|
|
|
33
33
|
<!--
|
|
34
34
|
If the component is used in the context of a "traditional" form post, the hashes (ids)
|
|
@@ -61,16 +61,8 @@ export default {
|
|
|
61
61
|
DpUploadedFileList
|
|
62
62
|
},
|
|
63
63
|
|
|
64
|
-
emits: ['upload-success'],
|
|
65
|
-
|
|
66
64
|
mixins: [prefixClassMixin, sessionStorageMixin],
|
|
67
65
|
|
|
68
|
-
provide () {
|
|
69
|
-
return {
|
|
70
|
-
getFileByHash: this.getFileByHash
|
|
71
|
-
}
|
|
72
|
-
},
|
|
73
|
-
|
|
74
66
|
props: {
|
|
75
67
|
/**
|
|
76
68
|
* Array of mimeTypes or a defined preset as String
|
|
@@ -243,6 +235,14 @@ export default {
|
|
|
243
235
|
}
|
|
244
236
|
},
|
|
245
237
|
|
|
238
|
+
emits: ['upload-success'],
|
|
239
|
+
|
|
240
|
+
provide () {
|
|
241
|
+
return {
|
|
242
|
+
getFileByHash: this.getFileByHash
|
|
243
|
+
}
|
|
244
|
+
},
|
|
245
|
+
|
|
246
246
|
data () {
|
|
247
247
|
return {
|
|
248
248
|
fileHashes: [],
|
|
@@ -1,8 +1,8 @@
|
|
|
1
1
|
<template>
|
|
2
2
|
<li data-cy="uploadFile:uploadedFileItem">
|
|
3
3
|
<span
|
|
4
|
-
|
|
5
|
-
|
|
4
|
+
v-if="file.mimeType === 'txt'"
|
|
5
|
+
aria-hidden="true">
|
|
6
6
|
<i
|
|
7
7
|
:class="fileIcon" />
|
|
8
8
|
</span>
|
|
@@ -42,10 +42,6 @@ import { prefixClassMixin } from '~/mixins'
|
|
|
42
42
|
export default {
|
|
43
43
|
name: 'DpUploadedFile',
|
|
44
44
|
|
|
45
|
-
emits: ['file-remove'],
|
|
46
|
-
|
|
47
|
-
inject: ['getFileByHash'],
|
|
48
|
-
|
|
49
45
|
mixins: [prefixClassMixin],
|
|
50
46
|
|
|
51
47
|
props: {
|
|
@@ -55,6 +51,10 @@ export default {
|
|
|
55
51
|
}
|
|
56
52
|
},
|
|
57
53
|
|
|
54
|
+
emits: ['file-remove'],
|
|
55
|
+
|
|
56
|
+
inject: ['getFileByHash'],
|
|
57
|
+
|
|
58
58
|
data () {
|
|
59
59
|
return {
|
|
60
60
|
translations: {
|
|
@@ -8,9 +8,9 @@
|
|
|
8
8
|
<ul :class="prefixClass('o-list space-stack-xs')">
|
|
9
9
|
<dp-uploaded-file
|
|
10
10
|
v-for="(file, idx) in files"
|
|
11
|
+
:key="idx"
|
|
11
12
|
:file="file"
|
|
12
|
-
@file-remove="file => $emit('file-remove', file)"
|
|
13
|
-
:key="idx" />
|
|
13
|
+
@file-remove="file => $emit('file-remove', file)" />
|
|
14
14
|
</ul>
|
|
15
15
|
</div>
|
|
16
16
|
</template>
|
|
@@ -23,8 +23,6 @@ import { de } from "~/components/shared/translations"
|
|
|
23
23
|
export default {
|
|
24
24
|
name: 'DpUploadedFileList',
|
|
25
25
|
|
|
26
|
-
emits: ['file-remove'],
|
|
27
|
-
|
|
28
26
|
components: {
|
|
29
27
|
DpUploadedFile
|
|
30
28
|
},
|
|
@@ -39,6 +37,8 @@ export default {
|
|
|
39
37
|
}
|
|
40
38
|
},
|
|
41
39
|
|
|
40
|
+
emits: ['file-remove'],
|
|
41
|
+
|
|
42
42
|
data () {
|
|
43
43
|
return {
|
|
44
44
|
translations: {
|
|
@@ -121,6 +121,12 @@ export default defineComponent({
|
|
|
121
121
|
}
|
|
122
122
|
},
|
|
123
123
|
|
|
124
|
+
data () {
|
|
125
|
+
return {
|
|
126
|
+
player: {}
|
|
127
|
+
}
|
|
128
|
+
},
|
|
129
|
+
|
|
124
130
|
computed: {
|
|
125
131
|
isEmbeddedSource() {
|
|
126
132
|
return this.primarySource && this.primarySource.embedId && this.primarySource.provider
|
|
@@ -130,14 +136,8 @@ export default defineComponent({
|
|
|
130
136
|
}
|
|
131
137
|
},
|
|
132
138
|
|
|
133
|
-
data () {
|
|
134
|
-
return {
|
|
135
|
-
player: {}
|
|
136
|
-
}
|
|
137
|
-
},
|
|
138
|
-
|
|
139
139
|
mounted () {
|
|
140
|
-
|
|
140
|
+
|
|
141
141
|
this.player = new Plyr('#' + this.id, {
|
|
142
142
|
iconUrl: this.iconUrl,
|
|
143
143
|
// For a full list of available controls see https://github.com/sampotts/plyr/blob/master/CONTROLS.md
|
|
@@ -42,7 +42,7 @@ const getOptions = (value) => {
|
|
|
42
42
|
*/
|
|
43
43
|
const setSanitizedInnerHTML = (el, binding) => {
|
|
44
44
|
const { content, options = {} } = getOptions(binding.value)
|
|
45
|
-
const _options = {...options, ...{ ADD_ATTR: ['target'] } }
|
|
45
|
+
const _options = { ...options, ...{ ADD_ATTR: ['target'] } }
|
|
46
46
|
el.innerHTML = DOMPurify.sanitize(content, _options)
|
|
47
47
|
}
|
|
48
48
|
|
package/src/lib/ActionMenu.js
CHANGED
|
@@ -75,29 +75,29 @@ class ActionMenu {
|
|
|
75
75
|
|
|
76
76
|
handleTriggerKeydown (event) {
|
|
77
77
|
switch (event.keyCode) {
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
78
|
+
// Down
|
|
79
|
+
case 40:
|
|
80
|
+
// Prevent page scrolling
|
|
81
|
+
event.preventDefault()
|
|
82
|
+
this.openMenu()
|
|
83
|
+
this.menu.classList.remove(prefixClass('has-focused-trigger'))
|
|
84
|
+
this.menuItems[this.currentlySelectedIndex].focus()
|
|
85
|
+
break
|
|
86
86
|
|
|
87
87
|
// Up, tab
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
88
|
+
case 38:
|
|
89
|
+
case 9:
|
|
90
|
+
this.closeMenu()
|
|
91
|
+
break
|
|
92
92
|
|
|
93
93
|
// Esc
|
|
94
|
-
|
|
95
|
-
|
|
96
|
-
|
|
97
|
-
|
|
94
|
+
case 27:
|
|
95
|
+
this.closeMenu()
|
|
96
|
+
this.trigger.focus()
|
|
97
|
+
break
|
|
98
98
|
|
|
99
|
-
|
|
100
|
-
|
|
99
|
+
default:
|
|
100
|
+
break
|
|
101
101
|
}
|
|
102
102
|
}
|
|
103
103
|
|
|
@@ -107,40 +107,40 @@ class ActionMenu {
|
|
|
107
107
|
|
|
108
108
|
handleMenuItemKeydown (event) {
|
|
109
109
|
switch (event.keyCode) {
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
110
|
+
// Down
|
|
111
|
+
case 40:
|
|
112
|
+
// Prevent page scrolling
|
|
113
|
+
event.preventDefault()
|
|
114
|
+
if (this.currentlySelectedIndex < this.menuItems.length - 1) {
|
|
115
|
+
this.currentlySelectedIndex++
|
|
116
|
+
} else {
|
|
117
|
+
this.currentlySelectedIndex = 0
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
this.menuItems[this.currentlySelectedIndex].focus()
|
|
121
|
+
break
|
|
122
122
|
|
|
123
123
|
// Up
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
124
|
+
case 38:
|
|
125
|
+
// Prevent page scrolling
|
|
126
|
+
event.preventDefault()
|
|
127
|
+
if (this.currentlySelectedIndex === 0) {
|
|
128
|
+
this.currentlySelectedIndex = this.menuItems.length - 1
|
|
129
|
+
} else {
|
|
130
|
+
this.currentlySelectedIndex--
|
|
131
|
+
}
|
|
132
|
+
this.menuItems[this.currentlySelectedIndex].focus()
|
|
133
|
+
break
|
|
134
134
|
|
|
135
135
|
// Tab, esc
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
136
|
+
case 9:
|
|
137
|
+
case 27:
|
|
138
|
+
this.trigger.focus()
|
|
139
|
+
this.closeMenu()
|
|
140
|
+
break
|
|
141
|
+
|
|
142
|
+
default:
|
|
143
|
+
break
|
|
144
144
|
}
|
|
145
145
|
}
|
|
146
146
|
|
package/src/lib/DpApi.js
CHANGED
|
@@ -72,8 +72,8 @@ const doRequest = (async ({ method = 'GET', url, data = {}, headers, params }) =
|
|
|
72
72
|
const content = contentType.includes('json')
|
|
73
73
|
? await response.json()
|
|
74
74
|
: contentType.includes('text')
|
|
75
|
-
|
|
76
|
-
|
|
75
|
+
? await response.text()
|
|
76
|
+
: null
|
|
77
77
|
|
|
78
78
|
return {
|
|
79
79
|
data: content,
|
package/src/lib/FileInfo.js
CHANGED
|
@@ -68,26 +68,26 @@ const mimeTypes = {
|
|
|
68
68
|
const convertSize = function (scale, value) {
|
|
69
69
|
let returnValue
|
|
70
70
|
switch (scale) {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
71
|
+
case 'KB':
|
|
72
|
+
returnValue = value / 1024
|
|
73
|
+
break
|
|
74
|
+
case 'MB':
|
|
75
|
+
returnValue = value / 1048576
|
|
76
|
+
break
|
|
77
|
+
case 'GB':
|
|
78
|
+
returnValue = value / 1073741824
|
|
79
|
+
break
|
|
80
|
+
case 'TB':
|
|
81
|
+
returnValue = value / 1099511627776
|
|
82
|
+
break
|
|
83
|
+
/* This is the Default */
|
|
84
84
|
/*
|
|
85
85
|
* case 'B':
|
|
86
86
|
* returnValue = value;
|
|
87
87
|
* break;
|
|
88
88
|
*/
|
|
89
|
-
|
|
90
|
-
|
|
89
|
+
default:
|
|
90
|
+
returnValue = value
|
|
91
91
|
}
|
|
92
92
|
|
|
93
93
|
return Math.round(returnValue) + ' ' + scale
|
|
@@ -62,15 +62,15 @@ export default function assignHandlerForTrigger (triggerButton, form) {
|
|
|
62
62
|
document.dispatchEvent(new CustomEvent('customValidationFailed', { detail: { form: form } }))
|
|
63
63
|
} else {
|
|
64
64
|
switch (callback) {
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
submitAction(form, triggerName)
|
|
70
|
-
}
|
|
71
|
-
break
|
|
72
|
-
default:
|
|
65
|
+
case 'dpconfirm':
|
|
66
|
+
if (window.dpconfirm(transKey, true) === false) {
|
|
67
|
+
e.preventDefault()
|
|
68
|
+
} else {
|
|
73
69
|
submitAction(form, triggerName)
|
|
70
|
+
}
|
|
71
|
+
break
|
|
72
|
+
default:
|
|
73
|
+
submitAction(form, triggerName)
|
|
74
74
|
}
|
|
75
75
|
}
|
|
76
76
|
})
|