calcite-option.js 4.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  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. import { proxyCustomElement, HTMLElement, createEvent, h } from '@stencil/core/internal/client/index.js';
  7. import { c as createObserver } from './observers.js';
  8. const optionCss = "@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:block}";
  9. const Option = /*@__PURE__*/ proxyCustomElement(class extends HTMLElement {
  10. constructor() {
  11. super();
  12. this.__registerHost();
  13. this.__attachShadow();
  14. this.calciteInternalOptionChange = createEvent(this, "calciteInternalOptionChange", 6);
  15. //--------------------------------------------------------------------------
  16. //
  17. // Properties
  18. //
  19. //--------------------------------------------------------------------------
  20. /**
  21. * When `true`, interaction is prevented and the component is displayed with lower opacity.
  22. */
  23. this.disabled = false;
  24. this.mutationObserver = createObserver("mutation", () => {
  25. this.ensureTextContentDependentProps();
  26. this.calciteInternalOptionChange.emit();
  27. });
  28. }
  29. handlePropChange(_newValue, _oldValue, propName) {
  30. if (propName === "label" || propName === "value") {
  31. this.ensureTextContentDependentProps();
  32. }
  33. this.calciteInternalOptionChange.emit();
  34. }
  35. //--------------------------------------------------------------------------
  36. //
  37. // Private Methods
  38. //
  39. //--------------------------------------------------------------------------
  40. ensureTextContentDependentProps() {
  41. const { el: { textContent } } = this;
  42. if (!this.label || this.label === this.internallySetLabel) {
  43. this.label = textContent;
  44. this.internallySetLabel = textContent;
  45. }
  46. if (!this.value || this.value === this.internallySetValue) {
  47. this.value = textContent;
  48. this.internallySetValue = textContent;
  49. }
  50. }
  51. //--------------------------------------------------------------------------
  52. //
  53. // Lifecycle
  54. //
  55. //--------------------------------------------------------------------------
  56. connectedCallback() {
  57. var _a;
  58. this.ensureTextContentDependentProps();
  59. (_a = this.mutationObserver) === null || _a === void 0 ? void 0 : _a.observe(this.el, {
  60. attributeFilter: ["label", "value"],
  61. characterData: true,
  62. childList: true,
  63. subtree: true
  64. });
  65. }
  66. disconnectedCallback() {
  67. var _a;
  68. (_a = this.mutationObserver) === null || _a === void 0 ? void 0 : _a.disconnect();
  69. }
  70. //--------------------------------------------------------------------------
  71. //
  72. // Render Methods
  73. //
  74. //--------------------------------------------------------------------------
  75. render() {
  76. return h("slot", null, this.label);
  77. }
  78. get el() { return this; }
  79. static get watchers() { return {
  80. "disabled": ["handlePropChange"],
  81. "label": ["handlePropChange"],
  82. "selected": ["handlePropChange"],
  83. "value": ["handlePropChange"]
  84. }; }
  85. static get style() { return optionCss; }
  86. }, [1, "calcite-option", {
  87. "disabled": [516],
  88. "label": [1025],
  89. "selected": [516],
  90. "value": [1032]
  91. }]);
  92. function defineCustomElement$1() {
  93. if (typeof customElements === "undefined") {
  94. return;
  95. }
  96. const components = ["calcite-option"];
  97. components.forEach(tagName => { switch (tagName) {
  98. case "calcite-option":
  99. if (!customElements.get(tagName)) {
  100. customElements.define(tagName, Option);
  101. }
  102. break;
  103. } });
  104. }
  105. defineCustomElement$1();
  106. const CalciteOption = Option;
  107. const defineCustomElement = defineCustomElement$1;
  108. export { CalciteOption, defineCustomElement };