@dialpad/dialtone-vue 3.22.0 → 3.22.1-beta.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.
@@ -25,7 +25,7 @@ ___CSS_LOADER_EXPORT___.push([module.id, ".enter-active,.leave-active{overflow:h
25
25
 
26
26
  /***/ }),
27
27
 
28
- /***/ 78:
28
+ /***/ 280:
29
29
  /***/ ((module, __webpack_exports__, __webpack_require__) => {
30
30
 
31
31
  "use strict";
@@ -169,7 +169,7 @@ ___CSS_LOADER_EXPORT___.push([module.id, ".dt-list-section[tabindex=\"-1\"]:focu
169
169
 
170
170
  /***/ }),
171
171
 
172
- /***/ 674:
172
+ /***/ 971:
173
173
  /***/ ((module, __webpack_exports__, __webpack_require__) => {
174
174
 
175
175
  "use strict";
@@ -265,7 +265,7 @@ ___CSS_LOADER_EXPORT___.push([module.id, ".skeleton-placeholder{display:flex;str
265
265
 
266
266
  /***/ }),
267
267
 
268
- /***/ 878:
268
+ /***/ 234:
269
269
  /***/ ((module, __webpack_exports__, __webpack_require__) => {
270
270
 
271
271
  "use strict";
@@ -542,19 +542,19 @@ var update = add("79334d9e", content, true, {"sourceMap":false,"shadowMode":fals
542
542
 
543
543
  /***/ }),
544
544
 
545
- /***/ 438:
545
+ /***/ 8:
546
546
  /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
547
547
 
548
548
  // style-loader: Adds some css to the DOM by adding a <style> tag
549
549
 
550
550
  // load the styles
551
- var content = __webpack_require__(78);
551
+ var content = __webpack_require__(280);
552
552
  if(content.__esModule) content = content.default;
553
553
  if(typeof content === 'string') content = [[module.id, content, '']];
554
554
  if(content.locals) module.exports = content.locals;
555
555
  // add the styles to the DOM
556
556
  var add = (__webpack_require__(402)/* ["default"] */ .Z)
557
- var update = add("06fe8c46", content, true, {"sourceMap":false,"shadowMode":false});
557
+ var update = add("7cc44206", content, true, {"sourceMap":false,"shadowMode":false});
558
558
 
559
559
  /***/ }),
560
560
 
@@ -638,19 +638,19 @@ var update = add("4d925410", content, true, {"sourceMap":false,"shadowMode":fals
638
638
 
639
639
  /***/ }),
640
640
 
641
- /***/ 925:
641
+ /***/ 284:
642
642
  /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
643
643
 
644
644
  // style-loader: Adds some css to the DOM by adding a <style> tag
645
645
 
646
646
  // load the styles
647
- var content = __webpack_require__(674);
647
+ var content = __webpack_require__(971);
648
648
  if(content.__esModule) content = content.default;
649
649
  if(typeof content === 'string') content = [[module.id, content, '']];
650
650
  if(content.locals) module.exports = content.locals;
651
651
  // add the styles to the DOM
652
652
  var add = (__webpack_require__(402)/* ["default"] */ .Z)
653
- var update = add("a4b9582c", content, true, {"sourceMap":false,"shadowMode":false});
653
+ var update = add("d8b627ea", content, true, {"sourceMap":false,"shadowMode":false});
654
654
 
655
655
  /***/ }),
656
656
 
@@ -702,19 +702,19 @@ var update = add("3230f382", content, true, {"sourceMap":false,"shadowMode":fals
702
702
 
703
703
  /***/ }),
704
704
 
705
- /***/ 504:
705
+ /***/ 27:
706
706
  /***/ ((module, __unused_webpack_exports, __webpack_require__) => {
707
707
 
708
708
  // style-loader: Adds some css to the DOM by adding a <style> tag
709
709
 
710
710
  // load the styles
711
- var content = __webpack_require__(878);
711
+ var content = __webpack_require__(234);
712
712
  if(content.__esModule) content = content.default;
713
713
  if(typeof content === 'string') content = [[module.id, content, '']];
714
714
  if(content.locals) module.exports = content.locals;
715
715
  // add the styles to the DOM
716
716
  var add = (__webpack_require__(402)/* ["default"] */ .Z)
717
- var update = add("7a6863ba", content, true, {"sourceMap":false,"shadowMode":false});
717
+ var update = add("da834e14", content, true, {"sourceMap":false,"shadowMode":false});
718
718
 
719
719
  /***/ }),
720
720
 
@@ -1354,6 +1354,24 @@ const LABEL_SIZE_MODIFIERS = {
1354
1354
  lg: 'd-label--lg',
1355
1355
  xl: 'd-label--xl'
1356
1356
  };
1357
+ const EVENT_KEYNAMES = {
1358
+ esc: 'Esc',
1359
+ escape: 'Escape',
1360
+ tab: 'Tab',
1361
+ enter: 'Enter',
1362
+ space: 'Space',
1363
+ spacebar: 'Spacebar',
1364
+ up: 'Up',
1365
+ arrowup: 'ArrowUp',
1366
+ left: 'Left',
1367
+ arrowleft: 'ArrowLeft',
1368
+ right: 'Right',
1369
+ arrowright: 'ArrowRight',
1370
+ down: 'Down',
1371
+ arrowdown: 'ArrowDown',
1372
+ home: 'Home',
1373
+ end: 'End'
1374
+ };
1357
1375
  /*
1358
1376
  * Any string message or message object in the messages prop that do not specify
1359
1377
  * a 'type' attributes will default to 'DEFAULT_MESSAGE_TYPE'.
@@ -1461,7 +1479,7 @@ const flushPromises = () => {
1461
1479
  });
1462
1480
  };
1463
1481
  /**
1464
- * Transform a string from kebab-case to pascalCase
1482
+ * Transform a string from kebab-case to PascalCase
1465
1483
  * @param string
1466
1484
  * @returns {string}
1467
1485
  */
@@ -1469,6 +1487,15 @@ const flushPromises = () => {
1469
1487
  const kebabCaseToPascalCase = string => {
1470
1488
  return string.toLowerCase().split('-').map(word => word.charAt(0).toUpperCase() + word.slice(1)).join('');
1471
1489
  };
1490
+ /**
1491
+ * Transform a string from PascalCase to kebab-case
1492
+ * @param string
1493
+ * @returns {string}
1494
+ */
1495
+
1496
+ const pascalCaseToKebabCase = string => {
1497
+ return string.replace(/\.?([A-Z0-9]+)/g, (x, y) => '-' + y.toLowerCase()).replace(/^-/, '');
1498
+ };
1472
1499
  /* harmony default export */ const utils = ({
1473
1500
  getUniqueString,
1474
1501
  formatMessages,
@@ -2084,10 +2111,10 @@ const IconClose_script = {}
2084
2111
  const IconClose_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(IconClose_script, [['render',IconClosevue_type_template_id_4ef5457b_render]])
2085
2112
 
2086
2113
  /* harmony default export */ const IconClose = (IconClose_exports_);
2087
- ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/button/button.vue?vue&type=template&id=6d10e472
2114
+ ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/button/button.vue?vue&type=template&id=6629834d
2088
2115
 
2089
- const buttonvue_type_template_id_6d10e472_hoisted_1 = ["type", "disabled", "aria-live", "aria-label"];
2090
- function buttonvue_type_template_id_6d10e472_render(_ctx, _cache, $props, $setup, $data, $options) {
2116
+ const buttonvue_type_template_id_6629834d_hoisted_1 = ["type", "disabled", "aria-live", "aria-label"];
2117
+ function buttonvue_type_template_id_6629834d_render(_ctx, _cache, $props, $setup, $data, $options) {
2091
2118
  return (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("button", (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.mergeProps)({
2092
2119
  class: ['base-button__button', $options.buttonClasses()],
2093
2120
  "data-qa": "dt-button",
@@ -2106,9 +2133,9 @@ function buttonvue_type_template_id_6d10e472_render(_ctx, _cache, $props, $setup
2106
2133
  key: 1,
2107
2134
  "data-qa": "dt-button-label",
2108
2135
  class: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.normalizeClass)(['d-w100p', 'd-btn__label', 'base-button__label', $props.labelClass])
2109
- }, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "default")], 2)) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true)], 16, buttonvue_type_template_id_6d10e472_hoisted_1);
2136
+ }, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "default")], 2)) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true)], 16, buttonvue_type_template_id_6629834d_hoisted_1);
2110
2137
  }
2111
- ;// CONCATENATED MODULE: ./components/button/button.vue?vue&type=template&id=6d10e472
2138
+ ;// CONCATENATED MODULE: ./components/button/button.vue?vue&type=template&id=6629834d
2112
2139
 
2113
2140
  ;// CONCATENATED MODULE: ./components/button/button_constants.js
2114
2141
  const BUTTON_SIZE_MODIFIERS = {
@@ -2350,13 +2377,6 @@ const LINK_KIND_MODIFIERS = {
2350
2377
  }
2351
2378
  },
2352
2379
  emits: [
2353
- /**
2354
- * Native button click event
2355
- *
2356
- * @event click
2357
- * @type {PointerEvent | KeyboardEvent}
2358
- */
2359
- 'click',
2360
2380
  /**
2361
2381
  * Native button focus in event
2362
2382
  *
@@ -2383,7 +2403,6 @@ const LINK_KIND_MODIFIERS = {
2383
2403
  computed: {
2384
2404
  buttonListeners() {
2385
2405
  return {
2386
- click: e => this.$emit('click', e),
2387
2406
  focusin: e => {
2388
2407
  this.isInFocus = this.assertiveOnFocus;
2389
2408
  this.$emit('focusin', e);
@@ -2465,7 +2484,7 @@ const LINK_KIND_MODIFIERS = {
2465
2484
 
2466
2485
 
2467
2486
  ;
2468
- const button_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(buttonvue_type_script_lang_js, [['render',buttonvue_type_template_id_6d10e472_render]])
2487
+ const button_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(buttonvue_type_script_lang_js, [['render',buttonvue_type_template_id_6629834d_render]])
2469
2488
 
2470
2489
  /* harmony default export */ const button_button = (button_exports_);
2471
2490
  ;// CONCATENATED MODULE: ./common/mixins/sr_only_close_button.js
@@ -5923,10 +5942,10 @@ const collapsible_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(collap
5923
5942
  /* harmony default export */ const collapsible = (collapsible_exports_);
5924
5943
  ;// CONCATENATED MODULE: ./components/collapsible/index.js
5925
5944
 
5926
- ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/dropdown/dropdown.vue?vue&type=template&id=2021ac9d
5945
+ ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/dropdown/dropdown.vue?vue&type=template&id=6b8ca270
5927
5946
 
5928
- const dropdownvue_type_template_id_2021ac9d_hoisted_1 = ["id"];
5929
- function dropdownvue_type_template_id_2021ac9d_render(_ctx, _cache, $props, $setup, $data, $options) {
5947
+ const dropdownvue_type_template_id_6b8ca270_hoisted_1 = ["id"];
5948
+ function dropdownvue_type_template_id_6b8ca270_render(_ctx, _cache, $props, $setup, $data, $options) {
5930
5949
  const _component_sr_only_close_button = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("sr-only-close-button");
5931
5950
 
5932
5951
  const _component_dt_popover = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("dt-popover");
@@ -5940,15 +5959,12 @@ function dropdownvue_type_template_id_2021ac9d_render(_ctx, _cache, $props, $set
5940
5959
  "fallback-placements": $props.fallbackPlacements,
5941
5960
  padding: "none",
5942
5961
  role: "menu",
5943
- modal: $props.modal
5944
- }, _ctx.$attrs, {
5962
+ modal: $props.modal,
5945
5963
  "max-height": $props.maxHeight,
5946
5964
  "max-width": $props.maxWidth,
5947
5965
  "open-with-arrow-keys": true,
5948
- "open-on-context": $props.openOnContext,
5949
- onOpened: $options.updateInitialHighlightIndex,
5950
- onKeydown: [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)($options.onEnterKey, ["enter"]), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)($options.onSpaceKey, ["space"]), _cache[2] || (_cache[2] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)($event => $options.onKeyValidation($event, 'onUpKeyPress'), ["stop", "prevent"]), ["up"])), _cache[3] || (_cache[3] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)($event => $options.onKeyValidation($event, 'onDownKeyPress'), ["stop", "prevent"]), ["down"])), _cache[4] || (_cache[4] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)($event => $options.onKeyValidation($event, 'onHomeKeyPress'), ["stop", "prevent"]), ["home"])), _cache[5] || (_cache[5] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)($event => $options.onKeyValidation($event, 'onEndKeyPress'), ["stop", "prevent"]), ["end"])), _cache[6] || (_cache[6] = $event => $options.onKeyValidation($event, 'onKeyPress'))]
5951
- }), {
5966
+ "open-on-context": $props.openOnContext
5967
+ }, _ctx.$attrs, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toHandlers)($options.dropdownListeners)), {
5952
5968
  anchor: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withCtx)(_ref => {
5953
5969
  let {
5954
5970
  attrs
@@ -5979,18 +5995,18 @@ function dropdownvue_type_template_id_2021ac9d_render(_ctx, _cache, $props, $set
5979
5995
  "visually-hidden-close-label": _ctx.visuallyHiddenCloseLabel,
5980
5996
  tabindex: $options.isArrowKeyNav ? -1 : 0,
5981
5997
  onClose: close
5982
- }, null, 8, ["visually-hidden-close-label", "tabindex", "onClose"])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true)], 42, dropdownvue_type_template_id_2021ac9d_hoisted_1)];
5998
+ }, null, 8, ["visually-hidden-close-label", "tabindex", "onClose"])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true)], 42, dropdownvue_type_template_id_6b8ca270_hoisted_1)];
5983
5999
  }),
5984
6000
  _: 3
5985
- }, 16, ["content-width", "open", "placement", "initial-focus-element", "fallback-placements", "modal", "max-height", "max-width", "open-on-context", "onOpened", "onKeydown"]);
6001
+ }, 16, ["content-width", "open", "placement", "initial-focus-element", "fallback-placements", "modal", "max-height", "max-width", "open-on-context"]);
5986
6002
  }
5987
- ;// CONCATENATED MODULE: ./components/dropdown/dropdown.vue?vue&type=template&id=2021ac9d
6003
+ ;// CONCATENATED MODULE: ./components/dropdown/dropdown.vue?vue&type=template&id=6b8ca270
5988
6004
 
5989
- ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/popover/popover.vue?vue&type=template&id=90818940
6005
+ ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/popover/popover.vue?vue&type=template&id=245d490f
5990
6006
 
5991
- const popovervue_type_template_id_90818940_hoisted_1 = ["aria-hidden"];
5992
- const popovervue_type_template_id_90818940_hoisted_2 = ["id", "tabindex"];
5993
- function popovervue_type_template_id_90818940_render(_ctx, _cache, $props, $setup, $data, $options) {
6007
+ const popovervue_type_template_id_245d490f_hoisted_1 = ["aria-hidden"];
6008
+ const popovervue_type_template_id_245d490f_hoisted_2 = ["id", "tabindex"];
6009
+ function popovervue_type_template_id_245d490f_render(_ctx, _cache, $props, $setup, $data, $options) {
5994
6010
  const _component_popover_header_footer = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("popover-header-footer");
5995
6011
 
5996
6012
  const _component_sr_only_close_button = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("sr-only-close-button");
@@ -6004,7 +6020,7 @@ function popovervue_type_template_id_90818940_render(_ctx, _cache, $props, $setu
6004
6020
  class: "d-modal--transparent",
6005
6021
  "aria-hidden": $props.modal && $data.isOpen ? 'false' : 'true',
6006
6022
  onClick: _cache[0] || (_cache[0] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)(() => {}, ["prevent", "stop"]))
6007
- }, null, 8, popovervue_type_template_id_90818940_hoisted_1)])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true), ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveDynamicComponent)($props.elementType), {
6023
+ }, null, 8, popovervue_type_template_id_245d490f_hoisted_1)])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true), ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveDynamicComponent)($props.elementType), {
6008
6024
  ref: "popover",
6009
6025
  class: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.normalizeClass)(['d-popover', {
6010
6026
  'd-popover__anchor--opened': $data.isOpen
@@ -6019,14 +6035,14 @@ function popovervue_type_template_id_90818940_render(_ctx, _cache, $props, $setu
6019
6035
  onClickCapture: _cache[1] || (_cache[1] = function () {
6020
6036
  return $options.defaultToggleOpen && $options.defaultToggleOpen(...arguments);
6021
6037
  }),
6022
- onContextmenu: _cache[2] || (_cache[2] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)(function () {
6038
+ onContextmenu: _cache[2] || (_cache[2] = function () {
6023
6039
  return $options.onContext && $options.onContext(...arguments);
6024
- }, ["prevent"])),
6040
+ }),
6025
6041
  onKeydown: [_cache[3] || (_cache[3] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)(function () {
6026
6042
  return $options.onArrowKeyPress && $options.onArrowKeyPress(...arguments);
6027
6043
  }, ["prevent"]), ["up"])), _cache[4] || (_cache[4] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)(function () {
6028
6044
  return $options.onArrowKeyPress && $options.onArrowKeyPress(...arguments);
6029
- }, ["prevent"]), ["down"]))],
6045
+ }, ["prevent"]), ["down"])), _cache[7] || (_cache[7] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)($event => _ctx.$emit('keydown', $event), ["enter"])), _cache[8] || (_cache[8] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)($event => _ctx.$emit('keydown', $event), ["space"]))],
6030
6046
  onWheel: _cache[5] || (_cache[5] = e => $data.isOpen && $props.modal && e.preventDefault()),
6031
6047
  onKeydownCapture: _cache[6] || (_cache[6] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)(function () {
6032
6048
  return $options.closePopover && $options.closePopover(...arguments);
@@ -6037,7 +6053,7 @@ function popovervue_type_template_id_90818940_render(_ctx, _cache, $props, $setu
6037
6053
  'aria-controls': $props.id,
6038
6054
  'aria-haspopup': $props.role
6039
6055
  }
6040
- })], 40, popovervue_type_template_id_90818940_hoisted_2), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createVNode)(_component_dt_lazy_show, {
6056
+ })], 40, popovervue_type_template_id_245d490f_hoisted_2), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createVNode)(_component_dt_lazy_show, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.mergeProps)({
6041
6057
  id: $props.id,
6042
6058
  ref: "content",
6043
6059
  role: $props.role,
@@ -6049,19 +6065,16 @@ function popovervue_type_template_id_90818940_render(_ctx, _cache, $props, $setu
6049
6065
  transition: $props.transition,
6050
6066
  show: $data.isOpen,
6051
6067
  appear: "",
6052
- class: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.normalizeClass)(['d-popover__dialog', {
6068
+ class: ['d-popover__dialog', {
6053
6069
  'd-popover__dialog--modal': $props.modal
6054
- }, $props.dialogClass]),
6055
- style: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.normalizeStyle)({
6070
+ }, $props.dialogClass],
6071
+ style: {
6056
6072
  'max-height': $props.maxHeight,
6057
6073
  'max-width': $props.maxWidth
6058
- }),
6074
+ },
6059
6075
  css: _ctx.$attrs.css,
6060
- tabindex: $props.contentTabindex,
6061
- onKeydownCapture: $options.onKeydown,
6062
- onAfterLeave: $options.onLeaveTransitionComplete,
6063
- onAfterEnter: $options.onEnterTransitionComplete
6064
- }, {
6076
+ tabindex: $props.contentTabindex
6077
+ }, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toHandlers)($options.popoverListeners)), {
6065
6078
  default: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withCtx)(() => [_ctx.$slots.headerContent || $props.showCloseButton ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)(_component_popover_header_footer, {
6066
6079
  key: 0,
6067
6080
  ref: "popover__header",
@@ -6099,11 +6112,11 @@ function popovervue_type_template_id_90818940_render(_ctx, _cache, $props, $setu
6099
6112
  onClose: $options.closePopover
6100
6113
  }, null, 8, ["visually-hidden-close-label", "onClose"])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true)]),
6101
6114
  _: 3
6102
- }, 8, ["id", "role", "aria-hidden", "aria-labelledby", "aria-label", "aria-modal", "transition", "show", "class", "style", "css", "tabindex", "onKeydownCapture", "onAfterLeave", "onAfterEnter"])]),
6115
+ }, 16, ["id", "role", "aria-hidden", "aria-labelledby", "aria-label", "aria-modal", "transition", "show", "class", "style", "css", "tabindex"])]),
6103
6116
  _: 3
6104
6117
  }, 8, ["class"]))]);
6105
6118
  }
6106
- ;// CONCATENATED MODULE: ./components/popover/popover.vue?vue&type=template&id=90818940
6119
+ ;// CONCATENATED MODULE: ./components/popover/popover.vue?vue&type=template&id=245d490f
6107
6120
 
6108
6121
  ;// CONCATENATED MODULE: ./node_modules/@popperjs/core/lib/dom-utils/getWindow.js
6109
6122
  function getWindow(node) {
@@ -11105,6 +11118,13 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11105
11118
  }
11106
11119
  },
11107
11120
  emits: [
11121
+ /**
11122
+ * Native keydown event
11123
+ *
11124
+ * @event keydown
11125
+ * @type {KeyboardEvent}
11126
+ */
11127
+ 'keydown',
11108
11128
  /**
11109
11129
  * Event fired to sync the open prop with the parent component
11110
11130
  * @event update:open
@@ -11129,6 +11149,20 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11129
11149
  },
11130
11150
 
11131
11151
  computed: {
11152
+ popoverListeners() {
11153
+ return {
11154
+ keydown: event => {
11155
+ this.onKeydown(event);
11156
+ },
11157
+ 'after-leave': event => {
11158
+ this.onLeaveTransitionComplete();
11159
+ },
11160
+ 'after-enter': event => {
11161
+ this.onEnterTransitionComplete();
11162
+ }
11163
+ };
11164
+ },
11165
+
11132
11166
  labelledBy() {
11133
11167
  // aria-labelledby should be set only if aria-labelledby is passed as a prop, or if
11134
11168
  // there is no aria-label and the labelledby should point to the anchor.
@@ -11190,8 +11224,7 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11190
11224
  if (open !== null) {
11191
11225
  this.isOpen = open;
11192
11226
  }
11193
- },
11194
- immediate: true
11227
+ }
11195
11228
  },
11196
11229
 
11197
11230
  isOpen(isOpen, isPrev) {
@@ -11234,11 +11267,10 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11234
11267
  zIndex: this.modal ? 650 : this.calculateAnchorZindex(),
11235
11268
  onClickOutside: this.onClickOutside,
11236
11269
  onShow: this.onShow
11237
- }); // immediate watcher fires before mounted, so have this here in case
11238
- // show prop was initially set to true.
11270
+ }); // Set internal open state on mounted since the watcher is not fired initially.
11239
11271
 
11240
- if (this.isOpen) {
11241
- this.tip.show();
11272
+ if (this.open !== null) {
11273
+ this.isOpen = this.open;
11242
11274
  }
11243
11275
  },
11244
11276
 
@@ -11303,6 +11335,7 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11303
11335
  return;
11304
11336
  }
11305
11337
 
11338
+ event.preventDefault();
11306
11339
  (_this$tip3 = this.tip) === null || _this$tip3 === void 0 ? void 0 : _this$tip3.setProps({
11307
11340
  placement: 'right-start'
11308
11341
  });
@@ -11333,6 +11366,8 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11333
11366
  this.isOpen = true;
11334
11367
  }
11335
11368
  }
11369
+
11370
+ this.$emit('keydown', e);
11336
11371
  },
11337
11372
 
11338
11373
  addClosePopoverEventListener() {
@@ -11446,6 +11481,8 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11446
11481
  if (e.key === 'Escape') {
11447
11482
  this.closePopover();
11448
11483
  }
11484
+
11485
+ this.$emit('keydown', e);
11449
11486
  },
11450
11487
 
11451
11488
  async setPopoverContentAnchorWidth() {
@@ -11472,9 +11509,9 @@ const popover_header_footer_exports_ = /*#__PURE__*/(0,exportHelper/* default */
11472
11509
  });
11473
11510
  ;// CONCATENATED MODULE: ./components/popover/popover.vue?vue&type=script&lang=js
11474
11511
 
11475
- // EXTERNAL MODULE: ./node_modules/vue-style-loader/index.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[4]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/popover/popover.vue?vue&type=style&index=0&id=90818940&lang=less
11476
- var popovervue_type_style_index_0_id_90818940_lang_less = __webpack_require__(925);
11477
- ;// CONCATENATED MODULE: ./components/popover/popover.vue?vue&type=style&index=0&id=90818940&lang=less
11512
+ // EXTERNAL MODULE: ./node_modules/vue-style-loader/index.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[4]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/popover/popover.vue?vue&type=style&index=0&id=245d490f&lang=less
11513
+ var popovervue_type_style_index_0_id_245d490f_lang_less = __webpack_require__(284);
11514
+ ;// CONCATENATED MODULE: ./components/popover/popover.vue?vue&type=style&index=0&id=245d490f&lang=less
11478
11515
 
11479
11516
  ;// CONCATENATED MODULE: ./components/popover/popover.vue
11480
11517
 
@@ -11484,7 +11521,7 @@ var popovervue_type_style_index_0_id_90818940_lang_less = __webpack_require__(92
11484
11521
  ;
11485
11522
 
11486
11523
 
11487
- const popover_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(popovervue_type_script_lang_js, [['render',popovervue_type_template_id_90818940_render]])
11524
+ const popover_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(popovervue_type_script_lang_js, [['render',popovervue_type_template_id_245d490f_render]])
11488
11525
 
11489
11526
  /* harmony default export */ const popover = (popover_exports_);
11490
11527
  ;// CONCATENATED MODULE: ./components/popover/index.js
@@ -11504,6 +11541,7 @@ const DROPDOWN_PADDING_CLASSES = {
11504
11541
 
11505
11542
 
11506
11543
 
11544
+
11507
11545
  /* harmony default export */ const dropdownvue_type_script_lang_js = ({
11508
11546
  name: 'DtDropdown',
11509
11547
  components: {
@@ -11658,6 +11696,13 @@ const DROPDOWN_PADDING_CLASSES = {
11658
11696
  }
11659
11697
  },
11660
11698
  emits: [
11699
+ /**
11700
+ * Native keydown event
11701
+ *
11702
+ * @event keydown
11703
+ * @type {KeyboardEvent}
11704
+ */
11705
+ 'keydown',
11661
11706
  /**
11662
11707
  * Event fired when the highlight changes
11663
11708
  *
@@ -11693,6 +11738,60 @@ const DROPDOWN_PADDING_CLASSES = {
11693
11738
  },
11694
11739
 
11695
11740
  computed: {
11741
+ dropdownListeners() {
11742
+ return {
11743
+ opened: isPopoverOpen => {
11744
+ this.updateInitialHighlightIndex(isPopoverOpen);
11745
+ },
11746
+ keydown: event => {
11747
+ const eventCode = event.code;
11748
+
11749
+ switch (eventCode) {
11750
+ case EVENT_KEYNAMES.up:
11751
+ case EVENT_KEYNAMES.arrowup:
11752
+ this.onKeyValidation(event, 'onUpKeyPress');
11753
+ event.stopPropagation();
11754
+ event.preventDefault();
11755
+ break;
11756
+
11757
+ case EVENT_KEYNAMES.down:
11758
+ case EVENT_KEYNAMES.arrowdown:
11759
+ this.onKeyValidation(event, 'onDownKeyPress');
11760
+ event.stopPropagation();
11761
+ event.preventDefault();
11762
+ break;
11763
+
11764
+ case EVENT_KEYNAMES.space:
11765
+ case EVENT_KEYNAMES.spacebar:
11766
+ this.onSpaceKey();
11767
+ break;
11768
+
11769
+ case EVENT_KEYNAMES.enter:
11770
+ this.onEnterKey();
11771
+ break;
11772
+
11773
+ case EVENT_KEYNAMES.home:
11774
+ this.onKeyValidation(event, 'onHomeKeyPress');
11775
+ event.stopPropagation();
11776
+ event.preventDefault();
11777
+ break;
11778
+
11779
+ case EVENT_KEYNAMES.end:
11780
+ this.onKeyValidation(event, 'onEndKeyPress');
11781
+ event.stopPropagation();
11782
+ event.preventDefault();
11783
+ break;
11784
+
11785
+ default:
11786
+ this.onKeyValidation(event, 'onKeyPress');
11787
+ break;
11788
+ }
11789
+
11790
+ this.$emit('keydown', event);
11791
+ }
11792
+ };
11793
+ },
11794
+
11696
11795
  beginningOfListMethod() {
11697
11796
  return this.onBeginningOfList || this.jumpToEnd;
11698
11797
  },
@@ -11830,9 +11929,9 @@ const DROPDOWN_PADDING_CLASSES = {
11830
11929
  });
11831
11930
  ;// CONCATENATED MODULE: ./components/dropdown/dropdown.vue?vue&type=script&lang=js
11832
11931
 
11833
- // EXTERNAL MODULE: ./node_modules/vue-style-loader/index.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[4]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/dropdown/dropdown.vue?vue&type=style&index=0&id=2021ac9d&lang=less
11834
- var dropdownvue_type_style_index_0_id_2021ac9d_lang_less = __webpack_require__(438);
11835
- ;// CONCATENATED MODULE: ./components/dropdown/dropdown.vue?vue&type=style&index=0&id=2021ac9d&lang=less
11932
+ // EXTERNAL MODULE: ./node_modules/vue-style-loader/index.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[4]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/dropdown/dropdown.vue?vue&type=style&index=0&id=6b8ca270&lang=less
11933
+ var dropdownvue_type_style_index_0_id_6b8ca270_lang_less = __webpack_require__(8);
11934
+ ;// CONCATENATED MODULE: ./components/dropdown/dropdown.vue?vue&type=style&index=0&id=6b8ca270&lang=less
11836
11935
 
11837
11936
  ;// CONCATENATED MODULE: ./components/dropdown/dropdown.vue
11838
11937
 
@@ -11842,7 +11941,7 @@ var dropdownvue_type_style_index_0_id_2021ac9d_lang_less = __webpack_require__(4
11842
11941
  ;
11843
11942
 
11844
11943
 
11845
- const dropdown_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(dropdownvue_type_script_lang_js, [['render',dropdownvue_type_template_id_2021ac9d_render]])
11944
+ const dropdown_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(dropdownvue_type_script_lang_js, [['render',dropdownvue_type_template_id_6b8ca270_render]])
11846
11945
 
11847
11946
  /* harmony default export */ const dropdown = (dropdown_exports_);
11848
11947
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/dropdown/dropdown_list.vue?vue&type=template&id=eefb7378
@@ -13321,26 +13420,26 @@ const input_group_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(input_
13321
13420
  /* harmony default export */ const input_group_input_group = (input_group_exports_);
13322
13421
  ;// CONCATENATED MODULE: ./components/input_group/index.js
13323
13422
 
13324
- ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/modal/modal.vue?vue&type=template&id=21785ac6
13423
+ ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/modal/modal.vue?vue&type=template&id=7bbbda2b
13325
13424
 
13326
- const modalvue_type_template_id_21785ac6_hoisted_1 = ["aria-describedby", "aria-labelledby"];
13327
- const modalvue_type_template_id_21785ac6_hoisted_2 = ["id"];
13328
- const modalvue_type_template_id_21785ac6_hoisted_3 = ["id"];
13329
- const modalvue_type_template_id_21785ac6_hoisted_4 = {
13425
+ const modalvue_type_template_id_7bbbda2b_hoisted_1 = ["aria-describedby", "aria-labelledby"];
13426
+ const modalvue_type_template_id_7bbbda2b_hoisted_2 = ["id"];
13427
+ const modalvue_type_template_id_7bbbda2b_hoisted_3 = ["id"];
13428
+ const modalvue_type_template_id_7bbbda2b_hoisted_4 = {
13330
13429
  key: 2,
13331
13430
  class: "d-modal__content",
13332
13431
  "data-qa": "dt-modal-copy"
13333
13432
  };
13334
- const modalvue_type_template_id_21785ac6_hoisted_5 = {
13433
+ const modalvue_type_template_id_7bbbda2b_hoisted_5 = {
13335
13434
  key: 3,
13336
13435
  class: "d-modal__content",
13337
13436
  "data-qa": "dt-modal-copy"
13338
13437
  };
13339
- const modalvue_type_template_id_21785ac6_hoisted_6 = {
13438
+ const modalvue_type_template_id_7bbbda2b_hoisted_6 = {
13340
13439
  key: 4,
13341
13440
  class: "d-modal__footer"
13342
13441
  };
13343
- function modalvue_type_template_id_21785ac6_render(_ctx, _cache, $props, $setup, $data, $options) {
13442
+ function modalvue_type_template_id_7bbbda2b_render(_ctx, _cache, $props, $setup, $data, $options) {
13344
13443
  const _component_icon_close = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("icon-close");
13345
13444
 
13346
13445
  const _component_dt_button = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("dt-button");
@@ -13349,16 +13448,13 @@ function modalvue_type_template_id_21785ac6_render(_ctx, _cache, $props, $setup,
13349
13448
 
13350
13449
  const _component_dt_lazy_show = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("dt-lazy-show");
13351
13450
 
13352
- return (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)(_component_dt_lazy_show, {
13451
+ return (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)(_component_dt_lazy_show, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.mergeProps)({
13353
13452
  transition: "d-zoom",
13354
13453
  show: $props.show,
13355
- class: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.normalizeClass)(['d-modal', $data.MODAL_KIND_MODIFIERS[$props.kind], $data.MODAL_SIZE_MODIFIERS[$props.size], $props.modalClass]),
13454
+ class: ['d-modal', $data.MODAL_KIND_MODIFIERS[$props.kind], $data.MODAL_SIZE_MODIFIERS[$props.size], $props.modalClass],
13356
13455
  "data-qa": "dt-modal",
13357
- "aria-hidden": $options.open,
13358
- onClick: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)($options.close, ["self"]),
13359
- onKeydown: [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)($options.close, ["esc"]), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)($options.trapFocus, ["tab"])],
13360
- onAfterEnter: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withModifiers)($options.setFocusAfterTransition, ["self"])
13361
- }, {
13456
+ "aria-hidden": $options.open
13457
+ }, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toHandlers)($options.modalListeners)), {
13362
13458
  default: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withCtx)(() => [$props.show && (_ctx.$slots.banner || $props.bannerTitle) ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("div", {
13363
13459
  key: 0,
13364
13460
  "data-qa": "dt-modal-banner",
@@ -13380,12 +13476,12 @@ function modalvue_type_template_id_21785ac6_render(_ctx, _cache, $props, $setup,
13380
13476
  id: $props.labelledById,
13381
13477
  class: "d-modal__header",
13382
13478
  "data-qa": "dt-modal-title"
13383
- }, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "header")], 8, modalvue_type_template_id_21785ac6_hoisted_2)) : ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("h2", {
13479
+ }, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "header")], 8, modalvue_type_template_id_7bbbda2b_hoisted_2)) : ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("h2", {
13384
13480
  key: 1,
13385
13481
  id: $props.labelledById,
13386
13482
  class: "d-modal__header",
13387
13483
  "data-qa": "dt-modal-title"
13388
- }, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toDisplayString)($props.title), 9, modalvue_type_template_id_21785ac6_hoisted_3)), _ctx.$slots.default ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("div", modalvue_type_template_id_21785ac6_hoisted_4, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "default")])) : ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("p", modalvue_type_template_id_21785ac6_hoisted_5, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toDisplayString)($props.copy), 1)), $options.hasFooterSlot ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("footer", modalvue_type_template_id_21785ac6_hoisted_6, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "footer")])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true), !$props.hideClose ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)(_component_dt_button, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.mergeProps)({
13484
+ }, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toDisplayString)($props.title), 9, modalvue_type_template_id_7bbbda2b_hoisted_3)), _ctx.$slots.default ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("div", modalvue_type_template_id_7bbbda2b_hoisted_4, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "default")])) : ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("p", modalvue_type_template_id_7bbbda2b_hoisted_5, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toDisplayString)($props.copy), 1)), $options.hasFooterSlot ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("footer", modalvue_type_template_id_7bbbda2b_hoisted_6, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "footer")])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true), !$props.hideClose ? ((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)(_component_dt_button, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.mergeProps)({
13389
13485
  key: 5,
13390
13486
  class: "d-modal__close",
13391
13487
  circle: "",
@@ -13402,13 +13498,13 @@ function modalvue_type_template_id_21785ac6_render(_ctx, _cache, $props, $setup,
13402
13498
  key: 6,
13403
13499
  "visually-hidden-close-label": _ctx.visuallyHiddenCloseLabel,
13404
13500
  onClose: $options.close
13405
- }, null, 8, ["visually-hidden-close-label", "onClose"])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true)], 10, modalvue_type_template_id_21785ac6_hoisted_1), [[external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.vShow, $props.show]])]),
13501
+ }, null, 8, ["visually-hidden-close-label", "onClose"])) : (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createCommentVNode)("", true)], 10, modalvue_type_template_id_7bbbda2b_hoisted_1), [[external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.vShow, $props.show]])]),
13406
13502
  _: 3
13407
13503
  })]),
13408
13504
  _: 3
13409
- }, 8, ["show", "class", "aria-hidden", "onClick", "onKeydown", "onAfterEnter"]);
13505
+ }, 16, ["show", "class", "aria-hidden"]);
13410
13506
  }
13411
- ;// CONCATENATED MODULE: ./components/modal/modal.vue?vue&type=template&id=21785ac6
13507
+ ;// CONCATENATED MODULE: ./components/modal/modal.vue?vue&type=template&id=7bbbda2b
13412
13508
 
13413
13509
  ;// CONCATENATED MODULE: ./components/modal/modal_constants.js
13414
13510
  // Modal style modifiers
@@ -13430,6 +13526,7 @@ const MODAL_SIZE_MODIFIERS = {
13430
13526
 
13431
13527
 
13432
13528
 
13529
+
13433
13530
  /**
13434
13531
  * Modals focus the user’s attention exclusively on one task or piece of information
13435
13532
  * via a window that sits on top of the page content.
@@ -13581,6 +13678,20 @@ const MODAL_SIZE_MODIFIERS = {
13581
13678
  }
13582
13679
  },
13583
13680
  emits: [
13681
+ /**
13682
+ * Native button click event
13683
+ *
13684
+ * @event click
13685
+ * @type {PointerEvent | KeyboardEvent}
13686
+ */
13687
+ 'click',
13688
+ /**
13689
+ * Native keydown event
13690
+ *
13691
+ * @event keydown
13692
+ * @type {KeyboardEvent}
13693
+ */
13694
+ 'keydown',
13584
13695
  /**
13585
13696
  * The modal will emit a "false" boolean value for this event when the user performs a modal-closing action.
13586
13697
  * Parent components can sync on this value to create a 2-way binding to control modal visibility.
@@ -13598,6 +13709,32 @@ const MODAL_SIZE_MODIFIERS = {
13598
13709
  },
13599
13710
 
13600
13711
  computed: {
13712
+ modalListeners() {
13713
+ return {
13714
+ click: event => {
13715
+ event.target === event.currentTarget && this.close();
13716
+ this.$emit('click', event);
13717
+ },
13718
+ keydown: event => {
13719
+ switch (event.code) {
13720
+ case EVENT_KEYNAMES.esc:
13721
+ case EVENT_KEYNAMES.escape:
13722
+ this.close();
13723
+ break;
13724
+
13725
+ case EVENT_KEYNAMES.tab:
13726
+ this.trapFocus(event);
13727
+ break;
13728
+ }
13729
+
13730
+ this.$emit('keydown', event);
13731
+ },
13732
+ 'after-enter': event => {
13733
+ event.target === event.currentTarget && this.setFocusAfterTransition();
13734
+ }
13735
+ };
13736
+ },
13737
+
13601
13738
  open() {
13602
13739
  return `${!this.show}`;
13603
13740
  },
@@ -13667,7 +13804,7 @@ const MODAL_SIZE_MODIFIERS = {
13667
13804
 
13668
13805
 
13669
13806
  ;
13670
- const modal_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(modalvue_type_script_lang_js, [['render',modalvue_type_template_id_21785ac6_render]])
13807
+ const modal_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(modalvue_type_script_lang_js, [['render',modalvue_type_template_id_7bbbda2b_render]])
13671
13808
 
13672
13809
  /* harmony default export */ const modal_modal = (modal_exports_);
13673
13810
  ;// CONCATENATED MODULE: ./components/modal/index.js
@@ -14989,9 +15126,9 @@ const TAB_IMPORTANCE_MODIFIERS = {
14989
15126
  const tab_group_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(tab_groupvue_type_script_lang_js, [['render',tab_groupvue_type_template_id_617fd84e_render]])
14990
15127
 
14991
15128
  /* harmony default export */ const tab_group = (tab_group_exports_);
14992
- ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tabs/tab.vue?vue&type=template&id=91977b48
15129
+ ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tabs/tab.vue?vue&type=template&id=af343bac
14993
15130
 
14994
- function tabvue_type_template_id_91977b48_render(_ctx, _cache, $props, $setup, $data, $options) {
15131
+ function tabvue_type_template_id_af343bac_render(_ctx, _cache, $props, $setup, $data, $options) {
14995
15132
  const _component_dt_button = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("dt-button");
14996
15133
 
14997
15134
  return (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createBlock)(_component_dt_button, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.mergeProps)({
@@ -15006,15 +15143,12 @@ function tabvue_type_template_id_91977b48_render(_ctx, _cache, $props, $setup, $
15006
15143
  "data-qa": "dt-tab",
15007
15144
  tabindex: $options.isSelected ? '0' : '-1',
15008
15145
  disabled: $options.groupContext.disabled || $props.disabled
15009
- }, _ctx.$attrs, {
15010
- onClick: _cache[0] || (_cache[0] = $event => $options.selectPanel()),
15011
- onFocus: _cache[1] || (_cache[1] = $event => $options.setFocus($props.id))
15012
- }), {
15146
+ }, _ctx.$attrs, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toHandlers)($options.tabListeners)), {
15013
15147
  default: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withCtx)(() => [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "default")]),
15014
15148
  _: 3
15015
15149
  }, 16, ["id", "class", "aria-selected", "aria-controls", "aria-label", "tabindex", "disabled"]);
15016
15150
  }
15017
- ;// CONCATENATED MODULE: ./components/tabs/tab.vue?vue&type=template&id=91977b48
15151
+ ;// CONCATENATED MODULE: ./components/tabs/tab.vue?vue&type=template&id=af343bac
15018
15152
 
15019
15153
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tabs/tab.vue?vue&type=script&lang=js
15020
15154
 
@@ -15082,6 +15216,21 @@ function tabvue_type_template_id_91977b48_render(_ctx, _cache, $props, $setup, $
15082
15216
  default: ''
15083
15217
  }
15084
15218
  },
15219
+ emits: [
15220
+ /**
15221
+ * Native button focus in event
15222
+ *
15223
+ * @event focus
15224
+ * @type {FocusEvent}
15225
+ */
15226
+ 'focus',
15227
+ /**
15228
+ * Native button click event
15229
+ *
15230
+ * @event click
15231
+ * @type {PointerEvent | KeyboardEvent}
15232
+ */
15233
+ 'click'],
15085
15234
 
15086
15235
  data() {
15087
15236
  return {
@@ -15090,6 +15239,19 @@ function tabvue_type_template_id_91977b48_render(_ctx, _cache, $props, $setup, $
15090
15239
  },
15091
15240
 
15092
15241
  computed: {
15242
+ tabListeners() {
15243
+ return {
15244
+ click: event => {
15245
+ this.selectPanel();
15246
+ this.$emit('click', event);
15247
+ },
15248
+ focus: event => {
15249
+ this.setFocus(this.id);
15250
+ this.$emit('focus', event);
15251
+ }
15252
+ };
15253
+ },
15254
+
15093
15255
  isSelected() {
15094
15256
  return this.groupContext.selected === this.panelId;
15095
15257
  }
@@ -15125,7 +15287,7 @@ function tabvue_type_template_id_91977b48_render(_ctx, _cache, $props, $setup, $
15125
15287
 
15126
15288
 
15127
15289
  ;
15128
- const tab_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(tabvue_type_script_lang_js, [['render',tabvue_type_template_id_91977b48_render]])
15290
+ const tab_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(tabvue_type_script_lang_js, [['render',tabvue_type_template_id_af343bac_render]])
15129
15291
 
15130
15292
  /* harmony default export */ const tab = (tab_exports_);
15131
15293
  ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tabs/tab_panel.vue?vue&type=template&id=572b0140
@@ -16604,15 +16766,15 @@ const toggle_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(togglevue_t
16604
16766
  /* harmony default export */ const toggle = (toggle_exports_);
16605
16767
  ;// CONCATENATED MODULE: ./components/toggle/index.js
16606
16768
 
16607
- ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tooltip/tooltip.vue?vue&type=template&id=3533d022
16769
+ ;// CONCATENATED MODULE: ./node_modules/thread-loader/dist/cjs.js!./node_modules/babel-loader/lib/index.js??clonedRuleSet-40.use[1]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[3]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tooltip/tooltip.vue?vue&type=template&id=bacc9698
16608
16770
 
16609
- const tooltipvue_type_template_id_3533d022_hoisted_1 = {
16771
+ const tooltipvue_type_template_id_bacc9698_hoisted_1 = {
16610
16772
  "data-qa": "dt-tooltip-container"
16611
16773
  };
16612
- function tooltipvue_type_template_id_3533d022_render(_ctx, _cache, $props, $setup, $data, $options) {
16774
+ function tooltipvue_type_template_id_bacc9698_render(_ctx, _cache, $props, $setup, $data, $options) {
16613
16775
  const _component_dt_lazy_show = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.resolveComponent)("dt-lazy-show");
16614
16776
 
16615
- return (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("div", tooltipvue_type_template_id_3533d022_hoisted_1, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementVNode)("div", {
16777
+ return (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.openBlock)(), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementBlock)("div", tooltipvue_type_template_id_bacc9698_hoisted_1, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createElementVNode)("div", {
16616
16778
  ref: "anchor",
16617
16779
  "data-qa": "dt-tooltip-anchor",
16618
16780
  onFocusin: _cache[0] || (_cache[0] = function () {
@@ -16630,7 +16792,7 @@ function tooltipvue_type_template_id_3533d022_render(_ctx, _cache, $props, $setu
16630
16792
  onKeydown: _cache[4] || (_cache[4] = (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withKeys)(function () {
16631
16793
  return $options.onLeaveAnchor && $options.onLeaveAnchor(...arguments);
16632
16794
  }, ["esc"]))
16633
- }, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "anchor")], 544), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createVNode)(_component_dt_lazy_show, {
16795
+ }, [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "anchor")], 544), (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createVNode)(_component_dt_lazy_show, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.mergeProps)({
16634
16796
  id: $props.id,
16635
16797
  ref: "content",
16636
16798
  show: $data.isShown && (!!$props.message.trim() || !$options.defaultSlotIsEmpty),
@@ -16639,17 +16801,15 @@ function tooltipvue_type_template_id_3533d022_render(_ctx, _cache, $props, $setu
16639
16801
  "data-qa": "dt-tooltip",
16640
16802
  appear: "",
16641
16803
  transition: $props.transition,
16642
- class: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.normalizeClass)(['d-tooltip', `d-tooltip__arrow-tippy--${$data.currentPlacement}`, {
16804
+ class: ['d-tooltip', `d-tooltip__arrow-tippy--${$data.currentPlacement}`, {
16643
16805
  [$data.TOOLTIP_KIND_MODIFIERS.inverted]: $props.inverted
16644
- }, $props.contentClass]),
16645
- onAfterLeave: $options.onLeaveTransitionComplete,
16646
- onAfterEnter: $options.onEnterTransitionComplete
16647
- }, {
16806
+ }, $props.contentClass]
16807
+ }, (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toHandlers)($options.tooltipListeners)), {
16648
16808
  default: (0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.withCtx)(() => [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.renderSlot)(_ctx.$slots, "default", {}, () => [(0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.createTextVNode)((0,external_commonjs_vue_commonjs2_vue_root_Vue_namespaceObject.toDisplayString)($props.message), 1)])]),
16649
16809
  _: 3
16650
- }, 8, ["id", "show", "transition", "class", "onAfterLeave", "onAfterEnter"])]);
16810
+ }, 16, ["id", "show", "transition", "class"])]);
16651
16811
  }
16652
- ;// CONCATENATED MODULE: ./components/tooltip/tooltip.vue?vue&type=template&id=3533d022
16812
+ ;// CONCATENATED MODULE: ./components/tooltip/tooltip.vue?vue&type=template&id=bacc9698
16653
16813
 
16654
16814
  ;// CONCATENATED MODULE: ./components/tooltip/tooltip_constants.js
16655
16815
  /*
@@ -16830,6 +16990,17 @@ const TOOLTIP_HIDE_ON_CLICK_VARIANTS = [true, false, 'toggle'];
16830
16990
  },
16831
16991
 
16832
16992
  computed: {
16993
+ tooltipListeners() {
16994
+ return {
16995
+ 'after-leave': event => {
16996
+ this.onLeaveTransitionComplete();
16997
+ },
16998
+ 'after-enter': event => {
16999
+ this.onEnterTransitionComplete();
17000
+ }
17001
+ };
17002
+ },
17003
+
16833
17004
  tippyProps() {
16834
17005
  return {
16835
17006
  offset: this.offset,
@@ -16988,9 +17159,9 @@ const TOOLTIP_HIDE_ON_CLICK_VARIANTS = [true, false, 'toggle'];
16988
17159
  });
16989
17160
  ;// CONCATENATED MODULE: ./components/tooltip/tooltip.vue?vue&type=script&lang=js
16990
17161
 
16991
- // EXTERNAL MODULE: ./node_modules/vue-style-loader/index.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[4]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tooltip/tooltip.vue?vue&type=style&index=0&id=3533d022&lang=less
16992
- var tooltipvue_type_style_index_0_id_3533d022_lang_less = __webpack_require__(504);
16993
- ;// CONCATENATED MODULE: ./components/tooltip/tooltip.vue?vue&type=style&index=0&id=3533d022&lang=less
17162
+ // EXTERNAL MODULE: ./node_modules/vue-style-loader/index.js??clonedRuleSet-32.use[0]!./node_modules/css-loader/dist/cjs.js??clonedRuleSet-32.use[1]!./node_modules/vue-loader/dist/stylePostLoader.js!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[2]!./node_modules/postcss-loader/dist/cjs.js??clonedRuleSet-32.use[3]!./node_modules/less-loader/dist/cjs.js??clonedRuleSet-32.use[4]!./node_modules/vue-loader/dist/index.js??ruleSet[0].use[0]!./components/tooltip/tooltip.vue?vue&type=style&index=0&id=bacc9698&lang=less
17163
+ var tooltipvue_type_style_index_0_id_bacc9698_lang_less = __webpack_require__(27);
17164
+ ;// CONCATENATED MODULE: ./components/tooltip/tooltip.vue?vue&type=style&index=0&id=bacc9698&lang=less
16994
17165
 
16995
17166
  ;// CONCATENATED MODULE: ./components/tooltip/tooltip.vue
16996
17167
 
@@ -17000,7 +17171,7 @@ var tooltipvue_type_style_index_0_id_3533d022_lang_less = __webpack_require__(50
17000
17171
  ;
17001
17172
 
17002
17173
 
17003
- const tooltip_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(tooltipvue_type_script_lang_js, [['render',tooltipvue_type_template_id_3533d022_render]])
17174
+ const tooltip_exports_ = /*#__PURE__*/(0,exportHelper/* default */.Z)(tooltipvue_type_script_lang_js, [['render',tooltipvue_type_template_id_bacc9698_render]])
17004
17175
 
17005
17176
  /* harmony default export */ const tooltip = (tooltip_exports_);
17006
17177
  ;// CONCATENATED MODULE: ./components/tooltip/index.js