snice 1.14.2 → 2.1.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 (311) hide show
  1. package/bin/templates/base/tsconfig.json +5 -4
  2. package/components/accordion/demo.html +403 -0
  3. package/components/alert/demo.html +445 -0
  4. package/components/avatar/demo.html +598 -0
  5. package/components/badge/demo.html +523 -0
  6. package/components/breadcrumbs/demo.html +404 -0
  7. package/components/button/demo.html +42 -0
  8. package/components/card/demo.html +525 -0
  9. package/components/checkbox/demo.html +253 -0
  10. package/components/chip/demo.html +383 -0
  11. package/components/date-picker/demo.html +191 -0
  12. package/components/divider/demo.html +233 -0
  13. package/components/drawer/demo.html +328 -0
  14. package/components/input/demo.html +303 -0
  15. package/components/input/test.html +77 -0
  16. package/components/layout/demo.html +538 -0
  17. package/components/login/demo-auth-controller.ts +185 -0
  18. package/components/login/demo.html +470 -0
  19. package/components/login/snice-login.ts +2 -2
  20. package/components/modal/demo.html +291 -0
  21. package/components/pagination/demo.html +395 -0
  22. package/components/progress/demo.html +510 -0
  23. package/components/radio/demo.html +287 -0
  24. package/components/select/demo.html +511 -0
  25. package/components/skeleton/demo.html +514 -0
  26. package/components/switch/demo.html +284 -0
  27. package/components/table/demo-table-controller.ts +100 -0
  28. package/components/table/demo.html +480 -0
  29. package/components/table/snice-table.ts +2 -2
  30. package/components/tabs/demo.html +487 -0
  31. package/components/toast/demo.html +329 -0
  32. package/components/tooltip/demo.html +350 -0
  33. package/dist/index.cjs +441 -329
  34. package/dist/index.cjs.map +1 -1
  35. package/dist/index.cjs.min.map +1 -1
  36. package/dist/index.esm.js +441 -329
  37. package/dist/index.esm.js.map +1 -1
  38. package/dist/index.esm.min.js +3 -3
  39. package/dist/index.esm.min.js.map +1 -1
  40. package/dist/index.iife.js +441 -329
  41. package/dist/index.iife.js.map +1 -1
  42. package/dist/index.iife.min.js +3 -3
  43. package/dist/index.iife.min.js.map +1 -1
  44. package/dist/symbols.esm.js +1 -1
  45. package/dist/transitions.esm.js +1 -1
  46. package/dist/types/controller.d.ts +1 -1
  47. package/dist/types/element.d.ts +10 -10
  48. package/dist/types/events.d.ts +2 -2
  49. package/dist/types/index.d.ts +1 -1
  50. package/dist/types/observe.d.ts +1 -1
  51. package/dist/types/request-response.d.ts +2 -3
  52. package/dist/types/router.d.ts +1 -1
  53. package/package.json +9 -10
  54. package/dist/components/accordion/snice-accordion-item.d.ts +0 -25
  55. package/dist/components/accordion/snice-accordion-item.js +0 -260
  56. package/dist/components/accordion/snice-accordion-item.js.map +0 -1
  57. package/dist/components/accordion/snice-accordion.d.ts +0 -28
  58. package/dist/components/accordion/snice-accordion.js +0 -221
  59. package/dist/components/accordion/snice-accordion.js.map +0 -1
  60. package/dist/components/accordion/snice-accordion.types.d.ts +0 -29
  61. package/dist/components/accordion/snice-accordion.types.js +0 -2
  62. package/dist/components/accordion/snice-accordion.types.js.map +0 -1
  63. package/dist/components/alert/snice-alert.d.ts +0 -26
  64. package/dist/components/alert/snice-alert.js +0 -191
  65. package/dist/components/alert/snice-alert.js.map +0 -1
  66. package/dist/components/alert/snice-alert.types.d.ts +0 -11
  67. package/dist/components/alert/snice-alert.types.js +0 -2
  68. package/dist/components/alert/snice-alert.types.js.map +0 -1
  69. package/dist/components/avatar/snice-avatar.d.ts +0 -24
  70. package/dist/components/avatar/snice-avatar.js +0 -177
  71. package/dist/components/avatar/snice-avatar.js.map +0 -1
  72. package/dist/components/avatar/snice-avatar.types.d.ts +0 -12
  73. package/dist/components/avatar/snice-avatar.types.js +0 -2
  74. package/dist/components/avatar/snice-avatar.types.js.map +0 -1
  75. package/dist/components/badge/snice-badge.d.ts +0 -25
  76. package/dist/components/badge/snice-badge.js +0 -157
  77. package/dist/components/badge/snice-badge.js.map +0 -1
  78. package/dist/components/badge/snice-badge.types.d.ts +0 -15
  79. package/dist/components/badge/snice-badge.types.js +0 -2
  80. package/dist/components/badge/snice-badge.types.js.map +0 -1
  81. package/dist/components/breadcrumbs/snice-breadcrumbs.d.ts +0 -27
  82. package/dist/components/breadcrumbs/snice-breadcrumbs.js +0 -212
  83. package/dist/components/breadcrumbs/snice-breadcrumbs.js.map +0 -1
  84. package/dist/components/breadcrumbs/snice-breadcrumbs.types.d.ts +0 -23
  85. package/dist/components/breadcrumbs/snice-breadcrumbs.types.js +0 -2
  86. package/dist/components/breadcrumbs/snice-breadcrumbs.types.js.map +0 -1
  87. package/dist/components/breadcrumbs/snice-crumb.d.ts +0 -9
  88. package/dist/components/breadcrumbs/snice-crumb.js +0 -50
  89. package/dist/components/breadcrumbs/snice-crumb.js.map +0 -1
  90. package/dist/components/button/snice-button.d.ts +0 -32
  91. package/dist/components/button/snice-button.js +0 -212
  92. package/dist/components/button/snice-button.js.map +0 -1
  93. package/dist/components/button/snice-button.types.d.ts +0 -23
  94. package/dist/components/button/snice-button.types.js +0 -2
  95. package/dist/components/button/snice-button.types.js.map +0 -1
  96. package/dist/components/card/snice-card.d.ts +0 -19
  97. package/dist/components/card/snice-card.js +0 -132
  98. package/dist/components/card/snice-card.js.map +0 -1
  99. package/dist/components/card/snice-card.types.d.ts +0 -9
  100. package/dist/components/card/snice-card.types.js +0 -2
  101. package/dist/components/card/snice-card.types.js.map +0 -1
  102. package/dist/components/checkbox/snice-checkbox.d.ts +0 -34
  103. package/dist/components/checkbox/snice-checkbox.js +0 -289
  104. package/dist/components/checkbox/snice-checkbox.js.map +0 -1
  105. package/dist/components/checkbox/snice-checkbox.types.d.ts +0 -20
  106. package/dist/components/checkbox/snice-checkbox.types.js +0 -2
  107. package/dist/components/checkbox/snice-checkbox.types.js.map +0 -1
  108. package/dist/components/chip/snice-chip.d.ts +0 -28
  109. package/dist/components/chip/snice-chip.js +0 -203
  110. package/dist/components/chip/snice-chip.js.map +0 -1
  111. package/dist/components/chip/snice-chip.types.d.ts +0 -14
  112. package/dist/components/chip/snice-chip.types.js +0 -2
  113. package/dist/components/chip/snice-chip.types.js.map +0 -1
  114. package/dist/components/date-picker/snice-date-picker.d.ts +0 -82
  115. package/dist/components/date-picker/snice-date-picker.js +0 -880
  116. package/dist/components/date-picker/snice-date-picker.js.map +0 -1
  117. package/dist/components/date-picker/snice-date-picker.types.d.ts +0 -71
  118. package/dist/components/date-picker/snice-date-picker.types.js +0 -2
  119. package/dist/components/date-picker/snice-date-picker.types.js.map +0 -1
  120. package/dist/components/divider/snice-divider.d.ts +0 -17
  121. package/dist/components/divider/snice-divider.js +0 -111
  122. package/dist/components/divider/snice-divider.js.map +0 -1
  123. package/dist/components/divider/snice-divider.types.d.ts +0 -14
  124. package/dist/components/divider/snice-divider.types.js +0 -2
  125. package/dist/components/divider/snice-divider.types.js.map +0 -1
  126. package/dist/components/drawer/snice-drawer.d.ts +0 -37
  127. package/dist/components/drawer/snice-drawer.js +0 -335
  128. package/dist/components/drawer/snice-drawer.js.map +0 -1
  129. package/dist/components/drawer/snice-drawer.types.d.ts +0 -16
  130. package/dist/components/drawer/snice-drawer.types.js +0 -2
  131. package/dist/components/drawer/snice-drawer.types.js.map +0 -1
  132. package/dist/components/input/snice-input.d.ts +0 -65
  133. package/dist/components/input/snice-input.js +0 -603
  134. package/dist/components/input/snice-input.js.map +0 -1
  135. package/dist/components/input/snice-input.types.d.ts +0 -53
  136. package/dist/components/input/snice-input.types.js +0 -2
  137. package/dist/components/input/snice-input.types.js.map +0 -1
  138. package/dist/components/layout/snice-layout-blog.d.ts +0 -4
  139. package/dist/components/layout/snice-layout-blog.js +0 -56
  140. package/dist/components/layout/snice-layout-blog.js.map +0 -1
  141. package/dist/components/layout/snice-layout-card.d.ts +0 -6
  142. package/dist/components/layout/snice-layout-card.js +0 -53
  143. package/dist/components/layout/snice-layout-card.js.map +0 -1
  144. package/dist/components/layout/snice-layout-centered.d.ts +0 -5
  145. package/dist/components/layout/snice-layout-centered.js +0 -38
  146. package/dist/components/layout/snice-layout-centered.js.map +0 -1
  147. package/dist/components/layout/snice-layout-dashboard.d.ts +0 -4
  148. package/dist/components/layout/snice-layout-dashboard.js +0 -53
  149. package/dist/components/layout/snice-layout-dashboard.js.map +0 -1
  150. package/dist/components/layout/snice-layout-fullscreen.d.ts +0 -5
  151. package/dist/components/layout/snice-layout-fullscreen.js +0 -50
  152. package/dist/components/layout/snice-layout-fullscreen.js.map +0 -1
  153. package/dist/components/layout/snice-layout-landing.d.ts +0 -4
  154. package/dist/components/layout/snice-layout-landing.js +0 -55
  155. package/dist/components/layout/snice-layout-landing.js.map +0 -1
  156. package/dist/components/layout/snice-layout-minimal.d.ts +0 -4
  157. package/dist/components/layout/snice-layout-minimal.js +0 -27
  158. package/dist/components/layout/snice-layout-minimal.js.map +0 -1
  159. package/dist/components/layout/snice-layout-sidebar.d.ts +0 -5
  160. package/dist/components/layout/snice-layout-sidebar.js +0 -64
  161. package/dist/components/layout/snice-layout-sidebar.js.map +0 -1
  162. package/dist/components/layout/snice-layout-split.d.ts +0 -6
  163. package/dist/components/layout/snice-layout-split.js +0 -47
  164. package/dist/components/layout/snice-layout-split.js.map +0 -1
  165. package/dist/components/layout/snice-layout.d.ts +0 -4
  166. package/dist/components/layout/snice-layout.js +0 -43
  167. package/dist/components/layout/snice-layout.js.map +0 -1
  168. package/dist/components/layout/snice-layout.types.d.ts +0 -3
  169. package/dist/components/layout/snice-layout.types.js +0 -2
  170. package/dist/components/layout/snice-layout.types.js.map +0 -1
  171. package/dist/components/login/snice-login.d.ts +0 -45
  172. package/dist/components/login/snice-login.js +0 -385
  173. package/dist/components/login/snice-login.js.map +0 -1
  174. package/dist/components/login/snice-login.types.d.ts +0 -31
  175. package/dist/components/login/snice-login.types.js +0 -2
  176. package/dist/components/login/snice-login.types.js.map +0 -1
  177. package/dist/components/modal/snice-modal.d.ts +0 -32
  178. package/dist/components/modal/snice-modal.js +0 -288
  179. package/dist/components/modal/snice-modal.js.map +0 -1
  180. package/dist/components/modal/snice-modal.types.d.ts +0 -18
  181. package/dist/components/modal/snice-modal.types.js +0 -2
  182. package/dist/components/modal/snice-modal.types.js.map +0 -1
  183. package/dist/components/pagination/snice-pagination.d.ts +0 -26
  184. package/dist/components/pagination/snice-pagination.js +0 -373
  185. package/dist/components/pagination/snice-pagination.js.map +0 -1
  186. package/dist/components/pagination/snice-pagination.types.d.ts +0 -18
  187. package/dist/components/pagination/snice-pagination.types.js +0 -2
  188. package/dist/components/pagination/snice-pagination.types.js.map +0 -1
  189. package/dist/components/progress/snice-progress.d.ts +0 -35
  190. package/dist/components/progress/snice-progress.js +0 -295
  191. package/dist/components/progress/snice-progress.js.map +0 -1
  192. package/dist/components/progress/snice-progress.types.d.ts +0 -18
  193. package/dist/components/progress/snice-progress.types.js +0 -2
  194. package/dist/components/progress/snice-progress.types.js.map +0 -1
  195. package/dist/components/radio/snice-radio.d.ts +0 -33
  196. package/dist/components/radio/snice-radio.js +0 -286
  197. package/dist/components/radio/snice-radio.js.map +0 -1
  198. package/dist/components/radio/snice-radio.types.d.ts +0 -19
  199. package/dist/components/radio/snice-radio.types.js +0 -2
  200. package/dist/components/radio/snice-radio.types.js.map +0 -1
  201. package/dist/components/select/snice-option.d.ts +0 -17
  202. package/dist/components/select/snice-option.js +0 -77
  203. package/dist/components/select/snice-option.js.map +0 -1
  204. package/dist/components/select/snice-option.types.d.ts +0 -14
  205. package/dist/components/select/snice-option.types.js +0 -2
  206. package/dist/components/select/snice-option.types.js.map +0 -1
  207. package/dist/components/select/snice-select.d.ts +0 -89
  208. package/dist/components/select/snice-select.js +0 -900
  209. package/dist/components/select/snice-select.js.map +0 -1
  210. package/dist/components/select/snice-select.types.d.ts +0 -49
  211. package/dist/components/select/snice-select.types.js +0 -2
  212. package/dist/components/select/snice-select.types.js.map +0 -1
  213. package/dist/components/skeleton/snice-skeleton.d.ts +0 -16
  214. package/dist/components/skeleton/snice-skeleton.js +0 -159
  215. package/dist/components/skeleton/snice-skeleton.js.map +0 -1
  216. package/dist/components/skeleton/snice-skeleton.types.d.ts +0 -10
  217. package/dist/components/skeleton/snice-skeleton.types.js +0 -2
  218. package/dist/components/skeleton/snice-skeleton.types.js.map +0 -1
  219. package/dist/components/switch/snice-switch.d.ts +0 -38
  220. package/dist/components/switch/snice-switch.js +0 -309
  221. package/dist/components/switch/snice-switch.js.map +0 -1
  222. package/dist/components/switch/snice-switch.types.d.ts +0 -21
  223. package/dist/components/switch/snice-switch.types.js +0 -2
  224. package/dist/components/switch/snice-switch.types.js.map +0 -1
  225. package/dist/components/symbols.d.ts +0 -1
  226. package/dist/components/symbols.js +0 -20
  227. package/dist/components/symbols.js.map +0 -1
  228. package/dist/components/table/snice-cell-boolean.d.ts +0 -21
  229. package/dist/components/table/snice-cell-boolean.js +0 -152
  230. package/dist/components/table/snice-cell-boolean.js.map +0 -1
  231. package/dist/components/table/snice-cell-date.d.ts +0 -24
  232. package/dist/components/table/snice-cell-date.js +0 -240
  233. package/dist/components/table/snice-cell-date.js.map +0 -1
  234. package/dist/components/table/snice-cell-duration.d.ts +0 -16
  235. package/dist/components/table/snice-cell-duration.js +0 -123
  236. package/dist/components/table/snice-cell-duration.js.map +0 -1
  237. package/dist/components/table/snice-cell-filesize.d.ts +0 -16
  238. package/dist/components/table/snice-cell-filesize.js +0 -119
  239. package/dist/components/table/snice-cell-filesize.js.map +0 -1
  240. package/dist/components/table/snice-cell-number.d.ts +0 -23
  241. package/dist/components/table/snice-cell-number.js +0 -202
  242. package/dist/components/table/snice-cell-number.js.map +0 -1
  243. package/dist/components/table/snice-cell-progress.d.ts +0 -17
  244. package/dist/components/table/snice-cell-progress.js +0 -114
  245. package/dist/components/table/snice-cell-progress.js.map +0 -1
  246. package/dist/components/table/snice-cell-rating.d.ts +0 -17
  247. package/dist/components/table/snice-cell-rating.js +0 -113
  248. package/dist/components/table/snice-cell-rating.js.map +0 -1
  249. package/dist/components/table/snice-cell-sparkline.d.ts +0 -29
  250. package/dist/components/table/snice-cell-sparkline.js +0 -290
  251. package/dist/components/table/snice-cell-sparkline.js.map +0 -1
  252. package/dist/components/table/snice-cell-text.d.ts +0 -19
  253. package/dist/components/table/snice-cell-text.js +0 -153
  254. package/dist/components/table/snice-cell-text.js.map +0 -1
  255. package/dist/components/table/snice-cell.d.ts +0 -32
  256. package/dist/components/table/snice-cell.js +0 -451
  257. package/dist/components/table/snice-cell.js.map +0 -1
  258. package/dist/components/table/snice-column.d.ts +0 -62
  259. package/dist/components/table/snice-column.js +0 -440
  260. package/dist/components/table/snice-column.js.map +0 -1
  261. package/dist/components/table/snice-header.d.ts +0 -33
  262. package/dist/components/table/snice-header.js +0 -303
  263. package/dist/components/table/snice-header.js.map +0 -1
  264. package/dist/components/table/snice-progress.d.ts +0 -10
  265. package/dist/components/table/snice-progress.js +0 -91
  266. package/dist/components/table/snice-progress.js.map +0 -1
  267. package/dist/components/table/snice-rating.d.ts +0 -9
  268. package/dist/components/table/snice-rating.js +0 -68
  269. package/dist/components/table/snice-rating.js.map +0 -1
  270. package/dist/components/table/snice-row.d.ts +0 -43
  271. package/dist/components/table/snice-row.js +0 -365
  272. package/dist/components/table/snice-row.js.map +0 -1
  273. package/dist/components/table/snice-table.d.ts +0 -69
  274. package/dist/components/table/snice-table.js +0 -814
  275. package/dist/components/table/snice-table.js.map +0 -1
  276. package/dist/components/table/snice-table.types.d.ts +0 -137
  277. package/dist/components/table/snice-table.types.js +0 -2
  278. package/dist/components/table/snice-table.types.js.map +0 -1
  279. package/dist/components/tabs/snice-tab-panel.d.ts +0 -12
  280. package/dist/components/tabs/snice-tab-panel.js +0 -78
  281. package/dist/components/tabs/snice-tab-panel.js.map +0 -1
  282. package/dist/components/tabs/snice-tab.d.ts +0 -13
  283. package/dist/components/tabs/snice-tab.js +0 -90
  284. package/dist/components/tabs/snice-tab.js.map +0 -1
  285. package/dist/components/tabs/snice-tabs.d.ts +0 -34
  286. package/dist/components/tabs/snice-tabs.js +0 -367
  287. package/dist/components/tabs/snice-tabs.js.map +0 -1
  288. package/dist/components/tabs/snice-tabs.types.d.ts +0 -23
  289. package/dist/components/tabs/snice-tabs.types.js +0 -2
  290. package/dist/components/tabs/snice-tabs.types.js.map +0 -1
  291. package/dist/components/toast/snice-toast-container.d.ts +0 -25
  292. package/dist/components/toast/snice-toast-container.js +0 -251
  293. package/dist/components/toast/snice-toast-container.js.map +0 -1
  294. package/dist/components/toast/snice-toast.d.ts +0 -23
  295. package/dist/components/toast/snice-toast.js +0 -316
  296. package/dist/components/toast/snice-toast.js.map +0 -1
  297. package/dist/components/toast/snice-toast.types.d.ts +0 -30
  298. package/dist/components/toast/snice-toast.types.js +0 -2
  299. package/dist/components/toast/snice-toast.types.js.map +0 -1
  300. package/dist/components/tooltip/snice-tooltip.d.ts +0 -50
  301. package/dist/components/tooltip/snice-tooltip.js +0 -656
  302. package/dist/components/tooltip/snice-tooltip.js.map +0 -1
  303. package/dist/components/tooltip/snice-tooltip.types.d.ts +0 -18
  304. package/dist/components/tooltip/snice-tooltip.types.js +0 -2
  305. package/dist/components/tooltip/snice-tooltip.types.js.map +0 -1
  306. package/dist/components/transitions.d.ts +0 -11
  307. package/dist/components/transitions.js +0 -69
  308. package/dist/components/transitions.js.map +0 -1
  309. package/dist/index.cjs.min +0 -15
  310. package/dist/symbols.cjs +0 -103
  311. package/dist/transitions.cjs +0 -219
@@ -1,656 +0,0 @@
1
- var __decorate = (this && this.__decorate) || function (decorators, target, key, desc) {
2
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
- return c > 3 && r && Object.defineProperty(target, key, r), r;
6
- };
7
- var __metadata = (this && this.__metadata) || function (k, v) {
8
- if (typeof Reflect === "object" && typeof Reflect.metadata === "function") return Reflect.metadata(k, v);
9
- };
10
- var SniceTooltip_1;
11
- import { element, property, query, on, watch, ready, dispose } from 'snice';
12
- import css from './snice-tooltip.css?inline';
13
- import portalCss from './snice-tooltip-portal.css?inline';
14
- let SniceTooltip = SniceTooltip_1 = class SniceTooltip extends HTMLElement {
15
- constructor() {
16
- super(...arguments);
17
- this.content = '';
18
- this.position = 'top';
19
- this.trigger = 'hover';
20
- this.delay = 0;
21
- this.hideDelay = 0;
22
- this.offset = 12;
23
- this.arrow = true;
24
- this.open = false;
25
- this.maxWidth = 250;
26
- this.zIndex = 10000;
27
- this.strictPositioning = false;
28
- this.activePosition = 'top';
29
- this.handleClickOutside = (e) => {
30
- if (!this.contains(e.target)) {
31
- this.hide();
32
- }
33
- };
34
- }
35
- static ensurePortalStyles() {
36
- if (SniceTooltip_1.portalStylesInjected)
37
- return;
38
- try {
39
- // Use Constructable Stylesheets if supported
40
- if ('adoptedStyleSheets' in document && 'CSSStyleSheet' in window) {
41
- const sheet = new CSSStyleSheet();
42
- sheet.replaceSync(portalCss);
43
- document.adoptedStyleSheets = [...document.adoptedStyleSheets, sheet];
44
- }
45
- else {
46
- // Fallback for older browsers
47
- const style = document.createElement('style');
48
- style.textContent = portalCss;
49
- document.head.appendChild(style);
50
- }
51
- SniceTooltip_1.portalStylesInjected = true;
52
- }
53
- catch (error) {
54
- console.warn('Failed to inject tooltip portal styles:', error);
55
- }
56
- }
57
- html() {
58
- return /*html*/ `
59
- <div class="tooltip-trigger">
60
- <slot></slot>
61
- </div>
62
- <div class="tooltip tooltip--${this.position}" role="tooltip" hidden>
63
- <div class="tooltip__content">${this.content}</div>
64
- <div class="tooltip__arrow"></div>
65
- </div>
66
- `;
67
- }
68
- css() {
69
- return css;
70
- }
71
- init() {
72
- if (this.tooltipElement) {
73
- this.tooltipElement.style.setProperty('--tooltip-max-width', `${this.maxWidth}px`);
74
- this.tooltipElement.style.setProperty('--tooltip-z-index', `${this.zIndex}`);
75
- }
76
- if (this.open && this.trigger === 'manual') {
77
- this.show();
78
- }
79
- }
80
- cleanup() {
81
- this.clearTimeouts();
82
- if (this.portalElement) {
83
- this.portalElement.remove();
84
- this.portalElement = undefined;
85
- }
86
- }
87
- updateContent() {
88
- const contentEl = this.shadowRoot?.querySelector('.tooltip__content');
89
- if (contentEl) {
90
- contentEl.textContent = this.content;
91
- }
92
- }
93
- updateArrow() {
94
- if (this.arrowElement) {
95
- if (this.arrow) {
96
- this.arrowElement.removeAttribute('hidden');
97
- }
98
- else {
99
- this.arrowElement.setAttribute('hidden', '');
100
- }
101
- }
102
- }
103
- updateMaxWidth() {
104
- if (this.tooltipElement) {
105
- this.tooltipElement.style.setProperty('--tooltip-max-width', `${this.maxWidth}px`);
106
- }
107
- }
108
- updateZIndex() {
109
- if (this.tooltipElement) {
110
- this.tooltipElement.style.setProperty('--tooltip-z-index', `${this.zIndex}`);
111
- }
112
- }
113
- handleOpenChange() {
114
- if (this.trigger === 'manual') {
115
- if (this.open) {
116
- this.show();
117
- }
118
- else {
119
- this.hide();
120
- }
121
- }
122
- }
123
- handleMouseEnter() {
124
- if (this.trigger === 'hover') {
125
- this.scheduleShow();
126
- }
127
- }
128
- handleMouseLeave() {
129
- if (this.trigger === 'hover') {
130
- this.scheduleHide();
131
- }
132
- }
133
- handleFocusIn() {
134
- if (this.trigger === 'focus') {
135
- this.scheduleShow();
136
- }
137
- }
138
- handleFocusOut() {
139
- if (this.trigger === 'focus') {
140
- this.scheduleHide();
141
- }
142
- }
143
- handleClick() {
144
- if (this.trigger === 'click') {
145
- this.toggle();
146
- }
147
- }
148
- scheduleShow() {
149
- this.clearTimeouts();
150
- if (this.delay > 0) {
151
- this.showTimeout = window.setTimeout(() => this.show(), this.delay);
152
- }
153
- else {
154
- this.show();
155
- }
156
- }
157
- scheduleHide() {
158
- this.clearTimeouts();
159
- if (this.hideDelay > 0) {
160
- this.hideTimeout = window.setTimeout(() => this.hide(), this.hideDelay);
161
- }
162
- else {
163
- this.hide();
164
- }
165
- }
166
- clearTimeouts() {
167
- if (this.showTimeout) {
168
- clearTimeout(this.showTimeout);
169
- this.showTimeout = undefined;
170
- }
171
- if (this.hideTimeout) {
172
- clearTimeout(this.hideTimeout);
173
- this.hideTimeout = undefined;
174
- }
175
- }
176
- show() {
177
- if (!this.content)
178
- return;
179
- // Ensure portal styles are injected
180
- SniceTooltip_1.ensurePortalStyles();
181
- // Create portal element if it doesn't exist
182
- if (!this.portalElement) {
183
- this.portalElement = this.createPortalElement();
184
- this.updateArrowStyles(this.position);
185
- }
186
- this.portalElement.style.display = 'block';
187
- this.updatePortalContent();
188
- // Force reflow before adding visible class
189
- void this.portalElement.offsetHeight;
190
- this.updatePosition();
191
- this.portalElement.classList.add('snice-tooltip--visible');
192
- if (this.trigger === 'click') {
193
- // Add click outside listener
194
- setTimeout(() => {
195
- document.addEventListener('click', this.handleClickOutside);
196
- }, 0);
197
- }
198
- }
199
- hide() {
200
- if (!this.portalElement)
201
- return;
202
- this.portalElement.classList.remove('snice-tooltip--visible');
203
- setTimeout(() => {
204
- if (this.portalElement) {
205
- this.portalElement.style.display = 'none';
206
- }
207
- }, 200); // Match transition duration
208
- if (this.trigger === 'click') {
209
- document.removeEventListener('click', this.handleClickOutside);
210
- }
211
- }
212
- toggle() {
213
- if (!this.portalElement || this.portalElement.style.display === 'none') {
214
- this.show();
215
- }
216
- else {
217
- this.hide();
218
- }
219
- }
220
- updatePosition() {
221
- if (!this.portalElement)
222
- return;
223
- // Make sure tooltip is visible but off-screen to get accurate dimensions
224
- this.portalElement.style.visibility = 'hidden';
225
- this.portalElement.style.left = '-9999px';
226
- this.portalElement.style.top = '-9999px';
227
- const triggerRect = this.getBoundingClientRect();
228
- const tooltipRect = this.portalElement.getBoundingClientRect();
229
- // Restore visibility
230
- this.portalElement.style.visibility = '';
231
- // Calculate position with smart viewport detection
232
- const position = this.calculatePosition(triggerRect, tooltipRect);
233
- // Update tooltip position class if it changed
234
- if (position.adjustedPosition !== this.activePosition) {
235
- this.portalElement.classList.remove(`snice-tooltip--${this.activePosition}`);
236
- this.portalElement.classList.add(`snice-tooltip--${position.adjustedPosition}`);
237
- this.activePosition = position.adjustedPosition;
238
- // Update arrow styles for new position
239
- this.updateArrowStyles(position.adjustedPosition);
240
- }
241
- // Apply calculated position
242
- this.portalElement.style.left = `${position.left}px`;
243
- this.portalElement.style.top = `${position.top}px`;
244
- }
245
- updateArrowStyles(position) {
246
- if (!this.portalElement || !this.arrow)
247
- return;
248
- const arrow = this.portalElement.querySelector('.snice-tooltip__arrow');
249
- if (!arrow)
250
- return;
251
- // Reset styles - set to explicit values instead of empty strings
252
- arrow.style.top = 'auto';
253
- arrow.style.bottom = 'auto';
254
- arrow.style.left = 'auto';
255
- arrow.style.right = 'auto';
256
- arrow.style.transform = 'none';
257
- arrow.style.borderTopColor = 'transparent';
258
- arrow.style.borderBottomColor = 'transparent';
259
- arrow.style.borderLeftColor = 'transparent';
260
- arrow.style.borderRightColor = 'transparent';
261
- // Apply position-specific styles
262
- switch (position) {
263
- case 'top':
264
- case 'top-start':
265
- case 'top-end':
266
- arrow.style.bottom = '-6px';
267
- arrow.style.borderWidth = '6px 6px 0';
268
- arrow.style.borderTopColor = '#333';
269
- arrow.style.borderLeftColor = 'transparent';
270
- arrow.style.borderRightColor = 'transparent';
271
- if (position === 'top') {
272
- arrow.style.left = '50%';
273
- arrow.style.transform = 'translateX(-50%)';
274
- }
275
- else if (position === 'top-start') {
276
- arrow.style.left = '16px';
277
- }
278
- else {
279
- arrow.style.right = '16px';
280
- }
281
- break;
282
- case 'bottom':
283
- case 'bottom-start':
284
- case 'bottom-end':
285
- arrow.style.top = '-6px';
286
- arrow.style.borderWidth = '0 6px 6px';
287
- arrow.style.borderBottomColor = '#333';
288
- arrow.style.borderLeftColor = 'transparent';
289
- arrow.style.borderRightColor = 'transparent';
290
- if (position === 'bottom') {
291
- arrow.style.left = '50%';
292
- arrow.style.transform = 'translateX(-50%)';
293
- }
294
- else if (position === 'bottom-start') {
295
- arrow.style.left = '16px';
296
- }
297
- else {
298
- arrow.style.right = '16px';
299
- }
300
- break;
301
- case 'left':
302
- case 'left-start':
303
- case 'left-end':
304
- arrow.style.right = '-6px';
305
- arrow.style.borderWidth = '6px 0 6px 6px';
306
- arrow.style.borderLeftColor = '#333';
307
- arrow.style.borderTopColor = 'transparent';
308
- arrow.style.borderBottomColor = 'transparent';
309
- if (position === 'left') {
310
- arrow.style.top = '50%';
311
- arrow.style.transform = 'translateY(-50%)';
312
- }
313
- else if (position === 'left-start') {
314
- arrow.style.top = '16px';
315
- }
316
- else {
317
- arrow.style.bottom = '16px';
318
- }
319
- break;
320
- case 'right':
321
- case 'right-start':
322
- case 'right-end':
323
- arrow.style.left = '-6px';
324
- arrow.style.borderWidth = '6px 6px 6px 0';
325
- arrow.style.borderRightColor = '#333';
326
- arrow.style.borderTopColor = 'transparent';
327
- arrow.style.borderBottomColor = 'transparent';
328
- if (position === 'right') {
329
- arrow.style.top = '50%';
330
- arrow.style.transform = 'translateY(-50%)';
331
- }
332
- else if (position === 'right-start') {
333
- arrow.style.top = '16px';
334
- }
335
- else {
336
- arrow.style.bottom = '16px';
337
- }
338
- break;
339
- }
340
- }
341
- calculatePosition(triggerRect, tooltipRect) {
342
- const viewport = {
343
- width: window.innerWidth,
344
- height: window.innerHeight,
345
- scrollX: window.scrollX,
346
- scrollY: window.scrollY
347
- };
348
- let position = this.position;
349
- let left = 0;
350
- let top = 0;
351
- // Calculate base position
352
- const positions = this.getPositionCoordinates(triggerRect, tooltipRect, position);
353
- left = positions.left;
354
- top = positions.top;
355
- // If strict positioning is disabled, check if tooltip fits in viewport
356
- if (!this.strictPositioning) {
357
- const fitsInViewport = left >= 0 &&
358
- top >= 0 &&
359
- left + tooltipRect.width <= viewport.width &&
360
- top + tooltipRect.height <= viewport.height;
361
- // If it doesn't fit, try alternative positions
362
- if (!fitsInViewport) {
363
- const alternativePositions = this.getAlternativePositions(position);
364
- for (const altPosition of alternativePositions) {
365
- const altCoords = this.getPositionCoordinates(triggerRect, tooltipRect, altPosition);
366
- if (altCoords.left >= 0 &&
367
- altCoords.top >= 0 &&
368
- altCoords.left + tooltipRect.width <= viewport.width &&
369
- altCoords.top + tooltipRect.height <= viewport.height) {
370
- position = altPosition;
371
- left = altCoords.left;
372
- top = altCoords.top;
373
- break;
374
- }
375
- }
376
- }
377
- }
378
- return { left, top, adjustedPosition: position };
379
- }
380
- getPositionCoordinates(triggerRect, tooltipRect, position) {
381
- let left = 0;
382
- let top = 0;
383
- const centerX = triggerRect.left + triggerRect.width / 2;
384
- const centerY = triggerRect.top + triggerRect.height / 2;
385
- // Different offsets for different directions
386
- // Left/right need more spacing, top/bottom need less
387
- const arrowSize = this.arrow ? 6 : 0;
388
- const verticalOffset = this.offset; // Just base offset for top/bottom
389
- const horizontalOffset = this.offset + arrowSize; // More offset for left/right
390
- switch (position) {
391
- case 'top':
392
- left = centerX - tooltipRect.width / 2;
393
- top = triggerRect.top - tooltipRect.height - verticalOffset;
394
- break;
395
- case 'top-start':
396
- left = triggerRect.left;
397
- top = triggerRect.top - tooltipRect.height - verticalOffset;
398
- break;
399
- case 'top-end':
400
- left = triggerRect.right - tooltipRect.width;
401
- top = triggerRect.top - tooltipRect.height - verticalOffset;
402
- break;
403
- case 'bottom':
404
- left = centerX - tooltipRect.width / 2;
405
- top = triggerRect.bottom + verticalOffset;
406
- break;
407
- case 'bottom-start':
408
- left = triggerRect.left;
409
- top = triggerRect.bottom + verticalOffset;
410
- break;
411
- case 'bottom-end':
412
- left = triggerRect.right - tooltipRect.width;
413
- top = triggerRect.bottom + verticalOffset;
414
- break;
415
- case 'left':
416
- left = triggerRect.left - tooltipRect.width - horizontalOffset;
417
- top = centerY - tooltipRect.height / 2;
418
- break;
419
- case 'left-start':
420
- left = triggerRect.left - tooltipRect.width - horizontalOffset;
421
- top = triggerRect.top;
422
- break;
423
- case 'left-end':
424
- left = triggerRect.left - tooltipRect.width - horizontalOffset;
425
- top = triggerRect.bottom - tooltipRect.height;
426
- break;
427
- case 'right':
428
- left = triggerRect.right + horizontalOffset;
429
- top = centerY - tooltipRect.height / 2;
430
- break;
431
- case 'right-start':
432
- left = triggerRect.right + horizontalOffset;
433
- top = triggerRect.top;
434
- break;
435
- case 'right-end':
436
- left = triggerRect.right + horizontalOffset;
437
- top = triggerRect.bottom - tooltipRect.height;
438
- break;
439
- }
440
- return { left, top };
441
- }
442
- getAlternativePositions(position) {
443
- const opposites = {
444
- 'top': ['bottom', 'left', 'right'],
445
- 'top-start': ['bottom-start', 'left', 'right'],
446
- 'top-end': ['bottom-end', 'left', 'right'],
447
- 'bottom': ['top', 'left', 'right'],
448
- 'bottom-start': ['top-start', 'left', 'right'],
449
- 'bottom-end': ['top-end', 'left', 'right'],
450
- 'left': ['right', 'top', 'bottom'],
451
- 'left-start': ['right-start', 'top', 'bottom'],
452
- 'left-end': ['right-end', 'top', 'bottom'],
453
- 'right': ['left', 'top', 'bottom'],
454
- 'right-start': ['left-start', 'top', 'bottom'],
455
- 'right-end': ['left-end', 'top', 'bottom']
456
- };
457
- return opposites[position] || ['top', 'bottom', 'left', 'right'];
458
- }
459
- createPortalElement() {
460
- const portal = document.createElement('div');
461
- portal.className = `snice-tooltip snice-tooltip--${this.position}`;
462
- portal.setAttribute('role', 'tooltip');
463
- portal.style.cssText = `
464
- position: fixed;
465
- z-index: ${this.zIndex};
466
- padding: 8px 12px;
467
- background: #333;
468
- color: white;
469
- border-radius: 6px;
470
- font-size: 14px;
471
- line-height: 1.4;
472
- max-width: ${this.maxWidth}px;
473
- width: max-content;
474
- pointer-events: none;
475
- opacity: 0;
476
- transform: scale(0.95);
477
- transition: opacity 0.2s, transform 0.2s;
478
- box-shadow: 0 2px 8px rgba(0, 0, 0, 0.15);
479
- display: none;
480
- `;
481
- // Create content element
482
- const content = document.createElement('div');
483
- content.className = 'snice-tooltip__content';
484
- portal.appendChild(content);
485
- // Create arrow element if needed
486
- if (this.arrow) {
487
- const arrow = document.createElement('div');
488
- arrow.className = 'snice-tooltip__arrow';
489
- arrow.style.cssText = `
490
- position: absolute;
491
- width: 0;
492
- height: 0;
493
- border-style: solid;
494
- `;
495
- portal.appendChild(arrow);
496
- }
497
- // Add to body
498
- document.body.appendChild(portal);
499
- return portal;
500
- }
501
- updatePortalContent() {
502
- if (!this.portalElement)
503
- return;
504
- const content = this.portalElement.querySelector('.snice-tooltip__content');
505
- if (content) {
506
- content.textContent = this.content;
507
- }
508
- // Update or create arrow if needed
509
- let arrow = this.portalElement.querySelector('.snice-tooltip__arrow');
510
- if (this.arrow && !arrow) {
511
- // Create arrow if it doesn't exist but should
512
- arrow = document.createElement('div');
513
- arrow.className = 'snice-tooltip__arrow';
514
- arrow.style.cssText = `
515
- position: absolute;
516
- width: 0;
517
- height: 0;
518
- border-style: solid;
519
- `;
520
- this.portalElement.appendChild(arrow);
521
- }
522
- else if (arrow) {
523
- arrow.style.display = this.arrow ? '' : 'none';
524
- }
525
- }
526
- };
527
- SniceTooltip.portalStylesInjected = false;
528
- __decorate([
529
- property({ reflect: true }),
530
- __metadata("design:type", String)
531
- ], SniceTooltip.prototype, "content", void 0);
532
- __decorate([
533
- property({ reflect: true }),
534
- __metadata("design:type", String)
535
- ], SniceTooltip.prototype, "position", void 0);
536
- __decorate([
537
- property({ reflect: true }),
538
- __metadata("design:type", String)
539
- ], SniceTooltip.prototype, "trigger", void 0);
540
- __decorate([
541
- property({ type: Number, reflect: true }),
542
- __metadata("design:type", Number)
543
- ], SniceTooltip.prototype, "delay", void 0);
544
- __decorate([
545
- property({ type: Number, attribute: 'hide-delay', reflect: true }),
546
- __metadata("design:type", Number)
547
- ], SniceTooltip.prototype, "hideDelay", void 0);
548
- __decorate([
549
- property({ type: Number, reflect: true }),
550
- __metadata("design:type", Number)
551
- ], SniceTooltip.prototype, "offset", void 0);
552
- __decorate([
553
- property({ type: Boolean, reflect: true }),
554
- __metadata("design:type", Boolean)
555
- ], SniceTooltip.prototype, "arrow", void 0);
556
- __decorate([
557
- property({ type: Boolean, reflect: true }),
558
- __metadata("design:type", Boolean)
559
- ], SniceTooltip.prototype, "open", void 0);
560
- __decorate([
561
- property({ type: Number, attribute: 'max-width', reflect: true }),
562
- __metadata("design:type", Number)
563
- ], SniceTooltip.prototype, "maxWidth", void 0);
564
- __decorate([
565
- property({ type: Number, attribute: 'z-index', reflect: true }),
566
- __metadata("design:type", Number)
567
- ], SniceTooltip.prototype, "zIndex", void 0);
568
- __decorate([
569
- property({ type: Boolean, attribute: 'strict-positioning', reflect: true }),
570
- __metadata("design:type", Boolean)
571
- ], SniceTooltip.prototype, "strictPositioning", void 0);
572
- __decorate([
573
- query('.tooltip'),
574
- __metadata("design:type", HTMLElement)
575
- ], SniceTooltip.prototype, "tooltipElement", void 0);
576
- __decorate([
577
- query('.tooltip__arrow'),
578
- __metadata("design:type", HTMLElement)
579
- ], SniceTooltip.prototype, "arrowElement", void 0);
580
- __decorate([
581
- ready(),
582
- __metadata("design:type", Function),
583
- __metadata("design:paramtypes", []),
584
- __metadata("design:returntype", void 0)
585
- ], SniceTooltip.prototype, "init", null);
586
- __decorate([
587
- dispose(),
588
- __metadata("design:type", Function),
589
- __metadata("design:paramtypes", []),
590
- __metadata("design:returntype", void 0)
591
- ], SniceTooltip.prototype, "cleanup", null);
592
- __decorate([
593
- watch('content'),
594
- __metadata("design:type", Function),
595
- __metadata("design:paramtypes", []),
596
- __metadata("design:returntype", void 0)
597
- ], SniceTooltip.prototype, "updateContent", null);
598
- __decorate([
599
- watch('arrow'),
600
- __metadata("design:type", Function),
601
- __metadata("design:paramtypes", []),
602
- __metadata("design:returntype", void 0)
603
- ], SniceTooltip.prototype, "updateArrow", null);
604
- __decorate([
605
- watch('maxWidth'),
606
- __metadata("design:type", Function),
607
- __metadata("design:paramtypes", []),
608
- __metadata("design:returntype", void 0)
609
- ], SniceTooltip.prototype, "updateMaxWidth", null);
610
- __decorate([
611
- watch('zIndex'),
612
- __metadata("design:type", Function),
613
- __metadata("design:paramtypes", []),
614
- __metadata("design:returntype", void 0)
615
- ], SniceTooltip.prototype, "updateZIndex", null);
616
- __decorate([
617
- watch('open'),
618
- __metadata("design:type", Function),
619
- __metadata("design:paramtypes", []),
620
- __metadata("design:returntype", void 0)
621
- ], SniceTooltip.prototype, "handleOpenChange", null);
622
- __decorate([
623
- on('mouseenter'),
624
- __metadata("design:type", Function),
625
- __metadata("design:paramtypes", []),
626
- __metadata("design:returntype", void 0)
627
- ], SniceTooltip.prototype, "handleMouseEnter", null);
628
- __decorate([
629
- on('mouseleave'),
630
- __metadata("design:type", Function),
631
- __metadata("design:paramtypes", []),
632
- __metadata("design:returntype", void 0)
633
- ], SniceTooltip.prototype, "handleMouseLeave", null);
634
- __decorate([
635
- on('focusin'),
636
- __metadata("design:type", Function),
637
- __metadata("design:paramtypes", []),
638
- __metadata("design:returntype", void 0)
639
- ], SniceTooltip.prototype, "handleFocusIn", null);
640
- __decorate([
641
- on('focusout'),
642
- __metadata("design:type", Function),
643
- __metadata("design:paramtypes", []),
644
- __metadata("design:returntype", void 0)
645
- ], SniceTooltip.prototype, "handleFocusOut", null);
646
- __decorate([
647
- on('click'),
648
- __metadata("design:type", Function),
649
- __metadata("design:paramtypes", []),
650
- __metadata("design:returntype", void 0)
651
- ], SniceTooltip.prototype, "handleClick", null);
652
- SniceTooltip = SniceTooltip_1 = __decorate([
653
- element('snice-tooltip')
654
- ], SniceTooltip);
655
- export { SniceTooltip };
656
- //# sourceMappingURL=snice-tooltip.js.map