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.
- package/README.md +90 -41
- package/dist/components/accordion/snice-accordion-item.js +1 -1
- package/dist/components/accordion/snice-accordion-item.js.map +1 -1
- package/dist/components/accordion/snice-accordion.js +1 -1
- package/dist/components/accordion/snice-accordion.js.map +1 -1
- package/dist/components/alert/snice-alert.js +1 -1
- package/dist/components/alert/snice-alert.js.map +1 -1
- package/dist/components/avatar/snice-avatar.js +1 -1
- package/dist/components/avatar/snice-avatar.js.map +1 -1
- package/dist/components/badge/snice-badge.js +1 -1
- package/dist/components/badge/snice-badge.js.map +1 -1
- package/dist/components/banner/snice-banner.d.ts +22 -0
- package/dist/components/banner/snice-banner.js +180 -0
- package/dist/components/banner/snice-banner.js.map +1 -0
- package/dist/components/banner/snice-banner.types.d.ts +14 -0
- package/dist/components/breadcrumbs/snice-breadcrumbs.js +1 -1
- package/dist/components/breadcrumbs/snice-breadcrumbs.js.map +1 -1
- package/dist/components/button/snice-button.js +1 -1
- package/dist/components/button/snice-button.js.map +1 -1
- package/dist/components/card/snice-card.js +1 -1
- package/dist/components/card/snice-card.js.map +1 -1
- package/dist/components/checkbox/snice-checkbox.js +1 -1
- package/dist/components/checkbox/snice-checkbox.js.map +1 -1
- package/dist/components/chip/snice-chip.js +1 -1
- package/dist/components/chip/snice-chip.js.map +1 -1
- package/dist/components/color-display/snice-color-display.d.ts +14 -0
- package/dist/components/color-display/snice-color-display.js +151 -0
- package/dist/components/color-display/snice-color-display.js.map +1 -0
- package/dist/components/color-display/snice-color-display.types.d.ts +10 -0
- package/dist/components/color-picker/snice-color-picker.d.ts +50 -0
- package/dist/components/color-picker/snice-color-picker.js +489 -0
- package/dist/components/color-picker/snice-color-picker.js.map +1 -0
- package/dist/components/color-picker/snice-color-picker.types.d.ts +19 -0
- package/dist/components/date-picker/snice-date-picker.js +1 -1
- package/dist/components/date-picker/snice-date-picker.js.map +1 -1
- package/dist/components/divider/snice-divider.js +1 -1
- package/dist/components/divider/snice-divider.js.map +1 -1
- package/dist/components/drawer/snice-drawer.js +1 -1
- package/dist/components/drawer/snice-drawer.js.map +1 -1
- package/dist/components/empty-state/snice-empty-state.d.ts +13 -0
- package/dist/components/empty-state/snice-empty-state.js +121 -0
- package/dist/components/empty-state/snice-empty-state.js.map +1 -0
- package/dist/components/empty-state/snice-empty-state.types.d.ts +9 -0
- package/dist/components/file-upload/snice-file-upload.d.ts +45 -0
- package/dist/components/file-upload/snice-file-upload.js +394 -0
- package/dist/components/file-upload/snice-file-upload.js.map +1 -0
- package/dist/components/file-upload/snice-file-upload.types.d.ts +22 -0
- package/dist/components/image/snice-image.d.ts +22 -0
- package/dist/components/image/snice-image.js +201 -0
- package/dist/components/image/snice-image.js.map +1 -0
- package/dist/components/image/snice-image.types.d.ts +17 -0
- package/dist/components/input/snice-input.js +1 -1
- package/dist/components/input/snice-input.js.map +1 -1
- package/dist/components/kpi/snice-kpi.d.ts +16 -0
- package/dist/components/kpi/snice-kpi.js +162 -0
- package/dist/components/kpi/snice-kpi.js.map +1 -0
- package/dist/components/kpi/snice-kpi.types.d.ts +12 -0
- package/dist/components/layout/snice-layout-blog.js +1 -1
- package/dist/components/layout/snice-layout-blog.js.map +1 -1
- package/dist/components/layout/snice-layout-card.js +1 -1
- package/dist/components/layout/snice-layout-card.js.map +1 -1
- package/dist/components/layout/snice-layout-centered.js +1 -1
- package/dist/components/layout/snice-layout-centered.js.map +1 -1
- package/dist/components/layout/snice-layout-dashboard.js +1 -1
- package/dist/components/layout/snice-layout-dashboard.js.map +1 -1
- package/dist/components/layout/snice-layout-fullscreen.js +1 -1
- package/dist/components/layout/snice-layout-fullscreen.js.map +1 -1
- package/dist/components/layout/snice-layout-landing.js +1 -1
- package/dist/components/layout/snice-layout-landing.js.map +1 -1
- package/dist/components/layout/snice-layout-minimal.js +1 -1
- package/dist/components/layout/snice-layout-minimal.js.map +1 -1
- package/dist/components/layout/snice-layout-sidebar.js +1 -1
- package/dist/components/layout/snice-layout-sidebar.js.map +1 -1
- package/dist/components/layout/snice-layout-split.js +1 -1
- package/dist/components/layout/snice-layout-split.js.map +1 -1
- package/dist/components/layout/snice-layout.js +1 -1
- package/dist/components/layout/snice-layout.js.map +1 -1
- package/dist/components/link/snice-link.d.ts +13 -0
- package/dist/components/link/snice-link.js +137 -0
- package/dist/components/link/snice-link.js.map +1 -0
- package/dist/components/link/snice-link.types.d.ts +11 -0
- package/dist/components/login/snice-login.js +1 -1
- package/dist/components/login/snice-login.js.map +1 -1
- package/dist/components/modal/snice-modal.js +1 -1
- package/dist/components/modal/snice-modal.js.map +1 -1
- package/dist/components/nav/snice-nav.js +1 -1
- package/dist/components/nav/snice-nav.js.map +1 -1
- package/dist/components/progress/snice-progress.js +1 -1
- package/dist/components/progress/snice-progress.js.map +1 -1
- package/dist/components/radio/snice-radio.js +1 -1
- package/dist/components/radio/snice-radio.js.map +1 -1
- package/dist/components/select/snice-select.js +1 -1
- package/dist/components/select/snice-select.js.map +1 -1
- package/dist/components/skeleton/snice-skeleton.js +1 -1
- package/dist/components/skeleton/snice-skeleton.js.map +1 -1
- package/dist/components/slider/snice-slider.d.ts +53 -0
- package/dist/components/slider/snice-slider.js +479 -0
- package/dist/components/slider/snice-slider.js.map +1 -0
- package/dist/components/slider/snice-slider.types.d.ts +26 -0
- package/dist/components/snice-cell-C0slgOpe.js +4 -0
- package/dist/components/snice-cell-C0slgOpe.js.map +1 -0
- package/dist/components/sparkline/snice-sparkline.d.ts +21 -0
- package/dist/components/sparkline/snice-sparkline.js +228 -0
- package/dist/components/sparkline/snice-sparkline.js.map +1 -0
- package/dist/components/sparkline/snice-sparkline.types.d.ts +16 -0
- package/dist/components/spinner/snice-spinner.d.ts +10 -0
- package/dist/components/spinner/snice-spinner.js +109 -0
- package/dist/components/spinner/snice-spinner.js.map +1 -0
- package/dist/components/spinner/snice-spinner.types.d.ts +8 -0
- package/dist/components/stepper/snice-stepper-panel.d.ts +8 -0
- package/dist/components/stepper/snice-stepper-panel.js +70 -0
- package/dist/components/stepper/snice-stepper-panel.js.map +1 -0
- package/dist/components/stepper/snice-stepper-panel.types.d.ts +4 -0
- package/dist/components/stepper/snice-stepper.d.ts +15 -0
- package/dist/components/stepper/snice-stepper.js +163 -0
- package/dist/components/stepper/snice-stepper.js.map +1 -0
- package/dist/components/stepper/snice-stepper.types.d.ts +13 -0
- package/dist/components/switch/snice-switch.js +1 -1
- package/dist/components/switch/snice-switch.js.map +1 -1
- package/dist/components/table/snice-cell-actions.js +1 -1
- package/dist/components/table/snice-cell-actions.js.map +1 -1
- package/dist/components/table/snice-cell-boolean.js +1 -1
- package/dist/components/table/snice-cell-color.js +1 -1
- package/dist/components/table/snice-cell-color.js.map +1 -1
- package/dist/components/table/snice-cell-currency.js +1 -1
- package/dist/components/table/snice-cell-date.js +1 -1
- package/dist/components/table/snice-cell-duration.js +1 -1
- package/dist/components/table/snice-cell-email.js +1 -1
- package/dist/components/table/snice-cell-email.js.map +1 -1
- package/dist/components/table/snice-cell-filesize.js +1 -1
- package/dist/components/table/snice-cell-image.js +1 -1
- package/dist/components/table/snice-cell-image.js.map +1 -1
- package/dist/components/table/snice-cell-json.js +1 -1
- package/dist/components/table/snice-cell-json.js.map +1 -1
- package/dist/components/table/snice-cell-link.js +1 -1
- package/dist/components/table/snice-cell-link.js.map +1 -1
- package/dist/components/table/snice-cell-location.js +1 -1
- package/dist/components/table/snice-cell-location.js.map +1 -1
- package/dist/components/table/snice-cell-number.js +1 -1
- package/dist/components/table/snice-cell-percentage.js +1 -1
- package/dist/components/table/snice-cell-percentage.js.map +1 -1
- package/dist/components/table/snice-cell-phone.js +1 -1
- package/dist/components/table/snice-cell-phone.js.map +1 -1
- package/dist/components/table/snice-cell-progress.js +1 -1
- package/dist/components/table/snice-cell-rating.js +1 -1
- package/dist/components/table/snice-cell-sparkline.js +1 -1
- package/dist/components/table/snice-cell-status.js +1 -1
- package/dist/components/table/snice-cell-status.js.map +1 -1
- package/dist/components/table/snice-cell-tag.js +1 -1
- package/dist/components/table/snice-cell-tag.js.map +1 -1
- package/dist/components/table/snice-cell-text.js +1 -1
- package/dist/components/table/snice-cell.js +1 -1
- package/dist/components/table/snice-header.js +1 -1
- package/dist/components/table/snice-header.js.map +1 -1
- package/dist/components/table/snice-row.js +2 -2
- package/dist/components/table/snice-row.js.map +1 -1
- package/dist/components/table/snice-table.js +1 -1
- package/dist/components/tabs/snice-tab-panel.js +1 -1
- package/dist/components/tabs/snice-tab-panel.js.map +1 -1
- package/dist/components/tabs/snice-tab.js +1 -1
- package/dist/components/tabs/snice-tab.js.map +1 -1
- package/dist/components/tabs/snice-tabs.js +1 -1
- package/dist/components/tabs/snice-tabs.js.map +1 -1
- package/dist/components/textarea/snice-textarea.d.ts +52 -0
- package/dist/components/textarea/snice-textarea.js +407 -0
- package/dist/components/textarea/snice-textarea.js.map +1 -0
- package/dist/components/textarea/snice-textarea.types.d.ts +30 -0
- package/dist/components/timeline/snice-timeline.d.ts +11 -0
- package/dist/components/timeline/snice-timeline.js +112 -0
- package/dist/components/timeline/snice-timeline.js.map +1 -0
- package/dist/components/timeline/snice-timeline.types.d.ts +16 -0
- package/dist/components/tooltip/snice-tooltip.js +2 -2
- package/dist/components/tooltip/snice-tooltip.js.map +1 -1
- package/dist/index.cjs +125 -158
- package/dist/index.cjs.map +1 -1
- package/dist/index.esm.js +125 -158
- package/dist/index.esm.js.map +1 -1
- package/dist/index.iife.js +125 -158
- package/dist/index.iife.js.map +1 -1
- package/dist/parts.d.ts +13 -16
- package/dist/symbols.cjs +1 -1
- package/dist/symbols.esm.js +1 -1
- package/dist/template.d.ts +0 -1
- package/dist/transitions.cjs +1 -1
- package/dist/transitions.esm.js +1 -1
- package/docs/ai/README.md +10 -1
- package/docs/ai/components/banner.md +84 -0
- package/docs/ai/components/color-display.md +48 -0
- package/docs/ai/components/color-picker.md +75 -0
- package/docs/ai/components/empty-state.md +72 -0
- package/docs/ai/components/file-upload.md +93 -0
- package/docs/ai/components/image.md +60 -0
- package/docs/ai/components/kpi.md +158 -0
- package/docs/ai/components/link.md +77 -0
- package/docs/ai/components/slider.md +87 -0
- package/docs/ai/components/sparkline.md +168 -0
- package/docs/ai/components/spinner.md +47 -0
- package/docs/ai/components/stepper.md +216 -0
- package/docs/ai/components/textarea.md +87 -0
- package/docs/ai/components/timeline.md +77 -0
- package/docs/components/banner.md +106 -0
- package/docs/components/color-display.md +96 -0
- package/docs/components/color-picker.md +81 -0
- package/docs/components/empty-state.md +79 -0
- package/docs/components/file-upload.md +263 -0
- package/docs/components/image.md +110 -0
- package/docs/components/kpi.md +251 -0
- package/docs/components/link.md +229 -0
- package/docs/components/slider.md +297 -0
- package/docs/components/sparkline.md +293 -0
- package/docs/components/spinner.md +63 -0
- package/docs/components/stepper.md +410 -0
- package/docs/components/textarea.md +235 -0
- package/docs/components/timeline.md +192 -0
- package/package.json +2 -1
- package/dist/components/snice-cell-BLFVdxPp.js +0 -4
- 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.
|
|
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;;;;"}
|