snice 1.14.3 → 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 (185) hide show
  1. package/bin/templates/base/tsconfig.json +5 -4
  2. package/components/accordion/demo.html +403 -0
  3. package/components/accordion/snice-accordion-item.css +85 -0
  4. package/components/accordion/snice-accordion-item.ts +226 -0
  5. package/components/accordion/snice-accordion.css +31 -0
  6. package/components/accordion/snice-accordion.ts +182 -0
  7. package/components/accordion/snice-accordion.types.ts +32 -0
  8. package/components/alert/demo.html +445 -0
  9. package/components/alert/snice-alert.css +195 -0
  10. package/components/alert/snice-alert.ts +141 -0
  11. package/components/alert/snice-alert.types.ts +12 -0
  12. package/components/avatar/demo.html +598 -0
  13. package/components/avatar/snice-avatar.css +131 -0
  14. package/components/avatar/snice-avatar.ts +136 -0
  15. package/components/avatar/snice-avatar.types.ts +13 -0
  16. package/components/badge/demo.html +523 -0
  17. package/components/badge/snice-badge.css +161 -0
  18. package/components/badge/snice-badge.ts +117 -0
  19. package/components/badge/snice-badge.types.ts +16 -0
  20. package/components/breadcrumbs/demo.html +404 -0
  21. package/components/breadcrumbs/snice-breadcrumbs.css +133 -0
  22. package/components/breadcrumbs/snice-breadcrumbs.ts +191 -0
  23. package/components/breadcrumbs/snice-breadcrumbs.types.ts +26 -0
  24. package/components/breadcrumbs/snice-crumb.ts +26 -0
  25. package/components/button/demo.html +42 -0
  26. package/components/button/snice-button.css +230 -0
  27. package/components/button/snice-button.ts +169 -0
  28. package/components/button/snice-button.types.ts +25 -0
  29. package/components/card/demo.html +525 -0
  30. package/components/card/snice-card.css +140 -0
  31. package/components/card/snice-card.ts +102 -0
  32. package/components/card/snice-card.types.ts +10 -0
  33. package/components/checkbox/demo.html +253 -0
  34. package/components/checkbox/snice-checkbox.css +164 -0
  35. package/components/checkbox/snice-checkbox.ts +223 -0
  36. package/components/checkbox/snice-checkbox.types.ts +22 -0
  37. package/components/chip/demo.html +383 -0
  38. package/components/chip/snice-chip.css +195 -0
  39. package/components/chip/snice-chip.ts +139 -0
  40. package/components/chip/snice-chip.types.ts +15 -0
  41. package/components/date-picker/README.md +233 -0
  42. package/components/date-picker/demo.html +191 -0
  43. package/components/date-picker/snice-date-picker.css +330 -0
  44. package/components/date-picker/snice-date-picker.ts +777 -0
  45. package/components/date-picker/snice-date-picker.types.ts +83 -0
  46. package/components/divider/demo.html +233 -0
  47. package/components/divider/snice-divider.css +155 -0
  48. package/components/divider/snice-divider.ts +69 -0
  49. package/components/divider/snice-divider.types.ts +15 -0
  50. package/components/drawer/demo.html +328 -0
  51. package/components/drawer/snice-drawer.css +476 -0
  52. package/components/drawer/snice-drawer.ts +287 -0
  53. package/components/drawer/snice-drawer.types.ts +17 -0
  54. package/components/global.d.ts +14 -0
  55. package/components/input/demo.html +303 -0
  56. package/components/input/snice-input.css +257 -0
  57. package/components/input/snice-input.ts +442 -0
  58. package/components/input/snice-input.types.ts +59 -0
  59. package/components/input/test.html +77 -0
  60. package/components/layout/README.md +260 -0
  61. package/components/layout/demo.html +538 -0
  62. package/components/layout/snice-layout-blog.css +129 -0
  63. package/components/layout/snice-layout-blog.ts +48 -0
  64. package/components/layout/snice-layout-card.css +104 -0
  65. package/components/layout/snice-layout-card.ts +35 -0
  66. package/components/layout/snice-layout-centered.css +51 -0
  67. package/components/layout/snice-layout-centered.ts +22 -0
  68. package/components/layout/snice-layout-dashboard.css +98 -0
  69. package/components/layout/snice-layout-dashboard.ts +45 -0
  70. package/components/layout/snice-layout-fullscreen.css +72 -0
  71. package/components/layout/snice-layout-fullscreen.ts +34 -0
  72. package/components/layout/snice-layout-landing.css +92 -0
  73. package/components/layout/snice-layout-landing.ts +47 -0
  74. package/components/layout/snice-layout-minimal.css +16 -0
  75. package/components/layout/snice-layout-minimal.ts +19 -0
  76. package/components/layout/snice-layout-sidebar.css +117 -0
  77. package/components/layout/snice-layout-sidebar.ts +48 -0
  78. package/components/layout/snice-layout-split.css +103 -0
  79. package/components/layout/snice-layout-split.ts +29 -0
  80. package/components/layout/snice-layout.css +72 -0
  81. package/components/layout/snice-layout.ts +35 -0
  82. package/components/layout/snice-layout.types.ts +5 -0
  83. package/components/login/demo-auth-controller.ts +185 -0
  84. package/components/login/demo.html +470 -0
  85. package/components/login/snice-login.css +204 -0
  86. package/components/login/snice-login.ts +337 -0
  87. package/components/login/snice-login.types.ts +34 -0
  88. package/components/modal/demo.html +291 -0
  89. package/components/modal/snice-modal.css +203 -0
  90. package/components/modal/snice-modal.ts +233 -0
  91. package/components/modal/snice-modal.types.ts +21 -0
  92. package/components/pagination/demo.html +395 -0
  93. package/components/pagination/snice-pagination.ts +333 -0
  94. package/components/pagination/snice-pagination.types.ts +21 -0
  95. package/components/progress/demo.html +510 -0
  96. package/components/progress/snice-progress.css +267 -0
  97. package/components/progress/snice-progress.ts +247 -0
  98. package/components/progress/snice-progress.types.ts +19 -0
  99. package/components/radio/demo.html +287 -0
  100. package/components/radio/snice-radio.css +171 -0
  101. package/components/radio/snice-radio.ts +218 -0
  102. package/components/radio/snice-radio.types.ts +21 -0
  103. package/components/select/demo.html +511 -0
  104. package/components/select/snice-option.ts +52 -0
  105. package/components/select/snice-option.types.ts +14 -0
  106. package/components/select/snice-select.css +392 -0
  107. package/components/select/snice-select.ts +796 -0
  108. package/components/select/snice-select.types.ts +55 -0
  109. package/components/skeleton/demo.html +514 -0
  110. package/components/skeleton/snice-skeleton.css +109 -0
  111. package/components/skeleton/snice-skeleton.ts +126 -0
  112. package/components/skeleton/snice-skeleton.types.ts +11 -0
  113. package/components/switch/demo.html +284 -0
  114. package/components/switch/snice-switch.css +221 -0
  115. package/components/switch/snice-switch.ts +229 -0
  116. package/components/switch/snice-switch.types.ts +23 -0
  117. package/components/symbols.ts +23 -0
  118. package/components/table/demo-table-controller.ts +100 -0
  119. package/components/table/demo.html +480 -0
  120. package/components/table/snice-cell-boolean.ts +112 -0
  121. package/components/table/snice-cell-date.ts +210 -0
  122. package/components/table/snice-cell-duration.ts +91 -0
  123. package/components/table/snice-cell-filesize.ts +90 -0
  124. package/components/table/snice-cell-number.ts +165 -0
  125. package/components/table/snice-cell-progress.ts +83 -0
  126. package/components/table/snice-cell-rating.ts +82 -0
  127. package/components/table/snice-cell-sparkline.ts +253 -0
  128. package/components/table/snice-cell-text.ts +125 -0
  129. package/components/table/snice-cell.css +296 -0
  130. package/components/table/snice-cell.ts +473 -0
  131. package/components/table/snice-column.ts +353 -0
  132. package/components/table/snice-header.css +243 -0
  133. package/components/table/snice-header.ts +261 -0
  134. package/components/table/snice-progress.ts +66 -0
  135. package/components/table/snice-rating.ts +45 -0
  136. package/components/table/snice-row.css +255 -0
  137. package/components/table/snice-row.ts +331 -0
  138. package/components/table/snice-table.css +241 -0
  139. package/components/table/snice-table.ts +737 -0
  140. package/components/table/snice-table.types.ts +158 -0
  141. package/components/tabs/demo.html +487 -0
  142. package/components/tabs/snice-tab-panel.css +264 -0
  143. package/components/tabs/snice-tab-panel.ts +47 -0
  144. package/components/tabs/snice-tab.css +96 -0
  145. package/components/tabs/snice-tab.ts +65 -0
  146. package/components/tabs/snice-tabs.css +189 -0
  147. package/components/tabs/snice-tabs.ts +332 -0
  148. package/components/tabs/snice-tabs.types.ts +28 -0
  149. package/components/theme/theme.css +234 -0
  150. package/components/toast/demo.html +329 -0
  151. package/components/toast/snice-toast-container.ts +256 -0
  152. package/components/toast/snice-toast.css +213 -0
  153. package/components/toast/snice-toast.ts +276 -0
  154. package/components/toast/snice-toast.types.ts +35 -0
  155. package/components/tooltip/demo.html +350 -0
  156. package/components/tooltip/snice-tooltip-portal.css +79 -0
  157. package/components/tooltip/snice-tooltip.css +117 -0
  158. package/components/tooltip/snice-tooltip.ts +612 -0
  159. package/components/tooltip/snice-tooltip.types.ts +32 -0
  160. package/components/transitions.ts +94 -0
  161. package/components/tsconfig.json +18 -0
  162. package/dist/index.cjs +441 -329
  163. package/dist/index.cjs.map +1 -1
  164. package/dist/index.cjs.min.map +1 -1
  165. package/dist/index.esm.js +441 -329
  166. package/dist/index.esm.js.map +1 -1
  167. package/dist/index.esm.min.js +3 -3
  168. package/dist/index.esm.min.js.map +1 -1
  169. package/dist/index.iife.js +441 -329
  170. package/dist/index.iife.js.map +1 -1
  171. package/dist/index.iife.min.js +3 -3
  172. package/dist/index.iife.min.js.map +1 -1
  173. package/dist/symbols.esm.js +1 -1
  174. package/dist/transitions.esm.js +1 -1
  175. package/dist/types/controller.d.ts +1 -1
  176. package/dist/types/element.d.ts +10 -10
  177. package/dist/types/events.d.ts +2 -2
  178. package/dist/types/index.d.ts +1 -1
  179. package/dist/types/observe.d.ts +1 -1
  180. package/dist/types/request-response.d.ts +2 -3
  181. package/dist/types/router.d.ts +1 -1
  182. package/package.json +9 -3
  183. package/dist/index.cjs.min +0 -15
  184. package/dist/symbols.cjs +0 -103
  185. package/dist/transitions.cjs +0 -219
@@ -0,0 +1,141 @@
1
+ import { element, property, watch, query, on, dispatch, part } from 'snice';
2
+ import css from './snice-alert.css?inline';
3
+ import type { AlertVariant, AlertSize, SniceAlertElement } from './snice-alert.types';
4
+
5
+ @element('snice-alert')
6
+ export class SniceAlert extends HTMLElement implements SniceAlertElement {
7
+ @property({ reflect: true })
8
+ variant: AlertVariant = 'info';
9
+
10
+ @property({ reflect: true })
11
+ size: AlertSize = 'medium';
12
+
13
+ @property({ reflect: true })
14
+ title = '';
15
+
16
+ @property({ type: Boolean, reflect: true })
17
+ dismissible = false;
18
+
19
+ @property({ reflect: true })
20
+ icon = '';
21
+
22
+ @query('.alert')
23
+ alertElement?: HTMLElement;
24
+
25
+ private isHidden = false;
26
+
27
+ html() {
28
+ return /*html*/`
29
+ <div class="alert ${this.isHidden ? 'alert--hidden' : ''}" role="alert" aria-live="polite">
30
+ <div part="icon-section"></div>
31
+ <div class="alert-content">
32
+ <div part="title-section"></div>
33
+ <div part="description-section"></div>
34
+ </div>
35
+ <div part="dismiss-section"></div>
36
+ </div>
37
+ `;
38
+ }
39
+
40
+ @part('icon-section')
41
+ renderIconSection() {
42
+ const hasIcon = this.icon || this.shouldShowDefaultIcon();
43
+ return hasIcon ? /*html*/`
44
+ <div class="alert-icon ${!this.icon ? 'alert-icon--default' : ''}">
45
+ ${this.icon || ''}
46
+ </div>
47
+ ` : '';
48
+ }
49
+
50
+ @watch('title')
51
+ @part('title-section')
52
+ renderTitleSection() {
53
+ return this.title ? /*html*/`
54
+ <div class="alert-title">${this.title}</div>
55
+ ` : '';
56
+ }
57
+
58
+ @part('description-section')
59
+ renderDescriptionSection() {
60
+ return /*html*/`
61
+ <div class="alert-description">
62
+ <slot></slot>
63
+ </div>
64
+ `;
65
+ }
66
+
67
+ @watch('dismissible')
68
+ @part('dismiss-section')
69
+ renderDismissSection() {
70
+ return this.dismissible ? /*html*/`
71
+ <button class="alert-dismiss" type="button" aria-label="Dismiss alert">
72
+ <svg viewBox="0 0 24 24" fill="currentColor">
73
+ <path d="M19 6.41L17.59 5L12 10.59L6.41 5L5 6.41L10.59 12L5 17.59L6.41 19L12 13.41L17.59 19L19 17.59L13.41 12L19 6.41Z"/>
74
+ </svg>
75
+ </button>
76
+ ` : '';
77
+ }
78
+
79
+ css() {
80
+ return css;
81
+ }
82
+
83
+ private shouldShowDefaultIcon(): boolean {
84
+ // Show default icons for variants unless explicitly disabled
85
+ return this.icon !== 'none';
86
+ }
87
+
88
+
89
+ @on('click', '.alert-dismiss')
90
+ @dispatch('alert-dismiss')
91
+ handleDismiss() {
92
+ this.hide();
93
+ return {
94
+ variant: this.variant,
95
+ title: this.title
96
+ };
97
+ }
98
+
99
+ @on('animationend', '.alert')
100
+ handleAnimationEnd(event: AnimationEvent) {
101
+ if (event.animationName === 'slideOut') {
102
+ this.isHidden = true;
103
+ if (this.alertElement) {
104
+ this.alertElement.classList.add('alert--hidden');
105
+ this.alertElement.classList.remove('alert--hiding');
106
+ }
107
+ this.dispatchAlertHidden();
108
+ }
109
+ }
110
+
111
+ @dispatch('alert-hidden')
112
+ private dispatchAlertHidden() {
113
+ return {
114
+ variant: this.variant,
115
+ title: this.title
116
+ };
117
+ }
118
+
119
+ @dispatch('alert-shown')
120
+ private dispatchAlertShown() {
121
+ return {
122
+ variant: this.variant,
123
+ title: this.title
124
+ };
125
+ }
126
+
127
+ show() {
128
+ this.isHidden = false;
129
+ if (this.alertElement) {
130
+ this.alertElement.classList.remove('alert--hidden', 'alert--hiding');
131
+ }
132
+ this.dispatchAlertShown();
133
+ }
134
+
135
+ hide() {
136
+ if (this.alertElement && !this.isHidden) {
137
+ this.alertElement.classList.add('alert--hiding');
138
+ }
139
+ }
140
+
141
+ }
@@ -0,0 +1,12 @@
1
+ export type AlertVariant = 'info' | 'success' | 'warning' | 'error';
2
+ export type AlertSize = 'small' | 'medium' | 'large';
3
+
4
+ export interface SniceAlertElement extends HTMLElement {
5
+ variant: AlertVariant;
6
+ size: AlertSize;
7
+ title: string;
8
+ dismissible: boolean;
9
+ icon: string;
10
+ show(): void;
11
+ hide(): void;
12
+ }