@sentropic/design-system-svelte 0.25.1 → 0.27.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.
@@ -0,0 +1,327 @@
1
+ <script lang="ts" module>
2
+ export type DivergentBarChartTone = "positive" | "negative" | "neutral";
3
+
4
+ export type DivergentBarChartDatum = {
5
+ label: string;
6
+ value: number;
7
+ tone?: DivergentBarChartTone;
8
+ };
9
+ </script>
10
+
11
+ <script lang="ts">
12
+ import ChartDataList from "./ChartDataList.svelte";
13
+
14
+ type DivergentBarChartProps = {
15
+ data: DivergentBarChartDatum[];
16
+ width?: number;
17
+ height?: number;
18
+ domain?: [number, number];
19
+ format?: (value: number) => string;
20
+ showLegend?: boolean;
21
+ label: string;
22
+ class?: string;
23
+ };
24
+
25
+ let {
26
+ data,
27
+ width = 480,
28
+ height = 260,
29
+ domain,
30
+ format = formatTick,
31
+ showLegend = true,
32
+ label,
33
+ class: className
34
+ }: DivergentBarChartProps = $props();
35
+
36
+ const MARGIN = { top: 14, right: 16, bottom: 34, left: 88 };
37
+
38
+ function niceTicks(min: number, max: number, target = 5): number[] {
39
+ if (!Number.isFinite(min) || !Number.isFinite(max) || min === max) {
40
+ const base = Number.isFinite(max) ? max : 0;
41
+ return [base];
42
+ }
43
+ const range = max - min;
44
+ const rough = range / Math.max(target - 1, 1);
45
+ const pow = Math.pow(10, Math.floor(Math.log10(rough)));
46
+ const norm = rough / pow;
47
+ const step = norm < 1.5 ? pow : norm < 3 ? 2 * pow : norm < 7 ? 5 * pow : 10 * pow;
48
+ const start = Math.floor(min / step) * step;
49
+ const end = Math.ceil(max / step) * step;
50
+ const ticks: number[] = [];
51
+ for (let v = start; v <= end + step / 2; v += step) ticks.push(Number(v.toFixed(10)));
52
+ return ticks;
53
+ }
54
+
55
+ const scaleLinear = (v: number, d0: number, d1: number, r0: number, r1: number) =>
56
+ d1 === d0 ? r0 : r0 + ((v - d0) * (r1 - r0)) / (d1 - d0);
57
+
58
+ function formatTick(v: number): string {
59
+ if (Math.abs(v) >= 1000) return `${(v / 1000).toFixed(v % 1000 === 0 ? 0 : 1)}k`;
60
+ if (Number.isInteger(v)) return String(v);
61
+ return v.toFixed(1);
62
+ }
63
+
64
+ function signFor(value: number): "positive" | "negative" | "zero" {
65
+ if (value > 0) return "positive";
66
+ if (value < 0) return "negative";
67
+ return "zero";
68
+ }
69
+
70
+ function toneFor(datum: DivergentBarChartDatum): DivergentBarChartTone {
71
+ if (datum.tone) return datum.tone;
72
+ if (datum.value > 0) return "positive";
73
+ if (datum.value < 0) return "negative";
74
+ return "neutral";
75
+ }
76
+
77
+ let hoveredIndex: number | null = $state(null);
78
+
79
+ const validData = $derived(data.filter((d) => Number.isFinite(d.value)));
80
+
81
+ const validDomain = $derived.by<[number, number] | null>(() => {
82
+ if (!domain) return null;
83
+ const [d0, d1] = domain;
84
+ if (!Number.isFinite(d0) || !Number.isFinite(d1) || d0 >= d1 || d0 > 0 || d1 < 0) return null;
85
+ return [d0, d1];
86
+ });
87
+
88
+ const scales = $derived.by(() => {
89
+ const plotWidth = Math.max(width - MARGIN.left - MARGIN.right, 1);
90
+ const plotHeight = Math.max(height - MARGIN.top - MARGIN.bottom, 1);
91
+ if (validDomain) {
92
+ const ticks = niceTicks(validDomain[0], validDomain[1]).filter((tick) => tick >= validDomain[0] && tick <= validDomain[1]);
93
+ return { plotWidth, plotHeight, domainMin: validDomain[0], domainMax: validDomain[1], ticks: ticks.length ? ticks : [0] };
94
+ }
95
+ const maxAbs = Math.max(1, ...validData.map((d) => Math.abs(d.value)));
96
+ const ticks = niceTicks(-maxAbs, maxAbs);
97
+ return { plotWidth, plotHeight, domainMin: ticks[0], domainMax: ticks[ticks.length - 1], ticks };
98
+ });
99
+
100
+ const bars = $derived.by(() => {
101
+ if (validData.length === 0) return [];
102
+ const { domainMin, domainMax, plotWidth, plotHeight } = scales;
103
+ const band = plotHeight / validData.length;
104
+ const barHeight = Math.max(band * 0.56, 1);
105
+ const zeroX = MARGIN.left + scaleLinear(0, domainMin, domainMax, 0, plotWidth);
106
+ return validData.map((datum, index) => {
107
+ const valueX = MARGIN.left + scaleLinear(datum.value, domainMin, domainMax, 0, plotWidth);
108
+ const x = Math.min(zeroX, valueX);
109
+ const barWidth = Math.max(Math.abs(valueX - zeroX), 0.5);
110
+ const y = MARGIN.top + band * index + (band - barHeight) / 2;
111
+ return {
112
+ datum,
113
+ index,
114
+ x,
115
+ y,
116
+ width: barWidth,
117
+ height: barHeight,
118
+ cx: datum.value === 0 ? zeroX : x + barWidth / 2,
119
+ cy: y + barHeight / 2,
120
+ sign: signFor(datum.value),
121
+ tone: toneFor(datum)
122
+ };
123
+ });
124
+ });
125
+
126
+ const dataValueItems = $derived(validData.map((d) => `${d.label}: ${format(d.value)}`));
127
+
128
+ const gridTicks = $derived.by(() => {
129
+ const { ticks, domainMin, domainMax, plotWidth } = scales;
130
+ return ticks.map((tick) => ({
131
+ value: tick,
132
+ x: MARGIN.left + scaleLinear(tick, domainMin, domainMax, 0, plotWidth)
133
+ }));
134
+ });
135
+
136
+ function handleVisualPointerMove(event: PointerEvent) {
137
+ const target = event.target;
138
+ if (!(target instanceof Element)) {
139
+ hoveredIndex = null;
140
+ return;
141
+ }
142
+ const index = Number(target.getAttribute("data-chart-index"));
143
+ hoveredIndex = Number.isInteger(index) ? index : null;
144
+ }
145
+
146
+ const hoveredBar = $derived(hoveredIndex !== null ? bars[hoveredIndex] : undefined);
147
+ const zeroAxisX = $derived(MARGIN.left + scaleLinear(0, scales.domainMin, scales.domainMax, 0, scales.plotWidth));
148
+ const classes = () => ["st-divergentBarChart", className].filter(Boolean).join(" ");
149
+ </script>
150
+
151
+ <div class={classes()}>
152
+ <div
153
+ class="st-divergentBarChart__visual"
154
+ role="img"
155
+ aria-label={label}
156
+ onpointermove={handleVisualPointerMove}
157
+ onpointerleave={() => (hoveredIndex = null)}
158
+ >
159
+ <svg viewBox="0 0 {width} {height}" preserveAspectRatio="xMidYMid meet" width="100%" height="100%" focusable="false" aria-hidden="true">
160
+ {#each gridTicks as tick (tick.value)}
161
+ <line class="st-divergentBarChart__grid" x1={tick.x} x2={tick.x} y1={MARGIN.top} y2={height - MARGIN.bottom} />
162
+ <text class="st-divergentBarChart__tickLabel" x={tick.x} y={height - MARGIN.bottom + 16} text-anchor="middle">
163
+ {formatTick(tick.value)}
164
+ </text>
165
+ {/each}
166
+
167
+ <line class="st-divergentBarChart__axis" x1={MARGIN.left} x2={width - MARGIN.right} y1={height - MARGIN.bottom} y2={height - MARGIN.bottom} />
168
+ <line class="st-divergentBarChart__zeroAxis" x1={zeroAxisX} x2={zeroAxisX} y1={MARGIN.top} y2={height - MARGIN.bottom} />
169
+
170
+ {#each bars as bar (bar.datum.label)}
171
+ <text class="st-divergentBarChart__categoryLabel" x={MARGIN.left - 8} y={bar.cy} text-anchor="end" dominant-baseline="middle">
172
+ {bar.datum.label}
173
+ </text>
174
+ <rect
175
+ class="st-divergentBarChart__bar st-divergentBarChart__bar--{bar.sign} st-divergentBarChart__bar--{bar.tone}"
176
+ x={bar.x}
177
+ y={bar.y}
178
+ width={bar.width}
179
+ height={bar.height}
180
+ rx="2"
181
+ data-chart-index={bar.index}
182
+ data-chart-key={bar.datum.label}
183
+ />
184
+ {/each}
185
+ </svg>
186
+ </div>
187
+
188
+ <ChartDataList {label} items={dataValueItems} />
189
+
190
+ {#if hoveredBar}
191
+ <div class="st-divergentBarChart__tooltip" role="presentation" style="left: {(hoveredBar.cx / width) * 100}%; top: {(hoveredBar.cy / height) * 100}%">
192
+ <span class="st-divergentBarChart__tooltipLabel">{hoveredBar.datum.label}</span>
193
+ <span class="st-divergentBarChart__tooltipValue">{format(hoveredBar.datum.value)}</span>
194
+ </div>
195
+ {/if}
196
+
197
+ {#if showLegend}
198
+ <ul class="st-divergentBarChart__legend">
199
+ <li class="st-divergentBarChart__legendItem"><span class="st-divergentBarChart__legendSwatch st-divergentBarChart__legendSwatch--positive" aria-hidden="true"></span>Positive</li>
200
+ <li class="st-divergentBarChart__legendItem"><span class="st-divergentBarChart__legendSwatch st-divergentBarChart__legendSwatch--negative" aria-hidden="true"></span>Negative</li>
201
+ <li class="st-divergentBarChart__legendItem"><span class="st-divergentBarChart__legendSwatch st-divergentBarChart__legendSwatch--neutral" aria-hidden="true"></span>Zero</li>
202
+ </ul>
203
+ {/if}
204
+ </div>
205
+
206
+ <style>
207
+ .st-divergentBarChart {
208
+ color: var(--st-component-divergentBarChart-labelColor, var(--st-semantic-text-secondary));
209
+ display: block;
210
+ font-family: inherit;
211
+ position: relative;
212
+ width: 100%;
213
+ }
214
+
215
+ .st-divergentBarChart svg,
216
+ .st-divergentBarChart__visual {
217
+ display: block;
218
+ overflow: visible;
219
+ }
220
+
221
+ .st-divergentBarChart__grid {
222
+ stroke: var(--st-component-divergentBarChart-gridStroke, var(--st-semantic-border-subtle));
223
+ stroke-dasharray: 2 3;
224
+ stroke-width: 1;
225
+ opacity: 0.7;
226
+ }
227
+
228
+ .st-divergentBarChart__axis {
229
+ stroke: var(--st-component-divergentBarChart-axisStroke, var(--st-semantic-border-subtle));
230
+ stroke-width: 1;
231
+ }
232
+
233
+ .st-divergentBarChart__zeroAxis {
234
+ stroke: var(--st-component-divergentBarChart-zeroStroke, var(--st-semantic-border-strong));
235
+ stroke-width: 1.5;
236
+ }
237
+
238
+ .st-divergentBarChart__tickLabel,
239
+ .st-divergentBarChart__categoryLabel {
240
+ fill: var(--st-component-divergentBarChart-labelColor, var(--st-semantic-text-secondary));
241
+ font-size: 0.6875rem;
242
+ }
243
+
244
+ .st-divergentBarChart__bar {
245
+ cursor: pointer;
246
+ transition: opacity var(--st-motion-fast, 120ms) var(--st-motion-easing, ease);
247
+ }
248
+
249
+ .st-divergentBarChart__bar--positive {
250
+ fill: var(--st-component-divergentBarChart-positiveFill, var(--st-semantic-data-category5));
251
+ }
252
+
253
+ .st-divergentBarChart__bar--negative {
254
+ fill: var(--st-component-divergentBarChart-negativeFill, var(--st-semantic-data-category3));
255
+ }
256
+
257
+ .st-divergentBarChart__bar--neutral,
258
+ .st-divergentBarChart__bar--zero {
259
+ fill: var(--st-component-divergentBarChart-neutralFill, var(--st-semantic-data-category6));
260
+ }
261
+
262
+ .st-divergentBarChart__tooltip {
263
+ background: var(--st-component-divergentBarChart-tooltipBackground, var(--st-semantic-surface-inverse));
264
+ border-radius: var(--st-radius-sm, 0.25rem);
265
+ color: var(--st-component-divergentBarChart-tooltipText, var(--st-semantic-text-inverse));
266
+ display: inline-flex;
267
+ flex-direction: column;
268
+ font-size: 0.75rem;
269
+ gap: 0.125rem;
270
+ line-height: 1.2;
271
+ padding: 0.375rem 0.5rem;
272
+ pointer-events: none;
273
+ position: absolute;
274
+ transform: translate(-50%, calc(-100% - 8px));
275
+ white-space: nowrap;
276
+ z-index: 1;
277
+ }
278
+
279
+ .st-divergentBarChart__tooltipLabel {
280
+ font-weight: 600;
281
+ }
282
+
283
+ .st-divergentBarChart__tooltipValue {
284
+ opacity: 0.85;
285
+ }
286
+
287
+ .st-divergentBarChart__legend {
288
+ display: flex;
289
+ flex-wrap: wrap;
290
+ gap: var(--st-spacing-3, 0.75rem);
291
+ list-style: none;
292
+ margin: var(--st-spacing-2, 0.5rem) 0 0;
293
+ padding: 0;
294
+ }
295
+
296
+ .st-divergentBarChart__legendItem {
297
+ align-items: center;
298
+ color: var(--st-semantic-text-secondary);
299
+ display: inline-flex;
300
+ font-size: 0.75rem;
301
+ gap: var(--st-spacing-1, 0.25rem);
302
+ }
303
+
304
+ .st-divergentBarChart__legendSwatch {
305
+ border-radius: 2px;
306
+ height: 0.7rem;
307
+ width: 0.7rem;
308
+ }
309
+
310
+ .st-divergentBarChart__legendSwatch--positive {
311
+ background: var(--st-component-divergentBarChart-positiveFill, var(--st-semantic-data-category5));
312
+ }
313
+
314
+ .st-divergentBarChart__legendSwatch--negative {
315
+ background: var(--st-component-divergentBarChart-negativeFill, var(--st-semantic-data-category3));
316
+ }
317
+
318
+ .st-divergentBarChart__legendSwatch--neutral {
319
+ background: var(--st-component-divergentBarChart-neutralFill, var(--st-semantic-data-category6));
320
+ }
321
+
322
+ @media (prefers-reduced-motion: reduce) {
323
+ .st-divergentBarChart__bar {
324
+ transition: none;
325
+ }
326
+ }
327
+ </style>
@@ -0,0 +1,20 @@
1
+ export type DivergentBarChartTone = "positive" | "negative" | "neutral";
2
+ export type DivergentBarChartDatum = {
3
+ label: string;
4
+ value: number;
5
+ tone?: DivergentBarChartTone;
6
+ };
7
+ type DivergentBarChartProps = {
8
+ data: DivergentBarChartDatum[];
9
+ width?: number;
10
+ height?: number;
11
+ domain?: [number, number];
12
+ format?: (value: number) => string;
13
+ showLegend?: boolean;
14
+ label: string;
15
+ class?: string;
16
+ };
17
+ declare const DivergentBarChart: import("svelte").Component<DivergentBarChartProps, {}, "">;
18
+ type DivergentBarChart = ReturnType<typeof DivergentBarChart>;
19
+ export default DivergentBarChart;
20
+ //# sourceMappingURL=DivergentBarChart.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DivergentBarChart.svelte.d.ts","sourceRoot":"","sources":["../src/lib/DivergentBarChart.svelte.ts"],"names":[],"mappings":"AAGE,MAAM,MAAM,qBAAqB,GAAG,UAAU,GAAG,UAAU,GAAG,SAAS,CAAC;AAExE,MAAM,MAAM,sBAAsB,GAAG;IACnC,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,qBAAqB,CAAC;CAC9B,CAAC;AAMF,KAAK,sBAAsB,GAAG;IAC5B,IAAI,EAAE,sBAAsB,EAAE,CAAC;IAC/B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,MAAM,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAC1B,MAAM,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IACnC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAiLJ,QAAA,MAAM,iBAAiB,4DAAwC,CAAC;AAChE,KAAK,iBAAiB,GAAG,UAAU,CAAC,OAAO,iBAAiB,CAAC,CAAC;AAC9D,eAAe,iBAAiB,CAAC"}
@@ -0,0 +1,366 @@
1
+ <script lang="ts" module>
2
+ export type RangeSliderSize = "sm" | "md" | "lg";
3
+
4
+ export type RangeSliderProps = {
5
+ /** Valeur contrôlée [poignée basse, poignée haute]. Non-contrôlé si absent. */
6
+ value?: [number, number];
7
+ /** Valeur initiale en mode non-contrôlé. Défaut [min, max]. */
8
+ defaultValue?: [number, number];
9
+ min?: number;
10
+ max?: number;
11
+ step?: number;
12
+ size?: RangeSliderSize;
13
+ disabled?: boolean;
14
+ label?: string;
15
+ helperText?: string;
16
+ errorText?: string;
17
+ invalid?: boolean;
18
+ showValue?: boolean;
19
+ valueFormatter?: (value: number) => string;
20
+ /** aria-label de la poignée basse. Défaut "Valeur minimale". */
21
+ ariaLabelMin?: string;
22
+ /** aria-label de la poignée haute. Défaut "Valeur maximale". */
23
+ ariaLabelMax?: string;
24
+ class?: string;
25
+ onChange?: (value: [number, number]) => void;
26
+ };
27
+ </script>
28
+
29
+ <script lang="ts">
30
+ import { untrack } from "svelte";
31
+
32
+ let {
33
+ value,
34
+ defaultValue,
35
+ min = 0,
36
+ max = 100,
37
+ step = 1,
38
+ size = "md",
39
+ disabled = false,
40
+ label,
41
+ helperText,
42
+ errorText,
43
+ invalid = false,
44
+ showValue = true,
45
+ valueFormatter,
46
+ ariaLabelMin = "Valeur minimale",
47
+ ariaLabelMax = "Valeur maximale",
48
+ class: className,
49
+ onChange,
50
+ }: RangeSliderProps = $props();
51
+
52
+ // ── État interne (mode non-contrôlé) ──────────────────────────────────────
53
+ function clampStep(n: number): number {
54
+ if (!Number.isFinite(n)) return min;
55
+ let v = Math.min(Math.max(n, min), max);
56
+ if (Number.isFinite(step) && step > 0) {
57
+ v = min + Math.round((v - min) / step) * step;
58
+ v = Math.min(Math.max(v, min), max);
59
+ }
60
+ return v;
61
+ }
62
+
63
+ function normalizePair(pair: [number, number]): [number, number] {
64
+ let lo = clampStep(pair[0]);
65
+ let hi = clampStep(pair[1]);
66
+ if (lo > hi) {
67
+ // ne se croisent pas : on rabat sur la valeur la plus contraignante
68
+ const mid = lo;
69
+ lo = Math.min(mid, hi);
70
+ hi = Math.max(mid, hi);
71
+ }
72
+ return [lo, hi];
73
+ }
74
+
75
+ let internal = $state<[number, number]>(
76
+ untrack(() => normalizePair(defaultValue ?? [min, max]))
77
+ );
78
+
79
+ const isControlled = $derived(Array.isArray(value));
80
+
81
+ const current = $derived.by<[number, number]>(() => {
82
+ const source = isControlled ? (value as [number, number]) : internal;
83
+ return normalizePair(source ?? [min, max]);
84
+ });
85
+
86
+ const lowValue = $derived(current[0]);
87
+ const highValue = $derived(current[1]);
88
+
89
+ const lowPercent = $derived(max === min ? 0 : ((lowValue - min) / (max - min)) * 100);
90
+ const highPercent = $derived(max === min ? 0 : ((highValue - min) / (max - min)) * 100);
91
+
92
+ const lowLabel = $derived(valueFormatter ? valueFormatter(lowValue) : String(lowValue));
93
+ const highLabel = $derived(valueFormatter ? valueFormatter(highValue) : String(highValue));
94
+
95
+ const fieldClasses = () => ["st-field", className].filter(Boolean).join(" ");
96
+ const groupClasses = () =>
97
+ ["st-rangeSlider", `st-rangeSlider--${size}`, disabled ? "st-rangeSlider--disabled" : null]
98
+ .filter(Boolean)
99
+ .join(" ");
100
+ const isInvalid = () => invalid || Boolean(errorText);
101
+
102
+ function commit(next: [number, number]) {
103
+ const normalized = normalizePair(next);
104
+ if (!isControlled) internal = normalized;
105
+ onChange?.(normalized);
106
+ }
107
+
108
+ function setLow(raw: number) {
109
+ if (disabled) return;
110
+ const clamped = clampStep(raw);
111
+ // la poignée basse ne dépasse pas la haute
112
+ const lo = Math.min(clamped, highValue);
113
+ commit([lo, highValue]);
114
+ }
115
+
116
+ function setHigh(raw: number) {
117
+ if (disabled) return;
118
+ const clamped = clampStep(raw);
119
+ // la poignée haute ne passe pas sous la basse
120
+ const hi = Math.max(clamped, lowValue);
121
+ commit([lowValue, hi]);
122
+ }
123
+
124
+ function keyDelta(event: KeyboardEvent, value: number): number | null {
125
+ const big = (Number.isFinite(step) && step > 0 ? step : 1) * 10;
126
+ const small = Number.isFinite(step) && step > 0 ? step : 1;
127
+ switch (event.key) {
128
+ case "ArrowRight":
129
+ case "ArrowUp":
130
+ return value + small;
131
+ case "ArrowLeft":
132
+ case "ArrowDown":
133
+ return value - small;
134
+ case "PageUp":
135
+ return value + big;
136
+ case "PageDown":
137
+ return value - big;
138
+ case "Home":
139
+ return min;
140
+ case "End":
141
+ return max;
142
+ default:
143
+ return null;
144
+ }
145
+ }
146
+
147
+ function onLowKeydown(event: KeyboardEvent) {
148
+ if (disabled) return;
149
+ const next = keyDelta(event, lowValue);
150
+ if (next === null) return;
151
+ event.preventDefault();
152
+ setLow(next);
153
+ }
154
+
155
+ function onHighKeydown(event: KeyboardEvent) {
156
+ if (disabled) return;
157
+ const next = keyDelta(event, highValue);
158
+ if (next === null) return;
159
+ event.preventDefault();
160
+ setHigh(next);
161
+ }
162
+ </script>
163
+
164
+ <div class={fieldClasses()}>
165
+ <div class="st-rangeSlider__header">
166
+ {#if label}<span class="st-field__label">{label}</span>{/if}
167
+ {#if showValue}
168
+ <output class="st-rangeSlider__value" aria-live="polite">{lowLabel} – {highLabel}</output>
169
+ {/if}
170
+ </div>
171
+ <span class={groupClasses()}>
172
+ <span class="st-rangeSlider__bounds" aria-hidden="true">{min}</span>
173
+ <span class="st-rangeSlider__track" aria-invalid={isInvalid() ? "true" : undefined}>
174
+ <span
175
+ class="st-rangeSlider__fill"
176
+ style={`left: ${lowPercent}%; width: ${Math.max(0, highPercent - lowPercent)}%`}
177
+ ></span>
178
+ <span
179
+ class="st-rangeSlider__thumb st-rangeSlider__thumb--low"
180
+ style={`left: ${lowPercent}%`}
181
+ role="slider"
182
+ tabindex={disabled ? -1 : 0}
183
+ aria-label={ariaLabelMin}
184
+ aria-valuemin={min}
185
+ aria-valuemax={highValue}
186
+ aria-valuenow={lowValue}
187
+ aria-valuetext={lowLabel}
188
+ aria-disabled={disabled ? "true" : undefined}
189
+ onkeydown={onLowKeydown}
190
+ >
191
+ {#if showValue}<span class="st-rangeSlider__tooltip">{lowLabel}</span>{/if}
192
+ </span>
193
+ <span
194
+ class="st-rangeSlider__thumb st-rangeSlider__thumb--high"
195
+ style={`left: ${highPercent}%`}
196
+ role="slider"
197
+ tabindex={disabled ? -1 : 0}
198
+ aria-label={ariaLabelMax}
199
+ aria-valuemin={lowValue}
200
+ aria-valuemax={max}
201
+ aria-valuenow={highValue}
202
+ aria-valuetext={highLabel}
203
+ aria-disabled={disabled ? "true" : undefined}
204
+ onkeydown={onHighKeydown}
205
+ >
206
+ {#if showValue}<span class="st-rangeSlider__tooltip">{highLabel}</span>{/if}
207
+ </span>
208
+ </span>
209
+ <span class="st-rangeSlider__bounds" aria-hidden="true">{max}</span>
210
+ </span>
211
+ {#if errorText}
212
+ <span class="st-field__error">{errorText}</span>
213
+ {:else if helperText}
214
+ <span class="st-field__help">{helperText}</span>
215
+ {/if}
216
+ </div>
217
+
218
+ <style>
219
+ .st-field {
220
+ color: var(--st-component-field-labelText, var(--st-semantic-text-primary));
221
+ display: grid;
222
+ gap: var(--st-component-field-gap, 0.5rem);
223
+ max-width: var(--st-component-field-maxWidth, 28rem);
224
+ }
225
+
226
+ .st-field__label {
227
+ font-size: 0.875rem;
228
+ font-weight: 600;
229
+ }
230
+
231
+ .st-field__help,
232
+ .st-field__error {
233
+ font-size: 0.8125rem;
234
+ line-height: 1.4;
235
+ }
236
+
237
+ .st-field__help {
238
+ color: var(--st-component-field-helpText, var(--st-semantic-text-secondary));
239
+ }
240
+
241
+ .st-field__error {
242
+ color: var(--st-component-field-errorText, var(--st-semantic-feedback-error));
243
+ }
244
+
245
+ .st-rangeSlider__header {
246
+ align-items: baseline;
247
+ display: flex;
248
+ gap: 0.5rem;
249
+ justify-content: space-between;
250
+ }
251
+
252
+ .st-rangeSlider__value {
253
+ color: var(--st-semantic-text-secondary);
254
+ font-size: 0.875rem;
255
+ font-variant-numeric: tabular-nums;
256
+ }
257
+
258
+ .st-rangeSlider {
259
+ align-items: center;
260
+ display: flex;
261
+ gap: 0.75rem;
262
+ width: 100%;
263
+ }
264
+
265
+ .st-rangeSlider__bounds {
266
+ color: var(--st-semantic-text-muted);
267
+ flex: 0 0 auto;
268
+ font-size: 0.75rem;
269
+ font-variant-numeric: tabular-nums;
270
+ }
271
+
272
+ .st-rangeSlider__track {
273
+ background: var(--st-component-control-border, var(--st-semantic-border-subtle));
274
+ border-radius: 999px;
275
+ flex: 1 1 auto;
276
+ height: 0.25rem;
277
+ position: relative;
278
+ }
279
+
280
+ .st-rangeSlider--sm .st-rangeSlider__track {
281
+ height: 0.1875rem;
282
+ }
283
+
284
+ .st-rangeSlider--lg .st-rangeSlider__track {
285
+ height: 0.375rem;
286
+ }
287
+
288
+ .st-rangeSlider__fill {
289
+ background: var(--st-semantic-action-primary);
290
+ border-radius: 999px;
291
+ display: block;
292
+ height: 100%;
293
+ position: absolute;
294
+ top: 0;
295
+ }
296
+
297
+ .st-rangeSlider__thumb {
298
+ background: var(--st-semantic-action-primary);
299
+ border-radius: 50%;
300
+ box-sizing: border-box;
301
+ cursor: pointer;
302
+ height: 1rem;
303
+ position: absolute;
304
+ top: 50%;
305
+ transform: translate(-50%, -50%);
306
+ width: 1rem;
307
+ }
308
+
309
+ .st-rangeSlider--sm .st-rangeSlider__thumb {
310
+ height: 0.75rem;
311
+ width: 0.75rem;
312
+ }
313
+
314
+ .st-rangeSlider--lg .st-rangeSlider__thumb {
315
+ height: 1.25rem;
316
+ width: 1.25rem;
317
+ }
318
+
319
+ .st-rangeSlider__thumb:focus-visible {
320
+ outline: 2px solid var(--st-component-control-focusRing, var(--st-semantic-border-interactive));
321
+ outline-offset: 4px;
322
+ }
323
+
324
+ .st-rangeSlider__tooltip {
325
+ background: var(--st-semantic-text-primary);
326
+ border-radius: var(--st-component-control-radius, 0.375rem);
327
+ bottom: calc(100% + 0.375rem);
328
+ color: var(--st-semantic-surface-default);
329
+ font-size: 0.6875rem;
330
+ font-weight: 600;
331
+ left: 50%;
332
+ line-height: 1;
333
+ opacity: 0;
334
+ padding: 0.25rem 0.375rem;
335
+ pointer-events: none;
336
+ position: absolute;
337
+ transform: translateX(-50%);
338
+ transition: opacity var(--st-motion-fast, 120ms) var(--st-motion-easing, ease);
339
+ white-space: nowrap;
340
+ }
341
+
342
+ .st-rangeSlider__thumb:hover .st-rangeSlider__tooltip,
343
+ .st-rangeSlider__thumb:focus-visible .st-rangeSlider__tooltip {
344
+ opacity: 1;
345
+ }
346
+
347
+ .st-rangeSlider--disabled .st-rangeSlider__thumb,
348
+ .st-rangeSlider--disabled .st-rangeSlider__fill {
349
+ background: var(--st-semantic-text-muted);
350
+ }
351
+
352
+ .st-rangeSlider--disabled .st-rangeSlider__thumb {
353
+ cursor: not-allowed;
354
+ }
355
+
356
+ .st-rangeSlider__track[aria-invalid="true"] .st-rangeSlider__fill,
357
+ .st-rangeSlider__track[aria-invalid="true"] .st-rangeSlider__thumb {
358
+ background: var(--st-semantic-feedback-error);
359
+ }
360
+
361
+ @media (prefers-reduced-motion: reduce) {
362
+ .st-rangeSlider__tooltip {
363
+ transition: none;
364
+ }
365
+ }
366
+ </style>
@@ -0,0 +1,28 @@
1
+ export type RangeSliderSize = "sm" | "md" | "lg";
2
+ export type RangeSliderProps = {
3
+ /** Valeur contrôlée [poignée basse, poignée haute]. Non-contrôlé si absent. */
4
+ value?: [number, number];
5
+ /** Valeur initiale en mode non-contrôlé. Défaut [min, max]. */
6
+ defaultValue?: [number, number];
7
+ min?: number;
8
+ max?: number;
9
+ step?: number;
10
+ size?: RangeSliderSize;
11
+ disabled?: boolean;
12
+ label?: string;
13
+ helperText?: string;
14
+ errorText?: string;
15
+ invalid?: boolean;
16
+ showValue?: boolean;
17
+ valueFormatter?: (value: number) => string;
18
+ /** aria-label de la poignée basse. Défaut "Valeur minimale". */
19
+ ariaLabelMin?: string;
20
+ /** aria-label de la poignée haute. Défaut "Valeur maximale". */
21
+ ariaLabelMax?: string;
22
+ class?: string;
23
+ onChange?: (value: [number, number]) => void;
24
+ };
25
+ declare const RangeSlider: import("svelte").Component<RangeSliderProps, {}, "">;
26
+ type RangeSlider = ReturnType<typeof RangeSlider>;
27
+ export default RangeSlider;
28
+ //# sourceMappingURL=RangeSlider.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"RangeSlider.svelte.d.ts","sourceRoot":"","sources":["../src/lib/RangeSlider.svelte.ts"],"names":[],"mappings":"AAGE,MAAM,MAAM,eAAe,GAAG,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;AAEjD,MAAM,MAAM,gBAAgB,GAAG;IAC7B,+EAA+E;IAC/E,KAAK,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IACzB,+DAA+D;IAC/D,YAAY,CAAC,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,CAAC;IAChC,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,GAAG,CAAC,EAAE,MAAM,CAAC;IACb,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,IAAI,CAAC,EAAE,eAAe,CAAC;IACvB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,cAAc,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,MAAM,CAAC;IAC3C,gEAAgE;IAChE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,gEAAgE;IAChE,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,QAAQ,CAAC,EAAE,CAAC,KAAK,EAAE,CAAC,MAAM,EAAE,MAAM,CAAC,KAAK,IAAI,CAAC;CAC9C,CAAC;AA6KJ,QAAA,MAAM,WAAW,sDAAwC,CAAC;AAC1D,KAAK,WAAW,GAAG,UAAU,CAAC,OAAO,WAAW,CAAC,CAAC;AAClD,eAAe,WAAW,CAAC"}
@@ -0,0 +1,382 @@
1
+ <script lang="ts" module>
2
+ export type StepLineChartTone =
3
+ | "category1"
4
+ | "category2"
5
+ | "category3"
6
+ | "category4"
7
+ | "category5"
8
+ | "category6"
9
+ | "category7"
10
+ | "category8";
11
+
12
+ export type StepLineChartDatum = {
13
+ x: number | string;
14
+ y: number;
15
+ };
16
+ </script>
17
+
18
+ <script lang="ts">
19
+ import ChartDataList from "./ChartDataList.svelte";
20
+
21
+ type StepLineChartProps = {
22
+ data: StepLineChartDatum[];
23
+ width?: number;
24
+ height?: number;
25
+ tone?: StepLineChartTone;
26
+ label: string;
27
+ class?: string;
28
+ };
29
+
30
+ let {
31
+ data = [],
32
+ width = 480,
33
+ height = 240,
34
+ tone = "category1",
35
+ label,
36
+ class: className
37
+ }: StepLineChartProps = $props();
38
+
39
+ const MARGIN = { top: 12, right: 16, bottom: 32, left: 44 };
40
+
41
+ function niceTicks(min: number, max: number, target = 5): number[] {
42
+ if (!Number.isFinite(min) || !Number.isFinite(max) || min === max) {
43
+ const base = Number.isFinite(max) ? max : 0;
44
+ return [base];
45
+ }
46
+ const range = max - min;
47
+ const rough = range / Math.max(target - 1, 1);
48
+ const pow = Math.pow(10, Math.floor(Math.log10(rough)));
49
+ const norm = rough / pow;
50
+ let step: number;
51
+ if (norm < 1.5) step = 1 * pow;
52
+ else if (norm < 3) step = 2 * pow;
53
+ else if (norm < 7) step = 5 * pow;
54
+ else step = 10 * pow;
55
+ const start = Math.floor(min / step) * step;
56
+ const end = Math.ceil(max / step) * step;
57
+ const ticks: number[] = [];
58
+ for (let v = start; v <= end + step / 2; v += step) {
59
+ ticks.push(Number(v.toFixed(10)));
60
+ }
61
+ return ticks;
62
+ }
63
+
64
+ function scaleLinear(v: number, d0: number, d1: number, r0: number, r1: number) {
65
+ if (d1 === d0) return r0;
66
+ return r0 + ((v - d0) * (r1 - r0)) / (d1 - d0);
67
+ }
68
+
69
+ function formatTick(v: number): string {
70
+ if (Math.abs(v) >= 1000) return `${(v / 1000).toFixed(v % 1000 === 0 ? 0 : 1)}k`;
71
+ if (Number.isInteger(v)) return String(v);
72
+ return v.toFixed(1);
73
+ }
74
+
75
+ function isNumeric(x: number | string): x is number {
76
+ return typeof x === "number" && Number.isFinite(x);
77
+ }
78
+
79
+ function isValidDatum(datum: StepLineChartDatum): boolean {
80
+ return Number.isFinite(datum.y) && (typeof datum.x === "string" || isNumeric(datum.x));
81
+ }
82
+
83
+ let hoveredIndex: number | null = $state(null);
84
+
85
+ const safeData = $derived(data.filter(isValidDatum));
86
+ const plotWidth = $derived(Math.max(width - MARGIN.left - MARGIN.right, 1));
87
+ const plotHeight = $derived(Math.max(height - MARGIN.top - MARGIN.bottom, 1));
88
+
89
+ const xDomain = $derived.by(() => {
90
+ if (safeData.length === 0) return { kind: "ordinal" as const, values: [] as (number | string)[] };
91
+ const allNumeric = safeData.every((d) => isNumeric(d.x));
92
+ if (allNumeric) {
93
+ const xs = safeData.map((d) => d.x as number);
94
+ return { kind: "numeric" as const, min: Math.min(...xs), max: Math.max(...xs) };
95
+ }
96
+ return { kind: "ordinal" as const, values: safeData.map((d) => d.x) };
97
+ });
98
+
99
+ const yTicks = $derived.by(() => {
100
+ const ys = safeData.map((d) => d.y);
101
+ if (ys.length === 0) return [0];
102
+ const minRaw = Math.min(...ys);
103
+ const maxRaw = Math.max(...ys);
104
+ const padded = (maxRaw - minRaw) * 0.08 || Math.max(Math.abs(maxRaw), 1) * 0.1;
105
+ return niceTicks(minRaw - padded, maxRaw + padded, 5);
106
+ });
107
+
108
+ const yDomain = $derived.by(() => {
109
+ if (yTicks.length === 0) return { min: 0, max: 1 };
110
+ return { min: yTicks[0], max: yTicks[yTicks.length - 1] };
111
+ });
112
+
113
+ const points = $derived.by(() => {
114
+ if (safeData.length === 0) return [];
115
+ return safeData.map((d, i) => {
116
+ let x: number;
117
+ if (xDomain.kind === "numeric") {
118
+ x = scaleLinear(d.x as number, xDomain.min, xDomain.max, 0, plotWidth);
119
+ } else {
120
+ const denom = Math.max(safeData.length - 1, 1);
121
+ x = safeData.length === 1 ? plotWidth / 2 : (i / denom) * plotWidth;
122
+ }
123
+ const y = scaleLinear(d.y, yDomain.min, yDomain.max, plotHeight, 0);
124
+ return {
125
+ x: MARGIN.left + x,
126
+ y: MARGIN.top + y,
127
+ datum: d,
128
+ index: i
129
+ };
130
+ });
131
+ });
132
+
133
+ const dataValueItems = $derived(safeData.map((d) => `${d.x}: ${d.y}`));
134
+
135
+ function buildStepPath(pts: { x: number; y: number }[]): string {
136
+ if (pts.length === 0) return "";
137
+ let path = `M${pts[0].x.toFixed(2)},${pts[0].y.toFixed(2)}`;
138
+ for (let i = 1; i < pts.length; i++) {
139
+ const point = pts[i];
140
+ path += ` H${point.x.toFixed(2)} V${point.y.toFixed(2)}`;
141
+ }
142
+ return path;
143
+ }
144
+
145
+ const linePath = $derived(buildStepPath(points));
146
+
147
+ const gridLines = $derived(
148
+ yTicks.map((tick) => ({
149
+ value: tick,
150
+ y: MARGIN.top + scaleLinear(tick, yDomain.min, yDomain.max, plotHeight, 0)
151
+ }))
152
+ );
153
+
154
+ const xTickEntries = $derived.by(() => {
155
+ if (safeData.length === 0) return [];
156
+ if (xDomain.kind === "ordinal") {
157
+ return points.map((p, i) => ({
158
+ x: p.x,
159
+ label: String(safeData[i].x)
160
+ }));
161
+ }
162
+ const target = Math.min(5, safeData.length);
163
+ const stride = Math.max(1, Math.round((safeData.length - 1) / (target - 1 || 1)));
164
+ const entries: { x: number; label: string }[] = [];
165
+ for (let i = 0; i < safeData.length; i += stride) {
166
+ entries.push({ x: points[i].x, label: String(safeData[i].x) });
167
+ }
168
+ const lastIdx = safeData.length - 1;
169
+ if (entries[entries.length - 1]?.label !== String(safeData[lastIdx].x)) {
170
+ entries.push({ x: points[lastIdx].x, label: String(safeData[lastIdx].x) });
171
+ }
172
+ return entries;
173
+ });
174
+
175
+ function handleLeave() {
176
+ hoveredIndex = null;
177
+ }
178
+
179
+ function handleVisualPointerMove(event: PointerEvent) {
180
+ const target = event.target;
181
+ if (!(target instanceof Element)) {
182
+ hoveredIndex = null;
183
+ return;
184
+ }
185
+ const index = Number(target.getAttribute("data-chart-index"));
186
+ hoveredIndex = Number.isInteger(index) ? index : null;
187
+ }
188
+
189
+ const classes = () =>
190
+ ["st-stepLineChart", `st-stepLineChart--${tone}`, className].filter(Boolean).join(" ");
191
+ </script>
192
+
193
+ <div class={classes()}>
194
+ <div
195
+ class="st-stepLineChart__visual"
196
+ role="img"
197
+ aria-label={label}
198
+ onpointermove={handleVisualPointerMove}
199
+ onpointerleave={handleLeave}
200
+ >
201
+ <svg
202
+ viewBox="0 0 {width} {height}"
203
+ preserveAspectRatio="xMidYMid meet"
204
+ width="100%"
205
+ height="100%"
206
+ focusable="false"
207
+ aria-hidden="true"
208
+ >
209
+ {#each gridLines as g (g.value)}
210
+ <line
211
+ class="st-stepLineChart__grid"
212
+ x1={MARGIN.left}
213
+ x2={width - MARGIN.right}
214
+ y1={g.y}
215
+ y2={g.y}
216
+ />
217
+ <text
218
+ class="st-stepLineChart__tickLabel"
219
+ x={MARGIN.left - 6}
220
+ y={g.y}
221
+ text-anchor="end"
222
+ dominant-baseline="middle"
223
+ >
224
+ {formatTick(g.value)}
225
+ </text>
226
+ {/each}
227
+
228
+ <line
229
+ class="st-stepLineChart__axis"
230
+ x1={MARGIN.left}
231
+ x2={MARGIN.left}
232
+ y1={MARGIN.top}
233
+ y2={height - MARGIN.bottom}
234
+ />
235
+ <line
236
+ class="st-stepLineChart__axis"
237
+ x1={MARGIN.left}
238
+ x2={width - MARGIN.right}
239
+ y1={height - MARGIN.bottom}
240
+ y2={height - MARGIN.bottom}
241
+ />
242
+
243
+ {#each xTickEntries as tick, i (i)}
244
+ <text
245
+ class="st-stepLineChart__tickLabel"
246
+ x={tick.x}
247
+ y={height - MARGIN.bottom + 16}
248
+ text-anchor="middle"
249
+ >
250
+ {tick.label}
251
+ </text>
252
+ {/each}
253
+
254
+ {#if linePath}
255
+ <path
256
+ class="st-stepLineChart__line"
257
+ d={linePath}
258
+ fill="none"
259
+ stroke-width="2"
260
+ stroke-linecap="butt"
261
+ stroke-linejoin="round"
262
+ />
263
+ {/if}
264
+
265
+ {#each points as p (p.index)}
266
+ <circle
267
+ class="st-stepLineChart__dot"
268
+ cx={p.x}
269
+ cy={p.y}
270
+ r="4"
271
+ data-chart-index={p.index}
272
+ />
273
+ {/each}
274
+ </svg>
275
+ </div>
276
+
277
+ <ChartDataList {label} items={dataValueItems} />
278
+
279
+ {#if hoveredIndex !== null && points[hoveredIndex]}
280
+ {@const p = points[hoveredIndex]}
281
+ <div
282
+ class="st-stepLineChart__tooltip"
283
+ role="presentation"
284
+ style="left: {(p.x / width) * 100}%; top: {(p.y / height) * 100}%"
285
+ >
286
+ <span class="st-stepLineChart__tooltipLabel">{p.datum.x}</span>
287
+ <span class="st-stepLineChart__tooltipValue">{p.datum.y}</span>
288
+ </div>
289
+ {/if}
290
+ </div>
291
+
292
+ <style>
293
+ .st-stepLineChart {
294
+ color: var(--st-semantic-data-category1);
295
+ display: block;
296
+ font-family: inherit;
297
+ position: relative;
298
+ width: 100%;
299
+ }
300
+
301
+ .st-stepLineChart--category1 { color: var(--st-semantic-data-category1); }
302
+ .st-stepLineChart--category2 { color: var(--st-semantic-data-category2); }
303
+ .st-stepLineChart--category3 { color: var(--st-semantic-data-category3); }
304
+ .st-stepLineChart--category4 { color: var(--st-semantic-data-category4); }
305
+ .st-stepLineChart--category5 { color: var(--st-semantic-data-category5); }
306
+ .st-stepLineChart--category6 { color: var(--st-semantic-data-category6); }
307
+ .st-stepLineChart--category7 { color: var(--st-semantic-data-category7); }
308
+ .st-stepLineChart--category8 { color: var(--st-semantic-data-category8); }
309
+
310
+ .st-stepLineChart svg {
311
+ display: block;
312
+ overflow: visible;
313
+ }
314
+
315
+ .st-stepLineChart__visual {
316
+ display: block;
317
+ }
318
+
319
+ .st-stepLineChart__grid {
320
+ stroke: var(--st-component-stepLineChart-gridStroke, var(--st-semantic-border-subtle));
321
+ stroke-dasharray: 2 3;
322
+ stroke-width: 1;
323
+ opacity: 0.7;
324
+ }
325
+
326
+ .st-stepLineChart__axis {
327
+ stroke: var(--st-component-stepLineChart-axisStroke, var(--st-semantic-border-subtle));
328
+ stroke-width: 1;
329
+ }
330
+
331
+ .st-stepLineChart__tickLabel {
332
+ fill: var(--st-component-stepLineChart-labelColor, var(--st-semantic-text-secondary));
333
+ font-size: 0.6875rem;
334
+ }
335
+
336
+ .st-stepLineChart__line {
337
+ stroke: currentColor;
338
+ }
339
+
340
+ .st-stepLineChart__dot {
341
+ fill: currentColor;
342
+ stroke: var(--st-semantic-surface-default);
343
+ stroke-width: 1.5;
344
+ cursor: pointer;
345
+ transition: r 120ms ease;
346
+ }
347
+
348
+ .st-stepLineChart__dot:hover {
349
+ r: 5.5;
350
+ }
351
+
352
+ .st-stepLineChart__tooltip {
353
+ background: var(--st-component-stepLineChart-tooltipBackground, var(--st-semantic-surface-inverse));
354
+ border-radius: var(--st-radius-sm, 0.25rem);
355
+ color: var(--st-component-stepLineChart-tooltipText, var(--st-semantic-text-inverse));
356
+ display: inline-flex;
357
+ flex-direction: column;
358
+ font-size: 0.75rem;
359
+ gap: 0.125rem;
360
+ line-height: 1.2;
361
+ padding: 0.375rem 0.5rem;
362
+ pointer-events: none;
363
+ position: absolute;
364
+ transform: translate(-50%, calc(-100% - 8px));
365
+ white-space: nowrap;
366
+ z-index: 1;
367
+ }
368
+
369
+ .st-stepLineChart__tooltipLabel {
370
+ font-weight: 600;
371
+ }
372
+
373
+ .st-stepLineChart__tooltipValue {
374
+ opacity: 0.85;
375
+ }
376
+
377
+ @media (prefers-reduced-motion: reduce) {
378
+ .st-stepLineChart__dot {
379
+ transition: none;
380
+ }
381
+ }
382
+ </style>
@@ -0,0 +1,17 @@
1
+ export type StepLineChartTone = "category1" | "category2" | "category3" | "category4" | "category5" | "category6" | "category7" | "category8";
2
+ export type StepLineChartDatum = {
3
+ x: number | string;
4
+ y: number;
5
+ };
6
+ type StepLineChartProps = {
7
+ data: StepLineChartDatum[];
8
+ width?: number;
9
+ height?: number;
10
+ tone?: StepLineChartTone;
11
+ label: string;
12
+ class?: string;
13
+ };
14
+ declare const StepLineChart: import("svelte").Component<StepLineChartProps, {}, "">;
15
+ type StepLineChart = ReturnType<typeof StepLineChart>;
16
+ export default StepLineChart;
17
+ //# sourceMappingURL=StepLineChart.svelte.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"StepLineChart.svelte.d.ts","sourceRoot":"","sources":["../src/lib/StepLineChart.svelte.ts"],"names":[],"mappings":"AAGE,MAAM,MAAM,iBAAiB,GACzB,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,GACX,WAAW,CAAC;AAEhB,MAAM,MAAM,kBAAkB,GAAG;IAC/B,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACnB,CAAC,EAAE,MAAM,CAAC;CACX,CAAC;AAMF,KAAK,kBAAkB,GAAG;IACxB,IAAI,EAAE,kBAAkB,EAAE,CAAC;IAC3B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,IAAI,CAAC,EAAE,iBAAiB,CAAC;IACzB,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB,CAAC;AAsNJ,QAAA,MAAM,aAAa,wDAAwC,CAAC;AAC5D,KAAK,aAAa,GAAG,UAAU,CAAC,OAAO,aAAa,CAAC,CAAC;AACtD,eAAe,aAAa,CAAC"}
package/dist/index.d.ts CHANGED
@@ -13,6 +13,10 @@ export { default as CalendarHeatmapChart } from "./CalendarHeatmapChart.svelte";
13
13
  export { default as BumpChart } from "./BumpChart.svelte";
14
14
  export { default as LollipopChart } from "./LollipopChart.svelte";
15
15
  export { default as ParetoChart } from "./ParetoChart.svelte";
16
+ export { default as StepLineChart } from "./StepLineChart.svelte";
17
+ export type { StepLineChartTone, StepLineChartDatum } from "./StepLineChart.svelte";
18
+ export { default as DivergentBarChart } from "./DivergentBarChart.svelte";
19
+ export type { DivergentBarChartTone, DivergentBarChartDatum } from "./DivergentBarChart.svelte";
16
20
  export { default as Alert } from "./Alert.svelte";
17
21
  export { default as AreaChart } from "./AreaChart.svelte";
18
22
  export { default as AspectRatio } from "./AspectRatio.svelte";
@@ -114,6 +118,7 @@ export { default as SkeletonText } from "./SkeletonText.svelte";
114
118
  export { default as SkipLink } from "./SkipLink.svelte";
115
119
  export { default as SlideIndicator } from "./SlideIndicator.svelte";
116
120
  export { default as Slider } from "./Slider.svelte";
121
+ export { default as RangeSlider } from "./RangeSlider.svelte";
117
122
  export { default as SankeyChart } from "./SankeyChart.svelte";
118
123
  export { default as Stack } from "./Stack.svelte";
119
124
  export { default as Stepper } from "./Stepper.svelte";
@@ -225,4 +230,5 @@ export type { PopperProps, PopperPlacement, PopperStrategy } from "./Popper.svel
225
230
  export type { FilterPillProps, FilterPillTone } from "./FilterPill.svelte";
226
231
  export type { FilterBarProps } from "./FilterBar.svelte";
227
232
  export type { SelectionChipProps, SelectionChipTone } from "./SelectionChip.svelte";
233
+ export type { RangeSliderProps, RangeSliderSize } from "./RangeSlider.svelte";
228
234
  //# sourceMappingURL=index.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/lib/index.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/lib/index.ts"],"names":[],"mappings":"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"}
package/dist/index.js CHANGED
@@ -10,6 +10,8 @@ export { default as CalendarHeatmapChart } from "./CalendarHeatmapChart.svelte";
10
10
  export { default as BumpChart } from "./BumpChart.svelte";
11
11
  export { default as LollipopChart } from "./LollipopChart.svelte";
12
12
  export { default as ParetoChart } from "./ParetoChart.svelte";
13
+ export { default as StepLineChart } from "./StepLineChart.svelte";
14
+ export { default as DivergentBarChart } from "./DivergentBarChart.svelte";
13
15
  export { default as Alert } from "./Alert.svelte";
14
16
  export { default as AreaChart } from "./AreaChart.svelte";
15
17
  export { default as AspectRatio } from "./AspectRatio.svelte";
@@ -111,6 +113,7 @@ export { default as SkeletonText } from "./SkeletonText.svelte";
111
113
  export { default as SkipLink } from "./SkipLink.svelte";
112
114
  export { default as SlideIndicator } from "./SlideIndicator.svelte";
113
115
  export { default as Slider } from "./Slider.svelte";
116
+ export { default as RangeSlider } from "./RangeSlider.svelte";
114
117
  export { default as SankeyChart } from "./SankeyChart.svelte";
115
118
  export { default as Stack } from "./Stack.svelte";
116
119
  export { default as Stepper } from "./Stepper.svelte";
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@sentropic/design-system-svelte",
3
- "version": "0.25.1",
3
+ "version": "0.27.0",
4
4
  "type": "module",
5
5
  "publishConfig": {
6
6
  "access": "public"