@furystack/shades-common-components 10.0.35 → 11.0.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 (295) hide show
  1. package/CHANGELOG.md +66 -0
  2. package/esm/components/animations.spec.d.ts +2 -0
  3. package/esm/components/animations.spec.d.ts.map +1 -0
  4. package/esm/components/animations.spec.js +201 -0
  5. package/esm/components/animations.spec.js.map +1 -0
  6. package/esm/components/app-bar-link.js +21 -20
  7. package/esm/components/app-bar-link.js.map +1 -1
  8. package/esm/components/app-bar-link.spec.d.ts +2 -0
  9. package/esm/components/app-bar-link.spec.d.ts.map +1 -0
  10. package/esm/components/app-bar-link.spec.js +252 -0
  11. package/esm/components/app-bar-link.spec.js.map +1 -0
  12. package/esm/components/app-bar.js +21 -21
  13. package/esm/components/app-bar.js.map +1 -1
  14. package/esm/components/app-bar.spec.d.ts +2 -0
  15. package/esm/components/app-bar.spec.d.ts.map +1 -0
  16. package/esm/components/app-bar.spec.js +117 -0
  17. package/esm/components/app-bar.spec.js.map +1 -0
  18. package/esm/components/avatar.d.ts.map +1 -1
  19. package/esm/components/avatar.js +15 -19
  20. package/esm/components/avatar.js.map +1 -1
  21. package/esm/components/avatar.spec.d.ts +2 -0
  22. package/esm/components/avatar.spec.d.ts.map +1 -0
  23. package/esm/components/avatar.spec.js +114 -0
  24. package/esm/components/avatar.spec.js.map +1 -0
  25. package/esm/components/button.d.ts.map +1 -1
  26. package/esm/components/button.js +145 -156
  27. package/esm/components/button.js.map +1 -1
  28. package/esm/components/button.spec.d.ts +2 -0
  29. package/esm/components/button.spec.d.ts.map +1 -0
  30. package/esm/components/button.spec.js +155 -0
  31. package/esm/components/button.spec.js.map +1 -0
  32. package/esm/components/command-palette/command-palette-input.d.ts.map +1 -1
  33. package/esm/components/command-palette/command-palette-input.js +18 -16
  34. package/esm/components/command-palette/command-palette-input.js.map +1 -1
  35. package/esm/components/command-palette/command-palette-input.spec.d.ts +2 -0
  36. package/esm/components/command-palette/command-palette-input.spec.d.ts.map +1 -0
  37. package/esm/components/command-palette/command-palette-input.spec.js +233 -0
  38. package/esm/components/command-palette/command-palette-input.spec.js.map +1 -0
  39. package/esm/components/command-palette/command-palette-manager.spec.d.ts +2 -0
  40. package/esm/components/command-palette/command-palette-manager.spec.d.ts.map +1 -0
  41. package/esm/components/command-palette/command-palette-manager.spec.js +362 -0
  42. package/esm/components/command-palette/command-palette-manager.spec.js.map +1 -0
  43. package/esm/components/command-palette/command-palette-suggestion-list.d.ts.map +1 -1
  44. package/esm/components/command-palette/command-palette-suggestion-list.js +42 -46
  45. package/esm/components/command-palette/command-palette-suggestion-list.js.map +1 -1
  46. package/esm/components/command-palette/command-palette-suggestion-list.spec.d.ts +2 -0
  47. package/esm/components/command-palette/command-palette-suggestion-list.spec.d.ts.map +1 -0
  48. package/esm/components/command-palette/command-palette-suggestion-list.spec.js +376 -0
  49. package/esm/components/command-palette/command-palette-suggestion-list.spec.js.map +1 -0
  50. package/esm/components/command-palette/index.d.ts.map +1 -1
  51. package/esm/components/command-palette/index.js +100 -110
  52. package/esm/components/command-palette/index.js.map +1 -1
  53. package/esm/components/command-palette/index.spec.d.ts +2 -0
  54. package/esm/components/command-palette/index.spec.d.ts.map +1 -0
  55. package/esm/components/command-palette/index.spec.js +509 -0
  56. package/esm/components/command-palette/index.spec.js.map +1 -0
  57. package/esm/components/data-grid/body.js +1 -1
  58. package/esm/components/data-grid/body.js.map +1 -1
  59. package/esm/components/data-grid/body.spec.d.ts +2 -0
  60. package/esm/components/data-grid/body.spec.d.ts.map +1 -0
  61. package/esm/components/data-grid/body.spec.js +228 -0
  62. package/esm/components/data-grid/body.spec.js.map +1 -0
  63. package/esm/components/data-grid/data-grid-row.d.ts.map +1 -1
  64. package/esm/components/data-grid/data-grid-row.js +49 -73
  65. package/esm/components/data-grid/data-grid-row.js.map +1 -1
  66. package/esm/components/data-grid/data-grid-row.spec.d.ts +2 -0
  67. package/esm/components/data-grid/data-grid-row.spec.d.ts.map +1 -0
  68. package/esm/components/data-grid/data-grid-row.spec.js +296 -0
  69. package/esm/components/data-grid/data-grid-row.spec.js.map +1 -0
  70. package/esm/components/data-grid/data-grid.d.ts.map +1 -1
  71. package/esm/components/data-grid/data-grid.js +35 -28
  72. package/esm/components/data-grid/data-grid.js.map +1 -1
  73. package/esm/components/data-grid/data-grid.spec.d.ts +2 -0
  74. package/esm/components/data-grid/data-grid.spec.d.ts.map +1 -0
  75. package/esm/components/data-grid/data-grid.spec.js +544 -0
  76. package/esm/components/data-grid/data-grid.spec.js.map +1 -0
  77. package/esm/components/data-grid/footer.js +21 -15
  78. package/esm/components/data-grid/footer.js.map +1 -1
  79. package/esm/components/data-grid/footer.spec.d.ts +2 -0
  80. package/esm/components/data-grid/footer.spec.d.ts.map +1 -0
  81. package/esm/components/data-grid/footer.spec.js +264 -0
  82. package/esm/components/data-grid/footer.spec.js.map +1 -0
  83. package/esm/components/data-grid/header.d.ts.map +1 -1
  84. package/esm/components/data-grid/header.js +55 -33
  85. package/esm/components/data-grid/header.js.map +1 -1
  86. package/esm/components/data-grid/header.spec.d.ts +2 -0
  87. package/esm/components/data-grid/header.spec.d.ts.map +1 -0
  88. package/esm/components/data-grid/header.spec.js +421 -0
  89. package/esm/components/data-grid/header.spec.js.map +1 -0
  90. package/esm/components/data-grid/selection-cell.d.ts.map +1 -1
  91. package/esm/components/data-grid/selection-cell.js +13 -6
  92. package/esm/components/data-grid/selection-cell.js.map +1 -1
  93. package/esm/components/data-grid/selection-cell.spec.d.ts +2 -0
  94. package/esm/components/data-grid/selection-cell.spec.d.ts.map +1 -0
  95. package/esm/components/data-grid/selection-cell.spec.js +118 -0
  96. package/esm/components/data-grid/selection-cell.spec.js.map +1 -0
  97. package/esm/components/fab.d.ts.map +1 -1
  98. package/esm/components/fab.js +10 -1
  99. package/esm/components/fab.js.map +1 -1
  100. package/esm/components/fab.spec.d.ts +2 -0
  101. package/esm/components/fab.spec.d.ts.map +1 -0
  102. package/esm/components/fab.spec.js +95 -0
  103. package/esm/components/fab.spec.js.map +1 -0
  104. package/esm/components/form.spec.d.ts +2 -0
  105. package/esm/components/form.spec.d.ts.map +1 -0
  106. package/esm/components/form.spec.js +314 -0
  107. package/esm/components/form.spec.js.map +1 -0
  108. package/esm/components/grid.d.ts.map +1 -1
  109. package/esm/components/grid.js +40 -37
  110. package/esm/components/grid.js.map +1 -1
  111. package/esm/components/grid.spec.d.ts +2 -0
  112. package/esm/components/grid.spec.d.ts.map +1 -0
  113. package/esm/components/grid.spec.js +316 -0
  114. package/esm/components/grid.spec.js.map +1 -0
  115. package/esm/components/inputs/autocomplete.spec.d.ts +2 -0
  116. package/esm/components/inputs/autocomplete.spec.d.ts.map +1 -0
  117. package/esm/components/inputs/autocomplete.spec.js +194 -0
  118. package/esm/components/inputs/autocomplete.spec.js.map +1 -0
  119. package/esm/components/inputs/input.d.ts.map +1 -1
  120. package/esm/components/inputs/input.js +141 -109
  121. package/esm/components/inputs/input.js.map +1 -1
  122. package/esm/components/inputs/input.spec.d.ts +2 -0
  123. package/esm/components/inputs/input.spec.d.ts.map +1 -0
  124. package/esm/components/inputs/input.spec.js +577 -0
  125. package/esm/components/inputs/input.spec.js.map +1 -0
  126. package/esm/components/inputs/text-area.d.ts.map +1 -1
  127. package/esm/components/inputs/text-area.js +54 -58
  128. package/esm/components/inputs/text-area.js.map +1 -1
  129. package/esm/components/inputs/text-area.spec.d.ts +2 -0
  130. package/esm/components/inputs/text-area.spec.d.ts.map +1 -0
  131. package/esm/components/inputs/text-area.spec.js +214 -0
  132. package/esm/components/inputs/text-area.spec.js.map +1 -0
  133. package/esm/components/loader.js +1 -1
  134. package/esm/components/loader.js.map +1 -1
  135. package/esm/components/loader.spec.d.ts +2 -0
  136. package/esm/components/loader.spec.d.ts.map +1 -0
  137. package/esm/components/loader.spec.js +251 -0
  138. package/esm/components/loader.spec.js.map +1 -0
  139. package/esm/components/modal.d.ts.map +1 -1
  140. package/esm/components/modal.js +11 -9
  141. package/esm/components/modal.js.map +1 -1
  142. package/esm/components/modal.spec.d.ts +2 -0
  143. package/esm/components/modal.spec.d.ts.map +1 -0
  144. package/esm/components/modal.spec.js +227 -0
  145. package/esm/components/modal.spec.js.map +1 -0
  146. package/esm/components/noty-list.d.ts.map +1 -1
  147. package/esm/components/noty-list.js +39 -40
  148. package/esm/components/noty-list.js.map +1 -1
  149. package/esm/components/noty-list.spec.d.ts +2 -0
  150. package/esm/components/noty-list.spec.d.ts.map +1 -0
  151. package/esm/components/noty-list.spec.js +486 -0
  152. package/esm/components/noty-list.spec.js.map +1 -0
  153. package/esm/components/paper.d.ts.map +1 -1
  154. package/esm/components/paper.js +15 -12
  155. package/esm/components/paper.js.map +1 -1
  156. package/esm/components/paper.spec.d.ts +2 -0
  157. package/esm/components/paper.spec.d.ts.map +1 -0
  158. package/esm/components/paper.spec.js +63 -0
  159. package/esm/components/paper.spec.js.map +1 -0
  160. package/esm/components/skeleton.js +1 -1
  161. package/esm/components/skeleton.js.map +1 -1
  162. package/esm/components/skeleton.spec.d.ts +2 -0
  163. package/esm/components/skeleton.spec.d.ts.map +1 -0
  164. package/esm/components/skeleton.spec.js +159 -0
  165. package/esm/components/skeleton.spec.js.map +1 -0
  166. package/esm/components/styles.spec.d.ts +2 -0
  167. package/esm/components/styles.spec.d.ts.map +1 -0
  168. package/esm/components/styles.spec.js +56 -0
  169. package/esm/components/styles.spec.js.map +1 -0
  170. package/esm/components/suggest/index.d.ts.map +1 -1
  171. package/esm/components/suggest/index.js +74 -83
  172. package/esm/components/suggest/index.js.map +1 -1
  173. package/esm/components/suggest/index.spec.d.ts +2 -0
  174. package/esm/components/suggest/index.spec.d.ts.map +1 -0
  175. package/esm/components/suggest/index.spec.js +515 -0
  176. package/esm/components/suggest/index.spec.js.map +1 -0
  177. package/esm/components/suggest/suggest-input.d.ts.map +1 -1
  178. package/esm/components/suggest/suggest-input.js +16 -17
  179. package/esm/components/suggest/suggest-input.js.map +1 -1
  180. package/esm/components/suggest/suggest-input.spec.d.ts +2 -0
  181. package/esm/components/suggest/suggest-input.spec.d.ts.map +1 -0
  182. package/esm/components/suggest/suggest-input.spec.js +138 -0
  183. package/esm/components/suggest/suggest-input.spec.js.map +1 -0
  184. package/esm/components/suggest/suggest-manager.spec.d.ts +2 -0
  185. package/esm/components/suggest/suggest-manager.spec.d.ts.map +1 -0
  186. package/esm/components/suggest/suggest-manager.spec.js +308 -0
  187. package/esm/components/suggest/suggest-manager.spec.js.map +1 -0
  188. package/esm/components/suggest/suggestion-list.d.ts.map +1 -1
  189. package/esm/components/suggest/suggestion-list.js +43 -48
  190. package/esm/components/suggest/suggestion-list.js.map +1 -1
  191. package/esm/components/suggest/suggestion-list.spec.d.ts +2 -0
  192. package/esm/components/suggest/suggestion-list.spec.d.ts.map +1 -0
  193. package/esm/components/suggest/suggestion-list.spec.js +252 -0
  194. package/esm/components/suggest/suggestion-list.spec.js.map +1 -0
  195. package/esm/components/tabs.d.ts.map +1 -1
  196. package/esm/components/tabs.js +32 -18
  197. package/esm/components/tabs.js.map +1 -1
  198. package/esm/components/tabs.spec.d.ts +2 -0
  199. package/esm/components/tabs.spec.d.ts.map +1 -0
  200. package/esm/components/tabs.spec.js +187 -0
  201. package/esm/components/tabs.spec.js.map +1 -0
  202. package/esm/components/wizard/index.d.ts.map +1 -1
  203. package/esm/components/wizard/index.js +10 -7
  204. package/esm/components/wizard/index.js.map +1 -1
  205. package/esm/components/wizard/index.spec.d.ts +2 -0
  206. package/esm/components/wizard/index.spec.d.ts.map +1 -0
  207. package/esm/components/wizard/index.spec.js +171 -0
  208. package/esm/components/wizard/index.spec.js.map +1 -0
  209. package/esm/services/collection-service.spec.js +391 -2
  210. package/esm/services/collection-service.spec.js.map +1 -1
  211. package/esm/services/css-variable-theme.d.ts.map +1 -1
  212. package/esm/services/css-variable-theme.js +21 -1
  213. package/esm/services/css-variable-theme.js.map +1 -1
  214. package/esm/services/css-variable-theme.spec.d.ts +2 -0
  215. package/esm/services/css-variable-theme.spec.d.ts.map +1 -0
  216. package/esm/services/css-variable-theme.spec.js +169 -0
  217. package/esm/services/css-variable-theme.spec.js.map +1 -0
  218. package/esm/services/default-palette.d.ts +4 -0
  219. package/esm/services/default-palette.d.ts.map +1 -1
  220. package/esm/services/default-palette.js +22 -0
  221. package/esm/services/default-palette.js.map +1 -1
  222. package/esm/services/theme-provider-service.d.ts +59 -1
  223. package/esm/services/theme-provider-service.d.ts.map +1 -1
  224. package/esm/services/theme-provider-service.js.map +1 -1
  225. package/esm/services/theme-provider-service.spec.d.ts +2 -0
  226. package/esm/services/theme-provider-service.spec.d.ts.map +1 -0
  227. package/esm/services/theme-provider-service.spec.js +166 -0
  228. package/esm/services/theme-provider-service.spec.js.map +1 -0
  229. package/package.json +2 -2
  230. package/src/components/animations.spec.ts +299 -0
  231. package/src/components/app-bar-link.spec.tsx +341 -0
  232. package/src/components/app-bar-link.tsx +21 -21
  233. package/src/components/app-bar.spec.tsx +142 -0
  234. package/src/components/app-bar.tsx +22 -22
  235. package/src/components/avatar.spec.tsx +146 -0
  236. package/src/components/avatar.tsx +17 -20
  237. package/src/components/button.spec.tsx +193 -0
  238. package/src/components/button.tsx +162 -197
  239. package/src/components/command-palette/command-palette-input.spec.tsx +320 -0
  240. package/src/components/command-palette/command-palette-input.tsx +19 -22
  241. package/src/components/command-palette/command-palette-manager.spec.ts +470 -0
  242. package/src/components/command-palette/command-palette-suggestion-list.spec.tsx +499 -0
  243. package/src/components/command-palette/command-palette-suggestion-list.tsx +42 -46
  244. package/src/components/command-palette/index.spec.tsx +684 -0
  245. package/src/components/command-palette/index.tsx +107 -136
  246. package/src/components/data-grid/body.spec.tsx +340 -0
  247. package/src/components/data-grid/body.tsx +1 -1
  248. package/src/components/data-grid/data-grid-row.spec.tsx +382 -0
  249. package/src/components/data-grid/data-grid-row.tsx +50 -82
  250. package/src/components/data-grid/data-grid.spec.tsx +939 -0
  251. package/src/components/data-grid/data-grid.tsx +38 -35
  252. package/src/components/data-grid/footer.spec.tsx +344 -0
  253. package/src/components/data-grid/footer.tsx +19 -19
  254. package/src/components/data-grid/header.spec.tsx +563 -0
  255. package/src/components/data-grid/header.tsx +53 -44
  256. package/src/components/data-grid/selection-cell.spec.tsx +150 -0
  257. package/src/components/data-grid/selection-cell.tsx +12 -6
  258. package/src/components/fab.spec.tsx +108 -0
  259. package/src/components/fab.tsx +10 -1
  260. package/src/components/form.spec.tsx +481 -0
  261. package/src/components/grid.spec.tsx +334 -0
  262. package/src/components/grid.tsx +57 -63
  263. package/src/components/inputs/autocomplete.spec.tsx +258 -0
  264. package/src/components/inputs/input.spec.tsx +808 -0
  265. package/src/components/inputs/input.tsx +153 -139
  266. package/src/components/inputs/text-area.spec.tsx +285 -0
  267. package/src/components/inputs/text-area.tsx +53 -79
  268. package/src/components/loader.spec.tsx +346 -0
  269. package/src/components/loader.tsx +1 -1
  270. package/src/components/modal.spec.tsx +304 -0
  271. package/src/components/modal.tsx +11 -9
  272. package/src/components/noty-list.spec.tsx +631 -0
  273. package/src/components/noty-list.tsx +39 -50
  274. package/src/components/paper.spec.tsx +72 -0
  275. package/src/components/paper.tsx +15 -13
  276. package/src/components/skeleton.spec.tsx +219 -0
  277. package/src/components/skeleton.tsx +1 -1
  278. package/src/components/styles.spec.ts +70 -0
  279. package/src/components/suggest/index.spec.tsx +861 -0
  280. package/src/components/suggest/index.tsx +74 -101
  281. package/src/components/suggest/suggest-input.spec.tsx +181 -0
  282. package/src/components/suggest/suggest-input.tsx +16 -24
  283. package/src/components/suggest/suggest-manager.spec.ts +409 -0
  284. package/src/components/suggest/suggestion-list.spec.tsx +334 -0
  285. package/src/components/suggest/suggestion-list.tsx +43 -48
  286. package/src/components/tabs.spec.tsx +236 -0
  287. package/src/components/tabs.tsx +33 -21
  288. package/src/components/wizard/index.spec.tsx +224 -0
  289. package/src/components/wizard/index.tsx +10 -9
  290. package/src/services/collection-service.spec.ts +492 -3
  291. package/src/services/css-variable-theme.spec.ts +204 -0
  292. package/src/services/css-variable-theme.ts +21 -1
  293. package/src/services/default-palette.ts +22 -0
  294. package/src/services/theme-provider-service.spec.ts +195 -0
  295. package/src/services/theme-provider-service.ts +60 -2
@@ -1,65 +1,61 @@
1
1
  import { createComponent, Shade } from '@furystack/shades';
2
- import { ThemeProviderService } from '../../services/theme-provider-service.js';
3
- import { promisifyAnimation } from '../../utils/promisify-animation.js';
2
+ import { cssVariableTheme } from '../../services/css-variable-theme.js';
4
3
  export const TextArea = Shade({
5
4
  shadowDomName: 'shade-text-area',
6
- render: ({ props, element, injector }) => {
7
- const themeProvider = injector.getInstance(ThemeProviderService);
8
- const { theme } = themeProvider;
9
- const { palette } = theme;
10
- return (createComponent("label", { ...props.labelProps, style: {
11
- display: 'flex',
12
- flexDirection: 'column',
13
- alignItems: 'flex-start',
14
- justifyContent: 'space-between',
15
- fontSize: '10px',
16
- color: props.disabled ? 'rgb(170, 170, 170)' : '#bbb',
17
- marginBottom: '1em',
18
- padding: '1em',
19
- borderRadius: '5px',
20
- border: props.variant === 'outlined' ? '1px solid #bbb' : 'none',
21
- ...props.labelProps?.style,
22
- } },
5
+ css: {
6
+ display: 'block',
7
+ marginBottom: '1em',
8
+ '& label': {
9
+ display: 'flex',
10
+ flexDirection: 'column',
11
+ alignItems: 'flex-start',
12
+ justifyContent: 'space-between',
13
+ fontSize: '10px',
14
+ color: '#bbb',
15
+ padding: '1em',
16
+ borderRadius: '5px',
17
+ border: 'none',
18
+ transition: 'color 0.3s cubic-bezier(0.455, 0.030, 0.515, 0.955)',
19
+ },
20
+ '&[data-variant="outlined"] label': {
21
+ border: '1px solid #bbb',
22
+ },
23
+ '&[data-disabled] label': {
24
+ color: 'rgb(170, 170, 170)',
25
+ },
26
+ '&:focus-within label': {
27
+ color: cssVariableTheme.palette.primary.main,
28
+ },
29
+ '& .textarea-content': {
30
+ border: 'none',
31
+ backgroundColor: 'transparent',
32
+ outline: 'none',
33
+ fontSize: '12px',
34
+ width: '100%',
35
+ textOverflow: 'ellipsis',
36
+ boxShadow: '0px 0px 0px rgba(128,128,128,0.1)',
37
+ transition: 'box-shadow 0.2s ease',
38
+ },
39
+ '&:focus-within .textarea-content': {
40
+ boxShadow: `0px 3px 0px ${cssVariableTheme.palette.primary.main}`,
41
+ },
42
+ },
43
+ render: ({ props, element }) => {
44
+ if (props.variant) {
45
+ element.setAttribute('data-variant', props.variant);
46
+ }
47
+ else {
48
+ element.removeAttribute('data-variant');
49
+ }
50
+ if (props.disabled) {
51
+ element.setAttribute('data-disabled', '');
52
+ }
53
+ else {
54
+ element.removeAttribute('data-disabled');
55
+ }
56
+ return (createComponent("label", { ...props.labelProps, style: props.labelProps?.style },
23
57
  createComponent("span", null, props.labelTitle),
24
- createComponent("div", { contentEditable: props.readOnly === true || props.disabled === true ? 'inherit' : 'true', ...props, style: {
25
- border: 'none',
26
- backgroundColor: 'transparent',
27
- outline: 'none',
28
- fontSize: '12px',
29
- width: '100%',
30
- textOverflow: 'ellipsis',
31
- ...props.style,
32
- }, onfocus: () => {
33
- if (!props.disabled) {
34
- void promisifyAnimation(element.querySelector('label'), [{ color: themeProvider.getTextColor(theme.background.default) }, { color: palette.primary.main }], {
35
- duration: 500,
36
- easing: 'cubic-bezier(0.455, 0.030, 0.515, 0.955)',
37
- fill: 'forwards',
38
- });
39
- void promisifyAnimation(element.querySelector('div[contenteditable="true"]'), [
40
- { boxShadow: '0px 0px 0px rgba(128,128,128,0.1)' },
41
- { boxShadow: `0px 3px 0px ${palette.primary.main}` },
42
- ], {
43
- duration: 200,
44
- fill: 'forwards',
45
- });
46
- }
47
- }, onblur: () => {
48
- if (!props.disabled) {
49
- void promisifyAnimation(element.querySelector('label'), [{ color: palette.primary.main }, { color: themeProvider.getTextColor(theme.background.default) }], {
50
- duration: 200,
51
- easing: 'cubic-bezier(0.455, 0.030, 0.515, 0.955)',
52
- fill: 'forwards',
53
- });
54
- void promisifyAnimation(element.querySelector('div[contenteditable="true"]'), [
55
- { boxShadow: '0px 3px 0px rgba(128,128,128,0.4)' },
56
- { boxShadow: '0px 0px 0px rgba(128,128,128,0.1)' },
57
- ], {
58
- duration: 400,
59
- fill: 'forwards',
60
- });
61
- }
62
- } }, props.value)));
58
+ createComponent("div", { className: "textarea-content", contentEditable: props.readOnly === true || props.disabled === true ? 'inherit' : 'true', ...props, style: props.style }, props.value)));
63
59
  },
64
60
  });
65
61
  //# sourceMappingURL=text-area.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"text-area.js","sourceRoot":"","sources":["../../../src/components/inputs/text-area.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"text-area.js","sourceRoot":"","sources":["../../../src/components/inputs/text-area.tsx"],"names":[],"mappings":"AACA,OAAO,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,EAAE,gBAAgB,EAAE,MAAM,sCAAsC,CAAA;AASvE,MAAM,CAAC,MAAM,QAAQ,GAAG,KAAK,CAAgB;IAC3C,aAAa,EAAE,iBAAiB;IAChC,GAAG,EAAE;QACH,OAAO,EAAE,OAAO;QAChB,YAAY,EAAE,KAAK;QACnB,SAAS,EAAE;YACT,OAAO,EAAE,MAAM;YACf,aAAa,EAAE,QAAQ;YACvB,UAAU,EAAE,YAAY;YACxB,cAAc,EAAE,eAAe;YAC/B,QAAQ,EAAE,MAAM;YAChB,KAAK,EAAE,MAAM;YACb,OAAO,EAAE,KAAK;YACd,YAAY,EAAE,KAAK;YACnB,MAAM,EAAE,MAAM;YACd,UAAU,EAAE,qDAAqD;SAClE;QACD,kCAAkC,EAAE;YAClC,MAAM,EAAE,gBAAgB;SACzB;QACD,wBAAwB,EAAE;YACxB,KAAK,EAAE,oBAAoB;SAC5B;QACD,sBAAsB,EAAE;YACtB,KAAK,EAAE,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI;SAC7C;QACD,qBAAqB,EAAE;YACrB,MAAM,EAAE,MAAM;YACd,eAAe,EAAE,aAAa;YAC9B,OAAO,EAAE,MAAM;YACf,QAAQ,EAAE,MAAM;YAChB,KAAK,EAAE,MAAM;YACb,YAAY,EAAE,UAAU;YACxB,SAAS,EAAE,mCAAmC;YAC9C,UAAU,EAAE,sBAAsB;SACnC;QACD,kCAAkC,EAAE;YAClC,SAAS,EAAE,eAAe,gBAAgB,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE;SAClE;KACF;IACD,MAAM,EAAE,CAAC,EAAE,KAAK,EAAE,OAAO,EAAE,EAAE,EAAE;QAC7B,IAAI,KAAK,CAAC,OAAO,EAAE,CAAC;YAClB,OAAO,CAAC,YAAY,CAAC,cAAc,EAAE,KAAK,CAAC,OAAO,CAAC,CAAA;QACrD,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,eAAe,CAAC,cAAc,CAAC,CAAA;QACzC,CAAC;QACD,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC;YACnB,OAAO,CAAC,YAAY,CAAC,eAAe,EAAE,EAAE,CAAC,CAAA;QAC3C,CAAC;aAAM,CAAC;YACN,OAAO,CAAC,eAAe,CAAC,eAAe,CAAC,CAAA;QAC1C,CAAC;QAED,OAAO,CACL,8BAAW,KAAK,CAAC,UAAU,EAAE,KAAK,EAAE,KAAK,CAAC,UAAU,EAAE,KAAK;YACzD,8BAAO,KAAK,CAAC,UAAU,CAAQ;YAE/B,yBACE,SAAS,EAAC,kBAAkB,EAC5B,eAAe,EAAE,KAAK,CAAC,QAAQ,KAAK,IAAI,IAAI,KAAK,CAAC,QAAQ,KAAK,IAAI,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,MAAM,KACpF,KAAK,EACT,KAAK,EAAE,KAAK,CAAC,KAAK,IAEjB,KAAK,CAAC,KAAK,CACR,CACA,CACT,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=text-area.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text-area.spec.d.ts","sourceRoot":"","sources":["../../../src/components/inputs/text-area.spec.tsx"],"names":[],"mappings":""}
@@ -0,0 +1,214 @@
1
+ import { Injector } from '@furystack/inject';
2
+ import { createComponent, initializeShadeRoot } from '@furystack/shades';
3
+ import { sleepAsync } from '@furystack/utils';
4
+ import { afterEach, beforeEach, describe, expect, it } from 'vitest';
5
+ import { TextArea } from './text-area.js';
6
+ describe('TextArea', () => {
7
+ beforeEach(() => {
8
+ document.body.innerHTML = '<div id="root"></div>';
9
+ });
10
+ afterEach(() => {
11
+ document.body.innerHTML = '';
12
+ });
13
+ it('should render with shadow DOM', async () => {
14
+ const injector = new Injector();
15
+ const rootElement = document.getElementById('root');
16
+ initializeShadeRoot({
17
+ injector,
18
+ rootElement,
19
+ jsxElement: createComponent(TextArea, null),
20
+ });
21
+ await sleepAsync(50);
22
+ const textArea = document.querySelector('shade-text-area');
23
+ expect(textArea).not.toBeNull();
24
+ });
25
+ it('should render label with labelTitle', async () => {
26
+ const injector = new Injector();
27
+ const rootElement = document.getElementById('root');
28
+ initializeShadeRoot({
29
+ injector,
30
+ rootElement,
31
+ jsxElement: createComponent(TextArea, { labelTitle: "Test Label" }),
32
+ });
33
+ await sleepAsync(50);
34
+ const textArea = document.querySelector('shade-text-area');
35
+ expect(textArea).not.toBeNull();
36
+ const label = textArea?.querySelector('label');
37
+ expect(label).not.toBeNull();
38
+ const span = textArea?.querySelector('span');
39
+ expect(span?.textContent).toBe('Test Label');
40
+ });
41
+ it('should apply labelProps to label element', async () => {
42
+ const injector = new Injector();
43
+ const rootElement = document.getElementById('root');
44
+ initializeShadeRoot({
45
+ injector,
46
+ rootElement,
47
+ jsxElement: createComponent(TextArea, { labelTitle: "Test", labelProps: { className: 'custom-label-class' } }),
48
+ });
49
+ await sleepAsync(50);
50
+ const textArea = document.querySelector('shade-text-area');
51
+ const label = textArea?.querySelector('label');
52
+ expect(label?.className).toBe('custom-label-class');
53
+ });
54
+ it('should set data-variant attribute for outlined variant', async () => {
55
+ const injector = new Injector();
56
+ const rootElement = document.getElementById('root');
57
+ initializeShadeRoot({
58
+ injector,
59
+ rootElement,
60
+ jsxElement: createComponent(TextArea, { variant: "outlined" }),
61
+ });
62
+ await sleepAsync(50);
63
+ const textArea = document.querySelector('shade-text-area');
64
+ expect(textArea).not.toBeNull();
65
+ expect(textArea.getAttribute('data-variant')).toBe('outlined');
66
+ });
67
+ it('should set data-variant attribute for contained variant', async () => {
68
+ const injector = new Injector();
69
+ const rootElement = document.getElementById('root');
70
+ initializeShadeRoot({
71
+ injector,
72
+ rootElement,
73
+ jsxElement: createComponent(TextArea, { variant: "contained" }),
74
+ });
75
+ await sleepAsync(50);
76
+ const textArea = document.querySelector('shade-text-area');
77
+ expect(textArea).not.toBeNull();
78
+ expect(textArea.getAttribute('data-variant')).toBe('contained');
79
+ });
80
+ it('should not set data-variant attribute when no variant is provided', async () => {
81
+ const injector = new Injector();
82
+ const rootElement = document.getElementById('root');
83
+ initializeShadeRoot({
84
+ injector,
85
+ rootElement,
86
+ jsxElement: createComponent(TextArea, null),
87
+ });
88
+ await sleepAsync(50);
89
+ const textArea = document.querySelector('shade-text-area');
90
+ expect(textArea).not.toBeNull();
91
+ expect(textArea.hasAttribute('data-variant')).toBe(false);
92
+ });
93
+ it('should set data-disabled attribute when disabled', async () => {
94
+ const injector = new Injector();
95
+ const rootElement = document.getElementById('root');
96
+ initializeShadeRoot({
97
+ injector,
98
+ rootElement,
99
+ jsxElement: createComponent(TextArea, { disabled: true }),
100
+ });
101
+ await sleepAsync(50);
102
+ const textArea = document.querySelector('shade-text-area');
103
+ expect(textArea).not.toBeNull();
104
+ expect(textArea.hasAttribute('data-disabled')).toBe(true);
105
+ });
106
+ it('should not set data-disabled attribute when not disabled', async () => {
107
+ const injector = new Injector();
108
+ const rootElement = document.getElementById('root');
109
+ initializeShadeRoot({
110
+ injector,
111
+ rootElement,
112
+ jsxElement: createComponent(TextArea, { disabled: false }),
113
+ });
114
+ await sleepAsync(50);
115
+ const textArea = document.querySelector('shade-text-area');
116
+ expect(textArea).not.toBeNull();
117
+ expect(textArea.hasAttribute('data-disabled')).toBe(false);
118
+ });
119
+ it('should render value in contentEditable div', async () => {
120
+ const injector = new Injector();
121
+ const rootElement = document.getElementById('root');
122
+ initializeShadeRoot({
123
+ injector,
124
+ rootElement,
125
+ jsxElement: createComponent(TextArea, { value: "Test content" }),
126
+ });
127
+ await sleepAsync(50);
128
+ const textArea = document.querySelector('shade-text-area');
129
+ const contentDiv = textArea?.querySelector('.textarea-content');
130
+ expect(contentDiv).not.toBeNull();
131
+ expect(contentDiv?.textContent).toBe('Test content');
132
+ });
133
+ it('should have contentEditable true when not readOnly or disabled', async () => {
134
+ const injector = new Injector();
135
+ const rootElement = document.getElementById('root');
136
+ initializeShadeRoot({
137
+ injector,
138
+ rootElement,
139
+ jsxElement: createComponent(TextArea, null),
140
+ });
141
+ await sleepAsync(50);
142
+ const textArea = document.querySelector('shade-text-area');
143
+ const contentDiv = textArea?.querySelector('.textarea-content');
144
+ expect(contentDiv?.contentEditable).toBe('true');
145
+ });
146
+ it('should have contentEditable inherit when readOnly is true', async () => {
147
+ const injector = new Injector();
148
+ const rootElement = document.getElementById('root');
149
+ initializeShadeRoot({
150
+ injector,
151
+ rootElement,
152
+ jsxElement: createComponent(TextArea, { readOnly: true }),
153
+ });
154
+ await sleepAsync(50);
155
+ const textArea = document.querySelector('shade-text-area');
156
+ const contentDiv = textArea?.querySelector('.textarea-content');
157
+ expect(contentDiv?.contentEditable).toBe('inherit');
158
+ });
159
+ it('should have contentEditable inherit when disabled is true', async () => {
160
+ const injector = new Injector();
161
+ const rootElement = document.getElementById('root');
162
+ initializeShadeRoot({
163
+ injector,
164
+ rootElement,
165
+ jsxElement: createComponent(TextArea, { disabled: true }),
166
+ });
167
+ await sleepAsync(50);
168
+ const textArea = document.querySelector('shade-text-area');
169
+ const contentDiv = textArea?.querySelector('.textarea-content');
170
+ expect(contentDiv?.contentEditable).toBe('inherit');
171
+ });
172
+ it('should apply custom style to content div', async () => {
173
+ const injector = new Injector();
174
+ const rootElement = document.getElementById('root');
175
+ initializeShadeRoot({
176
+ injector,
177
+ rootElement,
178
+ jsxElement: createComponent(TextArea, { style: { color: 'red' } }),
179
+ });
180
+ await sleepAsync(50);
181
+ const textArea = document.querySelector('shade-text-area');
182
+ const contentDiv = textArea?.querySelector('.textarea-content');
183
+ expect(contentDiv?.style.color).toBe('red');
184
+ });
185
+ it('should apply custom style to label element', async () => {
186
+ const injector = new Injector();
187
+ const rootElement = document.getElementById('root');
188
+ initializeShadeRoot({
189
+ injector,
190
+ rootElement,
191
+ jsxElement: createComponent(TextArea, { labelProps: { style: { backgroundColor: 'blue' } } }),
192
+ });
193
+ await sleepAsync(50);
194
+ const textArea = document.querySelector('shade-text-area');
195
+ const label = textArea?.querySelector('label');
196
+ expect(label?.style.backgroundColor).toBe('blue');
197
+ });
198
+ it('should have correct CSS styles applied', async () => {
199
+ const injector = new Injector();
200
+ const rootElement = document.getElementById('root');
201
+ initializeShadeRoot({
202
+ injector,
203
+ rootElement,
204
+ jsxElement: createComponent(TextArea, null),
205
+ });
206
+ await sleepAsync(50);
207
+ const textArea = document.querySelector('shade-text-area');
208
+ expect(textArea).not.toBeNull();
209
+ const computedStyle = window.getComputedStyle(textArea);
210
+ expect(computedStyle.display).toBe('block');
211
+ expect(computedStyle.marginBottom).toBe('1em');
212
+ });
213
+ });
214
+ //# sourceMappingURL=text-area.spec.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"text-area.spec.js","sourceRoot":"","sources":["../../../src/components/inputs/text-area.spec.tsx"],"names":[],"mappings":"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"}
@@ -3,7 +3,7 @@ import { ThemeProviderService } from '../services/theme-provider-service.js';
3
3
  import { promisifyAnimation } from '../utils/promisify-animation.js';
4
4
  export const Loader = Shade({
5
5
  shadowDomName: 'shade-loader',
6
- style: {
6
+ css: {
7
7
  display: 'inline-block',
8
8
  transformOrigin: 'center',
9
9
  opacity: '0',
@@ -1 +1 @@
1
- {"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/components/loader.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAA;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAA;AAuBpE,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,CAAc;IACvC,aAAa,EAAE,cAAc;IAC7B,KAAK,EAAE;QACL,OAAO,EAAE,cAAc;QACvB,eAAe,EAAE,QAAQ;QACzB,OAAO,EAAE,GAAG;KACb;IACD,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE;QACvC,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAA;QAE5D,MAAM,EAAE,KAAK,GAAG,GAAG,EAAE,GAAG,KAAK,CAAA;QAC7B,MAAM,EAAE,WAAW,GAAG,EAAE,EAAE,GAAG,KAAK,CAAA;QAClC,MAAM,EAAE,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,KAAK,CAAA;QAE1D,UAAU,CAAC,GAAG,EAAE;YACd,KAAK,kBAAkB,CAAC,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE;gBACrE,QAAQ,EAAE,GAAG;gBACb,KAAK;gBACL,IAAI,EAAE,UAAU;aACjB,CAAC,CAAA;YACF,KAAK,kBAAkB,CACrB,OAAO,CAAC,iBAAiB,EACzB,CAAC,EAAE,SAAS,EAAE,cAAc,EAAE,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,EACjG;gBACE,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,aAAa;gBACrB,UAAU,EAAE,QAAQ;aACrB,CACF,CAAA;QACH,CAAC,EAAE,CAAC,CAAC,CAAA;QACL,OAAO,CACL,yBACE,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,KAAK,EAAE,eAAe,WAAW,GAAG,CAAC,KAAK;gBAC1C,MAAM,EAAE,eAAe,WAAW,GAAG,CAAC,KAAK;gBAC3C,MAAM,EAAE,GAAG,WAAW,gCAAgC;gBACtD,YAAY,EAAE,GAAG,WAAW,YAAY,WAAW,EAAE;gBACrD,YAAY,EAAE,KAAK;aACpB,GACD,CACH,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
1
+ {"version":3,"file":"loader.js","sourceRoot":"","sources":["../../src/components/loader.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,KAAK,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAC1D,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAA;AAC5E,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAA;AAuBpE,MAAM,CAAC,MAAM,MAAM,GAAG,KAAK,CAAc;IACvC,aAAa,EAAE,cAAc;IAC7B,GAAG,EAAE;QACH,OAAO,EAAE,cAAc;QACvB,eAAe,EAAE,QAAQ;QACzB,OAAO,EAAE,GAAG;KACb;IACD,MAAM,EAAE,CAAC,EAAE,OAAO,EAAE,KAAK,EAAE,QAAQ,EAAE,EAAE,EAAE;QACvC,MAAM,EAAE,KAAK,EAAE,GAAG,QAAQ,CAAC,WAAW,CAAC,oBAAoB,CAAC,CAAA;QAE5D,MAAM,EAAE,KAAK,GAAG,GAAG,EAAE,GAAG,KAAK,CAAA;QAC7B,MAAM,EAAE,WAAW,GAAG,EAAE,EAAE,GAAG,KAAK,CAAA;QAClC,MAAM,EAAE,WAAW,GAAG,KAAK,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,KAAK,CAAA;QAE1D,UAAU,CAAC,GAAG,EAAE;YACd,KAAK,kBAAkB,CAAC,OAAO,EAAE,CAAC,EAAE,OAAO,EAAE,GAAG,EAAE,EAAE,EAAE,OAAO,EAAE,GAAG,EAAE,CAAC,EAAE;gBACrE,QAAQ,EAAE,GAAG;gBACb,KAAK;gBACL,IAAI,EAAE,UAAU;aACjB,CAAC,CAAA;YACF,KAAK,kBAAkB,CACrB,OAAO,CAAC,iBAAiB,EACzB,CAAC,EAAE,SAAS,EAAE,cAAc,EAAE,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,EAAE,EAAE,SAAS,EAAE,gBAAgB,EAAE,CAAC,EACjG;gBACE,QAAQ,EAAE,IAAI;gBACd,MAAM,EAAE,aAAa;gBACrB,UAAU,EAAE,QAAQ;aACrB,CACF,CAAA;QACH,CAAC,EAAE,CAAC,CAAC,CAAA;QACL,OAAO,CACL,yBACE,KAAK,EAAE;gBACL,QAAQ,EAAE,UAAU;gBACpB,KAAK,EAAE,eAAe,WAAW,GAAG,CAAC,KAAK;gBAC1C,MAAM,EAAE,eAAe,WAAW,GAAG,CAAC,KAAK;gBAC3C,MAAM,EAAE,GAAG,WAAW,gCAAgC;gBACtD,YAAY,EAAE,GAAG,WAAW,YAAY,WAAW,EAAE;gBACrD,YAAY,EAAE,KAAK;aACpB,GACD,CACH,CAAA;IACH,CAAC;CACF,CAAC,CAAA"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=loader.spec.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"loader.spec.d.ts","sourceRoot":"","sources":["../../src/components/loader.spec.tsx"],"names":[],"mappings":""}
@@ -0,0 +1,251 @@
1
+ import { Injector } from '@furystack/inject';
2
+ import { createComponent, initializeShadeRoot } from '@furystack/shades';
3
+ import { sleepAsync } from '@furystack/utils';
4
+ import { afterEach, beforeEach, describe, expect, it, vi } from 'vitest';
5
+ import { ThemeProviderService } from '../services/theme-provider-service.js';
6
+ import { Loader } from './loader.js';
7
+ describe('Loader', () => {
8
+ let originalAnimate;
9
+ let animateCalls;
10
+ beforeEach(() => {
11
+ document.body.innerHTML = '<div id="root"></div>';
12
+ animateCalls = [];
13
+ originalAnimate = Element.prototype.animate;
14
+ Element.prototype.animate = vi.fn((keyframes, options) => {
15
+ animateCalls.push({ keyframes, options });
16
+ const mockAnimation = {
17
+ onfinish: null,
18
+ oncancel: null,
19
+ cancel: vi.fn(),
20
+ play: vi.fn(),
21
+ pause: vi.fn(),
22
+ finish: vi.fn(),
23
+ addEventListener: vi.fn(),
24
+ removeEventListener: vi.fn(),
25
+ };
26
+ return mockAnimation;
27
+ });
28
+ });
29
+ afterEach(() => {
30
+ document.body.innerHTML = '';
31
+ Element.prototype.animate = originalAnimate;
32
+ vi.restoreAllMocks();
33
+ });
34
+ it('should render with shadow DOM', async () => {
35
+ const injector = new Injector();
36
+ const rootElement = document.getElementById('root');
37
+ initializeShadeRoot({
38
+ injector,
39
+ rootElement,
40
+ jsxElement: createComponent(Loader, null),
41
+ });
42
+ await sleepAsync(50);
43
+ const loader = document.querySelector('shade-loader');
44
+ expect(loader).not.toBeNull();
45
+ });
46
+ it('should have initial opacity of 0', async () => {
47
+ const injector = new Injector();
48
+ const rootElement = document.getElementById('root');
49
+ initializeShadeRoot({
50
+ injector,
51
+ rootElement,
52
+ jsxElement: createComponent(Loader, null),
53
+ });
54
+ await sleepAsync(50);
55
+ const loader = document.querySelector('shade-loader');
56
+ expect(loader).not.toBeNull();
57
+ const computedStyle = window.getComputedStyle(loader);
58
+ expect(computedStyle.opacity).toBe('0');
59
+ });
60
+ it('should have correct css styles applied', async () => {
61
+ const injector = new Injector();
62
+ const rootElement = document.getElementById('root');
63
+ initializeShadeRoot({
64
+ injector,
65
+ rootElement,
66
+ jsxElement: createComponent(Loader, null),
67
+ });
68
+ await sleepAsync(50);
69
+ const loader = document.querySelector('shade-loader');
70
+ expect(loader).not.toBeNull();
71
+ const computedStyle = window.getComputedStyle(loader);
72
+ expect(computedStyle.display).toBe('inline-block');
73
+ expect(computedStyle.transformOrigin).toBe('center');
74
+ });
75
+ it('should use default delay of 500ms', async () => {
76
+ const injector = new Injector();
77
+ const rootElement = document.getElementById('root');
78
+ initializeShadeRoot({
79
+ injector,
80
+ rootElement,
81
+ jsxElement: createComponent(Loader, null),
82
+ });
83
+ await sleepAsync(50);
84
+ const fadeInCall = animateCalls.find((call) => Array.isArray(call.keyframes) && call.keyframes.some((kf) => 'opacity' in kf));
85
+ expect(fadeInCall).toBeDefined();
86
+ expect(fadeInCall?.options?.delay).toBe(500);
87
+ });
88
+ it('should use custom delay when provided', async () => {
89
+ const injector = new Injector();
90
+ const rootElement = document.getElementById('root');
91
+ initializeShadeRoot({
92
+ injector,
93
+ rootElement,
94
+ jsxElement: createComponent(Loader, { delay: 200 }),
95
+ });
96
+ await sleepAsync(50);
97
+ const fadeInCall = animateCalls.find((call) => Array.isArray(call.keyframes) && call.keyframes.some((kf) => 'opacity' in kf));
98
+ expect(fadeInCall).toBeDefined();
99
+ expect(fadeInCall?.options?.delay).toBe(200);
100
+ });
101
+ it('should start fade-in animation with correct parameters', async () => {
102
+ const injector = new Injector();
103
+ const rootElement = document.getElementById('root');
104
+ initializeShadeRoot({
105
+ injector,
106
+ rootElement,
107
+ jsxElement: createComponent(Loader, { delay: 100 }),
108
+ });
109
+ await sleepAsync(50);
110
+ const fadeInCall = animateCalls.find((call) => Array.isArray(call.keyframes) &&
111
+ call.keyframes.length === 2 &&
112
+ call.keyframes[0].opacity === '0' &&
113
+ call.keyframes[1].opacity === '1');
114
+ expect(fadeInCall).toBeDefined();
115
+ const options = fadeInCall?.options;
116
+ expect(options.fill).toBe('forwards');
117
+ expect(options.duration).toBe(500);
118
+ expect(options.delay).toBe(100);
119
+ });
120
+ it('should start rotation animation', async () => {
121
+ const injector = new Injector();
122
+ const rootElement = document.getElementById('root');
123
+ initializeShadeRoot({
124
+ injector,
125
+ rootElement,
126
+ jsxElement: createComponent(Loader, null),
127
+ });
128
+ await sleepAsync(50);
129
+ const rotationCall = animateCalls.find((call) => Array.isArray(call.keyframes) && call.keyframes.some((kf) => 'transform' in kf));
130
+ expect(rotationCall).toBeDefined();
131
+ const options = rotationCall?.options;
132
+ expect(options.duration).toBe(1500);
133
+ expect(options.easing).toBe('ease-in-out');
134
+ expect(options.iterations).toBe(Infinity);
135
+ });
136
+ it('should have rotation keyframes from 0 to 360 degrees', async () => {
137
+ const injector = new Injector();
138
+ const rootElement = document.getElementById('root');
139
+ initializeShadeRoot({
140
+ injector,
141
+ rootElement,
142
+ jsxElement: createComponent(Loader, null),
143
+ });
144
+ await sleepAsync(50);
145
+ const rotationCall = animateCalls.find((call) => Array.isArray(call.keyframes) && call.keyframes.some((kf) => 'transform' in kf));
146
+ expect(rotationCall).toBeDefined();
147
+ const keyframes = rotationCall?.keyframes;
148
+ expect(keyframes).toHaveLength(3);
149
+ expect(keyframes[0].transform).toBe('rotate(0deg)');
150
+ expect(keyframes[1].transform).toBe('rotate(180deg)');
151
+ expect(keyframes[2].transform).toBe('rotate(360deg)');
152
+ });
153
+ it('should use default borderWidth of 15px', async () => {
154
+ const injector = new Injector();
155
+ const rootElement = document.getElementById('root');
156
+ initializeShadeRoot({
157
+ injector,
158
+ rootElement,
159
+ jsxElement: createComponent(Loader, null),
160
+ });
161
+ await sleepAsync(50);
162
+ const loader = document.querySelector('shade-loader');
163
+ expect(loader).not.toBeNull();
164
+ const innerDiv = loader.querySelector('div');
165
+ expect(innerDiv).not.toBeNull();
166
+ expect(innerDiv.style.width).toBe('calc(100% - 30px)');
167
+ expect(innerDiv.style.height).toBe('calc(100% - 30px)');
168
+ expect(innerDiv.style.borderTopWidth).toBe('15px');
169
+ });
170
+ it('should use custom borderWidth when provided', async () => {
171
+ const injector = new Injector();
172
+ const rootElement = document.getElementById('root');
173
+ initializeShadeRoot({
174
+ injector,
175
+ rootElement,
176
+ jsxElement: createComponent(Loader, { borderWidth: 10 }),
177
+ });
178
+ await sleepAsync(50);
179
+ const loader = document.querySelector('shade-loader');
180
+ expect(loader).not.toBeNull();
181
+ const innerDiv = loader.querySelector('div');
182
+ expect(innerDiv).not.toBeNull();
183
+ expect(innerDiv.style.width).toBe('calc(100% - 20px)');
184
+ expect(innerDiv.style.height).toBe('calc(100% - 20px)');
185
+ expect(innerDiv.style.borderTopWidth).toBe('10px');
186
+ });
187
+ it('should use custom borderColor when provided', async () => {
188
+ const injector = new Injector();
189
+ const rootElement = document.getElementById('root');
190
+ initializeShadeRoot({
191
+ injector,
192
+ rootElement,
193
+ jsxElement: createComponent(Loader, { borderColor: "#ff0000" }),
194
+ });
195
+ await sleepAsync(50);
196
+ const loader = document.querySelector('shade-loader');
197
+ expect(loader).not.toBeNull();
198
+ const innerDiv = loader.querySelector('div');
199
+ expect(innerDiv).not.toBeNull();
200
+ expect(innerDiv.style.borderBottomColor).toBe('rgb(255, 0, 0)');
201
+ });
202
+ it('should use theme primary color as default borderColor', async () => {
203
+ const injector = new Injector();
204
+ const rootElement = document.getElementById('root');
205
+ initializeShadeRoot({
206
+ injector,
207
+ rootElement,
208
+ jsxElement: createComponent(Loader, null),
209
+ });
210
+ await sleepAsync(50);
211
+ const loader = document.querySelector('shade-loader');
212
+ expect(loader).not.toBeNull();
213
+ const innerDiv = loader.querySelector('div');
214
+ expect(innerDiv).not.toBeNull();
215
+ const themeService = injector.getInstance(ThemeProviderService);
216
+ expect(innerDiv.style.borderBottom).toContain(themeService.theme.palette.primary.main);
217
+ });
218
+ it('should render with circular shape', async () => {
219
+ const injector = new Injector();
220
+ const rootElement = document.getElementById('root');
221
+ initializeShadeRoot({
222
+ injector,
223
+ rootElement,
224
+ jsxElement: createComponent(Loader, null),
225
+ });
226
+ await sleepAsync(50);
227
+ const loader = document.querySelector('shade-loader');
228
+ expect(loader).not.toBeNull();
229
+ const innerDiv = loader.querySelector('div');
230
+ expect(innerDiv).not.toBeNull();
231
+ expect(innerDiv.style.borderRadius).toBe('50%');
232
+ expect(innerDiv.style.position).toBe('relative');
233
+ });
234
+ it('should have a semi-transparent main border and colored bottom border', async () => {
235
+ const injector = new Injector();
236
+ const rootElement = document.getElementById('root');
237
+ initializeShadeRoot({
238
+ injector,
239
+ rootElement,
240
+ jsxElement: createComponent(Loader, { borderColor: "#00ff00" }),
241
+ });
242
+ await sleepAsync(50);
243
+ const loader = document.querySelector('shade-loader');
244
+ expect(loader).not.toBeNull();
245
+ const innerDiv = loader.querySelector('div');
246
+ expect(innerDiv).not.toBeNull();
247
+ expect(innerDiv.style.borderTopColor).toBe('rgba(128, 128, 128, 0.1)');
248
+ expect(innerDiv.style.borderBottomColor).toBe('rgb(0, 255, 0)');
249
+ });
250
+ });
251
+ //# sourceMappingURL=loader.spec.js.map