@sula-tech/webcomponents 0.3.3 → 0.4.0

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.
Files changed (190) hide show
  1. package/dist/cjs/{index-87eec792.js → index-BtkenDV1.js} +205 -156
  2. package/dist/cjs/index-BtkenDV1.js.map +1 -0
  3. package/dist/cjs/index.cjs.js +1 -0
  4. package/dist/cjs/index.cjs.js.map +1 -1
  5. package/dist/cjs/loader.cjs.js +4 -6
  6. package/dist/cjs/loader.cjs.js.map +1 -1
  7. 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
  8. package/dist/cjs/sula-avatar_14.cjs.entry.js +28270 -0
  9. package/dist/cjs/sula-avatar_14.cjs.entry.js.map +1 -0
  10. package/dist/cjs/webcomponents.cjs.js +8 -8
  11. package/dist/cjs/webcomponents.cjs.js.map +1 -1
  12. package/dist/collection/assets/lottie/loader.json +1 -0
  13. package/dist/collection/collection-manifest.json +7 -2
  14. package/dist/collection/components/sula-avatar/sula-avatar.css +1 -1
  15. package/dist/collection/components/sula-avatar/sula-avatar.js +4 -4
  16. package/dist/collection/components/sula-avatar/sula-avatar.stories.js +7 -0
  17. package/dist/collection/components/sula-avatar/sula-avatar.stories.js.map +1 -1
  18. package/dist/collection/components/sula-badge/sula-badge.css +1 -1
  19. package/dist/collection/components/sula-badge/sula-badge.js +5 -5
  20. package/dist/collection/components/sula-badge/sula-badge.stories.js +7 -0
  21. package/dist/collection/components/sula-badge/sula-badge.stories.js.map +1 -1
  22. package/dist/collection/components/sula-button/sula-button.css +1 -1
  23. package/dist/collection/components/sula-button/sula-button.js +8 -8
  24. package/dist/collection/components/sula-button/sula-button.stories.js +7 -0
  25. package/dist/collection/components/sula-button/sula-button.stories.js.map +1 -1
  26. package/dist/collection/components/sula-checkbox/sula-checkbox.css +1 -1
  27. package/dist/collection/components/sula-checkbox/sula-checkbox.js +5 -5
  28. package/dist/collection/components/sula-checkbox/sula-checkbox.stories.js +7 -0
  29. package/dist/collection/components/sula-checkbox/sula-checkbox.stories.js.map +1 -1
  30. package/dist/collection/components/sula-chip/model/sula-chip.model.js +6 -0
  31. package/dist/collection/components/sula-chip/model/sula-chip.model.js.map +1 -0
  32. package/dist/collection/components/sula-chip/sula-chip.css +1 -0
  33. package/dist/collection/components/sula-chip/sula-chip.js +243 -0
  34. package/dist/collection/components/sula-chip/sula-chip.js.map +1 -0
  35. package/dist/collection/components/sula-chip/sula-chip.stories.js +125 -0
  36. package/dist/collection/components/sula-chip/sula-chip.stories.js.map +1 -0
  37. package/dist/collection/components/sula-icon/sula-icon.css +1 -1
  38. package/dist/collection/components/sula-icon/sula-icon.js +3 -3
  39. package/dist/collection/components/sula-loader/model/sula-loader.model.js +7 -0
  40. package/dist/collection/components/sula-loader/model/sula-loader.model.js.map +1 -0
  41. package/dist/collection/components/sula-loader/sula-loader.css +1 -0
  42. package/dist/collection/components/sula-loader/sula-loader.js +102 -0
  43. package/dist/collection/components/sula-loader/sula-loader.js.map +1 -0
  44. package/dist/collection/components/sula-loader/sula-loader.stories.js +48 -0
  45. package/dist/collection/components/sula-loader/sula-loader.stories.js.map +1 -0
  46. package/dist/collection/components/sula-loader/test/__mocks__/lottie-web.js +10 -0
  47. package/dist/collection/components/sula-loader/test/__mocks__/lottie-web.js.map +1 -0
  48. package/dist/collection/components/sula-menu-select-list/model/sula-menu-select-list.model.js +2 -0
  49. package/dist/collection/components/sula-menu-select-list/model/sula-menu-select-list.model.js.map +1 -0
  50. package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.css +1 -0
  51. package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.js +81 -0
  52. package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.js.map +1 -0
  53. package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.stories.js +91 -0
  54. package/dist/collection/components/sula-menu-select-list/sula-menu-select-list.stories.js.map +1 -0
  55. package/dist/collection/components/sula-radio-button/sula-radio-button.css +1 -0
  56. package/dist/collection/components/sula-radio-button/sula-radio-button.js +176 -0
  57. package/dist/collection/components/sula-radio-button/sula-radio-button.js.map +1 -0
  58. package/dist/collection/components/sula-radio-button/sula-radio-button.stories.js +123 -0
  59. package/dist/collection/components/sula-radio-button/sula-radio-button.stories.js.map +1 -0
  60. package/dist/collection/components/sula-switch/sula-switch.css +1 -1
  61. package/dist/collection/components/sula-switch/sula-switch.js +9 -9
  62. package/dist/collection/components/sula-switch/sula-switch.stories.js +7 -0
  63. package/dist/collection/components/sula-switch/sula-switch.stories.js.map +1 -1
  64. package/dist/collection/components/sula-tag/sula-tag.css +1 -1
  65. package/dist/collection/components/sula-tag/sula-tag.js +9 -9
  66. package/dist/collection/components/sula-tag/sula-tag.stories.js +7 -0
  67. package/dist/collection/components/sula-tag/sula-tag.stories.js.map +1 -1
  68. package/dist/collection/components/sula-textarea/sula-textarea.css +1 -1
  69. package/dist/collection/components/sula-textarea/sula-textarea.js +14 -14
  70. package/dist/collection/components/sula-textarea/sula-textarea.js.map +1 -1
  71. package/dist/collection/components/sula-textarea/sula-textarea.stories.js +7 -0
  72. package/dist/collection/components/sula-textarea/sula-textarea.stories.js.map +1 -1
  73. package/dist/collection/components/sula-textfield/sula-textfield.css +1 -1
  74. package/dist/collection/components/sula-textfield/sula-textfield.js +12 -12
  75. package/dist/collection/components/sula-textfield/sula-textfield.js.map +1 -1
  76. package/dist/collection/components/sula-textfield/sula-textfield.stories.js +7 -0
  77. package/dist/collection/components/sula-textfield/sula-textfield.stories.js.map +1 -1
  78. package/dist/collection/components/sula-tiles/model/sula-tiles.model.js +11 -0
  79. package/dist/collection/components/sula-tiles/model/sula-tiles.model.js.map +1 -0
  80. package/dist/collection/components/sula-tiles/sula-tiles.css +1 -0
  81. package/dist/collection/components/sula-tiles/sula-tiles.js +316 -0
  82. package/dist/collection/components/sula-tiles/sula-tiles.js.map +1 -0
  83. package/dist/collection/components/sula-tiles/sula-tiles.stories.js +420 -0
  84. package/dist/collection/components/sula-tiles/sula-tiles.stories.js.map +1 -0
  85. package/dist/components/index.js +1251 -1
  86. package/dist/components/index.js.map +1 -1
  87. package/dist/components/{p-b0d1214f.js → p-CEU3PNQs.js} +6 -6
  88. package/dist/components/p-CEU3PNQs.js.map +1 -0
  89. package/dist/components/p-DJGFqp8r.js +44 -0
  90. package/dist/components/p-DJGFqp8r.js.map +1 -0
  91. package/dist/components/sula-avatar.js +5 -5
  92. package/dist/components/sula-avatar.js.map +1 -1
  93. package/dist/components/sula-badge.js +5 -5
  94. package/dist/components/sula-badge.js.map +1 -1
  95. package/dist/components/sula-button.js +6 -6
  96. package/dist/components/sula-button.js.map +1 -1
  97. package/dist/components/sula-checkbox.js +8 -8
  98. package/dist/components/sula-checkbox.js.map +1 -1
  99. package/dist/components/sula-chip.d.ts +11 -0
  100. package/dist/components/sula-chip.js +136 -0
  101. package/dist/components/sula-chip.js.map +1 -0
  102. package/dist/components/sula-icon.js +2 -1
  103. package/dist/components/sula-loader.d.ts +11 -0
  104. package/dist/components/sula-loader.js +27132 -0
  105. package/dist/components/sula-loader.js.map +1 -0
  106. package/dist/components/sula-menu-select-list.d.ts +11 -0
  107. package/dist/components/sula-menu-select-list.js +9 -0
  108. package/dist/components/sula-menu-select-list.js.map +1 -0
  109. package/dist/components/sula-radio-button.d.ts +11 -0
  110. package/dist/components/sula-radio-button.js +83 -0
  111. package/dist/components/sula-radio-button.js.map +1 -0
  112. package/dist/components/sula-switch.js +11 -11
  113. package/dist/components/sula-switch.js.map +1 -1
  114. package/dist/components/sula-tag.js +8 -8
  115. package/dist/components/sula-tag.js.map +1 -1
  116. package/dist/components/sula-textarea.js +13 -13
  117. package/dist/components/sula-textarea.js.map +1 -1
  118. package/dist/components/sula-textfield.js +11 -11
  119. package/dist/components/sula-textfield.js.map +1 -1
  120. package/dist/components/sula-tiles.d.ts +11 -0
  121. package/dist/components/sula-tiles.js +180 -0
  122. package/dist/components/sula-tiles.js.map +1 -0
  123. package/dist/esm/{index-aa1c5f36.js → index-Yyeke16a.js} +203 -135
  124. package/dist/esm/index-Yyeke16a.js.map +1 -0
  125. package/dist/esm/index.js +1 -0
  126. package/dist/esm/index.js.map +1 -1
  127. package/dist/esm/loader.js +4 -4
  128. package/dist/esm/loader.js.map +1 -1
  129. 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
  130. package/dist/esm/sula-avatar_14.entry.js +28255 -0
  131. package/dist/esm/sula-avatar_14.entry.js.map +1 -0
  132. package/dist/esm/webcomponents.js +6 -5
  133. package/dist/esm/webcomponents.js.map +1 -1
  134. package/dist/types/components/sula-avatar/sula-avatar.stories.d.ts +7 -0
  135. package/dist/types/components/sula-badge/sula-badge.stories.d.ts +7 -0
  136. package/dist/types/components/sula-button/sula-button.stories.d.ts +7 -0
  137. package/dist/types/components/sula-checkbox/sula-checkbox.stories.d.ts +7 -0
  138. package/dist/types/components/sula-chip/model/sula-chip.model.d.ts +4 -0
  139. package/dist/types/components/sula-chip/sula-chip.d.ts +40 -0
  140. package/dist/types/components/sula-chip/sula-chip.stories.d.ts +64 -0
  141. package/dist/types/components/sula-loader/model/sula-loader.model.d.ts +5 -0
  142. package/dist/types/components/sula-loader/sula-loader.d.ts +19 -0
  143. package/dist/types/components/sula-loader/sula-loader.stories.d.ts +29 -0
  144. package/dist/types/components/sula-loader/test/__mocks__/lottie-web.d.ts +4 -0
  145. package/dist/types/components/sula-menu-select-list/model/sula-menu-select-list.model.d.ts +4 -0
  146. package/dist/types/components/sula-menu-select-list/sula-menu-select-list.d.ts +14 -0
  147. package/dist/types/components/sula-menu-select-list/sula-menu-select-list.stories.d.ts +32 -0
  148. package/dist/types/components/sula-radio-button/sula-radio-button.d.ts +32 -0
  149. package/dist/types/components/sula-radio-button/sula-radio-button.stories.d.ts +57 -0
  150. package/dist/types/components/sula-switch/sula-switch.stories.d.ts +7 -0
  151. package/dist/types/components/sula-tag/sula-tag.stories.d.ts +7 -0
  152. package/dist/types/components/sula-textarea/sula-textarea.stories.d.ts +7 -0
  153. package/dist/types/components/sula-textfield/sula-textfield.stories.d.ts +7 -0
  154. package/dist/types/components/sula-tiles/model/sula-tiles.model.d.ts +8 -0
  155. package/dist/types/components/sula-tiles/sula-tiles.d.ts +54 -0
  156. package/dist/types/components/sula-tiles/sula-tiles.stories.d.ts +99 -0
  157. package/dist/types/components.d.ts +383 -0
  158. package/dist/types/stencil-public-runtime.d.ts +23 -1
  159. package/dist/webcomponents/assets/lottie/loader.json +1 -0
  160. package/dist/webcomponents/index.esm.js +1 -0
  161. package/dist/webcomponents/index.esm.js.map +1 -1
  162. package/dist/webcomponents/loader.esm.js.map +1 -0
  163. package/dist/webcomponents/p-67f9fa90.entry.js +21628 -0
  164. package/dist/webcomponents/p-67f9fa90.entry.js.map +1 -0
  165. package/dist/webcomponents/p-Yyeke16a.js +1469 -0
  166. package/dist/webcomponents/p-Yyeke16a.js.map +1 -0
  167. 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
  168. package/dist/webcomponents/webcomponents.esm.js +33 -9
  169. package/dist/webcomponents/webcomponents.esm.js.map +1 -1
  170. package/package.json +5 -2
  171. package/dist/cjs/app-globals-3a1e7e63.js +0 -7
  172. package/dist/cjs/app-globals-3a1e7e63.js.map +0 -1
  173. package/dist/cjs/index-87eec792.js.map +0 -1
  174. package/dist/cjs/sula-avatar_9.cjs.entry.js +0 -865
  175. package/dist/cjs/sula-avatar_9.cjs.entry.js.map +0 -1
  176. package/dist/components/p-881c6b35.js +0 -1198
  177. package/dist/components/p-881c6b35.js.map +0 -1
  178. package/dist/components/p-b0d1214f.js.map +0 -1
  179. package/dist/esm/app-globals-0f993ce5.js +0 -5
  180. package/dist/esm/app-globals-0f993ce5.js.map +0 -1
  181. package/dist/esm/index-aa1c5f36.js.map +0 -1
  182. package/dist/esm/sula-avatar_9.entry.js +0 -853
  183. package/dist/esm/sula-avatar_9.entry.js.map +0 -1
  184. package/dist/webcomponents/p-5a36af0f.js +0 -1492
  185. package/dist/webcomponents/p-5a36af0f.js.map +0 -1
  186. package/dist/webcomponents/p-7cde1edf.entry.js +0 -1123
  187. package/dist/webcomponents/p-7cde1edf.entry.js.map +0 -1
  188. package/dist/webcomponents/p-e1255160.js +0 -4
  189. package/dist/webcomponents/p-e1255160.js.map +0 -1
  190. package/loader/package.json +0 -11
@@ -0,0 +1,316 @@
1
+ import { Host, h } from "@stencil/core";
2
+ import { SulaTilesSize, SulaTilesType } from "./model/sula-tiles.model";
3
+ export class SulaTiles {
4
+ constructor() {
5
+ /**
6
+ * Tiles type
7
+ */
8
+ this.type = SulaTilesType.Rounded;
9
+ /**
10
+ * Tiles size
11
+ */
12
+ this.size = SulaTilesSize.Default;
13
+ /**
14
+ * Use ellipsis on tiles text
15
+ */
16
+ this.ellipsis = false;
17
+ /**
18
+ * Tiles icon
19
+ */
20
+ this.icon = '';
21
+ /**
22
+ * Tiles text
23
+ */
24
+ this.text = '';
25
+ /**
26
+ * Tiles subtext
27
+ */
28
+ this.subText = '';
29
+ /**
30
+ * Tiles is disabled
31
+ */
32
+ this.disabled = false;
33
+ this.TILE_SIZES = {
34
+ [SulaTilesSize.Default]: 'w-80 h-80',
35
+ [SulaTilesSize.Large]: 'w-120 h-120',
36
+ };
37
+ this.BASE_CLASSES = {
38
+ container: 'flex w-[167px]',
39
+ roundedContainer: 'flex-col justify-center items-center',
40
+ squareContainer: 'rounded-md p-20',
41
+ 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',
42
+ disabledBackground: 'bg-states-bg-disabled',
43
+ iconContainer: 'flex justify-center items-center leading-4',
44
+ roundedIcon: 'rounded-full',
45
+ textContainer: 'flex',
46
+ ellipsisText: 'truncate overflow-hidden whitespace-nowrap',
47
+ };
48
+ this.handleClick = () => {
49
+ if (this.disabled)
50
+ return;
51
+ this.tileClicked.emit();
52
+ };
53
+ }
54
+ get isRounded() {
55
+ return this.type === SulaTilesType.Rounded;
56
+ }
57
+ get isSquare() {
58
+ return this.type === SulaTilesType.Square;
59
+ }
60
+ get hasSubText() {
61
+ return !!this.subText;
62
+ }
63
+ get isInteractive() {
64
+ return !this.disabled;
65
+ }
66
+ getRoundedTileSize() {
67
+ return this.TILE_SIZES[this.size] || this.TILE_SIZES[SulaTilesSize.Default];
68
+ }
69
+ getContainerClasses() {
70
+ return {
71
+ [this.BASE_CLASSES.container]: true,
72
+ [this.BASE_CLASSES.roundedContainer]: this.isRounded,
73
+ [this.BASE_CLASSES.squareContainer]: this.isSquare,
74
+ [this.BASE_CLASSES.interactiveBackground]: this.isSquare && this.isInteractive,
75
+ [this.BASE_CLASSES.disabledBackground]: this.disabled && this.isSquare,
76
+ 'items-center': this.isSquare && !this.hasSubText,
77
+ 'flex-col items-start justify-end': this.isSquare && this.hasSubText,
78
+ };
79
+ }
80
+ getIconContainerClasses() {
81
+ return {
82
+ [this.BASE_CLASSES.iconContainer]: true,
83
+ [this.BASE_CLASSES.roundedIcon]: this.isRounded,
84
+ [this.BASE_CLASSES.interactiveBackground]: this.isRounded && this.isInteractive,
85
+ [this.BASE_CLASSES.disabledBackground]: this.isRounded && this.disabled,
86
+ [this.getRoundedTileSize()]: this.isRounded,
87
+ };
88
+ }
89
+ getTextContainerClasses() {
90
+ return {
91
+ [this.BASE_CLASSES.textContainer]: true,
92
+ 'mt-8': this.isRounded,
93
+ 'ml-12': this.isSquare && !this.hasSubText,
94
+ 'flex-col mt-36 space-y-4': this.isSquare && this.hasSubText,
95
+ 'max-w-full': this.ellipsis,
96
+ };
97
+ }
98
+ getTextClasses(isPrimary = true) {
99
+ return {
100
+ 'text-base leading-4': true,
101
+ 'font-bold': isPrimary,
102
+ 'text-text-primary': isPrimary && this.isInteractive,
103
+ 'text-text-secondary': !isPrimary && this.isInteractive,
104
+ 'text-icon-disabled': this.disabled,
105
+ [this.BASE_CLASSES.ellipsisText]: this.ellipsis,
106
+ 'whitespace-normal': !this.ellipsis,
107
+ };
108
+ }
109
+ getIconClasses() {
110
+ const baseClass = 'text-3xl';
111
+ const colorClass = this.disabled ? 'text-icon-disabled' : 'text-icon-primary';
112
+ return `${baseClass} ${colorClass}`;
113
+ }
114
+ getTabIndex(condition) {
115
+ return condition && this.isInteractive ? 0 : null;
116
+ }
117
+ renderIcon() {
118
+ return (h("div", { class: this.getIconContainerClasses(), tabIndex: this.getTabIndex(this.isRounded) }, h("sula-icon", { icon: this.icon, customClass: this.getIconClasses() })));
119
+ }
120
+ renderText() {
121
+ 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))));
122
+ }
123
+ render() {
124
+ return (h(Host, { key: '571dd0142465ec3483c7a460feedf63542836cfa' }, h("div", { key: '7bb61260329cbded9fb9a25201c74de94a060268', class: this.getContainerClasses(), tabIndex: this.getTabIndex(this.isSquare), onClick: this.handleClick }, this.renderIcon(), this.renderText())));
125
+ }
126
+ static get is() { return "sula-tiles"; }
127
+ static get encapsulation() { return "shadow"; }
128
+ static get originalStyleUrls() {
129
+ return {
130
+ "$": ["sula-tiles.scss"]
131
+ };
132
+ }
133
+ static get styleUrls() {
134
+ return {
135
+ "$": ["sula-tiles.css"]
136
+ };
137
+ }
138
+ static get properties() {
139
+ return {
140
+ "type": {
141
+ "type": "string",
142
+ "attribute": "type",
143
+ "mutable": false,
144
+ "complexType": {
145
+ "original": "SulaTilesType",
146
+ "resolved": "SulaTilesType.Rounded | SulaTilesType.Square",
147
+ "references": {
148
+ "SulaTilesType": {
149
+ "location": "import",
150
+ "path": "./model/sula-tiles.model",
151
+ "id": "src/components/sula-tiles/model/sula-tiles.model.ts::SulaTilesType"
152
+ }
153
+ }
154
+ },
155
+ "required": false,
156
+ "optional": false,
157
+ "docs": {
158
+ "tags": [],
159
+ "text": "Tiles type"
160
+ },
161
+ "getter": false,
162
+ "setter": false,
163
+ "reflect": false,
164
+ "defaultValue": "SulaTilesType.Rounded"
165
+ },
166
+ "size": {
167
+ "type": "string",
168
+ "attribute": "size",
169
+ "mutable": false,
170
+ "complexType": {
171
+ "original": "SulaTilesSize",
172
+ "resolved": "SulaTilesSize.Default | SulaTilesSize.Large",
173
+ "references": {
174
+ "SulaTilesSize": {
175
+ "location": "import",
176
+ "path": "./model/sula-tiles.model",
177
+ "id": "src/components/sula-tiles/model/sula-tiles.model.ts::SulaTilesSize"
178
+ }
179
+ }
180
+ },
181
+ "required": false,
182
+ "optional": false,
183
+ "docs": {
184
+ "tags": [],
185
+ "text": "Tiles size"
186
+ },
187
+ "getter": false,
188
+ "setter": false,
189
+ "reflect": false,
190
+ "defaultValue": "SulaTilesSize.Default"
191
+ },
192
+ "ellipsis": {
193
+ "type": "boolean",
194
+ "attribute": "ellipsis",
195
+ "mutable": false,
196
+ "complexType": {
197
+ "original": "boolean",
198
+ "resolved": "boolean",
199
+ "references": {}
200
+ },
201
+ "required": false,
202
+ "optional": false,
203
+ "docs": {
204
+ "tags": [],
205
+ "text": "Use ellipsis on tiles text"
206
+ },
207
+ "getter": false,
208
+ "setter": false,
209
+ "reflect": false,
210
+ "defaultValue": "false"
211
+ },
212
+ "icon": {
213
+ "type": "string",
214
+ "attribute": "icon",
215
+ "mutable": false,
216
+ "complexType": {
217
+ "original": "string",
218
+ "resolved": "string",
219
+ "references": {}
220
+ },
221
+ "required": false,
222
+ "optional": false,
223
+ "docs": {
224
+ "tags": [],
225
+ "text": "Tiles icon"
226
+ },
227
+ "getter": false,
228
+ "setter": false,
229
+ "reflect": false,
230
+ "defaultValue": "''"
231
+ },
232
+ "text": {
233
+ "type": "string",
234
+ "attribute": "text",
235
+ "mutable": false,
236
+ "complexType": {
237
+ "original": "string",
238
+ "resolved": "string",
239
+ "references": {}
240
+ },
241
+ "required": false,
242
+ "optional": false,
243
+ "docs": {
244
+ "tags": [],
245
+ "text": "Tiles text"
246
+ },
247
+ "getter": false,
248
+ "setter": false,
249
+ "reflect": false,
250
+ "defaultValue": "''"
251
+ },
252
+ "subText": {
253
+ "type": "string",
254
+ "attribute": "sub-text",
255
+ "mutable": false,
256
+ "complexType": {
257
+ "original": "string",
258
+ "resolved": "string",
259
+ "references": {}
260
+ },
261
+ "required": false,
262
+ "optional": false,
263
+ "docs": {
264
+ "tags": [],
265
+ "text": "Tiles subtext"
266
+ },
267
+ "getter": false,
268
+ "setter": false,
269
+ "reflect": false,
270
+ "defaultValue": "''"
271
+ },
272
+ "disabled": {
273
+ "type": "boolean",
274
+ "attribute": "disabled",
275
+ "mutable": false,
276
+ "complexType": {
277
+ "original": "boolean",
278
+ "resolved": "boolean",
279
+ "references": {}
280
+ },
281
+ "required": false,
282
+ "optional": false,
283
+ "docs": {
284
+ "tags": [],
285
+ "text": "Tiles is disabled"
286
+ },
287
+ "getter": false,
288
+ "setter": false,
289
+ "reflect": false,
290
+ "defaultValue": "false"
291
+ }
292
+ };
293
+ }
294
+ static get events() {
295
+ return [{
296
+ "method": "tileClicked",
297
+ "name": "tileClicked",
298
+ "bubbles": true,
299
+ "cancelable": true,
300
+ "composed": true,
301
+ "docs": {
302
+ "tags": [{
303
+ "name": "note",
304
+ "text": "If tile is disabled event won't be emitted"
305
+ }],
306
+ "text": "Event emitted when tile is clicked."
307
+ },
308
+ "complexType": {
309
+ "original": "void",
310
+ "resolved": "void",
311
+ "references": {}
312
+ }
313
+ }];
314
+ }
315
+ }
316
+ //# sourceMappingURL=sula-tiles.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"sula-tiles.js","sourceRoot":"","sources":["../../../src/components/sula-tiles/sula-tiles.tsx"],"names":[],"mappings":"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","sourcesContent":["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"]}