@dialpad/dialtone-vue 3.118.0 → 3.118.1-alpha.1
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/README.md +4 -4
- package/dist/chunks/_plugin-vue_export-helper-hUChTQA_.js +10 -0
- package/dist/chunks/_plugin-vue_export-helper-hUChTQA_.js.map +1 -0
- package/dist/chunks/dropdown-eWOvBvwq.js +396 -0
- package/dist/chunks/dropdown-eWOvBvwq.js.map +1 -0
- package/dist/chunks/dropdown_constants-EUcDxBrX.js +9 -0
- package/dist/chunks/dropdown_constants-EUcDxBrX.js.map +1 -0
- package/dist/chunks/icon_constants-OpYAAKwF.js +16 -0
- package/dist/chunks/icon_constants-OpYAAKwF.js.map +1 -0
- package/dist/chunks/index-BK8b99k1.js +256 -0
- package/dist/chunks/index-BK8b99k1.js.map +1 -0
- package/dist/chunks/index-b4iXYvId.js +399 -0
- package/dist/chunks/index-b4iXYvId.js.map +1 -0
- package/dist/chunks/input-4UQWegUk.js +273 -0
- package/dist/chunks/input-4UQWegUk.js.map +1 -0
- package/dist/chunks/input_group-bBKaq3Wi.js +150 -0
- package/dist/chunks/input_group-bBKaq3Wi.js.map +1 -0
- package/dist/chunks/keyboard_list_navigation-F0O8nht0.js +197 -0
- package/dist/chunks/keyboard_list_navigation-F0O8nht0.js.map +1 -0
- package/dist/chunks/link_constants-vIUB92L4.js +16 -0
- package/dist/chunks/link_constants-vIUB92L4.js.map +1 -0
- package/dist/chunks/list_item_constants-LTUc74pD.js +13 -0
- package/dist/chunks/list_item_constants-LTUc74pD.js.map +1 -0
- package/dist/chunks/modal-VuMFkZFH.js +82 -0
- package/dist/chunks/modal-VuMFkZFH.js.map +1 -0
- package/dist/chunks/notice_action-tJfD5Qw1.js +209 -0
- package/dist/chunks/notice_action-tJfD5Qw1.js.map +1 -0
- package/dist/chunks/notice_constants-c--hBFQw.js +6 -0
- package/dist/chunks/notice_constants-c--hBFQw.js.map +1 -0
- package/dist/chunks/popover_constants-qjlEkroB.js +114 -0
- package/dist/chunks/popover_constants-qjlEkroB.js.map +1 -0
- package/dist/chunks/sr_only_close_button-7O-Ev8uM.js +88 -0
- package/dist/chunks/sr_only_close_button-7O-Ev8uM.js.map +1 -0
- package/dist/chunks/stack_constants-u7tNqGtc.js +13 -0
- package/dist/chunks/stack_constants-u7tNqGtc.js.map +1 -0
- package/dist/chunks/tab-GQZFMq83.js +367 -0
- package/dist/chunks/tab-GQZFMq83.js.map +1 -0
- package/dist/component-documentation.json +1 -1
- package/dist/dialtone-vue.js +355 -12889
- package/dist/dialtone-vue.js.map +1 -1
- package/dist/lib/attachment-carousel.js +329 -0
- package/dist/lib/attachment-carousel.js.map +1 -0
- package/dist/lib/avatar.js +415 -0
- package/dist/lib/avatar.js.map +1 -0
- package/dist/lib/badge.js +192 -0
- package/dist/lib/badge.js.map +1 -0
- package/dist/lib/banner.js +234 -0
- package/dist/lib/banner.js.map +1 -0
- package/dist/lib/breadcrumbs.js +143 -0
- package/dist/lib/breadcrumbs.js.map +1 -0
- package/dist/lib/button-group.js +41 -0
- package/dist/lib/button-group.js.map +1 -0
- package/dist/lib/button.js +337 -0
- package/dist/lib/button.js.map +1 -0
- package/dist/lib/callbar-button-with-popover.js +306 -0
- package/dist/lib/callbar-button-with-popover.js.map +1 -0
- package/dist/lib/callbar-button.js +194 -0
- package/dist/lib/callbar-button.js.map +1 -0
- package/dist/lib/callbox.js +206 -0
- package/dist/lib/callbox.js.map +1 -0
- package/dist/lib/card.js +92 -0
- package/dist/lib/card.js.map +1 -0
- package/dist/lib/checkbox-group.js +105 -0
- package/dist/lib/checkbox-group.js.map +1 -0
- package/dist/lib/checkbox.js +145 -0
- package/dist/lib/checkbox.js.map +1 -0
- package/dist/lib/chip.js +220 -0
- package/dist/lib/chip.js.map +1 -0
- package/dist/lib/codeblock.js +24 -0
- package/dist/lib/codeblock.js.map +1 -0
- package/dist/lib/collapsible.js +377 -0
- package/dist/lib/collapsible.js.map +1 -0
- package/dist/lib/combobox-multi-select.js +497 -0
- package/dist/lib/combobox-multi-select.js.map +1 -0
- package/dist/lib/combobox-with-popover.js +408 -0
- package/dist/lib/combobox-with-popover.js.map +1 -0
- package/dist/lib/combobox.js +19 -0
- package/dist/lib/combobox.js.map +1 -0
- package/dist/lib/constants.js +53 -0
- package/dist/lib/constants.js.map +1 -0
- package/dist/lib/contact-info.js +198 -0
- package/dist/lib/contact-info.js.map +1 -0
- package/dist/lib/contact-row.js +243 -0
- package/dist/lib/contact-row.js.map +1 -0
- package/dist/lib/datepicker.js +712 -0
- package/dist/lib/datepicker.js.map +1 -0
- package/dist/lib/dates.js +57 -0
- package/dist/lib/dates.js.map +1 -0
- package/dist/lib/description-list.js +85 -0
- package/dist/lib/description-list.js.map +1 -0
- package/dist/lib/dropdown.js +37 -0
- package/dist/lib/dropdown.js.map +1 -0
- package/dist/lib/editor.js +676 -0
- package/dist/lib/editor.js.map +1 -0
- package/dist/{emoji_picker-vEQ--pAv.js → lib/emoji-picker.js} +139 -121
- package/dist/lib/emoji-picker.js.map +1 -0
- package/dist/lib/emoji-row.js +115 -0
- package/dist/lib/emoji-row.js.map +1 -0
- package/dist/{emoji_text_wrapper-icAiqYqk.js → lib/emoji-text-wrapper.js} +21 -15
- package/dist/lib/emoji-text-wrapper.js.map +1 -0
- package/dist/lib/emoji.js +12 -0
- package/dist/{emoji.js.map → lib/emoji.js.map} +1 -1
- package/dist/lib/feed-item-row.js +279 -0
- package/dist/lib/feed-item-row.js.map +1 -0
- package/dist/lib/feed-pill.js +162 -0
- package/dist/lib/feed-pill.js.map +1 -0
- package/dist/lib/general-row.js +481 -0
- package/dist/lib/general-row.js.map +1 -0
- package/dist/lib/group-row.js +115 -0
- package/dist/lib/group-row.js.map +1 -0
- package/dist/lib/grouped-chip.js +93 -0
- package/dist/lib/grouped-chip.js.map +1 -0
- package/dist/lib/hovercard.js +190 -0
- package/dist/lib/hovercard.js.map +1 -0
- package/dist/lib/icon.js +90 -0
- package/dist/lib/icon.js.map +1 -0
- package/dist/lib/image-viewer.js +221 -0
- package/dist/lib/image-viewer.js.map +1 -0
- package/dist/lib/input-group.js +90 -0
- package/dist/lib/input-group.js.map +1 -0
- package/dist/lib/input.js +531 -0
- package/dist/lib/input.js.map +1 -0
- package/dist/lib/item-layout.js +86 -0
- package/dist/lib/item-layout.js.map +1 -0
- package/dist/lib/ivr-node.js +247 -0
- package/dist/lib/ivr-node.js.map +1 -0
- package/dist/lib/keyboard-shortcut.js +111 -0
- package/dist/lib/keyboard-shortcut.js.map +1 -0
- package/dist/lib/lazy-show.js +81 -0
- package/dist/lib/lazy-show.js.map +1 -0
- package/dist/lib/link.js +43 -0
- package/dist/lib/link.js.map +1 -0
- package/dist/lib/list-item-group.js +66 -0
- package/dist/lib/list-item-group.js.map +1 -0
- package/dist/lib/list-item.js +207 -0
- package/dist/lib/list-item.js.map +1 -0
- package/dist/{message_input.js → lib/message-input.js} +173 -124
- package/dist/lib/message-input.js.map +1 -0
- package/dist/lib/mixins.js +17 -0
- package/dist/lib/mixins.js.map +1 -0
- package/dist/lib/modal.js +413 -0
- package/dist/lib/modal.js.map +1 -0
- package/dist/lib/notice.js +196 -0
- package/dist/lib/notice.js.map +1 -0
- package/dist/lib/pagination.js +192 -0
- package/dist/lib/pagination.js.map +1 -0
- package/dist/lib/popover.js +903 -0
- package/dist/lib/popover.js.map +1 -0
- package/dist/lib/presence.js +65 -0
- package/dist/lib/presence.js.map +1 -0
- package/dist/lib/radio-group.js +89 -0
- package/dist/lib/radio-group.js.map +1 -0
- package/dist/lib/radio.js +154 -0
- package/dist/lib/radio.js.map +1 -0
- package/dist/lib/rich-text-editor.js +925 -0
- package/dist/lib/rich-text-editor.js.map +1 -0
- package/dist/lib/root-layout.js +157 -0
- package/dist/lib/root-layout.js.map +1 -0
- package/dist/lib/scroller.js +768 -0
- package/dist/lib/scroller.js.map +1 -0
- package/dist/lib/select-menu.js +268 -0
- package/dist/lib/select-menu.js.map +1 -0
- package/dist/lib/settings-menu-button.js +78 -0
- package/dist/lib/settings-menu-button.js.map +1 -0
- package/dist/lib/skeleton.js +599 -0
- package/dist/lib/skeleton.js.map +1 -0
- package/dist/lib/stack.js +116 -0
- package/dist/lib/stack.js.map +1 -0
- package/dist/lib/tabs.js +97 -0
- package/dist/lib/tabs.js.map +1 -0
- package/dist/lib/time-pill.js +38 -0
- package/dist/lib/time-pill.js.map +1 -0
- package/dist/lib/toast.js +261 -0
- package/dist/lib/toast.js.map +1 -0
- package/dist/lib/toggle.js +182 -0
- package/dist/lib/toggle.js.map +1 -0
- package/dist/{directives.js → lib/tooltip-directive.js} +25 -19
- package/dist/lib/tooltip-directive.js.map +1 -0
- package/dist/lib/tooltip.js +403 -0
- package/dist/lib/tooltip.js.map +1 -0
- package/dist/lib/top-banner-info.js +67 -0
- package/dist/lib/top-banner-info.js.map +1 -0
- package/dist/lib/unread-pill.js +72 -0
- package/dist/lib/unread-pill.js.map +1 -0
- package/dist/lib/utils.js +171 -0
- package/dist/lib/utils.js.map +1 -0
- package/dist/lib/validation-messages.js +85 -0
- package/dist/lib/validation-messages.js.map +1 -0
- package/dist/lib/validators.js +12 -0
- package/dist/lib/validators.js.map +1 -0
- package/dist/style.css +1 -1
- package/dist/types/common/{constants.d.ts → constants/index.d.ts} +1 -1
- package/dist/types/common/constants/index.d.ts.map +1 -0
- package/dist/types/common/{dates.d.ts → dates/index.d.ts} +1 -1
- package/dist/types/common/dates/index.d.ts.map +1 -0
- package/dist/types/common/{emoji.d.ts → emoji/index.d.ts} +3 -3
- package/dist/types/common/emoji/index.d.ts.map +1 -0
- package/dist/types/common/mixins/modal.d.ts +2 -1
- package/dist/types/common/mixins/modal.d.ts.map +1 -1
- package/dist/types/common/{utils.d.ts → utils/index.d.ts} +1 -1
- package/dist/types/common/utils/index.d.ts.map +1 -0
- package/dist/types/common/{validators.d.ts → validators/index.d.ts} +1 -1
- package/dist/types/common/validators/index.d.ts.map +1 -0
- package/dist/types/components/avatar/avatar.vue.d.ts +1 -1
- package/dist/types/components/banner/banner.vue.d.ts +2 -1
- package/dist/types/components/banner/banner.vue.d.ts.map +1 -1
- package/dist/types/components/button/button.vue.d.ts +2 -2
- package/dist/types/components/card/card.vue.d.ts +1 -1
- package/dist/types/components/checkbox/checkbox.vue.d.ts +1 -6
- package/dist/types/components/checkbox/checkbox.vue.d.ts.map +1 -1
- package/dist/types/components/chip/chip.vue.d.ts +2 -2
- package/dist/types/components/collapsible/collapsible.vue.d.ts +3 -3
- package/dist/types/components/combobox/combobox.vue.d.ts +5 -12
- package/dist/types/components/combobox/combobox.vue.d.ts.map +1 -1
- package/dist/types/components/dropdown/dropdown.vue.d.ts +1 -6
- package/dist/types/components/dropdown/dropdown.vue.d.ts.map +1 -1
- package/dist/types/components/emoji/emoji.vue.d.ts +1 -1
- package/dist/types/components/icon/icon.vue.d.ts +20 -16
- package/dist/types/components/icon/icon.vue.d.ts.map +1 -1
- package/dist/types/components/icon/icon_constants.d.ts +2 -0
- package/dist/types/components/icon/icon_constants.d.ts.map +1 -1
- package/dist/types/components/icon/index.d.ts +1 -1
- package/dist/types/components/image_viewer/image_viewer.vue.d.ts +2 -1
- package/dist/types/components/image_viewer/image_viewer.vue.d.ts.map +1 -1
- package/dist/types/components/input_group/input_group.vue.d.ts +6 -2
- package/dist/types/components/input_group/input_group.vue.d.ts.map +1 -1
- package/dist/types/components/item_layout/item_layout.vue.d.ts +1 -1
- package/dist/types/components/item_layout/item_layout.vue.d.ts.map +1 -1
- package/dist/types/components/list_item/list_item.vue.d.ts +8 -2
- package/dist/types/components/list_item/list_item.vue.d.ts.map +1 -1
- package/dist/types/components/list_item_group/list_item_group.vue.d.ts +1 -1
- package/dist/types/components/modal/modal.vue.d.ts +36 -7
- package/dist/types/components/modal/modal.vue.d.ts.map +1 -1
- package/dist/types/components/notice/notice_action.vue.d.ts +3 -1
- package/dist/types/components/notice/notice_action.vue.d.ts.map +1 -1
- package/dist/types/components/popover/popover_header_footer.vue.d.ts +1 -1
- package/dist/types/components/radio/radio.vue.d.ts +1 -3
- package/dist/types/components/radio/radio.vue.d.ts.map +1 -1
- package/dist/types/components/radio_group/radio_group.vue.d.ts +8 -8
- package/dist/types/components/radio_group/radio_group.vue.d.ts.map +1 -1
- package/dist/types/components/root_layout/root_layout.vue.d.ts +1 -1
- package/dist/types/components/skeleton/skeleton-list-item.vue.d.ts +1 -1
- package/dist/types/components/skeleton/skeleton-paragraph.vue.d.ts +3 -3
- package/dist/types/components/skeleton/skeleton-shape.vue.d.ts +2 -2
- package/dist/types/components/skeleton/skeleton-text.vue.d.ts +8 -3
- package/dist/types/components/skeleton/skeleton-text.vue.d.ts.map +1 -1
- package/dist/types/components/skeleton/skeleton.vue.d.ts +1 -1
- package/dist/types/components/tabs/tab_panel.vue.d.ts +2 -1
- package/dist/types/components/tabs/tab_panel.vue.d.ts.map +1 -1
- package/dist/types/components/toggle/toggle.vue.d.ts +1 -1
- package/dist/types/components/tooltip/tooltip.vue.d.ts +2 -2
- package/dist/types/index.d.ts +37 -30
- package/dist/types/recipes/buttons/callbar_button/callbar_button.vue.d.ts +1 -1
- package/dist/types/recipes/buttons/callbar_button_with_popover/callbar_button_with_popover.vue.d.ts +2 -2
- package/dist/types/recipes/comboboxes/combobox_multi_select/combobox_multi_select.vue.d.ts +1 -1
- package/dist/types/recipes/comboboxes/combobox_with_popover/combobox_with_popover.vue.d.ts +2 -2
- package/dist/types/recipes/conversation_view/feed_item_row/feed_item_row.vue.d.ts +2 -1
- package/dist/types/recipes/conversation_view/feed_item_row/feed_item_row.vue.d.ts.map +1 -1
- package/package.json +19 -59
- package/CHANGELOG.json +0 -1
- package/CHANGELOG.md +0 -2823
- package/dist/dialtone-vue.cjs +0 -6
- package/dist/dialtone-vue.cjs.map +0 -1
- package/dist/directives.cjs +0 -2
- package/dist/directives.cjs.map +0 -1
- package/dist/directives.js.map +0 -1
- package/dist/emoji-DpXo7Avz.js +0 -101388
- package/dist/emoji-DpXo7Avz.js.map +0 -1
- package/dist/emoji-njsSZBHg.cjs +0 -2
- package/dist/emoji-njsSZBHg.cjs.map +0 -1
- package/dist/emoji.cjs +0 -2
- package/dist/emoji.cjs.map +0 -1
- package/dist/emoji.js +0 -37
- package/dist/emoji_picker-rUhIsKoU.cjs +0 -2
- package/dist/emoji_picker-rUhIsKoU.cjs.map +0 -1
- package/dist/emoji_picker-vEQ--pAv.js.map +0 -1
- package/dist/emoji_text_wrapper-icAiqYqk.js.map +0 -1
- package/dist/emoji_text_wrapper-zz_nxXi-.cjs +0 -2
- package/dist/emoji_text_wrapper-zz_nxXi-.cjs.map +0 -1
- package/dist/message_input.cjs +0 -2
- package/dist/message_input.cjs.map +0 -1
- package/dist/message_input.js.map +0 -1
- package/dist/rich_text_editor-B2jQbDxj.cjs +0 -98
- package/dist/rich_text_editor-B2jQbDxj.cjs.map +0 -1
- package/dist/rich_text_editor-mgv4CNR6.js +0 -16673
- package/dist/rich_text_editor-mgv4CNR6.js.map +0 -1
- package/dist/tooltip-P8ouLQqi.cjs +0 -22
- package/dist/tooltip-P8ouLQqi.cjs.map +0 -1
- package/dist/tooltip-S6S4up2q.js +0 -2518
- package/dist/tooltip-S6S4up2q.js.map +0 -1
- package/dist/types/common/constants.d.ts.map +0 -1
- package/dist/types/common/dates.d.ts.map +0 -1
- package/dist/types/common/emoji.d.ts.map +0 -1
- package/dist/types/common/utils.d.ts.map +0 -1
- package/dist/types/common/validators.d.ts.map +0 -1
- package/dist/types/components/emoji_picker/emojis/index.d.ts +0 -50
- package/dist/types/components/emoji_picker/emojis/index.d.ts.map +0 -1
- package/dist/types/directives.d.ts +0 -2
- package/dist/types/directives.d.ts.map +0 -1
- package/dist/types/emoji.d.ts +0 -5
- package/dist/types/emoji.d.ts.map +0 -1
- package/dist/types/message_input.d.ts +0 -3
- package/dist/types/message_input.d.ts.map +0 -1
package/README.md
CHANGED
|
@@ -23,13 +23,13 @@ You can install the Dialtone Vue library into your project via the following com
|
|
|
23
23
|
First you must globally import Dialtone's css:
|
|
24
24
|
|
|
25
25
|
```js
|
|
26
|
-
import '@dialpad/dialtone-css
|
|
26
|
+
import '@dialpad/dialtone-css';
|
|
27
27
|
```
|
|
28
28
|
|
|
29
29
|
or
|
|
30
30
|
|
|
31
31
|
```css
|
|
32
|
-
@import '
|
|
32
|
+
@import '@dialpad/dialtone-css';
|
|
33
33
|
```
|
|
34
34
|
|
|
35
35
|
Dialtone Vue components can be imported directly from the package. Some components also export named constants, which can be imported as well:
|
|
@@ -53,7 +53,7 @@ You may wish to use self-hosted JoyPixels assets such as the SVGs only available
|
|
|
53
53
|
In order to do this, set your custom asset URL with the following functions for small and large emojis during initialization of your app:
|
|
54
54
|
|
|
55
55
|
```js
|
|
56
|
-
import { setEmojiAssetUrlSmall, setEmojiAssetUrlLarge } from '@dialpad/dialtone-vue
|
|
56
|
+
import { setEmojiAssetUrlSmall, setEmojiAssetUrlLarge } from '@dialpad/dialtone-vue'
|
|
57
57
|
|
|
58
58
|
// 16px and smaller
|
|
59
59
|
setEmojiAssetUrlSmall('https://my.example.website.com/joypixels/svg/unicode/32/', '.png')
|
|
@@ -64,7 +64,7 @@ setEmojiAssetUrlLarge('https://my.example.website.com/joypixels/svg/unicode/', '
|
|
|
64
64
|
You may access the emoji.json data for all emojis Dialtone Vue supports via executing the following function
|
|
65
65
|
|
|
66
66
|
```js
|
|
67
|
-
import { getEmojiData } from '@dialpad/dialtone-vue
|
|
67
|
+
import { getEmojiData } from '@dialpad/dialtone-vue'
|
|
68
68
|
const emojiData = getEmojiData();
|
|
69
69
|
```
|
|
70
70
|
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"_plugin-vue_export-helper-hUChTQA_.js","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;;;"}
|
|
@@ -0,0 +1,396 @@
|
|
|
1
|
+
import { K } from "./keyboard_list_navigation-F0O8nht0.js";
|
|
2
|
+
import { D as a } from "./dropdown_constants-EUcDxBrX.js";
|
|
3
|
+
import { getUniqueString as w } from "../lib/utils.js";
|
|
4
|
+
import { EVENT_KEYNAMES as n } from "../lib/constants.js";
|
|
5
|
+
import { S as b, a as O } from "./sr_only_close_button-7O-Ev8uM.js";
|
|
6
|
+
import { resolveComponent as h, openBlock as d, createBlock as p, mergeProps as u, toHandlers as E, withCtx as g, renderSlot as m, createElementVNode as I, normalizeClass as x, createCommentVNode as S } from "vue";
|
|
7
|
+
import { _ as H } from "./_plugin-vue_export-helper-hUChTQA_.js";
|
|
8
|
+
import { DtPopover as P } from "../lib/popover.js";
|
|
9
|
+
import { a as l } from "./list_item_constants-LTUc74pD.js";
|
|
10
|
+
import { e as _ } from "./popover_constants-qjlEkroB.js";
|
|
11
|
+
const A = {
|
|
12
|
+
name: "DtDropdown",
|
|
13
|
+
components: {
|
|
14
|
+
DtPopover: P,
|
|
15
|
+
SrOnlyCloseButton: b
|
|
16
|
+
},
|
|
17
|
+
mixins: [
|
|
18
|
+
K({
|
|
19
|
+
indexKey: "highlightIndex",
|
|
20
|
+
idKey: "highlightId",
|
|
21
|
+
listElementKey: "getListElement",
|
|
22
|
+
listItemRole: "menuitem",
|
|
23
|
+
afterHighlightMethod: "afterHighlight",
|
|
24
|
+
beginningOfListMethod: "beginningOfListMethod",
|
|
25
|
+
endOfListMethod: "endOfListMethod",
|
|
26
|
+
activeItemKey: "activeItemEl",
|
|
27
|
+
focusOnKeyboardNavigation: !0
|
|
28
|
+
}),
|
|
29
|
+
O
|
|
30
|
+
],
|
|
31
|
+
inheritAttrs: !1,
|
|
32
|
+
props: {
|
|
33
|
+
/**
|
|
34
|
+
* Controls whether the dropdown is shown. Leaving this null will have the dropdown trigger on click by default.
|
|
35
|
+
* If you set this value, the default trigger behavior will be disabled and you can control it as you need.
|
|
36
|
+
* Supports v-model
|
|
37
|
+
*/
|
|
38
|
+
open: {
|
|
39
|
+
type: Boolean,
|
|
40
|
+
default: null
|
|
41
|
+
},
|
|
42
|
+
/**
|
|
43
|
+
* Opens the dropdown on right click (context menu). If you set this value to `true`,
|
|
44
|
+
* the default trigger behavior will be disabled.
|
|
45
|
+
*/
|
|
46
|
+
openOnContext: {
|
|
47
|
+
type: Boolean,
|
|
48
|
+
default: !1
|
|
49
|
+
},
|
|
50
|
+
/**
|
|
51
|
+
* Vertical padding size around the list element.
|
|
52
|
+
* @values none, small, large
|
|
53
|
+
*/
|
|
54
|
+
padding: {
|
|
55
|
+
type: String,
|
|
56
|
+
default: "small",
|
|
57
|
+
validator: (e) => Object.keys(a).some((t) => t === e)
|
|
58
|
+
},
|
|
59
|
+
/**
|
|
60
|
+
* Determines modal state, dropdown has a modal overlay preventing interaction with elements
|
|
61
|
+
* below it, but it is invisible.
|
|
62
|
+
*/
|
|
63
|
+
modal: {
|
|
64
|
+
type: Boolean,
|
|
65
|
+
default: !0
|
|
66
|
+
},
|
|
67
|
+
/**
|
|
68
|
+
* Width configuration for the popover content. When its value is 'anchor',
|
|
69
|
+
* the popover content will have the same width as the anchor.
|
|
70
|
+
* @values null, anchor
|
|
71
|
+
*/
|
|
72
|
+
contentWidth: {
|
|
73
|
+
type: String,
|
|
74
|
+
default: null
|
|
75
|
+
},
|
|
76
|
+
/**
|
|
77
|
+
* Determines maximum height for the popover before overflow.
|
|
78
|
+
* Possible units rem|px|em
|
|
79
|
+
*/
|
|
80
|
+
maxHeight: {
|
|
81
|
+
type: String,
|
|
82
|
+
default: ""
|
|
83
|
+
},
|
|
84
|
+
/**
|
|
85
|
+
* Determines maximum width for the popover before overflow.
|
|
86
|
+
* Possible units rem|px|%|em
|
|
87
|
+
*/
|
|
88
|
+
maxWidth: {
|
|
89
|
+
type: String,
|
|
90
|
+
default: ""
|
|
91
|
+
},
|
|
92
|
+
/**
|
|
93
|
+
* Sets an ID on the list element of the component. Used by several aria attributes
|
|
94
|
+
* as well as when deriving the IDs for each item.
|
|
95
|
+
*/
|
|
96
|
+
listId: {
|
|
97
|
+
type: String,
|
|
98
|
+
default() {
|
|
99
|
+
return w();
|
|
100
|
+
}
|
|
101
|
+
},
|
|
102
|
+
/**
|
|
103
|
+
* The type of navigation that this component should support.
|
|
104
|
+
* - "arrow-keys" for items that are navigated with UP/DOWN keys.
|
|
105
|
+
* - "tab" for items that are navigated using the TAB key.
|
|
106
|
+
* - "none" for static items that are not interactive.
|
|
107
|
+
* @values arrow-keys, tab, none
|
|
108
|
+
*/
|
|
109
|
+
navigationType: {
|
|
110
|
+
type: String,
|
|
111
|
+
default: l.ARROW_KEYS,
|
|
112
|
+
validator: (e) => Object.values(l).includes(e)
|
|
113
|
+
},
|
|
114
|
+
/**
|
|
115
|
+
* If the dropdown does not fit in the direction described by "placement",
|
|
116
|
+
* it will attempt to change it's direction to the "fallbackPlacements".
|
|
117
|
+
*
|
|
118
|
+
* @values top, top-start, top-end,
|
|
119
|
+
* right, right-start, right-end,
|
|
120
|
+
* left, left-start, left-end,
|
|
121
|
+
* bottom, bottom-start, bottom-end,
|
|
122
|
+
* auto, auto-start, auto-end
|
|
123
|
+
* */
|
|
124
|
+
fallbackPlacements: {
|
|
125
|
+
type: Array,
|
|
126
|
+
default: () => ["auto"]
|
|
127
|
+
},
|
|
128
|
+
/**
|
|
129
|
+
* The direction the dropdown displays relative to the anchor.
|
|
130
|
+
*/
|
|
131
|
+
placement: {
|
|
132
|
+
type: String,
|
|
133
|
+
default: "bottom"
|
|
134
|
+
},
|
|
135
|
+
/**
|
|
136
|
+
* A method that will be called when the selection goes past the beginning of the list.
|
|
137
|
+
*/
|
|
138
|
+
onBeginningOfList: {
|
|
139
|
+
type: Function,
|
|
140
|
+
default: null
|
|
141
|
+
},
|
|
142
|
+
/**
|
|
143
|
+
* A method that will be called when the selection goes past the end of the list.
|
|
144
|
+
*/
|
|
145
|
+
onEndOfList: {
|
|
146
|
+
type: Function,
|
|
147
|
+
default: null
|
|
148
|
+
},
|
|
149
|
+
/**
|
|
150
|
+
* Additional class for the wrapper list element.
|
|
151
|
+
*/
|
|
152
|
+
listClass: {
|
|
153
|
+
type: [String, Array, Object],
|
|
154
|
+
default: ""
|
|
155
|
+
},
|
|
156
|
+
/**
|
|
157
|
+
* Sets the element to which the popover is going to append to.
|
|
158
|
+
* 'body' will append to the nearest body (supports shadow DOM).
|
|
159
|
+
* @values 'body', 'parent', HTMLElement,
|
|
160
|
+
*/
|
|
161
|
+
appendTo: {
|
|
162
|
+
type: [HTMLElement, String],
|
|
163
|
+
default: "body",
|
|
164
|
+
validator: (e) => _.includes(e) || e instanceof HTMLElement
|
|
165
|
+
},
|
|
166
|
+
/**
|
|
167
|
+
* If set to false the dialog will display over top of the anchor when there is insufficient space.
|
|
168
|
+
* If set to true it will never move from its position relative to the anchor and will clip instead.
|
|
169
|
+
* <a
|
|
170
|
+
* class="d-link"
|
|
171
|
+
* href="https://popper.js.org/docs/v2/modifiers/prevent-overflow/#tether"
|
|
172
|
+
* target="_blank"
|
|
173
|
+
* >
|
|
174
|
+
* Popper.js docs
|
|
175
|
+
* </a>
|
|
176
|
+
* @values true, false
|
|
177
|
+
*/
|
|
178
|
+
tether: {
|
|
179
|
+
type: Boolean,
|
|
180
|
+
default: !0
|
|
181
|
+
},
|
|
182
|
+
/**
|
|
183
|
+
* Named transition when the content display is toggled.
|
|
184
|
+
* @see DtLazyShow
|
|
185
|
+
*/
|
|
186
|
+
transition: {
|
|
187
|
+
type: String,
|
|
188
|
+
default: "fade"
|
|
189
|
+
}
|
|
190
|
+
},
|
|
191
|
+
emits: [
|
|
192
|
+
/**
|
|
193
|
+
* Native keydown event
|
|
194
|
+
*
|
|
195
|
+
* @event keydown
|
|
196
|
+
* @type {KeyboardEvent}
|
|
197
|
+
*/
|
|
198
|
+
"keydown",
|
|
199
|
+
/**
|
|
200
|
+
* Event fired when the highlight changes
|
|
201
|
+
*
|
|
202
|
+
* @event highlight
|
|
203
|
+
* @type {Number}
|
|
204
|
+
*/
|
|
205
|
+
"highlight",
|
|
206
|
+
/**
|
|
207
|
+
* Event fired to sync the open prop with the parent component
|
|
208
|
+
* @event update:open
|
|
209
|
+
*/
|
|
210
|
+
"update:open",
|
|
211
|
+
/**
|
|
212
|
+
* Event fired when dropdown is shown or hidden
|
|
213
|
+
*
|
|
214
|
+
* @event opened
|
|
215
|
+
* @type {Boolean | Array}
|
|
216
|
+
*/
|
|
217
|
+
"opened",
|
|
218
|
+
/**
|
|
219
|
+
* Event fired to sync the open prop with the parent component
|
|
220
|
+
* @event update:open
|
|
221
|
+
*/
|
|
222
|
+
"update:open"
|
|
223
|
+
],
|
|
224
|
+
data() {
|
|
225
|
+
return {
|
|
226
|
+
LIST_ITEM_NAVIGATION_TYPES: l,
|
|
227
|
+
DROPDOWN_PADDING_CLASSES: a,
|
|
228
|
+
EVENT_KEYNAMES: n,
|
|
229
|
+
openedWithKeyboard: !1,
|
|
230
|
+
isOpen: null
|
|
231
|
+
};
|
|
232
|
+
},
|
|
233
|
+
computed: {
|
|
234
|
+
dropdownListeners() {
|
|
235
|
+
return {
|
|
236
|
+
opened: (e) => {
|
|
237
|
+
this.updateInitialHighlightIndex(e);
|
|
238
|
+
},
|
|
239
|
+
keydown: (e) => {
|
|
240
|
+
switch (e.code) {
|
|
241
|
+
case n.up:
|
|
242
|
+
case n.arrowup:
|
|
243
|
+
this.onUpKeyPress(e), e.stopPropagation(), e.preventDefault();
|
|
244
|
+
break;
|
|
245
|
+
case n.down:
|
|
246
|
+
case n.arrowdown:
|
|
247
|
+
this.onDownKeyPress(e), e.stopPropagation(), e.preventDefault();
|
|
248
|
+
break;
|
|
249
|
+
case n.space:
|
|
250
|
+
case n.spacebar:
|
|
251
|
+
this.onSpaceKey();
|
|
252
|
+
break;
|
|
253
|
+
case n.enter:
|
|
254
|
+
this.onEnterKey();
|
|
255
|
+
break;
|
|
256
|
+
case n.home:
|
|
257
|
+
this.onHomeKeyPress(e), e.stopPropagation(), e.preventDefault();
|
|
258
|
+
break;
|
|
259
|
+
case n.end:
|
|
260
|
+
this.onEndKeyPress(e), e.stopPropagation(), e.preventDefault();
|
|
261
|
+
break;
|
|
262
|
+
default:
|
|
263
|
+
this.onKeyPress(e);
|
|
264
|
+
break;
|
|
265
|
+
}
|
|
266
|
+
this.$emit("keydown", e);
|
|
267
|
+
}
|
|
268
|
+
};
|
|
269
|
+
},
|
|
270
|
+
beginningOfListMethod() {
|
|
271
|
+
return this.onBeginningOfList || this.jumpToEnd;
|
|
272
|
+
},
|
|
273
|
+
endOfListMethod() {
|
|
274
|
+
return this.onEndOfList || this.jumpToBeginning;
|
|
275
|
+
},
|
|
276
|
+
activeItemEl() {
|
|
277
|
+
return this.getListElement().querySelector("#" + this.highlightId);
|
|
278
|
+
},
|
|
279
|
+
isArrowKeyNav() {
|
|
280
|
+
return this.navigationType === this.LIST_ITEM_NAVIGATION_TYPES.ARROW_KEYS;
|
|
281
|
+
},
|
|
282
|
+
listClasses() {
|
|
283
|
+
return [
|
|
284
|
+
"d-dropdown-list",
|
|
285
|
+
a[this.padding],
|
|
286
|
+
this.listClass,
|
|
287
|
+
{ "d-context-menu-list": this.openOnContext }
|
|
288
|
+
];
|
|
289
|
+
},
|
|
290
|
+
shouldOpenWithArrowKeys() {
|
|
291
|
+
return !this.openOnContext;
|
|
292
|
+
}
|
|
293
|
+
},
|
|
294
|
+
methods: {
|
|
295
|
+
onMouseHighlight(e) {
|
|
296
|
+
const t = e.target.closest("li");
|
|
297
|
+
t && t.role && this.highlightId !== t.id && (this.setHighlightId(t.id), t.focus());
|
|
298
|
+
},
|
|
299
|
+
getListElement() {
|
|
300
|
+
return this.$refs.listWrapper;
|
|
301
|
+
},
|
|
302
|
+
clearHighlightIndex() {
|
|
303
|
+
this.setHighlightIndex(-1);
|
|
304
|
+
},
|
|
305
|
+
afterHighlight() {
|
|
306
|
+
this.visuallyHiddenClose && this.highlightIndex === this._itemsLength() - 1 || this.$emit("highlight", this.highlightIndex);
|
|
307
|
+
},
|
|
308
|
+
updateInitialHighlightIndex(e) {
|
|
309
|
+
this.isOpen = e, e ? (this.openedWithKeyboard && this.isArrowKeyNav && this.setHighlightIndex(0), this.$emit("opened", !0)) : (this.clearHighlightIndex(), this.openedWithKeyboard = !1, this.$emit("opened", !1));
|
|
310
|
+
},
|
|
311
|
+
onSpaceKey() {
|
|
312
|
+
this.open || (this.openedWithKeyboard = !0);
|
|
313
|
+
},
|
|
314
|
+
onEnterKey() {
|
|
315
|
+
this.open || (this.openedWithKeyboard = !0);
|
|
316
|
+
},
|
|
317
|
+
onUpKeyPress() {
|
|
318
|
+
if (!this.isOpen) {
|
|
319
|
+
this.openedWithKeyboard = !0;
|
|
320
|
+
return;
|
|
321
|
+
}
|
|
322
|
+
if (this.isArrowKeyNav)
|
|
323
|
+
return this.onUpKey();
|
|
324
|
+
},
|
|
325
|
+
onDownKeyPress() {
|
|
326
|
+
if (!this.isOpen) {
|
|
327
|
+
this.openedWithKeyboard = !0;
|
|
328
|
+
return;
|
|
329
|
+
}
|
|
330
|
+
if (this.isArrowKeyNav)
|
|
331
|
+
return this.onDownKey();
|
|
332
|
+
},
|
|
333
|
+
onHomeKeyPress() {
|
|
334
|
+
if (!(!this.isOpen || !this.isArrowKeyNav))
|
|
335
|
+
return this.onHomeKey();
|
|
336
|
+
},
|
|
337
|
+
onEndKeyPress() {
|
|
338
|
+
if (!(!this.isOpen || !this.isArrowKeyNav))
|
|
339
|
+
return this.onEndKey();
|
|
340
|
+
},
|
|
341
|
+
onKeyPress(e) {
|
|
342
|
+
if (!(!this.isOpen || !this.isArrowKeyNav || !this.isValidLetter(e.key)))
|
|
343
|
+
return e.stopPropagation(), e.preventDefault(), this.onNavigationKey(e.key);
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
}, L = ["id"];
|
|
347
|
+
function v(e, t, i, C, y, o) {
|
|
348
|
+
const f = h("sr-only-close-button"), c = h("dt-popover");
|
|
349
|
+
return d(), p(c, u({
|
|
350
|
+
ref: "popover",
|
|
351
|
+
"content-width": i.contentWidth,
|
|
352
|
+
open: i.open,
|
|
353
|
+
placement: i.placement,
|
|
354
|
+
"initial-focus-element": y.openedWithKeyboard ? "first" : "dialog",
|
|
355
|
+
"fallback-placements": i.fallbackPlacements,
|
|
356
|
+
padding: "none",
|
|
357
|
+
role: "menu",
|
|
358
|
+
"append-to": i.appendTo,
|
|
359
|
+
modal: i.modal,
|
|
360
|
+
"max-height": i.maxHeight,
|
|
361
|
+
"max-width": i.maxWidth,
|
|
362
|
+
"open-with-arrow-keys": o.shouldOpenWithArrowKeys,
|
|
363
|
+
"open-on-context": i.openOnContext
|
|
364
|
+
}, e.$attrs, {
|
|
365
|
+
tether: i.tether,
|
|
366
|
+
transition: i.transition
|
|
367
|
+
}, E(o.dropdownListeners)), {
|
|
368
|
+
anchor: g(({ attrs: s }) => [
|
|
369
|
+
m(e.$slots, "anchor", u({ ref: "anchor" }, s))
|
|
370
|
+
]),
|
|
371
|
+
content: g(({ close: s }) => [
|
|
372
|
+
I("ul", {
|
|
373
|
+
id: i.listId,
|
|
374
|
+
ref: "listWrapper",
|
|
375
|
+
class: x(o.listClasses),
|
|
376
|
+
"data-qa": "dt-dropdown-list-wrapper",
|
|
377
|
+
onMouseleave: t[0] || (t[0] = (...r) => o.clearHighlightIndex && o.clearHighlightIndex(...r)),
|
|
378
|
+
onMousemoveCapture: t[1] || (t[1] = (...r) => o.onMouseHighlight && o.onMouseHighlight(...r))
|
|
379
|
+
}, [
|
|
380
|
+
m(e.$slots, "list", { close: s }),
|
|
381
|
+
e.showVisuallyHiddenClose ? (d(), p(f, {
|
|
382
|
+
key: 0,
|
|
383
|
+
"visually-hidden-close-label": e.visuallyHiddenCloseLabel,
|
|
384
|
+
tabindex: o.isArrowKeyNav ? -1 : 0,
|
|
385
|
+
onClose: s
|
|
386
|
+
}, null, 8, ["visually-hidden-close-label", "tabindex", "onClose"])) : S("", !0)
|
|
387
|
+
], 42, L)
|
|
388
|
+
]),
|
|
389
|
+
_: 3
|
|
390
|
+
}, 16, ["content-width", "open", "placement", "initial-focus-element", "fallback-placements", "append-to", "modal", "max-height", "max-width", "open-with-arrow-keys", "open-on-context", "tether", "transition"]);
|
|
391
|
+
}
|
|
392
|
+
const U = /* @__PURE__ */ H(A, [["render", v]]);
|
|
393
|
+
export {
|
|
394
|
+
U as D
|
|
395
|
+
};
|
|
396
|
+
//# sourceMappingURL=dropdown-eWOvBvwq.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown-eWOvBvwq.js","sources":["../../components/dropdown/dropdown.vue"],"sourcesContent":["<!-- eslint-disable max-lines -->\n<template>\n <dt-popover\n ref=\"popover\"\n :content-width=\"contentWidth\"\n :open=\"open\"\n :placement=\"placement\"\n :initial-focus-element=\"openedWithKeyboard ? 'first' : 'dialog'\"\n :fallback-placements=\"fallbackPlacements\"\n padding=\"none\"\n role=\"menu\"\n :append-to=\"appendTo\"\n :modal=\"modal\"\n :max-height=\"maxHeight\"\n :max-width=\"maxWidth\"\n :open-with-arrow-keys=\"shouldOpenWithArrowKeys\"\n :open-on-context=\"openOnContext\"\n v-bind=\"$attrs\"\n :tether=\"tether\"\n :transition=\"transition\"\n v-on=\"dropdownListeners\"\n >\n <template #anchor=\"{ attrs }\">\n <!-- @slot Anchor element that activates the dropdown -->\n <slot\n ref=\"anchor\"\n name=\"anchor\"\n v-bind=\"attrs\"\n />\n </template>\n <template #content=\"{ close }\">\n <!-- eslint-disable-next-line max-len -->\n <!-- eslint-disable-next-line vuejs-accessibility/mouse-events-have-key-events vuejs-accessibility/no-static-element-interactions -->\n <ul\n :id=\"listId\"\n ref=\"listWrapper\"\n :class=\"listClasses\"\n data-qa=\"dt-dropdown-list-wrapper\"\n @mouseleave=\"clearHighlightIndex\"\n @mousemove.capture=\"onMouseHighlight\"\n >\n <!-- @slot Slot for the list component -->\n <slot\n name=\"list\"\n :close=\"close\"\n />\n <sr-only-close-button\n v-if=\"showVisuallyHiddenClose\"\n :visually-hidden-close-label=\"visuallyHiddenCloseLabel\"\n :tabindex=\"isArrowKeyNav ? -1 : 0\"\n @close=\"close\"\n />\n </ul>\n </template>\n </dt-popover>\n</template>\n\n<script>\nimport KeyboardNavigation from '@/common/mixins/keyboard_list_navigation';\nimport { DtPopover, POPOVER_APPEND_TO_VALUES } from '@/components/popover';\nimport { LIST_ITEM_NAVIGATION_TYPES } from '@/components/list_item';\nimport { DROPDOWN_PADDING_CLASSES } from './dropdown_constants';\nimport { getUniqueString } from '@/common/utils';\nimport { EVENT_KEYNAMES } from '@/common/constants';\nimport SrOnlyCloseButtonMixin from '@/common/mixins/sr_only_close_button';\nimport SrOnlyCloseButton from '@/common/sr_only_close_button.vue';\n\nexport default {\n name: 'DtDropdown',\n\n components: {\n DtPopover,\n SrOnlyCloseButton,\n },\n\n mixins: [\n KeyboardNavigation({\n indexKey: 'highlightIndex',\n idKey: 'highlightId',\n listElementKey: 'getListElement',\n listItemRole: 'menuitem',\n afterHighlightMethod: 'afterHighlight',\n beginningOfListMethod: 'beginningOfListMethod',\n endOfListMethod: 'endOfListMethod',\n activeItemKey: 'activeItemEl',\n focusOnKeyboardNavigation: true,\n }),\n SrOnlyCloseButtonMixin,\n ],\n\n inheritAttrs: false,\n\n props: {\n /**\n * Controls whether the dropdown is shown. Leaving this null will have the dropdown trigger on click by default.\n * If you set this value, the default trigger behavior will be disabled and you can control it as you need.\n * Supports v-model\n */\n open: {\n type: Boolean,\n default: null,\n },\n\n /**\n * Opens the dropdown on right click (context menu). If you set this value to `true`,\n * the default trigger behavior will be disabled.\n */\n openOnContext: {\n type: Boolean,\n default: false,\n },\n\n /**\n * Vertical padding size around the list element.\n * @values none, small, large\n */\n padding: {\n type: String,\n default: 'small',\n validator: (padding) => {\n return Object.keys(DROPDOWN_PADDING_CLASSES).some((item) => item === padding);\n },\n },\n\n /**\n * Determines modal state, dropdown has a modal overlay preventing interaction with elements\n * below it, but it is invisible.\n */\n modal: {\n type: Boolean,\n default: true,\n },\n\n /**\n * Width configuration for the popover content. When its value is 'anchor',\n * the popover content will have the same width as the anchor.\n * @values null, anchor\n */\n contentWidth: {\n type: String,\n default: null,\n },\n\n /**\n * Determines maximum height for the popover before overflow.\n * Possible units rem|px|em\n */\n maxHeight: {\n type: String,\n default: '',\n },\n\n /**\n * Determines maximum width for the popover before overflow.\n * Possible units rem|px|%|em\n */\n maxWidth: {\n type: String,\n default: '',\n },\n\n /**\n * Sets an ID on the list element of the component. Used by several aria attributes\n * as well as when deriving the IDs for each item.\n */\n listId: {\n type: String,\n default () { return getUniqueString(); },\n },\n\n /**\n * The type of navigation that this component should support.\n * - \"arrow-keys\" for items that are navigated with UP/DOWN keys.\n * - \"tab\" for items that are navigated using the TAB key.\n * - \"none\" for static items that are not interactive.\n * @values arrow-keys, tab, none\n */\n navigationType: {\n type: String,\n default: LIST_ITEM_NAVIGATION_TYPES.ARROW_KEYS,\n validator: (t) => Object.values(LIST_ITEM_NAVIGATION_TYPES).includes(t),\n },\n\n /**\n * If the dropdown does not fit in the direction described by \"placement\",\n * it will attempt to change it's direction to the \"fallbackPlacements\".\n *\n * @values top, top-start, top-end,\n * right, right-start, right-end,\n * left, left-start, left-end,\n * bottom, bottom-start, bottom-end,\n * auto, auto-start, auto-end\n * */\n fallbackPlacements: {\n type: Array,\n default: () => {\n return ['auto'];\n },\n },\n\n /**\n * The direction the dropdown displays relative to the anchor.\n */\n placement: {\n type: String,\n default: 'bottom',\n },\n\n /**\n * A method that will be called when the selection goes past the beginning of the list.\n */\n onBeginningOfList: {\n type: Function,\n default: null,\n },\n\n /**\n * A method that will be called when the selection goes past the end of the list.\n */\n onEndOfList: {\n type: Function,\n default: null,\n },\n\n /**\n * Additional class for the wrapper list element.\n */\n listClass: {\n type: [String, Array, Object],\n default: '',\n },\n\n /**\n * Sets the element to which the popover is going to append to.\n * 'body' will append to the nearest body (supports shadow DOM).\n * @values 'body', 'parent', HTMLElement,\n */\n appendTo: {\n type: [HTMLElement, String],\n default: 'body',\n validator: appendTo => {\n return POPOVER_APPEND_TO_VALUES.includes(appendTo) ||\n (appendTo instanceof HTMLElement);\n },\n },\n\n /**\n * If set to false the dialog will display over top of the anchor when there is insufficient space.\n * If set to true it will never move from its position relative to the anchor and will clip instead.\n * <a\n * class=\"d-link\"\n * href=\"https://popper.js.org/docs/v2/modifiers/prevent-overflow/#tether\"\n * target=\"_blank\"\n * >\n * Popper.js docs\n * </a>\n * @values true, false\n */\n tether: {\n type: Boolean,\n default: true,\n },\n\n /**\n * Named transition when the content display is toggled.\n * @see DtLazyShow\n */\n transition: {\n type: String,\n default: 'fade',\n },\n },\n\n emits: [\n /**\n * Native keydown event\n *\n * @event keydown\n * @type {KeyboardEvent}\n */\n 'keydown',\n\n /**\n * Event fired when the highlight changes\n *\n * @event highlight\n * @type {Number}\n */\n 'highlight',\n\n /**\n * Event fired to sync the open prop with the parent component\n * @event update:open\n */\n 'update:open',\n\n /**\n * Event fired when dropdown is shown or hidden\n *\n * @event opened\n * @type {Boolean | Array}\n */\n 'opened',\n\n /**\n * Event fired to sync the open prop with the parent component\n * @event update:open\n */\n 'update:open',\n ],\n\n data () {\n return {\n LIST_ITEM_NAVIGATION_TYPES,\n DROPDOWN_PADDING_CLASSES,\n EVENT_KEYNAMES,\n openedWithKeyboard: false,\n isOpen: null,\n };\n },\n\n computed: {\n dropdownListeners () {\n return {\n opened: isPopoverOpen => {\n this.updateInitialHighlightIndex(isPopoverOpen);\n },\n\n keydown: event => {\n const eventCode = event.code;\n\n switch (eventCode) {\n case EVENT_KEYNAMES.up:\n case EVENT_KEYNAMES.arrowup:\n this.onUpKeyPress(event);\n event.stopPropagation();\n event.preventDefault();\n break;\n case EVENT_KEYNAMES.down:\n case EVENT_KEYNAMES.arrowdown:\n this.onDownKeyPress(event);\n event.stopPropagation();\n event.preventDefault();\n break;\n case EVENT_KEYNAMES.space:\n case EVENT_KEYNAMES.spacebar:\n this.onSpaceKey();\n break;\n case EVENT_KEYNAMES.enter:\n this.onEnterKey();\n break;\n case EVENT_KEYNAMES.home:\n this.onHomeKeyPress(event);\n event.stopPropagation();\n event.preventDefault();\n break;\n case EVENT_KEYNAMES.end:\n this.onEndKeyPress(event);\n event.stopPropagation();\n event.preventDefault();\n break;\n default:\n this.onKeyPress(event);\n break;\n }\n\n this.$emit('keydown', event);\n },\n };\n },\n\n beginningOfListMethod () {\n return this.onBeginningOfList || this.jumpToEnd;\n },\n\n endOfListMethod () {\n return this.onEndOfList || this.jumpToBeginning;\n },\n\n activeItemEl () {\n return this.getListElement().querySelector('#' + this.highlightId);\n },\n\n isArrowKeyNav () {\n return this.navigationType === this.LIST_ITEM_NAVIGATION_TYPES.ARROW_KEYS;\n },\n\n listClasses () {\n return [\n 'd-dropdown-list',\n DROPDOWN_PADDING_CLASSES[this.padding],\n this.listClass,\n { 'd-context-menu-list': this.openOnContext },\n ];\n },\n\n shouldOpenWithArrowKeys () {\n return !this.openOnContext;\n },\n },\n\n methods: {\n onMouseHighlight (e) {\n const liElement = e.target.closest('li');\n\n if (liElement && liElement.role && this.highlightId !== liElement.id) {\n this.setHighlightId(liElement.id);\n liElement.focus();\n }\n },\n\n getListElement () {\n return this.$refs.listWrapper;\n },\n\n clearHighlightIndex () {\n this.setHighlightIndex(-1);\n },\n\n afterHighlight () {\n if (this.visuallyHiddenClose && this.highlightIndex === this._itemsLength() - 1) {\n return;\n }\n\n this.$emit('highlight', this.highlightIndex);\n },\n\n updateInitialHighlightIndex (isPopoverOpen) {\n this.isOpen = isPopoverOpen;\n\n if (isPopoverOpen) {\n if (this.openedWithKeyboard && this.isArrowKeyNav) {\n this.setHighlightIndex(0);\n }\n this.$emit('opened', true);\n } else {\n this.clearHighlightIndex();\n this.openedWithKeyboard = false;\n this.$emit('opened', false);\n }\n },\n\n onSpaceKey () {\n if (!this.open) {\n this.openedWithKeyboard = true;\n }\n },\n\n onEnterKey () {\n if (!this.open) {\n this.openedWithKeyboard = true;\n }\n },\n\n onUpKeyPress () {\n if (!this.isOpen) {\n this.openedWithKeyboard = true;\n return;\n }\n if (this.isArrowKeyNav) {\n return this.onUpKey();\n }\n },\n\n onDownKeyPress () {\n if (!this.isOpen) {\n this.openedWithKeyboard = true;\n return;\n }\n if (this.isArrowKeyNav) {\n return this.onDownKey();\n }\n },\n\n onHomeKeyPress () {\n if (!this.isOpen || !this.isArrowKeyNav) {\n return;\n }\n\n return this.onHomeKey();\n },\n\n onEndKeyPress () {\n if (!this.isOpen || !this.isArrowKeyNav) {\n return;\n }\n\n return this.onEndKey();\n },\n\n onKeyPress (e) {\n if (!this.isOpen || !this.isArrowKeyNav || !this.isValidLetter(e.key)) {\n return;\n }\n\n e.stopPropagation();\n e.preventDefault();\n\n return this.onNavigationKey(e.key);\n },\n },\n};\n</script>\n\n<style lang=\"less\">\n.d-context-menu-list {\n width: var(--dt-size-850);\n}\n.d-dropdown-list {\n position: relative;\n margin: var(--dt-space-300);\n padding-left: var(--dt-space-0);\n padding-right: var(--dt-space-0);\n >.dt-list-item {\n margin-top: var(--dt-space-200);\n }\n}\n</style>\n"],"names":["_sfc_main","DtPopover","SrOnlyCloseButton","KeyboardNavigation","SrOnlyCloseButtonMixin","padding","DROPDOWN_PADDING_CLASSES","item","getUniqueString","LIST_ITEM_NAVIGATION_TYPES","t","appendTo","POPOVER_APPEND_TO_VALUES","EVENT_KEYNAMES","isPopoverOpen","event","liElement","_openBlock","_createBlock","_component_dt_popover","_mergeProps","$props","$data","$options","_ctx","_toHandlers","_withCtx","attrs","_renderSlot","close","_createElementVNode","args","_component_sr_only_close_button"],"mappings":"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"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"dropdown_constants-EUcDxBrX.js","sources":["../../components/dropdown/dropdown_constants.js"],"sourcesContent":["export const DROPDOWN_PADDING_CLASSES = {\n none: undefined,\n small: 'd-py0',\n large: 'd-py4',\n};\n\nexport default {\n DROPDOWN_PADDING_CLASSES,\n};\n"],"names":["DROPDOWN_PADDING_CLASSES"],"mappings":"AAAY,MAACA,IAA2B;AAAA,EACtC,MAAM;AAAA,EACN,OAAO;AAAA,EACP,OAAO;AACT;"}
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import i from "@dialpad/dialtone-icons/icons.json";
|
|
2
|
+
const s = {
|
|
3
|
+
100: "d-icon--size-100",
|
|
4
|
+
200: "d-icon--size-200",
|
|
5
|
+
300: "d-icon--size-300",
|
|
6
|
+
400: "d-icon--size-400",
|
|
7
|
+
500: "d-icon--size-500",
|
|
8
|
+
600: "d-icon--size-600",
|
|
9
|
+
700: "d-icon--size-700",
|
|
10
|
+
800: "d-icon--size-800"
|
|
11
|
+
}, c = i;
|
|
12
|
+
export {
|
|
13
|
+
s as I,
|
|
14
|
+
c as a
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=icon_constants-OpYAAKwF.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"icon_constants-OpYAAKwF.js","sources":["../../components/icon/icon_constants.js"],"sourcesContent":["import iconNames from '@dialpad/dialtone-icons/icons.json';\nexport const ICON_SIZE_MODIFIERS = {\n 100: 'd-icon--size-100',\n 200: 'd-icon--size-200',\n 300: 'd-icon--size-300',\n 400: 'd-icon--size-400',\n 500: 'd-icon--size-500',\n 600: 'd-icon--size-600',\n 700: 'd-icon--size-700',\n 800: 'd-icon--size-800',\n};\n\nexport const ICON_NAMES = iconNames;\n\nexport default {\n ICON_SIZE_MODIFIERS,\n ICON_NAMES,\n};\n"],"names":["ICON_SIZE_MODIFIERS","ICON_NAMES","iconNames"],"mappings":";AACY,MAACA,IAAsB;AAAA,EACjC,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AAAA,EACL,KAAK;AACP,GAEaC,IAAaC;"}
|