@sula-tech/webcomponents 0.3.3 → 0.4.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/dist/cjs/{index-87eec792.js → index-BtkenDV1.js} +205 -156
- package/dist/cjs/index-BtkenDV1.js.map +1 -0
- package/dist/cjs/index.cjs.js +1 -0
- package/dist/cjs/index.cjs.js.map +1 -1
- package/dist/cjs/loader.cjs.js +4 -6
- package/dist/cjs/loader.cjs.js.map +1 -1
- package/dist/cjs/sula-avatar.sula-badge.sula-button.sula-checkbox.sula-chip.sula-icon.sula-loader.sula-menu-select-list.sula-radio-button.sula-switch.sula-tag.sula-textarea.sula-textfield.sula-tiles.entry.cjs.js.map +1 -0
- package/dist/cjs/sula-avatar_14.cjs.entry.js +28284 -0
- package/dist/cjs/sula-avatar_14.cjs.entry.js.map +1 -0
- package/dist/cjs/webcomponents.cjs.js +8 -8
- package/dist/cjs/webcomponents.cjs.js.map +1 -1
- package/dist/collection/assets/lottie/loader.json +1 -0
- package/dist/collection/collection-manifest.json +7 -2
- package/dist/collection/components/sula-avatar/sula-avatar.css +1 -1
- package/dist/collection/components/sula-avatar/sula-avatar.js +4 -4
- package/dist/collection/components/sula-avatar/sula-avatar.stories.js +7 -0
- package/dist/collection/components/sula-avatar/sula-avatar.stories.js.map +1 -1
- package/dist/collection/components/sula-badge/sula-badge.css +1 -1
- package/dist/collection/components/sula-badge/sula-badge.js +5 -5
- package/dist/collection/components/sula-badge/sula-badge.stories.js +7 -0
- package/dist/collection/components/sula-badge/sula-badge.stories.js.map +1 -1
- package/dist/collection/components/sula-button/sula-button.css +1 -1
- package/dist/collection/components/sula-button/sula-button.js +8 -8
- package/dist/collection/components/sula-button/sula-button.stories.js +7 -0
- package/dist/collection/components/sula-button/sula-button.stories.js.map +1 -1
- package/dist/collection/components/sula-checkbox/sula-checkbox.css +1 -1
- package/dist/collection/components/sula-checkbox/sula-checkbox.js +5 -5
- package/dist/collection/components/sula-checkbox/sula-checkbox.stories.js +7 -0
- package/dist/collection/components/sula-checkbox/sula-checkbox.stories.js.map +1 -1
- package/dist/collection/components/sula-chip/model/sula-chip.model.js +6 -0
- package/dist/collection/components/sula-chip/model/sula-chip.model.js.map +1 -0
- package/dist/collection/components/sula-chip/sula-chip.css +1 -0
- package/dist/collection/components/sula-chip/sula-chip.js +243 -0
- package/dist/collection/components/sula-chip/sula-chip.js.map +1 -0
- package/dist/collection/components/sula-chip/sula-chip.stories.js +125 -0
- package/dist/collection/components/sula-chip/sula-chip.stories.js.map +1 -0
- package/dist/collection/components/sula-icon/sula-icon.css +1 -1
- package/dist/collection/components/sula-icon/sula-icon.js +3 -3
- package/dist/collection/components/sula-loader/model/sula-loader.model.js +7 -0
- package/dist/collection/components/sula-loader/model/sula-loader.model.js.map +1 -0
- package/dist/collection/components/sula-loader/sula-loader.css +1 -0
- package/dist/collection/components/sula-loader/sula-loader.js +102 -0
- package/dist/collection/components/sula-loader/sula-loader.js.map +1 -0
- package/dist/collection/components/sula-loader/sula-loader.stories.js +48 -0
- package/dist/collection/components/sula-loader/sula-loader.stories.js.map +1 -0
- package/dist/collection/components/sula-loader/test/__mocks__/lottie-web.js +10 -0
- package/dist/collection/components/sula-loader/test/__mocks__/lottie-web.js.map +1 -0
- package/dist/collection/components/sula-menu-select-list/model/sula-menu-select-list.model.js +2 -0
- package/dist/collection/components/sula-menu-select-list/model/sula-menu-select-list.model.js.map +1 -0
- package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.css +1 -0
- package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.js +81 -0
- package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.js.map +1 -0
- package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.stories.js +91 -0
- package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.stories.js.map +1 -0
- package/dist/collection/components/sula-radio-button/sula-radio-button.css +1 -0
- package/dist/collection/components/sula-radio-button/sula-radio-button.js +176 -0
- package/dist/collection/components/sula-radio-button/sula-radio-button.js.map +1 -0
- package/dist/collection/components/sula-radio-button/sula-radio-button.stories.js +123 -0
- package/dist/collection/components/sula-radio-button/sula-radio-button.stories.js.map +1 -0
- package/dist/collection/components/sula-switch/sula-switch.css +1 -1
- package/dist/collection/components/sula-switch/sula-switch.js +9 -9
- package/dist/collection/components/sula-switch/sula-switch.stories.js +7 -0
- package/dist/collection/components/sula-switch/sula-switch.stories.js.map +1 -1
- package/dist/collection/components/sula-tag/sula-tag.css +1 -1
- package/dist/collection/components/sula-tag/sula-tag.js +9 -9
- package/dist/collection/components/sula-tag/sula-tag.stories.js +7 -0
- package/dist/collection/components/sula-tag/sula-tag.stories.js.map +1 -1
- package/dist/collection/components/sula-textarea/sula-textarea.css +1 -1
- package/dist/collection/components/sula-textarea/sula-textarea.js +35 -22
- package/dist/collection/components/sula-textarea/sula-textarea.js.map +1 -1
- package/dist/collection/components/sula-textarea/sula-textarea.stories.js +7 -0
- package/dist/collection/components/sula-textarea/sula-textarea.stories.js.map +1 -1
- package/dist/collection/components/sula-textfield/sula-textfield.css +1 -1
- package/dist/collection/components/sula-textfield/sula-textfield.js +12 -12
- package/dist/collection/components/sula-textfield/sula-textfield.js.map +1 -1
- package/dist/collection/components/sula-textfield/sula-textfield.stories.js +7 -0
- package/dist/collection/components/sula-textfield/sula-textfield.stories.js.map +1 -1
- package/dist/collection/components/sula-tiles/model/sula-tiles.model.js +11 -0
- package/dist/collection/components/sula-tiles/model/sula-tiles.model.js.map +1 -0
- package/dist/collection/components/sula-tiles/sula-tiles.css +1 -0
- package/dist/collection/components/sula-tiles/sula-tiles.js +316 -0
- package/dist/collection/components/sula-tiles/sula-tiles.js.map +1 -0
- package/dist/collection/components/sula-tiles/sula-tiles.stories.js +420 -0
- package/dist/collection/components/sula-tiles/sula-tiles.stories.js.map +1 -0
- package/dist/components/index.js +1251 -1
- package/dist/components/index.js.map +1 -1
- package/dist/components/{p-b0d1214f.js → p-CEU3PNQs.js} +6 -6
- package/dist/components/p-CEU3PNQs.js.map +1 -0
- package/dist/components/p-DJGFqp8r.js +44 -0
- package/dist/components/p-DJGFqp8r.js.map +1 -0
- package/dist/components/sula-avatar.js +5 -5
- package/dist/components/sula-avatar.js.map +1 -1
- package/dist/components/sula-badge.js +5 -5
- package/dist/components/sula-badge.js.map +1 -1
- package/dist/components/sula-button.js +6 -6
- package/dist/components/sula-button.js.map +1 -1
- package/dist/components/sula-checkbox.js +8 -8
- package/dist/components/sula-checkbox.js.map +1 -1
- package/dist/components/sula-chip.d.ts +11 -0
- package/dist/components/sula-chip.js +136 -0
- package/dist/components/sula-chip.js.map +1 -0
- package/dist/components/sula-icon.js +2 -1
- package/dist/components/sula-loader.d.ts +11 -0
- package/dist/components/sula-loader.js +27132 -0
- package/dist/components/sula-loader.js.map +1 -0
- package/dist/components/sula-menu-select-list.d.ts +11 -0
- package/dist/components/sula-menu-select-list.js +9 -0
- package/dist/components/sula-menu-select-list.js.map +1 -0
- package/dist/components/sula-radio-button.d.ts +11 -0
- package/dist/components/sula-radio-button.js +83 -0
- package/dist/components/sula-radio-button.js.map +1 -0
- package/dist/components/sula-switch.js +11 -11
- package/dist/components/sula-switch.js.map +1 -1
- package/dist/components/sula-tag.js +8 -8
- package/dist/components/sula-tag.js.map +1 -1
- package/dist/components/sula-textarea.js +34 -21
- package/dist/components/sula-textarea.js.map +1 -1
- package/dist/components/sula-textfield.js +11 -11
- package/dist/components/sula-textfield.js.map +1 -1
- package/dist/components/sula-tiles.d.ts +11 -0
- package/dist/components/sula-tiles.js +180 -0
- package/dist/components/sula-tiles.js.map +1 -0
- package/dist/esm/{index-aa1c5f36.js → index-Yyeke16a.js} +203 -135
- package/dist/esm/index-Yyeke16a.js.map +1 -0
- package/dist/esm/index.js +1 -0
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/loader.js +4 -4
- package/dist/esm/loader.js.map +1 -1
- package/dist/esm/sula-avatar.sula-badge.sula-button.sula-checkbox.sula-chip.sula-icon.sula-loader.sula-menu-select-list.sula-radio-button.sula-switch.sula-tag.sula-textarea.sula-textfield.sula-tiles.entry.js.map +1 -0
- package/dist/esm/sula-avatar_14.entry.js +28269 -0
- package/dist/esm/sula-avatar_14.entry.js.map +1 -0
- package/dist/esm/webcomponents.js +6 -5
- package/dist/esm/webcomponents.js.map +1 -1
- package/dist/types/components/sula-avatar/sula-avatar.stories.d.ts +7 -0
- package/dist/types/components/sula-badge/sula-badge.stories.d.ts +7 -0
- package/dist/types/components/sula-button/sula-button.stories.d.ts +7 -0
- package/dist/types/components/sula-checkbox/sula-checkbox.stories.d.ts +7 -0
- package/dist/types/components/sula-chip/model/sula-chip.model.d.ts +4 -0
- package/dist/types/components/sula-chip/sula-chip.d.ts +40 -0
- package/dist/types/components/sula-chip/sula-chip.stories.d.ts +64 -0
- package/dist/types/components/sula-loader/model/sula-loader.model.d.ts +5 -0
- package/dist/types/components/sula-loader/sula-loader.d.ts +19 -0
- package/dist/types/components/sula-loader/sula-loader.stories.d.ts +29 -0
- package/dist/types/components/sula-loader/test/__mocks__/lottie-web.d.ts +4 -0
- package/dist/types/components/sula-menu-select-list/model/sula-menu-select-list.model.d.ts +4 -0
- package/dist/types/components/sula-menu-select-list/sula-menu-select-list.d.ts +14 -0
- package/dist/types/components/sula-menu-select-list/sula-menu-select-list.stories.d.ts +32 -0
- package/dist/types/components/sula-radio-button/sula-radio-button.d.ts +32 -0
- package/dist/types/components/sula-radio-button/sula-radio-button.stories.d.ts +57 -0
- package/dist/types/components/sula-switch/sula-switch.stories.d.ts +7 -0
- package/dist/types/components/sula-tag/sula-tag.stories.d.ts +7 -0
- package/dist/types/components/sula-textarea/sula-textarea.d.ts +4 -1
- package/dist/types/components/sula-textarea/sula-textarea.stories.d.ts +7 -0
- package/dist/types/components/sula-textfield/sula-textfield.stories.d.ts +7 -0
- package/dist/types/components/sula-tiles/model/sula-tiles.model.d.ts +8 -0
- package/dist/types/components/sula-tiles/sula-tiles.d.ts +54 -0
- package/dist/types/components/sula-tiles/sula-tiles.stories.d.ts +99 -0
- package/dist/types/components.d.ts +383 -0
- package/dist/types/stencil-public-runtime.d.ts +23 -1
- package/dist/webcomponents/assets/lottie/loader.json +1 -0
- package/dist/webcomponents/index.esm.js +1 -0
- package/dist/webcomponents/index.esm.js.map +1 -1
- package/dist/webcomponents/loader.esm.js.map +1 -0
- package/dist/webcomponents/p-5ba79323.entry.js +21643 -0
- package/dist/webcomponents/p-5ba79323.entry.js.map +1 -0
- package/dist/webcomponents/p-Yyeke16a.js +1469 -0
- package/dist/webcomponents/p-Yyeke16a.js.map +1 -0
- package/dist/webcomponents/sula-avatar.sula-badge.sula-button.sula-checkbox.sula-chip.sula-icon.sula-loader.sula-menu-select-list.sula-radio-button.sula-switch.sula-tag.sula-textarea.sula-textfield.sula-tiles.entry.esm.js.map +1 -0
- package/dist/webcomponents/webcomponents.esm.js +37 -14
- package/dist/webcomponents/webcomponents.esm.js.map +1 -1
- package/package.json +5 -2
- package/dist/cjs/app-globals-3a1e7e63.js +0 -7
- package/dist/cjs/app-globals-3a1e7e63.js.map +0 -1
- package/dist/cjs/index-87eec792.js.map +0 -1
- package/dist/cjs/sula-avatar_9.cjs.entry.js +0 -865
- package/dist/cjs/sula-avatar_9.cjs.entry.js.map +0 -1
- package/dist/components/p-881c6b35.js +0 -1198
- package/dist/components/p-881c6b35.js.map +0 -1
- package/dist/components/p-b0d1214f.js.map +0 -1
- package/dist/esm/app-globals-0f993ce5.js +0 -5
- package/dist/esm/app-globals-0f993ce5.js.map +0 -1
- package/dist/esm/index-aa1c5f36.js.map +0 -1
- package/dist/esm/sula-avatar_9.entry.js +0 -853
- package/dist/esm/sula-avatar_9.entry.js.map +0 -1
- package/dist/webcomponents/p-5a36af0f.js +0 -1492
- package/dist/webcomponents/p-5a36af0f.js.map +0 -1
- package/dist/webcomponents/p-7cde1edf.entry.js +0 -1123
- package/dist/webcomponents/p-7cde1edf.entry.js.map +0 -1
- package/dist/webcomponents/p-e1255160.js +0 -4
- package/dist/webcomponents/p-e1255160.js.map +0 -1
- package/loader/package.json +0 -11
|
@@ -0,0 +1,180 @@
|
|
|
1
|
+
import { p as proxyCustomElement, H, c as createEvent, h, a as Host } from './index.js';
|
|
2
|
+
import { d as defineCustomElement$2 } from './p-CEU3PNQs.js';
|
|
3
|
+
|
|
4
|
+
var SulaTilesType;
|
|
5
|
+
(function (SulaTilesType) {
|
|
6
|
+
SulaTilesType["Rounded"] = "rounded";
|
|
7
|
+
SulaTilesType["Square"] = "square";
|
|
8
|
+
})(SulaTilesType || (SulaTilesType = {}));
|
|
9
|
+
var SulaTilesSize;
|
|
10
|
+
(function (SulaTilesSize) {
|
|
11
|
+
SulaTilesSize["Default"] = "default";
|
|
12
|
+
SulaTilesSize["Large"] = "large";
|
|
13
|
+
})(SulaTilesSize || (SulaTilesSize = {}));
|
|
14
|
+
|
|
15
|
+
const sulaTilesCss = "*,:after,:before{--tw-ring-color:rgba(59,130,246,.5);--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scroll-snap-strictness:proximity;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(147,197,253,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;border:0 solid #e5e7eb;box-sizing:border-box}::backdrop{--tw-ring-color:rgba(59,130,246,.5);--tw-border-spacing-x:0;--tw-border-spacing-y:0;--tw-translate-x:0;--tw-translate-y:0;--tw-rotate:0;--tw-skew-x:0;--tw-skew-y:0;--tw-scale-x:1;--tw-scale-y:1;--tw-scroll-snap-strictness:proximity;--tw-ring-offset-width:0px;--tw-ring-offset-color:#fff;--tw-ring-color:rgba(147,197,253,.5);--tw-ring-offset-shadow:0 0 #0000;--tw-ring-shadow:0 0 #0000;--tw-shadow:0 0 #0000;--tw-shadow-colored:0 0 #0000;}/*! tailwindcss v3.4.17 | MIT License | https://tailwindcss.com*/:after,:before{--tw-content:\"\"}:host,html{-webkit-text-size-adjust:100%;font-feature-settings:normal;-webkit-tap-highlight-color:transparent;font-family:ui-sans-serif,system-ui,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;font-variation-settings:normal;line-height:1.5;-moz-tab-size:4;tab-size:4}body{line-height:inherit;margin:0}hr{border-top-width:1px;color:inherit;height:0}abbr:where([title]){text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-feature-settings:normal;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,Liberation Mono,Courier New,monospace;font-size:1em;font-variation-settings:normal}small{font-size:80%}sub,sup{font-size:75%;line-height:0;position:relative;vertical-align:baseline}sub{bottom:-.25em}sup{top:-.5em}table{border-collapse:collapse;border-color:inherit;text-indent:0}button,input,optgroup,select,textarea{font-feature-settings:inherit;color:inherit;font-family:inherit;font-size:100%;font-variation-settings:inherit;font-weight:inherit;letter-spacing:inherit;line-height:inherit;margin:0;padding:0}button,select{text-transform:none}button,input:where([type=button]),input:where([type=reset]),input:where([type=submit]){-webkit-appearance:button;background-color:transparent;background-image:none}:-moz-focusring{outline:auto}:-moz-ui-invalid{box-shadow:none}progress{vertical-align:baseline}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[type=search]{-webkit-appearance:textfield;outline-offset:-2px}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-file-upload-button{-webkit-appearance:button;font:inherit}summary{display:list-item}blockquote,dd,dl,fieldset,figure,h1,h2,h3,h4,h5,h6,hr,p,pre{margin:0}fieldset,legend{padding:0}menu,ol,ul{list-style:none;margin:0;padding:0}dialog{padding:0}textarea{resize:vertical}input::placeholder,textarea::placeholder{color:#9ca3af;opacity:1}[role=button],button{cursor:pointer}:disabled{cursor:default}audio,canvas,embed,iframe,img,object,svg,video{display:block;vertical-align:middle}img,video{height:auto;max-width:100%}[hidden]:where(:not([hidden=until-found])){display:none}.block{display:block}:host{display:block}:root{--color-green-50:#f1f9f4;--color-green-100:#e6f4ed;--color-green-200:#cae7d8;--color-green-300:#a0d4b8;--color-green-400:#68bb8e;--color-green-500:#04843f;--color-green-600:#037236;--color-green-700:#03632f;--color-green-800:#035428;--color-green-900:#024521;--color-green-950:#02361a;--color-red-50:#fef6f6;--color-red-100:#fde8e8;--color-red-200:#fad1d1;--color-red-300:#f7abab;--color-red-400:#f17474;--color-red-500:#c80505;--color-red-600:#b30404;--color-red-700:#9f0404;--color-red-800:#860303;--color-red-900:#6d0303;--color-red-950:#500202;--color-yellow-50:#fdf4e7;--color-yellow-100:#fcedd9;--color-yellow-200:#fae0bd;--color-yellow-300:#f6c788;--color-yellow-400:#f3b159;--color-yellow-500:#ef9928;--color-yellow-600:#e49226;--color-yellow-700:#d17e10;--color-yellow-800:#b46d0e;--color-yellow-900:#93590b;--color-yellow-950:#683f08;--color-orange-50:#fef4f1;--color-orange-100:#fde8e2;--color-orange-200:#fbd2c6;--color-orange-300:#f8b4a0;--color-orange-400:#f58e70;--color-orange-500:#f05223;--color-orange-600:#ea4210;--color-orange-700:#d23b0e;--color-orange-800:#b5330c;--color-orange-900:#942a0a;--color-orange-950:#691e07;--color-blue-50:#ecf0f9;--color-blue-100:#dde3f4;--color-blue-200:#b2c2e5;--color-blue-300:#7994d2;--color-blue-400:#4066bf;--color-blue-500:#001e64;--color-blue-600:#001c5c;--color-blue-700:#00174c;--color-blue-800:#00123d;--color-blue-900:#000f33;--color-blue-950:#000d2b;--color-ambar-50:#fff6eb;--color-ambar-100:#ffefdc;--color-ambar-200:#fedfb9;--color-ambar-300:#fdca8b;--color-ambar-400:#fdb359;--color-ambar-500:#fc9c26;--color-ambar-600:#ec8403;--color-ambar-700:#d87803;--color-ambar-800:#ba6803;--color-ambar-900:#975402;--color-ambar-950:#6a3b01;--color-gray-50:#fff;--color-gray-100:#f4f4f4;--color-gray-200:#e6e6e6;--color-gray-300:#c3c3c3;--color-gray-400:#b9b9b9;--color-gray-500:#949494;--color-gray-600:#737373;--color-gray-700:#5c5c5c;--color-gray-800:#323232;--color-gray-900:#292929;--color-gray-950:#141414;--color-white-opacity-50:#ffffff0d;--color-white-opacity-100:#ffffff1a;--color-white-opacity-200:#ffffff26;--color-white-opacity-300:#ffffff45;--color-white-opacity-400:#ffffff5c;--color-white-opacity-500:#ffffff80;--color-white-opacity-600:#ffffff8c;--color-white-opacity-700:#ffffffa3;--color-white-opacity-800:#ffffffba;--color-white-opacity-900:#fffc;--color-white-opacity-950:#ffffffe8;--color-ciano-50:#f1f6fe;--color-ciano-100:#dfeafc;--color-ciano-200:#c3d9f9;--color-ciano-300:#90b9f4;--color-ciano-400:#5d98ee;--color-ciano-500:#1769e0;--color-ciano-600:#155fcb;--color-ciano-700:#1355b4;--color-ciano-800:#104899;--color-ciano-900:#0d3b7d;--color-ciano-950:#0a2e61;--color-extra-color-blue-light:#e7f0f4;--color-extra-color-blue-dark:#162931;--color-black-opacity-50:#14141405;--color-black-opacity-100:#1414141a;--color-black-opacity-200:#14141426;--color-black-opacity-300:#14141445;--color-black-opacity-400:#1414145c;--color-black-opacity-500:#14141480;--color-black-opacity-600:#1414148c;--color-black-opacity-700:#141414a3;--color-black-opacity-800:#141414ba;--color-black-opacity-900:#141414cc;--color-black-opacity-950:#141414e8;--color-feedback-success:#04843f;--color-feedback-error:#c80505;--color-feedback-informational:#1355b4;--color-feedback-alert:#ef9928;--color-brand-primary:#f05223;--color-brand-secondary:#001c5c;--color-brand-tertiary-1:#1769e0;--color-brand-tertiary-2:#fc9c26;--color-surface-body:#fff;--color-surface-on-body:#f4f4f4;--color-surface-on-body-blue:#e7f0f4;--color-surface-on-body-brand:#fff6eb;--color-surface-on-body-feedback-success:#e6f4ed;--color-surface-on-body-feedback-error:#fde8e8;--color-surface-on-body-feedback-alert:#fdf4e7;--color-surface-on-body-feedback-info:#dfeafc;--color-text-brand:#f05223;--color-text-primary:#323232;--color-text-secondary:#5c5c5c;--color-text-disabled:#949494;--color-text-link:#1355b4;--color-states-empty-bg-hover:#1414141a;--color-states-empty-bg-pressed:#14141426;--color-states-bg-disabled:#14141405;--color-states-bg-focus:#1355b4;--color-states-primary-hover:#ea4210;--color-states-primary-pressed:#d23b0e;--color-states-danger-hover:#b30404;--color-states-danger-pressed:#9f0404;--color-states-negative-hover:#e6e6e6;--color-states-negative-pressed:#c3c3c3;--color-icon-primary:#5c5c5c;--color-icon-secondary:#fff;--color-icon-tertiary:#b30404;--color-icon-disabled:#b9b9b9;--color-neutral-neutral-1:#fff;--color-neutral-neutral-2:#f4f4f4;--color-neutral-neutral-3:#b9b9b9;--color-neutral-neutral-4:#949494;--color-neutral-neutral-5:#737373;--color-neutral-neutral-6:#5c5c5c;--color-neutral-neutral-7:#323232;--color-neutral-neutral-8:#292929;--color-negative-negative-1:#fff;--color-negative-negative-2:#323232;--color-opacity-body:#fffc;--color-opacity-on-body:#14141405;--color-opacity-overlay:#1414148c;--color-opacity-on-overlay:#ffffff1a;--color-line-input:#949494;--color-line-general-strong:#c3c3c3;--color-line-general:#e6e6e6}.static{position:static}.ml-12{margin-left:.75rem}.mt-36{margin-top:2.25rem}.mt-8{margin-top:.5rem}.flex{display:flex}.h-120{height:7.5rem}.h-80{height:5rem}.w-120{width:7.5rem}.w-80{width:5rem}.w-\\[167px\\]{width:167px}.max-w-full{max-width:100%}.cursor-pointer{cursor:pointer}.flex-col{flex-direction:column}.items-start{align-items:flex-start}.items-center{align-items:center}.justify-end{justify-content:flex-end}.justify-center{justify-content:center}.space-y-4>:not([hidden])~:not([hidden]){--tw-space-y-reverse:0;margin-bottom:calc(.25rem*var(--tw-space-y-reverse));margin-top:calc(.25rem*(1 - var(--tw-space-y-reverse)))}.overflow-hidden,.truncate{overflow:hidden}.truncate{text-overflow:ellipsis;white-space:nowrap}.whitespace-normal{white-space:normal}.whitespace-nowrap{white-space:nowrap}.rounded-full{border-radius:9999px}.rounded-md{border-radius:1.25rem}.bg-states-bg-disabled{background-color:var(--color-states-bg-disabled)}.bg-surface-on-body{background-color:var(--color-surface-on-body)}.p-20{padding:1.25rem}.text-3xl{font-size:1.875rem;line-height:2.25rem}.text-base{font-size:1rem;line-height:1.5rem}.font-bold{font-weight:700}.leading-4{line-height:1rem}.text-icon-disabled{color:var(--color-icon-disabled)}.text-icon-primary{color:var(--color-icon-primary)}.text-text-primary{color:var(--color-text-primary)}.text-text-secondary{color:var(--color-text-secondary)}.shadow{--tw-shadow:0 1px 3px 0 rgba(0,0,0,.1),0 1px 2px -1px rgba(0,0,0,.1);--tw-shadow-colored:0 1px 3px 0 var(--tw-shadow-color),0 1px 2px -1px var(--tw-shadow-color);box-shadow:var(--tw-ring-offset-shadow,0 0 #0000),var(--tw-ring-shadow,0 0 #0000),var(--tw-shadow)}.outline-2{outline-width:2px}.outline-offset-2{outline-offset:2px}.outline-feedback-informational{outline-color:var(--color-feedback-informational)}.container{width:100%}@media (min-width:360px){.container{max-width:360px}}@media (min-width:744px){.container{max-width:744px}}@media (min-width:1024px){.container{max-width:1024px}}@media (min-width:1366px){.container{max-width:1366px}}@media (min-width:1680px){.container{max-width:1680px}}.hover\\:bg-states-empty-bg-hover:hover{background-color:var(--color-states-empty-bg-hover)}.active\\:bg-states-empty-bg-pressed:active{background-color:var(--color-states-empty-bg-pressed)}";
|
|
16
|
+
|
|
17
|
+
const SulaTiles$1 = /*@__PURE__*/ proxyCustomElement(class SulaTiles extends H {
|
|
18
|
+
constructor() {
|
|
19
|
+
super();
|
|
20
|
+
this.__registerHost();
|
|
21
|
+
this.__attachShadow();
|
|
22
|
+
this.tileClicked = createEvent(this, "tileClicked");
|
|
23
|
+
/**
|
|
24
|
+
* Tiles type
|
|
25
|
+
*/
|
|
26
|
+
this.type = SulaTilesType.Rounded;
|
|
27
|
+
/**
|
|
28
|
+
* Tiles size
|
|
29
|
+
*/
|
|
30
|
+
this.size = SulaTilesSize.Default;
|
|
31
|
+
/**
|
|
32
|
+
* Use ellipsis on tiles text
|
|
33
|
+
*/
|
|
34
|
+
this.ellipsis = false;
|
|
35
|
+
/**
|
|
36
|
+
* Tiles icon
|
|
37
|
+
*/
|
|
38
|
+
this.icon = '';
|
|
39
|
+
/**
|
|
40
|
+
* Tiles text
|
|
41
|
+
*/
|
|
42
|
+
this.text = '';
|
|
43
|
+
/**
|
|
44
|
+
* Tiles subtext
|
|
45
|
+
*/
|
|
46
|
+
this.subText = '';
|
|
47
|
+
/**
|
|
48
|
+
* Tiles is disabled
|
|
49
|
+
*/
|
|
50
|
+
this.disabled = false;
|
|
51
|
+
this.TILE_SIZES = {
|
|
52
|
+
[SulaTilesSize.Default]: 'w-80 h-80',
|
|
53
|
+
[SulaTilesSize.Large]: 'w-120 h-120',
|
|
54
|
+
};
|
|
55
|
+
this.BASE_CLASSES = {
|
|
56
|
+
container: 'flex w-[167px]',
|
|
57
|
+
roundedContainer: 'flex-col justify-center items-center',
|
|
58
|
+
squareContainer: 'rounded-md p-20',
|
|
59
|
+
interactiveBackground: 'bg-surface-on-body hover:bg-states-empty-bg-hover active:bg-states-empty-bg-pressed outline-2 outline-offset-2 outline-feedback-informational cursor-pointer',
|
|
60
|
+
disabledBackground: 'bg-states-bg-disabled',
|
|
61
|
+
iconContainer: 'flex justify-center items-center leading-4',
|
|
62
|
+
roundedIcon: 'rounded-full',
|
|
63
|
+
textContainer: 'flex',
|
|
64
|
+
ellipsisText: 'truncate overflow-hidden whitespace-nowrap',
|
|
65
|
+
};
|
|
66
|
+
this.handleClick = () => {
|
|
67
|
+
if (this.disabled)
|
|
68
|
+
return;
|
|
69
|
+
this.tileClicked.emit();
|
|
70
|
+
};
|
|
71
|
+
}
|
|
72
|
+
get isRounded() {
|
|
73
|
+
return this.type === SulaTilesType.Rounded;
|
|
74
|
+
}
|
|
75
|
+
get isSquare() {
|
|
76
|
+
return this.type === SulaTilesType.Square;
|
|
77
|
+
}
|
|
78
|
+
get hasSubText() {
|
|
79
|
+
return !!this.subText;
|
|
80
|
+
}
|
|
81
|
+
get isInteractive() {
|
|
82
|
+
return !this.disabled;
|
|
83
|
+
}
|
|
84
|
+
getRoundedTileSize() {
|
|
85
|
+
return this.TILE_SIZES[this.size] || this.TILE_SIZES[SulaTilesSize.Default];
|
|
86
|
+
}
|
|
87
|
+
getContainerClasses() {
|
|
88
|
+
return {
|
|
89
|
+
[this.BASE_CLASSES.container]: true,
|
|
90
|
+
[this.BASE_CLASSES.roundedContainer]: this.isRounded,
|
|
91
|
+
[this.BASE_CLASSES.squareContainer]: this.isSquare,
|
|
92
|
+
[this.BASE_CLASSES.interactiveBackground]: this.isSquare && this.isInteractive,
|
|
93
|
+
[this.BASE_CLASSES.disabledBackground]: this.disabled && this.isSquare,
|
|
94
|
+
'items-center': this.isSquare && !this.hasSubText,
|
|
95
|
+
'flex-col items-start justify-end': this.isSquare && this.hasSubText,
|
|
96
|
+
};
|
|
97
|
+
}
|
|
98
|
+
getIconContainerClasses() {
|
|
99
|
+
return {
|
|
100
|
+
[this.BASE_CLASSES.iconContainer]: true,
|
|
101
|
+
[this.BASE_CLASSES.roundedIcon]: this.isRounded,
|
|
102
|
+
[this.BASE_CLASSES.interactiveBackground]: this.isRounded && this.isInteractive,
|
|
103
|
+
[this.BASE_CLASSES.disabledBackground]: this.isRounded && this.disabled,
|
|
104
|
+
[this.getRoundedTileSize()]: this.isRounded,
|
|
105
|
+
};
|
|
106
|
+
}
|
|
107
|
+
getTextContainerClasses() {
|
|
108
|
+
return {
|
|
109
|
+
[this.BASE_CLASSES.textContainer]: true,
|
|
110
|
+
'mt-8': this.isRounded,
|
|
111
|
+
'ml-12': this.isSquare && !this.hasSubText,
|
|
112
|
+
'flex-col mt-36 space-y-4': this.isSquare && this.hasSubText,
|
|
113
|
+
'max-w-full': this.ellipsis,
|
|
114
|
+
};
|
|
115
|
+
}
|
|
116
|
+
getTextClasses(isPrimary = true) {
|
|
117
|
+
return {
|
|
118
|
+
'text-base leading-4': true,
|
|
119
|
+
'font-bold': isPrimary,
|
|
120
|
+
'text-text-primary': isPrimary && this.isInteractive,
|
|
121
|
+
'text-text-secondary': !isPrimary && this.isInteractive,
|
|
122
|
+
'text-icon-disabled': this.disabled,
|
|
123
|
+
[this.BASE_CLASSES.ellipsisText]: this.ellipsis,
|
|
124
|
+
'whitespace-normal': !this.ellipsis,
|
|
125
|
+
};
|
|
126
|
+
}
|
|
127
|
+
getIconClasses() {
|
|
128
|
+
const baseClass = 'text-3xl';
|
|
129
|
+
const colorClass = this.disabled ? 'text-icon-disabled' : 'text-icon-primary';
|
|
130
|
+
return `${baseClass} ${colorClass}`;
|
|
131
|
+
}
|
|
132
|
+
getTabIndex(condition) {
|
|
133
|
+
return condition && this.isInteractive ? 0 : null;
|
|
134
|
+
}
|
|
135
|
+
renderIcon() {
|
|
136
|
+
return (h("div", { class: this.getIconContainerClasses(), tabIndex: this.getTabIndex(this.isRounded) }, h("sula-icon", { icon: this.icon, customClass: this.getIconClasses() })));
|
|
137
|
+
}
|
|
138
|
+
renderText() {
|
|
139
|
+
return (h("div", { class: this.getTextContainerClasses() }, h("span", { class: this.getTextClasses(true), title: this.ellipsis ? this.text : undefined }, this.text), this.hasSubText && (h("span", { class: this.getTextClasses(false), title: this.ellipsis ? this.subText : undefined }, this.subText))));
|
|
140
|
+
}
|
|
141
|
+
render() {
|
|
142
|
+
return (h(Host, { key: '4ad25c005432166588fd14cc596db7f67455519d' }, h("div", { key: 'f1ed2bad68c99002ff7eda09fefa467981237918', class: this.getContainerClasses(), tabIndex: this.getTabIndex(this.isSquare), onClick: this.handleClick }, this.renderIcon(), this.renderText())));
|
|
143
|
+
}
|
|
144
|
+
static get style() { return sulaTilesCss; }
|
|
145
|
+
}, [1, "sula-tiles", {
|
|
146
|
+
"type": [1],
|
|
147
|
+
"size": [1],
|
|
148
|
+
"ellipsis": [4],
|
|
149
|
+
"icon": [1],
|
|
150
|
+
"text": [1],
|
|
151
|
+
"subText": [1, "sub-text"],
|
|
152
|
+
"disabled": [4]
|
|
153
|
+
}]);
|
|
154
|
+
function defineCustomElement$1() {
|
|
155
|
+
if (typeof customElements === "undefined") {
|
|
156
|
+
return;
|
|
157
|
+
}
|
|
158
|
+
const components = ["sula-tiles", "sula-icon"];
|
|
159
|
+
components.forEach(tagName => { switch (tagName) {
|
|
160
|
+
case "sula-tiles":
|
|
161
|
+
if (!customElements.get(tagName)) {
|
|
162
|
+
customElements.define(tagName, SulaTiles$1);
|
|
163
|
+
}
|
|
164
|
+
break;
|
|
165
|
+
case "sula-icon":
|
|
166
|
+
if (!customElements.get(tagName)) {
|
|
167
|
+
defineCustomElement$2();
|
|
168
|
+
}
|
|
169
|
+
break;
|
|
170
|
+
} });
|
|
171
|
+
}
|
|
172
|
+
defineCustomElement$1();
|
|
173
|
+
|
|
174
|
+
const SulaTiles = SulaTiles$1;
|
|
175
|
+
const defineCustomElement = defineCustomElement$1;
|
|
176
|
+
|
|
177
|
+
export { SulaTiles, defineCustomElement };
|
|
178
|
+
//# sourceMappingURL=sula-tiles.js.map
|
|
179
|
+
|
|
180
|
+
//# sourceMappingURL=sula-tiles.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"file":"sula-tiles.js","mappings":";;;AAAA,IAAY,aAGX;AAHD,CAAA,UAAY,aAAa,EAAA;AACvB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB;AACnB,IAAA,aAAA,CAAA,QAAA,CAAA,GAAA,QAAiB;AACnB,CAAC,EAHW,aAAa,KAAb,aAAa,GAGxB,EAAA,CAAA,CAAA;AAED,IAAY,aAGX;AAHD,CAAA,UAAY,aAAa,EAAA;AACvB,IAAA,aAAA,CAAA,SAAA,CAAA,GAAA,SAAmB;AACnB,IAAA,aAAA,CAAA,OAAA,CAAA,GAAA,OAAe;AACjB,CAAC,EAHW,aAAa,KAAb,aAAa,GAGxB,EAAA,CAAA,CAAA;;ACRD,MAAM,YAAY,GAAG,oxUAAoxU;;MCQ5xUA,WAAS,iBAAAC,kBAAA,CAAA,MAAA,SAAA,SAAAC,CAAA,CAAA;AALtB,IAAA,WAAA,GAAA;;;;;AAME;;AAEG;AACK,QAAA,IAAA,CAAA,IAAI,GAAkB,aAAa,CAAC,OAAO;AAEnD;;AAEG;AACK,QAAA,IAAA,CAAA,IAAI,GAAkB,aAAa,CAAC,OAAO;AAEnD;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAY,KAAK;AAEjC;;AAEG;AACK,QAAA,IAAI,CAAA,IAAA,GAAW,EAAE;AAEzB;;AAEG;AACK,QAAA,IAAI,CAAA,IAAA,GAAW,EAAE;AAEzB;;AAEG;AACK,QAAA,IAAO,CAAA,OAAA,GAAW,EAAE;AAE5B;;AAEG;AACK,QAAA,IAAQ,CAAA,QAAA,GAAY,KAAK;QAShB,IAAA,CAAA,UAAU,GAAG;AAC5B,YAAA,CAAC,aAAa,CAAC,OAAO,GAAG,WAAW;AACpC,YAAA,CAAC,aAAa,CAAC,KAAK,GAAG,aAAa;SAC5B;QAEO,IAAA,CAAA,YAAY,GAAG;AAC9B,YAAA,SAAS,EAAE,gBAAgB;AAC3B,YAAA,gBAAgB,EAAE,sCAAsC;AACxD,YAAA,eAAe,EAAE,iBAAiB;AAClC,YAAA,qBAAqB,EACnB,8JAA8J;AAChK,YAAA,kBAAkB,EAAE,uBAAuB;AAC3C,YAAA,aAAa,EAAE,4CAA4C;AAC3D,YAAA,WAAW,EAAE,cAAc;AAC3B,YAAA,aAAa,EAAE,MAAM;AACrB,YAAA,YAAY,EAAE,4CAA4C;SAClD;AAmGV,QAAA,IAAW,CAAA,WAAA,GAAG,MAAK;YACjB,IAAI,IAAI,CAAC,QAAQ;gBAAE;AAEnB,YAAA,IAAI,CAAC,WAAW,CAAC,IAAI,EAAE;AACzB,SAAC;AAYF;AAjHC,IAAA,IAAY,SAAS,GAAA;AACnB,QAAA,OAAO,IAAI,CAAC,IAAI,KAAK,aAAa,CAAC,OAAO;;AAG5C,IAAA,IAAY,QAAQ,GAAA;AAClB,QAAA,OAAO,IAAI,CAAC,IAAI,KAAK,aAAa,CAAC,MAAM;;AAG3C,IAAA,IAAY,UAAU,GAAA;AACpB,QAAA,OAAO,CAAC,CAAC,IAAI,CAAC,OAAO;;AAGvB,IAAA,IAAY,aAAa,GAAA;AACvB,QAAA,OAAO,CAAC,IAAI,CAAC,QAAQ;;IAGf,kBAAkB,GAAA;AACxB,QAAA,OAAO,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC,OAAO,CAAC;;IAGrE,mBAAmB,GAAA;QACzB,OAAO;AACL,YAAA,CAAC,IAAI,CAAC,YAAY,CAAC,SAAS,GAAG,IAAI;YACnC,CAAC,IAAI,CAAC,YAAY,CAAC,gBAAgB,GAAG,IAAI,CAAC,SAAS;YACpD,CAAC,IAAI,CAAC,YAAY,CAAC,eAAe,GAAG,IAAI,CAAC,QAAQ;AAClD,YAAA,CAAC,IAAI,CAAC,YAAY,CAAC,qBAAqB,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,aAAa;AAC9E,YAAA,CAAC,IAAI,CAAC,YAAY,CAAC,kBAAkB,GAAG,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ;YACtE,cAAc,EAAE,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,UAAU;AACjD,YAAA,kCAAkC,EAAE,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU;SACrE;;IAGK,uBAAuB,GAAA;QAC7B,OAAO;AACL,YAAA,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,IAAI;YACvC,CAAC,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,IAAI,CAAC,SAAS;AAC/C,YAAA,CAAC,IAAI,CAAC,YAAY,CAAC,qBAAqB,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa;AAC/E,YAAA,CAAC,IAAI,CAAC,YAAY,CAAC,kBAAkB,GAAG,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,QAAQ;YACvE,CAAC,IAAI,CAAC,kBAAkB,EAAE,GAAG,IAAI,CAAC,SAAS;SAC5C;;IAGK,uBAAuB,GAAA;QAC7B,OAAO;AACL,YAAA,CAAC,IAAI,CAAC,YAAY,CAAC,aAAa,GAAG,IAAI;YACvC,MAAM,EAAE,IAAI,CAAC,SAAS;YACtB,OAAO,EAAE,IAAI,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,UAAU;AAC1C,YAAA,0BAA0B,EAAE,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,UAAU;YAC5D,YAAY,EAAE,IAAI,CAAC,QAAQ;SAC5B;;IAGK,cAAc,CAAC,YAAqB,IAAI,EAAA;QAC9C,OAAO;AACL,YAAA,qBAAqB,EAAE,IAAI;AAC3B,YAAA,WAAW,EAAE,SAAS;AACtB,YAAA,mBAAmB,EAAE,SAAS,IAAI,IAAI,CAAC,aAAa;AACpD,YAAA,qBAAqB,EAAE,CAAC,SAAS,IAAI,IAAI,CAAC,aAAa;YACvD,oBAAoB,EAAE,IAAI,CAAC,QAAQ;YACnC,CAAC,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,IAAI,CAAC,QAAQ;AAC/C,YAAA,mBAAmB,EAAE,CAAC,IAAI,CAAC,QAAQ;SACpC;;IAGK,cAAc,GAAA;QACpB,MAAM,SAAS,GAAG,UAAU;AAC5B,QAAA,MAAM,UAAU,GAAG,IAAI,CAAC,QAAQ,GAAG,oBAAoB,GAAG,mBAAmB;AAC7E,QAAA,OAAO,CAAG,EAAA,SAAS,CAAI,CAAA,EAAA,UAAU,EAAE;;AAG7B,IAAA,WAAW,CAAC,SAAkB,EAAA;AACpC,QAAA,OAAO,SAAS,IAAI,IAAI,CAAC,aAAa,GAAG,CAAC,GAAG,IAAI;;IAG3C,UAAU,GAAA;QAChB,QACE,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,IAAI,CAAC,uBAAuB,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,SAAS,CAAC,EAAA,EACpF,CAAA,CAAA,WAAA,EAAA,EAAW,IAAI,EAAE,IAAI,CAAC,IAAI,EAAE,WAAW,EAAE,IAAI,CAAC,cAAc,EAAE,EAAI,CAAA,CAC9D;;IAIF,UAAU,GAAA;QAChB,QACE,CAAK,CAAA,KAAA,EAAA,EAAA,KAAK,EAAE,IAAI,CAAC,uBAAuB,EAAE,EAAA,EACxC,CAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,IAAI,GAAG,SAAS,EACjF,EAAA,IAAI,CAAC,IAAI,CACL,EACN,IAAI,CAAC,UAAU,KACd,CAAA,CAAA,MAAA,EAAA,EAAM,KAAK,EAAE,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,OAAO,GAAG,SAAS,EAAA,EACrF,IAAI,CAAC,OAAO,CACR,CACR,CACG;;IAUV,MAAM,GAAA;QACJ,QACE,EAAC,IAAI,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,EACH,CAAK,CAAA,KAAA,EAAA,EAAA,GAAA,EAAA,0CAAA,EAAA,KAAK,EAAE,IAAI,CAAC,mBAAmB,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,WAAW,EAAA,EACzG,IAAI,CAAC,UAAU,EAAE,EACjB,IAAI,CAAC,UAAU,EAAE,CACd,CACD;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;","names":["SulaTiles","__stencil_proxyCustomElement","HTMLElement"],"sources":["src/components/sula-tiles/model/sula-tiles.model.ts","src/components/sula-tiles/sula-tiles.scss?tag=sula-tiles&encapsulation=shadow","src/components/sula-tiles/sula-tiles.tsx"],"sourcesContent":["export enum SulaTilesType {\n Rounded = 'rounded',\n Square = 'square',\n}\n\nexport enum SulaTilesSize {\n Default = 'default',\n Large = 'large',\n}\n",":host {\n display: block;\n}\n","import { Component, Event, EventEmitter, Host, Prop, h } from '@stencil/core';\nimport { SulaTilesSize, SulaTilesType } from './model/sula-tiles.model';\n\n@Component({\n tag: 'sula-tiles',\n styleUrl: 'sula-tiles.scss',\n shadow: true,\n})\nexport class SulaTiles {\n /**\n * Tiles type\n */\n @Prop() type: SulaTilesType = SulaTilesType.Rounded;\n\n /**\n * Tiles size\n */\n @Prop() size: SulaTilesSize = SulaTilesSize.Default;\n\n /**\n * Use ellipsis on tiles text\n */\n @Prop() ellipsis: boolean = false;\n\n /**\n * Tiles icon\n */\n @Prop() icon: string = '';\n\n /**\n * Tiles text\n */\n @Prop() text: string = '';\n\n /**\n * Tiles subtext\n */\n @Prop() subText: string = '';\n\n /**\n * Tiles is disabled\n */\n @Prop() disabled: boolean = false;\n\n /**\n * Event emitted when tile is clicked.\n * @note If tile is disabled event won't be emitted\n */\n @Event()\n tileClicked: EventEmitter<void>;\n\n private readonly TILE_SIZES = {\n [SulaTilesSize.Default]: 'w-80 h-80',\n [SulaTilesSize.Large]: 'w-120 h-120',\n } as const;\n\n private readonly BASE_CLASSES = {\n container: 'flex w-[167px]',\n roundedContainer: 'flex-col justify-center items-center',\n squareContainer: 'rounded-md p-20',\n interactiveBackground:\n 'bg-surface-on-body hover:bg-states-empty-bg-hover active:bg-states-empty-bg-pressed outline-2 outline-offset-2 outline-feedback-informational cursor-pointer',\n disabledBackground: 'bg-states-bg-disabled',\n iconContainer: 'flex justify-center items-center leading-4',\n roundedIcon: 'rounded-full',\n textContainer: 'flex',\n ellipsisText: 'truncate overflow-hidden whitespace-nowrap',\n } as const;\n\n private get isRounded(): boolean {\n return this.type === SulaTilesType.Rounded;\n }\n\n private get isSquare(): boolean {\n return this.type === SulaTilesType.Square;\n }\n\n private get hasSubText(): boolean {\n return !!this.subText;\n }\n\n private get isInteractive(): boolean {\n return !this.disabled;\n }\n\n private getRoundedTileSize(): string {\n return this.TILE_SIZES[this.size] || this.TILE_SIZES[SulaTilesSize.Default];\n }\n\n private getContainerClasses(): Record<string, boolean> {\n return {\n [this.BASE_CLASSES.container]: true,\n [this.BASE_CLASSES.roundedContainer]: this.isRounded,\n [this.BASE_CLASSES.squareContainer]: this.isSquare,\n [this.BASE_CLASSES.interactiveBackground]: this.isSquare && this.isInteractive,\n [this.BASE_CLASSES.disabledBackground]: this.disabled && this.isSquare,\n 'items-center': this.isSquare && !this.hasSubText,\n 'flex-col items-start justify-end': this.isSquare && this.hasSubText,\n };\n }\n\n private getIconContainerClasses(): Record<string, boolean> {\n return {\n [this.BASE_CLASSES.iconContainer]: true,\n [this.BASE_CLASSES.roundedIcon]: this.isRounded,\n [this.BASE_CLASSES.interactiveBackground]: this.isRounded && this.isInteractive,\n [this.BASE_CLASSES.disabledBackground]: this.isRounded && this.disabled,\n [this.getRoundedTileSize()]: this.isRounded,\n };\n }\n\n private getTextContainerClasses(): Record<string, boolean> {\n return {\n [this.BASE_CLASSES.textContainer]: true,\n 'mt-8': this.isRounded,\n 'ml-12': this.isSquare && !this.hasSubText,\n 'flex-col mt-36 space-y-4': this.isSquare && this.hasSubText,\n 'max-w-full': this.ellipsis,\n };\n }\n\n private getTextClasses(isPrimary: boolean = true): Record<string, boolean> {\n return {\n 'text-base leading-4': true,\n 'font-bold': isPrimary,\n 'text-text-primary': isPrimary && this.isInteractive,\n 'text-text-secondary': !isPrimary && this.isInteractive,\n 'text-icon-disabled': this.disabled,\n [this.BASE_CLASSES.ellipsisText]: this.ellipsis,\n 'whitespace-normal': !this.ellipsis,\n };\n }\n\n private getIconClasses(): string {\n const baseClass = 'text-3xl';\n const colorClass = this.disabled ? 'text-icon-disabled' : 'text-icon-primary';\n return `${baseClass} ${colorClass}`;\n }\n\n private getTabIndex(condition: boolean): number | null {\n return condition && this.isInteractive ? 0 : null;\n }\n\n private renderIcon() {\n return (\n <div class={this.getIconContainerClasses()} tabIndex={this.getTabIndex(this.isRounded)}>\n <sula-icon icon={this.icon} customClass={this.getIconClasses()} />\n </div>\n );\n }\n\n private renderText() {\n return (\n <div class={this.getTextContainerClasses()}>\n <span class={this.getTextClasses(true)} title={this.ellipsis ? this.text : undefined}>\n {this.text}\n </span>\n {this.hasSubText && (\n <span class={this.getTextClasses(false)} title={this.ellipsis ? this.subText : undefined}>\n {this.subText}\n </span>\n )}\n </div>\n );\n }\n\n handleClick = () => {\n if (this.disabled) return;\n\n this.tileClicked.emit();\n };\n\n render() {\n return (\n <Host>\n <div class={this.getContainerClasses()} tabIndex={this.getTabIndex(this.isSquare)} onClick={this.handleClick}>\n {this.renderIcon()}\n {this.renderText()}\n </div>\n </Host>\n );\n }\n}\n"],"version":3}
|