calcite-handle.cjs.entry.js 4.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394
  1. /*!
  2. * All material copyright ESRI, All Rights Reserved, unless otherwise specified.
  3. * See https://github.com/Esri/calcite-components/blob/master/LICENSE.md for details.
  4. * v1.0.0-beta.97
  5. */
  6. 'use strict';
  7. Object.defineProperty(exports, '__esModule', { value: true });
  8. const index = require('./index-a0010f96.js');
  9. const dom = require('./dom-2ec8c9ed.js');
  10. require('./resources-b5a5f8a7.js');
  11. require('./guid-f4f03a7a.js');
  12. const CSS = {
  13. handle: "handle",
  14. handleActivated: "handle--activated"
  15. };
  16. const ICONS = {
  17. drag: "drag"
  18. };
  19. const handleCss = "@keyframes in{0%{opacity:0}100%{opacity:1}}@keyframes in-down{0%{opacity:0;transform:translate3D(0, -5px, 0)}100%{opacity:1;transform:translate3D(0, 0, 0)}}@keyframes in-up{0%{opacity:0;transform:translate3D(0, 5px, 0)}100%{opacity:1;transform:translate3D(0, 0, 0)}}@keyframes in-scale{0%{opacity:0;transform:scale3D(0.95, 0.95, 1)}100%{opacity:1;transform:scale3D(1, 1, 1)}}:root{--calcite-animation-timing:calc(150ms * var(--calcite-internal-duration-factor));--calcite-internal-duration-factor:var(--calcite-duration-factor, 1);--calcite-internal-animation-timing-fast:calc(100ms * var(--calcite-internal-duration-factor));--calcite-internal-animation-timing-medium:calc(200ms * var(--calcite-internal-duration-factor));--calcite-internal-animation-timing-slow:calc(300ms * var(--calcite-internal-duration-factor))}.calcite-animate{opacity:0;animation-fill-mode:both;animation-duration:var(--calcite-animation-timing)}.calcite-animate__in{animation-name:in}.calcite-animate__in-down{animation-name:in-down}.calcite-animate__in-up{animation-name:in-up}.calcite-animate__in-scale{animation-name:in-scale}@media (prefers-reduced-motion: reduce){:root{--calcite-internal-duration-factor:0.01}}:root{--calcite-floating-ui-transition:var(--calcite-animation-timing)}:host([hidden]){display:none}:host{display:flex}.handle{display:flex;cursor:move;align-items:center;justify-content:center;align-self:stretch;border-style:none;background-color:transparent;outline-color:transparent;color:var(--calcite-ui-border-input);padding-block:0.75rem;padding-inline:0.25rem;line-height:0}.handle:hover{background-color:var(--calcite-ui-foreground-2);color:var(--calcite-ui-text-1)}.handle:focus{color:var(--calcite-ui-text-1);outline:2px solid var(--calcite-ui-brand);outline-offset:-2px}.handle--activated{background-color:var(--calcite-ui-foreground-3);color:var(--calcite-ui-text-1)}.handle calcite-icon{color:inherit}";
  20. const Handle = class {
  21. constructor(hostRef) {
  22. index.registerInstance(this, hostRef);
  23. this.calciteHandleNudge = index.createEvent(this, "calciteHandleNudge", 6);
  24. // --------------------------------------------------------------------------
  25. //
  26. // Properties
  27. //
  28. // --------------------------------------------------------------------------
  29. /**
  30. * @internal
  31. */
  32. this.activated = false;
  33. /**
  34. * Value for the button title attribute
  35. */
  36. this.textTitle = "handle";
  37. // --------------------------------------------------------------------------
  38. //
  39. // Private Methods
  40. //
  41. // --------------------------------------------------------------------------
  42. this.handleKeyDown = (event) => {
  43. switch (event.key) {
  44. case " ":
  45. this.activated = !this.activated;
  46. event.preventDefault();
  47. break;
  48. case "ArrowUp":
  49. case "ArrowDown":
  50. if (!this.activated) {
  51. return;
  52. }
  53. event.preventDefault();
  54. const direction = event.key.toLowerCase().replace("arrow", "");
  55. this.calciteHandleNudge.emit({ handle: this.el, direction });
  56. break;
  57. }
  58. };
  59. this.handleBlur = () => {
  60. this.activated = false;
  61. };
  62. }
  63. // --------------------------------------------------------------------------
  64. //
  65. // Methods
  66. //
  67. // --------------------------------------------------------------------------
  68. /** Sets focus on the component. */
  69. async setFocus() {
  70. var _a;
  71. (_a = this.handleButton) === null || _a === void 0 ? void 0 : _a.focus();
  72. }
  73. // --------------------------------------------------------------------------
  74. //
  75. // Render Methods
  76. //
  77. // --------------------------------------------------------------------------
  78. render() {
  79. return (
  80. // Needs to be a span because of https://github.com/SortableJS/Sortable/issues/1486
  81. index.h("span", { "aria-pressed": dom.toAriaBoolean(this.activated), class: { [CSS.handle]: true, [CSS.handleActivated]: this.activated }, onBlur: this.handleBlur, onKeyDown: this.handleKeyDown, ref: (el) => {
  82. this.handleButton = el;
  83. }, role: "button", tabindex: "0", title: this.textTitle }, index.h("calcite-icon", { icon: ICONS.drag, scale: "s" })));
  84. }
  85. get el() { return index.getElement(this); }
  86. };
  87. Handle.style = handleCss;
  88. exports.calcite_handle = Handle;