snice 3.1.0 → 3.2.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 (217) hide show
  1. package/README.md +90 -41
  2. package/dist/components/accordion/snice-accordion-item.js +1 -1
  3. package/dist/components/accordion/snice-accordion-item.js.map +1 -1
  4. package/dist/components/accordion/snice-accordion.js +1 -1
  5. package/dist/components/accordion/snice-accordion.js.map +1 -1
  6. package/dist/components/alert/snice-alert.js +1 -1
  7. package/dist/components/alert/snice-alert.js.map +1 -1
  8. package/dist/components/avatar/snice-avatar.js +1 -1
  9. package/dist/components/avatar/snice-avatar.js.map +1 -1
  10. package/dist/components/badge/snice-badge.js +1 -1
  11. package/dist/components/badge/snice-badge.js.map +1 -1
  12. package/dist/components/banner/snice-banner.d.ts +22 -0
  13. package/dist/components/banner/snice-banner.js +180 -0
  14. package/dist/components/banner/snice-banner.js.map +1 -0
  15. package/dist/components/banner/snice-banner.types.d.ts +14 -0
  16. package/dist/components/breadcrumbs/snice-breadcrumbs.js +1 -1
  17. package/dist/components/breadcrumbs/snice-breadcrumbs.js.map +1 -1
  18. package/dist/components/button/snice-button.js +1 -1
  19. package/dist/components/button/snice-button.js.map +1 -1
  20. package/dist/components/card/snice-card.js +1 -1
  21. package/dist/components/card/snice-card.js.map +1 -1
  22. package/dist/components/checkbox/snice-checkbox.js +1 -1
  23. package/dist/components/checkbox/snice-checkbox.js.map +1 -1
  24. package/dist/components/chip/snice-chip.js +1 -1
  25. package/dist/components/chip/snice-chip.js.map +1 -1
  26. package/dist/components/color-display/snice-color-display.d.ts +14 -0
  27. package/dist/components/color-display/snice-color-display.js +151 -0
  28. package/dist/components/color-display/snice-color-display.js.map +1 -0
  29. package/dist/components/color-display/snice-color-display.types.d.ts +10 -0
  30. package/dist/components/color-picker/snice-color-picker.d.ts +50 -0
  31. package/dist/components/color-picker/snice-color-picker.js +489 -0
  32. package/dist/components/color-picker/snice-color-picker.js.map +1 -0
  33. package/dist/components/color-picker/snice-color-picker.types.d.ts +19 -0
  34. package/dist/components/date-picker/snice-date-picker.js +1 -1
  35. package/dist/components/date-picker/snice-date-picker.js.map +1 -1
  36. package/dist/components/divider/snice-divider.js +1 -1
  37. package/dist/components/divider/snice-divider.js.map +1 -1
  38. package/dist/components/drawer/snice-drawer.js +1 -1
  39. package/dist/components/drawer/snice-drawer.js.map +1 -1
  40. package/dist/components/empty-state/snice-empty-state.d.ts +13 -0
  41. package/dist/components/empty-state/snice-empty-state.js +121 -0
  42. package/dist/components/empty-state/snice-empty-state.js.map +1 -0
  43. package/dist/components/empty-state/snice-empty-state.types.d.ts +9 -0
  44. package/dist/components/file-upload/snice-file-upload.d.ts +45 -0
  45. package/dist/components/file-upload/snice-file-upload.js +394 -0
  46. package/dist/components/file-upload/snice-file-upload.js.map +1 -0
  47. package/dist/components/file-upload/snice-file-upload.types.d.ts +22 -0
  48. package/dist/components/image/snice-image.d.ts +22 -0
  49. package/dist/components/image/snice-image.js +201 -0
  50. package/dist/components/image/snice-image.js.map +1 -0
  51. package/dist/components/image/snice-image.types.d.ts +17 -0
  52. package/dist/components/input/snice-input.js +1 -1
  53. package/dist/components/input/snice-input.js.map +1 -1
  54. package/dist/components/kpi/snice-kpi.d.ts +16 -0
  55. package/dist/components/kpi/snice-kpi.js +162 -0
  56. package/dist/components/kpi/snice-kpi.js.map +1 -0
  57. package/dist/components/kpi/snice-kpi.types.d.ts +12 -0
  58. package/dist/components/layout/snice-layout-blog.js +1 -1
  59. package/dist/components/layout/snice-layout-blog.js.map +1 -1
  60. package/dist/components/layout/snice-layout-card.js +1 -1
  61. package/dist/components/layout/snice-layout-card.js.map +1 -1
  62. package/dist/components/layout/snice-layout-centered.js +1 -1
  63. package/dist/components/layout/snice-layout-centered.js.map +1 -1
  64. package/dist/components/layout/snice-layout-dashboard.js +1 -1
  65. package/dist/components/layout/snice-layout-dashboard.js.map +1 -1
  66. package/dist/components/layout/snice-layout-fullscreen.js +1 -1
  67. package/dist/components/layout/snice-layout-fullscreen.js.map +1 -1
  68. package/dist/components/layout/snice-layout-landing.js +1 -1
  69. package/dist/components/layout/snice-layout-landing.js.map +1 -1
  70. package/dist/components/layout/snice-layout-minimal.js +1 -1
  71. package/dist/components/layout/snice-layout-minimal.js.map +1 -1
  72. package/dist/components/layout/snice-layout-sidebar.js +1 -1
  73. package/dist/components/layout/snice-layout-sidebar.js.map +1 -1
  74. package/dist/components/layout/snice-layout-split.js +1 -1
  75. package/dist/components/layout/snice-layout-split.js.map +1 -1
  76. package/dist/components/layout/snice-layout.js +1 -1
  77. package/dist/components/layout/snice-layout.js.map +1 -1
  78. package/dist/components/link/snice-link.d.ts +13 -0
  79. package/dist/components/link/snice-link.js +137 -0
  80. package/dist/components/link/snice-link.js.map +1 -0
  81. package/dist/components/link/snice-link.types.d.ts +11 -0
  82. package/dist/components/login/snice-login.js +1 -1
  83. package/dist/components/login/snice-login.js.map +1 -1
  84. package/dist/components/modal/snice-modal.js +1 -1
  85. package/dist/components/modal/snice-modal.js.map +1 -1
  86. package/dist/components/nav/snice-nav.js +1 -1
  87. package/dist/components/nav/snice-nav.js.map +1 -1
  88. package/dist/components/progress/snice-progress.js +1 -1
  89. package/dist/components/progress/snice-progress.js.map +1 -1
  90. package/dist/components/radio/snice-radio.js +1 -1
  91. package/dist/components/radio/snice-radio.js.map +1 -1
  92. package/dist/components/select/snice-select.js +1 -1
  93. package/dist/components/select/snice-select.js.map +1 -1
  94. package/dist/components/skeleton/snice-skeleton.js +1 -1
  95. package/dist/components/skeleton/snice-skeleton.js.map +1 -1
  96. package/dist/components/slider/snice-slider.d.ts +53 -0
  97. package/dist/components/slider/snice-slider.js +479 -0
  98. package/dist/components/slider/snice-slider.js.map +1 -0
  99. package/dist/components/slider/snice-slider.types.d.ts +26 -0
  100. package/dist/components/snice-cell-C0slgOpe.js +4 -0
  101. package/dist/components/snice-cell-C0slgOpe.js.map +1 -0
  102. package/dist/components/sparkline/snice-sparkline.d.ts +21 -0
  103. package/dist/components/sparkline/snice-sparkline.js +228 -0
  104. package/dist/components/sparkline/snice-sparkline.js.map +1 -0
  105. package/dist/components/sparkline/snice-sparkline.types.d.ts +16 -0
  106. package/dist/components/spinner/snice-spinner.d.ts +10 -0
  107. package/dist/components/spinner/snice-spinner.js +109 -0
  108. package/dist/components/spinner/snice-spinner.js.map +1 -0
  109. package/dist/components/spinner/snice-spinner.types.d.ts +8 -0
  110. package/dist/components/stepper/snice-stepper-panel.d.ts +8 -0
  111. package/dist/components/stepper/snice-stepper-panel.js +70 -0
  112. package/dist/components/stepper/snice-stepper-panel.js.map +1 -0
  113. package/dist/components/stepper/snice-stepper-panel.types.d.ts +4 -0
  114. package/dist/components/stepper/snice-stepper.d.ts +15 -0
  115. package/dist/components/stepper/snice-stepper.js +163 -0
  116. package/dist/components/stepper/snice-stepper.js.map +1 -0
  117. package/dist/components/stepper/snice-stepper.types.d.ts +13 -0
  118. package/dist/components/switch/snice-switch.js +1 -1
  119. package/dist/components/switch/snice-switch.js.map +1 -1
  120. package/dist/components/table/snice-cell-actions.js +1 -1
  121. package/dist/components/table/snice-cell-actions.js.map +1 -1
  122. package/dist/components/table/snice-cell-boolean.js +1 -1
  123. package/dist/components/table/snice-cell-color.js +1 -1
  124. package/dist/components/table/snice-cell-color.js.map +1 -1
  125. package/dist/components/table/snice-cell-currency.js +1 -1
  126. package/dist/components/table/snice-cell-date.js +1 -1
  127. package/dist/components/table/snice-cell-duration.js +1 -1
  128. package/dist/components/table/snice-cell-email.js +1 -1
  129. package/dist/components/table/snice-cell-email.js.map +1 -1
  130. package/dist/components/table/snice-cell-filesize.js +1 -1
  131. package/dist/components/table/snice-cell-image.js +1 -1
  132. package/dist/components/table/snice-cell-image.js.map +1 -1
  133. package/dist/components/table/snice-cell-json.js +1 -1
  134. package/dist/components/table/snice-cell-json.js.map +1 -1
  135. package/dist/components/table/snice-cell-link.js +1 -1
  136. package/dist/components/table/snice-cell-link.js.map +1 -1
  137. package/dist/components/table/snice-cell-location.js +1 -1
  138. package/dist/components/table/snice-cell-location.js.map +1 -1
  139. package/dist/components/table/snice-cell-number.js +1 -1
  140. package/dist/components/table/snice-cell-percentage.js +1 -1
  141. package/dist/components/table/snice-cell-percentage.js.map +1 -1
  142. package/dist/components/table/snice-cell-phone.js +1 -1
  143. package/dist/components/table/snice-cell-phone.js.map +1 -1
  144. package/dist/components/table/snice-cell-progress.js +1 -1
  145. package/dist/components/table/snice-cell-rating.js +1 -1
  146. package/dist/components/table/snice-cell-sparkline.js +1 -1
  147. package/dist/components/table/snice-cell-status.js +1 -1
  148. package/dist/components/table/snice-cell-status.js.map +1 -1
  149. package/dist/components/table/snice-cell-tag.js +1 -1
  150. package/dist/components/table/snice-cell-tag.js.map +1 -1
  151. package/dist/components/table/snice-cell-text.js +1 -1
  152. package/dist/components/table/snice-cell.js +1 -1
  153. package/dist/components/table/snice-header.js +1 -1
  154. package/dist/components/table/snice-header.js.map +1 -1
  155. package/dist/components/table/snice-row.js +2 -2
  156. package/dist/components/table/snice-row.js.map +1 -1
  157. package/dist/components/table/snice-table.js +1 -1
  158. package/dist/components/tabs/snice-tab-panel.js +1 -1
  159. package/dist/components/tabs/snice-tab-panel.js.map +1 -1
  160. package/dist/components/tabs/snice-tab.js +1 -1
  161. package/dist/components/tabs/snice-tab.js.map +1 -1
  162. package/dist/components/tabs/snice-tabs.js +1 -1
  163. package/dist/components/tabs/snice-tabs.js.map +1 -1
  164. package/dist/components/textarea/snice-textarea.d.ts +52 -0
  165. package/dist/components/textarea/snice-textarea.js +407 -0
  166. package/dist/components/textarea/snice-textarea.js.map +1 -0
  167. package/dist/components/textarea/snice-textarea.types.d.ts +30 -0
  168. package/dist/components/timeline/snice-timeline.d.ts +11 -0
  169. package/dist/components/timeline/snice-timeline.js +112 -0
  170. package/dist/components/timeline/snice-timeline.js.map +1 -0
  171. package/dist/components/timeline/snice-timeline.types.d.ts +16 -0
  172. package/dist/components/tooltip/snice-tooltip.js +2 -2
  173. package/dist/components/tooltip/snice-tooltip.js.map +1 -1
  174. package/dist/index.cjs +125 -158
  175. package/dist/index.cjs.map +1 -1
  176. package/dist/index.esm.js +125 -158
  177. package/dist/index.esm.js.map +1 -1
  178. package/dist/index.iife.js +125 -158
  179. package/dist/index.iife.js.map +1 -1
  180. package/dist/parts.d.ts +13 -16
  181. package/dist/symbols.cjs +1 -1
  182. package/dist/symbols.esm.js +1 -1
  183. package/dist/template.d.ts +0 -1
  184. package/dist/transitions.cjs +1 -1
  185. package/dist/transitions.esm.js +1 -1
  186. package/docs/ai/README.md +10 -1
  187. package/docs/ai/components/banner.md +84 -0
  188. package/docs/ai/components/color-display.md +48 -0
  189. package/docs/ai/components/color-picker.md +75 -0
  190. package/docs/ai/components/empty-state.md +72 -0
  191. package/docs/ai/components/file-upload.md +93 -0
  192. package/docs/ai/components/image.md +60 -0
  193. package/docs/ai/components/kpi.md +158 -0
  194. package/docs/ai/components/link.md +77 -0
  195. package/docs/ai/components/slider.md +87 -0
  196. package/docs/ai/components/sparkline.md +168 -0
  197. package/docs/ai/components/spinner.md +47 -0
  198. package/docs/ai/components/stepper.md +216 -0
  199. package/docs/ai/components/textarea.md +87 -0
  200. package/docs/ai/components/timeline.md +77 -0
  201. package/docs/components/banner.md +106 -0
  202. package/docs/components/color-display.md +96 -0
  203. package/docs/components/color-picker.md +81 -0
  204. package/docs/components/empty-state.md +79 -0
  205. package/docs/components/file-upload.md +263 -0
  206. package/docs/components/image.md +110 -0
  207. package/docs/components/kpi.md +251 -0
  208. package/docs/components/link.md +229 -0
  209. package/docs/components/slider.md +297 -0
  210. package/docs/components/sparkline.md +293 -0
  211. package/docs/components/spinner.md +63 -0
  212. package/docs/components/stepper.md +410 -0
  213. package/docs/components/textarea.md +235 -0
  214. package/docs/components/timeline.md +192 -0
  215. package/package.json +2 -1
  216. package/dist/components/snice-cell-BLFVdxPp.js +0 -4
  217. package/dist/components/snice-cell-BLFVdxPp.js.map +0 -1
@@ -0,0 +1,192 @@
1
+ # Timeline Component
2
+
3
+ The `<snice-timeline>` component displays events in chronological order with markers, timestamps, and descriptions.
4
+
5
+ ## Basic Usage
6
+
7
+ ```html
8
+ <snice-timeline id="timeline"></snice-timeline>
9
+
10
+ <script>
11
+ const timeline = document.getElementById('timeline');
12
+ timeline.items = [
13
+ {
14
+ timestamp: '2024-01-15',
15
+ title: 'Event Title',
16
+ description: 'Event description'
17
+ }
18
+ ];
19
+ </script>
20
+ ```
21
+
22
+ ## Properties
23
+
24
+ | Property | Type | Default | Description |
25
+ |----------|------|---------|-------------|
26
+ | `orientation` | `'vertical' \| 'horizontal'` | `'vertical'` | Timeline orientation |
27
+ | `position` | `'left' \| 'right' \| 'alternate'` | `'left'` | Item position (vertical only) |
28
+ | `items` | `TimelineItem[]` | `[]` | Timeline items |
29
+ | `reverse` | `boolean` | `false` | Reverse item order |
30
+
31
+ ## TimelineItem Interface
32
+
33
+ ```typescript
34
+ interface TimelineItem {
35
+ timestamp?: string;
36
+ title: string;
37
+ description?: string;
38
+ icon?: string;
39
+ variant?: 'default' | 'success' | 'warning' | 'error' | 'info';
40
+ }
41
+ ```
42
+
43
+ ## Examples
44
+
45
+ ### Vertical Timeline
46
+
47
+ ```html
48
+ <snice-timeline id="timeline"></snice-timeline>
49
+
50
+ <script>
51
+ document.getElementById('timeline').items = [
52
+ {
53
+ timestamp: '2024-01-15 09:00',
54
+ title: 'Project Started',
55
+ description: 'Initial planning phase'
56
+ },
57
+ {
58
+ timestamp: '2024-01-20 14:30',
59
+ title: 'Design Complete',
60
+ description: 'Mockups approved'
61
+ }
62
+ ];
63
+ </script>
64
+ ```
65
+
66
+ ### Horizontal Timeline
67
+
68
+ ```html
69
+ <snice-timeline orientation="horizontal" id="horizontal-timeline"></snice-timeline>
70
+
71
+ <script>
72
+ document.getElementById('horizontal-timeline').items = [
73
+ { title: 'Step 1', description: 'First step' },
74
+ { title: 'Step 2', description: 'Second step' },
75
+ { title: 'Step 3', description: 'Third step' }
76
+ ];
77
+ </script>
78
+ ```
79
+
80
+ ### Alternate Position
81
+
82
+ ```html
83
+ <snice-timeline position="alternate" id="alt-timeline"></snice-timeline>
84
+
85
+ <script>
86
+ document.getElementById('alt-timeline').items = [
87
+ { title: 'Event 1', timestamp: 'Jan 2024' },
88
+ { title: 'Event 2', timestamp: 'Feb 2024' },
89
+ { title: 'Event 3', timestamp: 'Mar 2024' }
90
+ ];
91
+ </script>
92
+ ```
93
+
94
+ ### With Variants
95
+
96
+ ```html
97
+ <snice-timeline id="variant-timeline"></snice-timeline>
98
+
99
+ <script>
100
+ document.getElementById('variant-timeline').items = [
101
+ {
102
+ title: 'Completed',
103
+ variant: 'success',
104
+ description: 'Task finished successfully'
105
+ },
106
+ {
107
+ title: 'Warning',
108
+ variant: 'warning',
109
+ description: 'Attention needed'
110
+ },
111
+ {
112
+ title: 'Error',
113
+ variant: 'error',
114
+ description: 'Action failed'
115
+ }
116
+ ];
117
+ </script>
118
+ ```
119
+
120
+ ### Custom Icons
121
+
122
+ ```html
123
+ <snice-timeline id="icon-timeline"></snice-timeline>
124
+
125
+ <script>
126
+ document.getElementById('icon-timeline').items = [
127
+ { title: 'Planning', icon: '📋' },
128
+ { title: 'Development', icon: '💻' },
129
+ { title: 'Launch', icon: '🚀' }
130
+ ];
131
+ </script>
132
+ ```
133
+
134
+ ### Reversed Order
135
+
136
+ ```html
137
+ <snice-timeline reverse id="reversed-timeline"></snice-timeline>
138
+
139
+ <script>
140
+ document.getElementById('reversed-timeline').items = [
141
+ { title: 'Latest Event', timestamp: '2024-03-01' },
142
+ { title: 'Earlier Event', timestamp: '2024-02-01' },
143
+ { title: 'First Event', timestamp: '2024-01-01' }
144
+ ];
145
+ </script>
146
+ ```
147
+
148
+ ## Styling
149
+
150
+ The component exposes several CSS parts for styling:
151
+
152
+ ```css
153
+ snice-timeline::part(container) {
154
+ /* Timeline container */
155
+ }
156
+
157
+ snice-timeline::part(item) {
158
+ /* Timeline item */
159
+ }
160
+
161
+ snice-timeline::part(marker) {
162
+ /* Item marker/circle */
163
+ }
164
+
165
+ snice-timeline::part(icon) {
166
+ /* Marker icon */
167
+ }
168
+
169
+ snice-timeline::part(content) {
170
+ /* Item content area */
171
+ }
172
+
173
+ snice-timeline::part(timestamp) {
174
+ /* Timestamp text */
175
+ }
176
+
177
+ snice-timeline::part(title) {
178
+ /* Title text */
179
+ }
180
+
181
+ snice-timeline::part(description) {
182
+ /* Description text */
183
+ }
184
+ ```
185
+
186
+ ## Notes
187
+
188
+ - Items without timestamps will still render but won't display a timestamp
189
+ - Items without descriptions will only show the title
190
+ - Default icons are provided for each variant
191
+ - Horizontal timelines work best with 3-5 items
192
+ - Alternate positioning creates a zigzag layout
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "snice",
3
- "version": "3.1.0",
3
+ "version": "3.2.0",
4
4
  "type": "module",
5
5
  "description": "Imperative TypeScript framework for building vanilla web components with decorators, differential rendering, routing, and controllers. No virtual DOM, no build complexity.",
6
6
  "main": "dist/index.cjs",
@@ -106,6 +106,7 @@
106
106
  "@swc/core": "^1.13.5",
107
107
  "@types/node": "^20.0.0",
108
108
  "@vitest/ui": "^1.0.0",
109
+ "clean-css": "^5.3.3",
109
110
  "happy-dom": "^12.0.0",
110
111
  "rollup": "^4.50.2",
111
112
  "semantic-release": "^24.2.7",
@@ -1,4 +0,0 @@
1
- var cssContent = "/* Cell Base */\n:host {\n display: flex;\n align-items: center;\n padding: 0 var(--snice-table-cell-padding, var(--snice-spacing-md, 0.75rem)); /* Default: 12px */\n min-height: 2.5rem; /* 40px */\n height: 2.5rem; /* 40px */\n min-width: 6.25rem; /* 100px */\n flex: 1;\n font-size: 0.875rem; /* 14px */\n line-height: 1.25rem; /* 20px */\n}\n\n.cell-content {\n width: 100%;\n min-width: 6.25rem; /* 100px */\n min-height: 1.25rem; /* 20px */\n word-wrap: break-word;\n}\n\n/* Text Alignment */\n:host([align=\"left\"]) {\n text-align: left;\n}\n\n:host([align=\"center\"]) {\n text-align: center;\n}\n\n:host([align=\"right\"]) {\n text-align: right;\n}\n\n/* Type Specific Styles */\n:host([type=\"number\"]),\n:host([type=\"currency\"]),\n:host([type=\"percent\"]),\n:host([type=\"accounting\"]),\n:host([type=\"scientific\"]),\n:host([type=\"fraction\"]) {\n font-variant-numeric: tabular-nums;\n text-align: right;\n}\n\n:host([type=\"date\"]) {\n font-variant-numeric: tabular-nums;\n}\n\n:host([type=\"boolean\"]) {\n text-align: center;\n font-size: 1rem; /* 16px */\n}\n\n:host([type=\"rating\"]) {\n text-align: center;\n}\n\n:host([type=\"progress\"]) {\n /* Remove padding */\n}\n\n:host([type=\"sparkline\"]) {\n text-align: center;\n /* Remove padding */\n}\n\n/* Text Content Specific */\n.cell-content--text {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n.cell-content--text[data-multiline=\"true\"] {\n white-space: pre-wrap;\n word-wrap: break-word;\n overflow-wrap: break-word;\n}\n\n/* Number Content Specific */\n.cell-content--number {\n font-feature-settings: 'tnum';\n}\n\n/* Date Content Specific */\n.cell-content--date {\n font-feature-settings: 'tnum';\n}\n\n/* Boolean Content Styling */\n:host([type=\"boolean\"]) .cell-content {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n}\n\n/* Rating Content Styling */\n:host([type=\"rating\"]) .cell-content {\n display: inline-flex;\n align-items: center;\n justify-content: center;\n gap: 0.125rem; /* 2px */\n}\n\n/* Progress Content Styling */\n.cell-content--progress {\n width: 100%;\n min-width: 4rem; /* 64px */\n}\n\n/* Sparkline Content Styling */\n.cell-content--sparkline {\n display: flex;\n align-items: center;\n justify-content: center;\n min-width: 3rem; /* 48px */\n}\n\n/* Conditional Formatting Support */\n:host(.positive) {\n color: var(--snice-color-success);\n}\n\n:host(.negative) {\n color: var(--snice-color-danger);\n}\n\n:host(.warning) {\n color: var(--snice-color-warning);\n background-color: rgb(var(--snice-color-yellow-100));\n}\n\n:host(.danger) {\n color: var(--snice-color-danger);\n background-color: rgb(var(--snice-color-red-100));\n}\n\n:host(.success) {\n color: var(--snice-color-success);\n background-color: rgb(var(--snice-color-green-100));\n}\n\n:host(.info) {\n color: var(--snice-color-primary);\n background-color: rgb(var(--snice-color-blue-100));\n}\n\n/* Date-specific styling */\n:host(.date--today) {\n font-weight: var(--snice-font-weight-semibold);\n color: var(--snice-color-primary);\n}\n\n:host(.date--past) {\n color: var(--snice-color-text-secondary);\n}\n\n:host(.date--future) {\n color: var(--snice-color-success);\n}\n\n/* Number-specific styling */\n:host(.number--negative.number--negative-red) {\n color: var(--snice-color-danger);\n}\n\n:host(.number--positive.number--highlighted) {\n color: var(--snice-color-success);\n font-weight: var(--snice-font-weight-semibold);\n}\n\n:host(.number--zero) {\n color: var(--snice-color-text-secondary);\n}\n\n/* Truncation Support */\n:host([truncate]) .cell-content {\n overflow: hidden;\n text-overflow: ellipsis;\n white-space: nowrap;\n}\n\n/* Wrap Support */\n:host([wrap]) .cell-content {\n white-space: pre-wrap;\n word-wrap: break-word;\n overflow-wrap: break-word;\n}\n\n/* Empty State */\n:host([value=\"\"]) .cell-content,\n:host(:not([value])) .cell-content {\n color: #6c757d;\n}\n\n/* Loading State */\n:host(.loading) {\n position: relative;\n overflow: hidden;\n}\n\n:host(.loading) .cell-content {\n opacity: 0.6;\n}\n\n:host(.loading)::after {\n content: '';\n position: absolute;\n top: 0;\n left: 0;\n right: 0;\n bottom: 0;\n background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.6), transparent);\n animation: cell-shimmer 1.5s infinite;\n}\n\n@keyframes cell-shimmer {\n 0% {\n transform: translateX(-100%);\n }\n 100% {\n transform: translateX(100%);\n }\n}\n\n/* Focus States */\n:host(:focus-within) {\n outline: 2px solid #007bff;\n outline-offset: -2px;\n}\n\n/* Interactive Elements */\n.cell-content button,\n.cell-content input,\n.cell-content select {\n font-size: inherit;\n line-height: inherit;\n}\n\n.cell-content a {\n color: #007bff;\n text-decoration: none;\n}\n\n.cell-content a:hover {\n text-decoration: underline;\n}\n\n/* Responsive Design */\n@media (max-width: 768px) {\n :host {\n font-size: 0.75rem; /* 12px */\n line-height: 1rem; /* 16px */\n }\n \n :host([type=\"boolean\"]) {\n font-size: 0.875rem; /* 14px */\n }\n}\n\n/* Accessibility */\n@media (prefers-reduced-motion: reduce) {\n :host(.loading)::after {\n animation: none;\n }\n}\n\n/* High Contrast Mode */\n@media (prefers-contrast: high) {\n :host(.positive) {\n background-color: #d4edda;\n }\n \n :host(.negative) {\n background-color: #f8d7da;\n }\n \n .cell-content a {\n text-decoration: underline;\n }\n}\n\n/* Print Styles */\n@media print {\n :host {\n font-size: 0.75rem; /* 12px */\n }\n \n :host(.loading)::after {\n display: none;\n }\n \n .cell-content a {\n text-decoration: underline;\n }\n}";
2
-
3
- export { cssContent as c };
4
- //# sourceMappingURL=snice-cell-BLFVdxPp.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"snice-cell-BLFVdxPp.js","sources":["../../components/table/snice-cell.css?inline"],"sourcesContent":["export default \"/* Cell Base */\\n:host {\\n display: flex;\\n align-items: center;\\n padding: 0 var(--snice-table-cell-padding, var(--snice-spacing-md, 0.75rem)); /* Default: 12px */\\n min-height: 2.5rem; /* 40px */\\n height: 2.5rem; /* 40px */\\n min-width: 6.25rem; /* 100px */\\n flex: 1;\\n font-size: 0.875rem; /* 14px */\\n line-height: 1.25rem; /* 20px */\\n}\\n\\n.cell-content {\\n width: 100%;\\n min-width: 6.25rem; /* 100px */\\n min-height: 1.25rem; /* 20px */\\n word-wrap: break-word;\\n}\\n\\n/* Text Alignment */\\n:host([align=\\\"left\\\"]) {\\n text-align: left;\\n}\\n\\n:host([align=\\\"center\\\"]) {\\n text-align: center;\\n}\\n\\n:host([align=\\\"right\\\"]) {\\n text-align: right;\\n}\\n\\n/* Type Specific Styles */\\n:host([type=\\\"number\\\"]),\\n:host([type=\\\"currency\\\"]),\\n:host([type=\\\"percent\\\"]),\\n:host([type=\\\"accounting\\\"]),\\n:host([type=\\\"scientific\\\"]),\\n:host([type=\\\"fraction\\\"]) {\\n font-variant-numeric: tabular-nums;\\n text-align: right;\\n}\\n\\n:host([type=\\\"date\\\"]) {\\n font-variant-numeric: tabular-nums;\\n}\\n\\n:host([type=\\\"boolean\\\"]) {\\n text-align: center;\\n font-size: 1rem; /* 16px */\\n}\\n\\n:host([type=\\\"rating\\\"]) {\\n text-align: center;\\n}\\n\\n:host([type=\\\"progress\\\"]) {\\n /* Remove padding */\\n}\\n\\n:host([type=\\\"sparkline\\\"]) {\\n text-align: center;\\n /* Remove padding */\\n}\\n\\n/* Text Content Specific */\\n.cell-content--text {\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n}\\n\\n.cell-content--text[data-multiline=\\\"true\\\"] {\\n white-space: pre-wrap;\\n word-wrap: break-word;\\n overflow-wrap: break-word;\\n}\\n\\n/* Number Content Specific */\\n.cell-content--number {\\n font-feature-settings: 'tnum';\\n}\\n\\n/* Date Content Specific */\\n.cell-content--date {\\n font-feature-settings: 'tnum';\\n}\\n\\n/* Boolean Content Styling */\\n:host([type=\\\"boolean\\\"]) .cell-content {\\n display: inline-flex;\\n align-items: center;\\n justify-content: center;\\n}\\n\\n/* Rating Content Styling */\\n:host([type=\\\"rating\\\"]) .cell-content {\\n display: inline-flex;\\n align-items: center;\\n justify-content: center;\\n gap: 0.125rem; /* 2px */\\n}\\n\\n/* Progress Content Styling */\\n.cell-content--progress {\\n width: 100%;\\n min-width: 4rem; /* 64px */\\n}\\n\\n/* Sparkline Content Styling */\\n.cell-content--sparkline {\\n display: flex;\\n align-items: center;\\n justify-content: center;\\n min-width: 3rem; /* 48px */\\n}\\n\\n/* Conditional Formatting Support */\\n:host(.positive) {\\n color: var(--snice-color-success);\\n}\\n\\n:host(.negative) {\\n color: var(--snice-color-danger);\\n}\\n\\n:host(.warning) {\\n color: var(--snice-color-warning);\\n background-color: rgb(var(--snice-color-yellow-100));\\n}\\n\\n:host(.danger) {\\n color: var(--snice-color-danger);\\n background-color: rgb(var(--snice-color-red-100));\\n}\\n\\n:host(.success) {\\n color: var(--snice-color-success);\\n background-color: rgb(var(--snice-color-green-100));\\n}\\n\\n:host(.info) {\\n color: var(--snice-color-primary);\\n background-color: rgb(var(--snice-color-blue-100));\\n}\\n\\n/* Date-specific styling */\\n:host(.date--today) {\\n font-weight: var(--snice-font-weight-semibold);\\n color: var(--snice-color-primary);\\n}\\n\\n:host(.date--past) {\\n color: var(--snice-color-text-secondary);\\n}\\n\\n:host(.date--future) {\\n color: var(--snice-color-success);\\n}\\n\\n/* Number-specific styling */\\n:host(.number--negative.number--negative-red) {\\n color: var(--snice-color-danger);\\n}\\n\\n:host(.number--positive.number--highlighted) {\\n color: var(--snice-color-success);\\n font-weight: var(--snice-font-weight-semibold);\\n}\\n\\n:host(.number--zero) {\\n color: var(--snice-color-text-secondary);\\n}\\n\\n/* Truncation Support */\\n:host([truncate]) .cell-content {\\n overflow: hidden;\\n text-overflow: ellipsis;\\n white-space: nowrap;\\n}\\n\\n/* Wrap Support */\\n:host([wrap]) .cell-content {\\n white-space: pre-wrap;\\n word-wrap: break-word;\\n overflow-wrap: break-word;\\n}\\n\\n/* Empty State */\\n:host([value=\\\"\\\"]) .cell-content,\\n:host(:not([value])) .cell-content {\\n color: #6c757d;\\n}\\n\\n/* Loading State */\\n:host(.loading) {\\n position: relative;\\n overflow: hidden;\\n}\\n\\n:host(.loading) .cell-content {\\n opacity: 0.6;\\n}\\n\\n:host(.loading)::after {\\n content: '';\\n position: absolute;\\n top: 0;\\n left: 0;\\n right: 0;\\n bottom: 0;\\n background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.6), transparent);\\n animation: cell-shimmer 1.5s infinite;\\n}\\n\\n@keyframes cell-shimmer {\\n 0% {\\n transform: translateX(-100%);\\n }\\n 100% {\\n transform: translateX(100%);\\n }\\n}\\n\\n/* Focus States */\\n:host(:focus-within) {\\n outline: 2px solid #007bff;\\n outline-offset: -2px;\\n}\\n\\n/* Interactive Elements */\\n.cell-content button,\\n.cell-content input,\\n.cell-content select {\\n font-size: inherit;\\n line-height: inherit;\\n}\\n\\n.cell-content a {\\n color: #007bff;\\n text-decoration: none;\\n}\\n\\n.cell-content a:hover {\\n text-decoration: underline;\\n}\\n\\n/* Responsive Design */\\n@media (max-width: 768px) {\\n :host {\\n font-size: 0.75rem; /* 12px */\\n line-height: 1rem; /* 16px */\\n }\\n \\n :host([type=\\\"boolean\\\"]) {\\n font-size: 0.875rem; /* 14px */\\n }\\n}\\n\\n/* Accessibility */\\n@media (prefers-reduced-motion: reduce) {\\n :host(.loading)::after {\\n animation: none;\\n }\\n}\\n\\n/* High Contrast Mode */\\n@media (prefers-contrast: high) {\\n :host(.positive) {\\n background-color: #d4edda;\\n }\\n \\n :host(.negative) {\\n background-color: #f8d7da;\\n }\\n \\n .cell-content a {\\n text-decoration: underline;\\n }\\n}\\n\\n/* Print Styles */\\n@media print {\\n :host {\\n font-size: 0.75rem; /* 12px */\\n }\\n \\n :host(.loading)::after {\\n display: none;\\n }\\n \\n .cell-content a {\\n text-decoration: underline;\\n }\\n}\";"],"names":[],"mappings":"AAAA,iBAAe,umLAAumL;;;;"}