@geoffcox/sterling-svelte 0.0.20 → 0.0.22

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 (103) hide show
  1. package/Button.constants.d.ts +2 -0
  2. package/Button.constants.js +2 -0
  3. package/Button.svelte +11 -0
  4. package/Button.svelte.d.ts +10 -5
  5. package/Button.types.d.ts +6 -2
  6. package/Checkbox.svelte +16 -3
  7. package/Checkbox.svelte.d.ts +8 -0
  8. package/Dialog.svelte +2 -3
  9. package/Dropdown.svelte +11 -2
  10. package/Dropdown.svelte.d.ts +6 -0
  11. package/Field.constants.d.ts +1 -0
  12. package/Field.constants.js +1 -0
  13. package/Field.svelte +25 -10
  14. package/Field.svelte.d.ts +10 -4
  15. package/Field.types.d.ts +4 -1
  16. package/Input.svelte +27 -3
  17. package/Input.svelte.d.ts +12 -0
  18. package/Label.svelte +12 -2
  19. package/Label.svelte.d.ts +9 -1
  20. package/Link.constants.d.ts +1 -0
  21. package/Link.constants.js +1 -0
  22. package/Link.svelte +11 -0
  23. package/Link.svelte.d.ts +8 -3
  24. package/Link.types.d.ts +4 -1
  25. package/List.constants.d.ts +1 -1
  26. package/List.constants.js +1 -1
  27. package/List.svelte +13 -10
  28. package/List.svelte.d.ts +6 -2
  29. package/ListItem.svelte +11 -2
  30. package/ListItem.svelte.d.ts +6 -0
  31. package/Menu.svelte +46 -12
  32. package/Menu.svelte.d.ts +26 -0
  33. package/MenuBar.constants.d.ts +1 -0
  34. package/MenuBar.constants.js +1 -0
  35. package/MenuBar.svelte +12 -3
  36. package/MenuBar.svelte.d.ts +5 -1
  37. package/MenuBar.types.d.ts +4 -0
  38. package/MenuButton.svelte +45 -11
  39. package/MenuButton.svelte.d.ts +12 -4
  40. package/MenuItem.constants.d.ts +1 -0
  41. package/MenuItem.constants.js +1 -0
  42. package/MenuItem.svelte +20 -10
  43. package/MenuItem.svelte.d.ts +12 -3
  44. package/{Menus.types.d.ts → MenuItem.types.d.ts} +0 -4
  45. package/MenuItem.types.js +1 -0
  46. package/{Menus.utils.d.ts → MenuItem.utils.d.ts} +1 -1
  47. package/Progress.constants.d.ts +1 -0
  48. package/Progress.constants.js +1 -0
  49. package/Progress.svelte +16 -3
  50. package/Progress.svelte.d.ts +15 -3
  51. package/Progress.types.d.ts +4 -1
  52. package/Radio.svelte +16 -3
  53. package/Radio.svelte.d.ts +8 -0
  54. package/Select.svelte +17 -3
  55. package/Select.svelte.d.ts +10 -0
  56. package/Slider.svelte +9 -0
  57. package/Slider.svelte.d.ts +6 -0
  58. package/Switch.svelte +14 -3
  59. package/Switch.svelte.d.ts +6 -0
  60. package/Tab.svelte +11 -2
  61. package/Tab.svelte.d.ts +6 -0
  62. package/TabList.constants.d.ts +1 -1
  63. package/TabList.constants.js +1 -1
  64. package/TabList.svelte +8 -2
  65. package/TabList.svelte.d.ts +4 -0
  66. package/TextArea.constants.d.ts +1 -0
  67. package/TextArea.constants.js +1 -0
  68. package/TextArea.svelte +22 -0
  69. package/TextArea.svelte.d.ts +13 -2
  70. package/TextArea.types.d.ts +4 -1
  71. package/Tooltip.constants.d.ts +1 -0
  72. package/Tooltip.constants.js +1 -0
  73. package/Tooltip.svelte +26 -10
  74. package/Tooltip.svelte.d.ts +7 -3
  75. package/Tooltip.types.d.ts +4 -3
  76. package/Tree.constants.d.ts +2 -2
  77. package/Tree.constants.js +2 -2
  78. package/Tree.svelte +41 -7
  79. package/Tree.svelte.d.ts +34 -1
  80. package/Tree.types.d.ts +4 -16
  81. package/TreeChevron.svelte +33 -2
  82. package/TreeChevron.svelte.d.ts +27 -0
  83. package/TreeItem.svelte +76 -52
  84. package/TreeItem.svelte.d.ts +26 -3
  85. package/TreeItem.types.d.ts +13 -0
  86. package/TreeItem.types.js +1 -0
  87. package/TreeItemDisplay.svelte +12 -0
  88. package/TreeItemDisplay.svelte.d.ts +6 -0
  89. package/floating-ui.constants.d.ts +1 -0
  90. package/floating-ui.constants.js +14 -0
  91. package/floating-ui.types.d.ts +2 -0
  92. package/floating-ui.types.js +1 -0
  93. package/idGenerator.d.ts +4 -0
  94. package/idGenerator.js +10 -0
  95. package/index.d.ts +19 -7
  96. package/index.js +14 -5
  97. package/package.json +21 -11
  98. package/theme/toggleDarkTheme.d.ts +1 -1
  99. package/theme/toggleDarkTheme.js +1 -1
  100. package/Menus.constants.d.ts +0 -2
  101. package/Menus.constants.js +0 -2
  102. /package/{Menus.types.js → MenuBar.types.js} +0 -0
  103. /package/{Menus.utils.js → MenuItem.utils.js} +0 -0
package/Tree.svelte.d.ts CHANGED
@@ -1,24 +1,57 @@
1
1
  import { SvelteComponentTyped } from "svelte";
2
2
  declare const __propDef: {
3
3
  props: {
4
+ [x: string]: any;
4
5
  composed?: boolean | undefined;
5
6
  disabled?: boolean | undefined;
6
7
  selectedValue?: string | undefined;
7
8
  expandedValues?: string[] | undefined;
9
+ blur?: (() => void) | undefined;
10
+ focus?: ((options?: FocusOptions) => void) | undefined;
8
11
  };
9
12
  events: {
13
+ blur: FocusEvent;
14
+ click: MouseEvent;
15
+ dblclick: MouseEvent;
16
+ focus: FocusEvent;
17
+ focusin: FocusEvent;
18
+ focusout: FocusEvent;
19
+ keydown: KeyboardEvent;
20
+ keypress: KeyboardEvent;
21
+ keyup: KeyboardEvent;
22
+ mousedown: MouseEvent;
23
+ mouseenter: MouseEvent;
24
+ mouseleave: MouseEvent;
25
+ mousemove: MouseEvent;
26
+ mouseover: MouseEvent;
27
+ mouseout: MouseEvent;
28
+ mouseup: MouseEvent;
29
+ pointercancel: PointerEvent;
30
+ pointerdown: PointerEvent;
31
+ pointerenter: PointerEvent;
32
+ pointerleave: PointerEvent;
33
+ pointermove: PointerEvent;
34
+ pointerover: PointerEvent;
35
+ pointerout: PointerEvent;
36
+ pointerup: PointerEvent;
37
+ wheel: WheelEvent;
10
38
  expandCollapse: CustomEvent<any>;
11
39
  select: CustomEvent<any>;
12
40
  } & {
13
41
  [evt: string]: CustomEvent<any>;
14
42
  };
15
43
  slots: {
16
- default: {};
44
+ default: {
45
+ composed: boolean;
46
+ disabled: boolean;
47
+ };
17
48
  };
18
49
  };
19
50
  export type TreeProps = typeof __propDef.props;
20
51
  export type TreeEvents = typeof __propDef.events;
21
52
  export type TreeSlots = typeof __propDef.slots;
22
53
  export default class Tree extends SvelteComponentTyped<TreeProps, TreeEvents, TreeSlots> {
54
+ get blur(): () => void;
55
+ get focus(): (options?: FocusOptions | undefined) => void;
23
56
  }
24
57
  export {};
package/Tree.types.d.ts CHANGED
@@ -3,26 +3,14 @@ import type { Readable, Writable } from 'svelte/store';
3
3
  * Context for a Tree and its tree items.
4
4
  */
5
5
  export type TreeContext = {
6
+ /** If the tree is disabled */
7
+ disabled: Readable<boolean>;
6
8
  /**
7
- * The IDs of the expanded ttree tree items.
9
+ * The values of the expanded tree tree items.
8
10
  */
9
11
  expandedValues: Writable<string[]>;
10
12
  /**
11
- * The ID of the selected tree tree item.
13
+ * The value of the selected tree item.
12
14
  */
13
15
  selectedValue: Writable<string | undefined>;
14
- /** If the tree is disabled */
15
- disabled: Readable<boolean>;
16
- };
17
- /**
18
- * The context for a tree item.
19
- */
20
- export type TreeItemContext = {
21
- /**
22
- * How many levels deep this tree item is in the tree hierarchy.
23
- * A top level item's depth is zero.
24
- */
25
- depth: number;
26
- /** If the tree item is disabled */
27
- disabled: Readable<boolean>;
28
16
  };
@@ -6,7 +6,7 @@ let mounted = false;
6
6
  onMount(() => {
7
7
  setTimeout(() => {
8
8
  mounted = true;
9
- }, 10);
9
+ }, 0);
10
10
  });
11
11
  let animate = false;
12
12
  $: {
@@ -17,7 +17,38 @@ $: {
17
17
  }
18
18
  </script>
19
19
 
20
- <div class="tree-chevron" class:leaf={!hasChildren} class:animate class:expanded />
20
+ <div
21
+ class="tree-chevron"
22
+ class:leaf={!hasChildren}
23
+ class:animate
24
+ class:expanded
25
+ on:blur
26
+ on:click
27
+ on:dblclick
28
+ on:focus
29
+ on:focusin
30
+ on:focusout
31
+ on:keydown
32
+ on:keypress
33
+ on:keyup
34
+ on:mousedown
35
+ on:mouseenter
36
+ on:mouseleave
37
+ on:mousemove
38
+ on:mouseover
39
+ on:mouseout
40
+ on:mouseup
41
+ on:pointercancel
42
+ on:pointerdown
43
+ on:pointerenter
44
+ on:pointerleave
45
+ on:pointermove
46
+ on:pointerover
47
+ on:pointerout
48
+ on:pointerup
49
+ on:wheel
50
+ {...$$restProps}
51
+ />
21
52
 
22
53
  <style>
23
54
  .tree-chevron {
@@ -1,10 +1,37 @@
1
1
  import { SvelteComponentTyped } from "svelte";
2
2
  declare const __propDef: {
3
3
  props: {
4
+ [x: string]: any;
4
5
  expanded?: boolean | undefined;
5
6
  hasChildren?: boolean | undefined;
6
7
  };
7
8
  events: {
9
+ blur: FocusEvent;
10
+ click: MouseEvent;
11
+ dblclick: MouseEvent;
12
+ focus: FocusEvent;
13
+ focusin: FocusEvent;
14
+ focusout: FocusEvent;
15
+ keydown: KeyboardEvent;
16
+ keypress: KeyboardEvent;
17
+ keyup: KeyboardEvent;
18
+ mousedown: MouseEvent;
19
+ mouseenter: MouseEvent;
20
+ mouseleave: MouseEvent;
21
+ mousemove: MouseEvent;
22
+ mouseover: MouseEvent;
23
+ mouseout: MouseEvent;
24
+ mouseup: MouseEvent;
25
+ pointercancel: PointerEvent;
26
+ pointerdown: PointerEvent;
27
+ pointerenter: PointerEvent;
28
+ pointerleave: PointerEvent;
29
+ pointermove: PointerEvent;
30
+ pointerover: PointerEvent;
31
+ pointerout: PointerEvent;
32
+ pointerup: PointerEvent;
33
+ wheel: WheelEvent;
34
+ } & {
8
35
  [evt: string]: CustomEvent<any>;
9
36
  };
10
37
  slots: {};
package/TreeItem.svelte CHANGED
@@ -1,6 +1,6 @@
1
1
  <script>import { getContext, setContext } from "svelte";
2
2
  import { slide } from "svelte/transition";
3
- import { treeContextKey, treeItemContextKey } from "./Tree.constants";
3
+ import { TREE_CONTEXT_KEY, TREE_ITEM_CONTEXT_KEY } from "./Tree.constants";
4
4
  import TreeItemDisplay from "./TreeItemDisplay.svelte";
5
5
  import { writable } from "svelte/store";
6
6
  export let disabled = false;
@@ -9,8 +9,8 @@ const {
9
9
  expandedValues,
10
10
  selectedValue,
11
11
  disabled: treeDisabled
12
- } = getContext(treeContextKey);
13
- const { depth = 0, disabled: parentDisabled } = getContext(treeItemContextKey) || {};
12
+ } = getContext(TREE_CONTEXT_KEY);
13
+ const { depth = 0, disabled: parentDisabled } = getContext(TREE_ITEM_CONTEXT_KEY) || {};
14
14
  let treeItemRef;
15
15
  $:
16
16
  hasChildren = $$slots.default;
@@ -26,7 +26,7 @@ $: {
26
26
  }
27
27
  const collapseItem = (index) => {
28
28
  if (!disabled) {
29
- index = index ?? $expandedValues.findIndex((id) => id === value);
29
+ index = index ?? $expandedValues.findIndex((expandedValue) => expandedValue === value);
30
30
  if (index !== -1) {
31
31
  expandedValues.set([
32
32
  ...$expandedValues.slice(0, index),
@@ -37,9 +37,10 @@ const collapseItem = (index) => {
37
37
  }
38
38
  return false;
39
39
  };
40
+ export const collapse = () => collapseItem();
40
41
  const expandItem = (index) => {
41
42
  if (!disabled) {
42
- index = index ?? $expandedValues.findIndex((id) => id === value);
43
+ index = index ?? $expandedValues.findIndex((expandedValue) => expandedValue === value);
43
44
  if (index === -1) {
44
45
  expandedValues.set([...$expandedValues, value]);
45
46
  return true;
@@ -47,42 +48,93 @@ const expandItem = (index) => {
47
48
  }
48
49
  return false;
49
50
  };
50
- const toggleExpanded = () => {
51
+ export const expand = () => expandItem();
52
+ export const toggleExpanded = () => {
51
53
  if (!disabled) {
52
- const index = $expandedValues.findIndex((id) => id === value);
54
+ const index = $expandedValues.findIndex((expandedValue) => expandedValue === value);
53
55
  return index !== -1 ? collapseItem(index) : expandItem(index);
54
56
  }
55
57
  return false;
56
58
  };
57
- const focusItem = (treeItemElement) => {
59
+ const blurItem = (treeItemElement) => {
58
60
  if (!_disabled) {
59
- const item = treeItemElement.querySelector(".item");
60
- item?.focus();
61
+ const item = treeItemElement?.querySelector(".item");
62
+ item?.blur();
61
63
  }
62
64
  };
63
- const selectItemById = (value2) => {
65
+ export const blur = () => {
66
+ blurItem(treeItemRef);
67
+ };
68
+ const focusItem = (treeItemElement, options) => {
69
+ if (!_disabled) {
70
+ const item = treeItemElement?.querySelector(".item");
71
+ item?.focus(options);
72
+ }
73
+ };
74
+ export const focus = (options) => {
75
+ focusItem(treeItemRef);
76
+ treeItemRef?.focus(options);
77
+ };
78
+ const clickItem = (treeItemElement) => {
79
+ if (!_disabled) {
80
+ const item = treeItemElement?.querySelector(".item");
81
+ item?.click();
82
+ }
83
+ };
84
+ export const click = () => {
85
+ clickItem(treeItemRef);
86
+ };
87
+ const selectItemByValue = (value2) => {
64
88
  if (!_disabled) {
65
89
  selectedValue.set(value2);
66
90
  }
67
91
  };
68
- export const selectItem = () => {
92
+ export const select = () => {
69
93
  if (!_disabled) {
70
- selectItemById(value);
94
+ selectItemByValue(value);
71
95
  }
72
96
  };
73
- const selectParentItem = () => {
97
+ export const selectParent = () => {
74
98
  if (!_disabled) {
75
99
  let candidate = treeItemRef.parentElement?.closest('[role="treeitem"][data-value]');
76
100
  let candidateValue = candidate?.getAttribute("data-value");
77
101
  if (candidateValue && candidate) {
78
- selectItemById(candidateValue);
102
+ selectItemByValue(candidateValue);
79
103
  focusItem(candidate);
80
104
  return true;
81
105
  }
82
106
  }
83
107
  return false;
84
108
  };
85
- const selectNextItem = () => {
109
+ export const selectPrevious = () => {
110
+ if (!_disabled) {
111
+ let candidate = void 0;
112
+ let candidateValue = void 0;
113
+ const previousSibling = treeItemRef?.previousElementSibling;
114
+ if (previousSibling) {
115
+ const decendants = previousSibling.querySelectorAll('[role="treeitem"][data-value]');
116
+ if (decendants) {
117
+ candidate = decendants[decendants.length - 1];
118
+ candidateValue = candidate?.getAttribute("data-value");
119
+ }
120
+ if (!candidateValue) {
121
+ candidate = previousSibling;
122
+ candidateValue = candidate?.getAttribute("data-value");
123
+ }
124
+ }
125
+ if (!candidateValue) {
126
+ candidate = treeItemRef.parentElement?.closest('[role="treeitem"][data-value]');
127
+ candidateValue = candidate?.getAttribute("data-value");
128
+ }
129
+ if (candidateValue && candidate) {
130
+ selectItemByValue(candidateValue);
131
+ focusItem(candidate);
132
+ return true;
133
+ }
134
+ }
135
+ return false;
136
+ };
137
+ export const selectNext = () => {
86
138
  if (!_disabled) {
87
139
  let candidateValue = void 0;
88
140
  let candidate = treeItemRef.querySelector('[role="treeitem"][data-value]');
@@ -105,35 +157,7 @@ const selectNextItem = () => {
105
157
  }
106
158
  }
107
159
  if (candidateValue && candidate) {
108
- selectItemById(candidateValue);
109
- focusItem(candidate);
110
- return true;
111
- }
112
- }
113
- return false;
114
- };
115
- const selectPreviousItem = () => {
116
- if (!_disabled) {
117
- let candidate = void 0;
118
- let candidateValue = void 0;
119
- const previousSibling = treeItemRef?.previousElementSibling;
120
- if (previousSibling) {
121
- const decendants = previousSibling.querySelectorAll('[role="treeitem"][data-value]');
122
- if (decendants) {
123
- candidate = decendants[decendants.length - 1];
124
- candidateValue = candidate?.getAttribute("data-value");
125
- }
126
- if (!candidateValue) {
127
- candidate = previousSibling;
128
- candidateValue = candidate?.getAttribute("data-value");
129
- }
130
- }
131
- if (!candidateValue) {
132
- candidate = treeItemRef.parentElement?.closest('[role="treeitem"][data-value]');
133
- candidateValue = candidate?.getAttribute("data-value");
134
- }
135
- if (candidateValue && candidate) {
136
- selectItemById(candidateValue);
160
+ selectItemByValue(candidateValue);
137
161
  focusItem(candidate);
138
162
  return true;
139
163
  }
@@ -143,7 +167,7 @@ const selectPreviousItem = () => {
143
167
  const onClick = () => {
144
168
  if (!_disabled) {
145
169
  toggleExpanded();
146
- selectItem();
170
+ select();
147
171
  }
148
172
  };
149
173
  const onKeydown = (event) => {
@@ -160,7 +184,7 @@ const onKeydown = (event) => {
160
184
  case "ArrowRight":
161
185
  if (hasChildren) {
162
186
  if (expanded) {
163
- if (selectNextItem()) {
187
+ if (selectNext()) {
164
188
  event.preventDefault();
165
189
  event.stopPropagation();
166
190
  return false;
@@ -179,21 +203,21 @@ const onKeydown = (event) => {
179
203
  event.stopPropagation();
180
204
  return false;
181
205
  }
182
- } else if (selectParentItem()) {
206
+ } else if (selectParent()) {
183
207
  event.preventDefault();
184
208
  event.stopPropagation();
185
209
  return false;
186
210
  }
187
211
  break;
188
212
  case "ArrowUp":
189
- if (selectPreviousItem()) {
213
+ if (selectPrevious()) {
190
214
  event.preventDefault();
191
215
  event.stopPropagation();
192
216
  return false;
193
217
  }
194
218
  break;
195
219
  case "ArrowDown":
196
- if (selectNextItem()) {
220
+ if (selectNext()) {
197
221
  event.preventDefault();
198
222
  event.stopPropagation();
199
223
  return false;
@@ -202,7 +226,7 @@ const onKeydown = (event) => {
202
226
  }
203
227
  }
204
228
  };
205
- setContext(treeItemContextKey, { depth: depth + 1, disabled: disabledStore });
229
+ setContext(TREE_ITEM_CONTEXT_KEY, { depth: depth + 1, disabled: disabledStore });
206
230
  </script>
207
231
 
208
232
  <!--
@@ -264,7 +288,7 @@ A item in a Tree displaying the item and children.
264
288
  </div>
265
289
  {#if expanded && hasChildren}
266
290
  <div class="children" transition:slide={{ duration: 200 }} role="group">
267
- <slot />
291
+ <slot {depth} {disabled} {selected} {value} />
268
292
  </div>
269
293
  {/if}
270
294
  </div>
@@ -4,7 +4,16 @@ declare const __propDef: {
4
4
  [x: string]: any;
5
5
  disabled?: boolean | undefined;
6
6
  value: string;
7
- selectItem?: (() => void) | undefined;
7
+ collapse?: (() => boolean) | undefined;
8
+ expand?: (() => boolean) | undefined;
9
+ toggleExpanded?: (() => boolean) | undefined;
10
+ blur?: (() => void) | undefined;
11
+ focus?: ((options?: FocusOptions) => void) | undefined;
12
+ click?: (() => void) | undefined;
13
+ select?: (() => void) | undefined;
14
+ selectParent?: (() => boolean) | undefined;
15
+ selectPrevious?: (() => boolean) | undefined;
16
+ selectNext?: (() => boolean) | undefined;
8
17
  };
9
18
  events: {
10
19
  blur: FocusEvent;
@@ -52,7 +61,12 @@ declare const __propDef: {
52
61
  selected: boolean;
53
62
  value: string;
54
63
  };
55
- default: {};
64
+ default: {
65
+ depth: number;
66
+ disabled: boolean;
67
+ selected: boolean;
68
+ value: string;
69
+ };
56
70
  };
57
71
  };
58
72
  export type TreeItemProps = typeof __propDef.props;
@@ -60,6 +74,15 @@ export type TreeItemEvents = typeof __propDef.events;
60
74
  export type TreeItemSlots = typeof __propDef.slots;
61
75
  /** A item in a Tree displaying the item and children. */
62
76
  export default class TreeItem extends SvelteComponentTyped<TreeItemProps, TreeItemEvents, TreeItemSlots> {
63
- get selectItem(): () => void;
77
+ get collapse(): () => boolean;
78
+ get expand(): () => boolean;
79
+ get toggleExpanded(): () => boolean;
80
+ get blur(): () => void;
81
+ get focus(): (options?: FocusOptions | undefined) => void;
82
+ get click(): () => void;
83
+ get select(): () => void;
84
+ get selectParent(): () => boolean;
85
+ get selectPrevious(): () => boolean;
86
+ get selectNext(): () => boolean;
64
87
  }
65
88
  export {};
@@ -0,0 +1,13 @@
1
+ import type { Readable } from 'svelte/store';
2
+ /**
3
+ * The context for a tree item.
4
+ */
5
+ export type TreeItemContext = {
6
+ /**
7
+ * How many levels deep this tree item is in the tree hierarchy.
8
+ * A top level item's depth is zero.
9
+ */
10
+ depth: number;
11
+ /** If the tree item is disabled */
12
+ disabled: Readable<boolean>;
13
+ };
@@ -0,0 +1 @@
1
+ export {};
@@ -5,9 +5,20 @@ export let expanded = false;
5
5
  export let hasChildren = false;
6
6
  export let value;
7
7
  export let selected = false;
8
+ let divRef;
9
+ export const click = () => {
10
+ divRef?.click();
11
+ };
12
+ export const blur = () => {
13
+ divRef?.blur();
14
+ };
15
+ export const focus = (options) => {
16
+ divRef?.focus(options);
17
+ };
8
18
  </script>
9
19
 
10
20
  <div
21
+ bind:this={divRef}
11
22
  class="sterling-tree-item"
12
23
  class:disabled
13
24
  class:expanded
@@ -74,6 +85,7 @@ export let selected = false;
74
85
  }
75
86
 
76
87
  .sterling-tree-item.disabled {
88
+ background-color: var(--stsv-Input__background-color--disabled);
77
89
  color: var(--stsv-Common__color--disabled);
78
90
  cursor: not-allowed;
79
91
  }
@@ -8,6 +8,9 @@ declare const __propDef: {
8
8
  hasChildren?: boolean | undefined;
9
9
  value: string;
10
10
  selected?: boolean | undefined;
11
+ click?: (() => void) | undefined;
12
+ blur?: (() => void) | undefined;
13
+ focus?: ((options?: FocusOptions) => void) | undefined;
11
14
  };
12
15
  events: {
13
16
  blur: FocusEvent;
@@ -53,5 +56,8 @@ export type TreeItemDisplayProps = typeof __propDef.props;
53
56
  export type TreeItemDisplayEvents = typeof __propDef.events;
54
57
  export type TreeItemDisplaySlots = typeof __propDef.slots;
55
58
  export default class TreeItemDisplay extends SvelteComponentTyped<TreeItemDisplayProps, TreeItemDisplayEvents, TreeItemDisplaySlots> {
59
+ get click(): () => void;
60
+ get blur(): () => void;
61
+ get focus(): (options?: FocusOptions | undefined) => void;
56
62
  }
57
63
  export {};
@@ -0,0 +1 @@
1
+ export declare const FLOATING_PLACEMENTS: string[];
@@ -0,0 +1,14 @@
1
+ export const FLOATING_PLACEMENTS = [
2
+ 'top',
3
+ 'right',
4
+ 'bottom',
5
+ 'left',
6
+ 'top-start',
7
+ 'right-start',
8
+ 'bottom-start',
9
+ 'left-start',
10
+ 'top-end',
11
+ 'right-end',
12
+ 'bottom-end',
13
+ 'left-end'
14
+ ];
@@ -0,0 +1,2 @@
1
+ import type { Placement } from '@floating-ui/dom';
2
+ export type FloatingPlacement = Placement;
@@ -0,0 +1 @@
1
+ export {};
@@ -0,0 +1,4 @@
1
+ export declare const idGenerator: {
2
+ next: () => number;
3
+ nextId: (prefix?: string) => string;
4
+ };
package/idGenerator.js ADDED
@@ -0,0 +1,10 @@
1
+ let id = 0;
2
+ const next = () => {
3
+ return ++id;
4
+ };
5
+ export const idGenerator = {
6
+ next,
7
+ nextId: (prefix) => {
8
+ return prefix ? `${prefix}-${next()}` : `${next()}`;
9
+ }
10
+ };
package/index.d.ts CHANGED
@@ -1,6 +1,7 @@
1
1
  export { clickOutside } from './actions/clickOutside';
2
2
  export { forwardEvents } from './actions/forwardEvents';
3
3
  export { portal } from './actions/portal';
4
+ export { idGenerator } from './idGenerator';
4
5
  export { type Theme, type ThemeActionParams } from './theme/types';
5
6
  export { applyDarkTheme } from './theme/applyDarkTheme';
6
7
  export { applyLightTheme } from './theme/applyLightTheme';
@@ -9,20 +10,31 @@ export { darkTheme } from './theme/darkTheme';
9
10
  export { lightTheme } from './theme/lightTheme';
10
11
  export { neutralColors, lightStatusColors, darkStatusColors } from './theme/colors';
11
12
  export { toggleDarkTheme } from './theme/toggleDarkTheme';
12
- export { menuBarContextKey, menuItemContextKey } from './Menus.constants';
13
13
  export type { ButtonVariant, ButtonShape } from './Button.types';
14
14
  export type { FieldStatus } from './Field.types';
15
+ export type { FloatingPlacement } from './floating-ui.types';
15
16
  export type { LinkVariant } from './Link.types';
16
17
  export type { ListContext } from './List.types';
17
- export type { MenuBarContext, MenuItemContext, MenuItemRegistration } from './Menus.types';
18
+ export type { MenuBarContext } from './MenuBar.types';
19
+ export type { MenuItemContext, MenuItemRegistration } from './MenuItem.types';
18
20
  export type { ProgressColorful } from './Progress.types';
19
21
  export type { TabListContext } from './TabList.types';
20
22
  export type { TextAreaResize } from './TextArea.types';
21
- export type { TooltipAutoShow, TooltipPlacement } from './Tooltip.types';
22
- export type { TreeContext, TreeItemContext } from './Tree.types';
23
- export { listContextKey } from './List.constants';
24
- export { tabListContextKey } from './TabList.constants';
25
- export { treeContextKey, treeItemContextKey } from './Tree.constants';
23
+ export type { TooltipShowOn } from './Tooltip.types';
24
+ export type { TreeContext } from './Tree.types';
25
+ export type { TreeItemContext } from './TreeItem.types';
26
+ export { BUTTON_SHAPES, BUTTON_VARIANTS } from './Button.constants';
27
+ export { FIELD_STATUSES } from './Field.constants';
28
+ export { FLOATING_PLACEMENTS } from './floating-ui.constants';
29
+ export { LINK_VARIANTS } from './Link.constants';
30
+ export { LIST_CONTEXT_KEY } from './List.constants';
31
+ export { MENU_BAR_CONTEXT_KEY } from './MenuBar.constants';
32
+ export { MENU_ITEM_CONTEXT_KEY } from './MenuItem.constants';
33
+ export { PROGRESS_COLORFULS } from './Progress.constants';
34
+ export { TAB_LIST_CONTEXT_KEY } from './TabList.constants';
35
+ export { TEXT_AREA_RESIZES } from './TextArea.constants';
36
+ export { TOOLTIP_SHOW_ONS } from './Tooltip.constants';
37
+ export { TREE_CONTEXT_KEY as treeContextKey, TREE_ITEM_CONTEXT_KEY as treeItemContextKey } from './Tree.constants';
26
38
  import Button from './Button.svelte';
27
39
  import Checkbox from './Checkbox.svelte';
28
40
  import Dialog from './Dialog.svelte';
package/index.js CHANGED
@@ -2,6 +2,8 @@
2
2
  export { clickOutside } from './actions/clickOutside';
3
3
  export { forwardEvents } from './actions/forwardEvents';
4
4
  export { portal } from './actions/portal';
5
+ // ----- functions ----- //
6
+ export { idGenerator } from './idGenerator';
5
7
  // ----- theme ----- //
6
8
  export {} from './theme/types';
7
9
  export { applyDarkTheme } from './theme/applyDarkTheme';
@@ -11,12 +13,19 @@ export { darkTheme } from './theme/darkTheme';
11
13
  export { lightTheme } from './theme/lightTheme';
12
14
  export { neutralColors, lightStatusColors, darkStatusColors } from './theme/colors';
13
15
  export { toggleDarkTheme } from './theme/toggleDarkTheme';
14
- // ----- Button ----- //
15
- export { menuBarContextKey, menuItemContextKey } from './Menus.constants';
16
16
  // ----- Component constants ----- //
17
- export { listContextKey } from './List.constants';
18
- export { tabListContextKey } from './TabList.constants';
19
- export { treeContextKey, treeItemContextKey } from './Tree.constants';
17
+ export { BUTTON_SHAPES, BUTTON_VARIANTS } from './Button.constants';
18
+ export { FIELD_STATUSES } from './Field.constants';
19
+ export { FLOATING_PLACEMENTS } from './floating-ui.constants';
20
+ export { LINK_VARIANTS } from './Link.constants';
21
+ export { LIST_CONTEXT_KEY } from './List.constants';
22
+ export { MENU_BAR_CONTEXT_KEY } from './MenuBar.constants';
23
+ export { MENU_ITEM_CONTEXT_KEY } from './MenuItem.constants';
24
+ export { PROGRESS_COLORFULS } from './Progress.constants';
25
+ export { TAB_LIST_CONTEXT_KEY } from './TabList.constants';
26
+ export { TEXT_AREA_RESIZES } from './TextArea.constants';
27
+ export { TOOLTIP_SHOW_ONS } from './Tooltip.constants';
28
+ export { TREE_CONTEXT_KEY as treeContextKey, TREE_ITEM_CONTEXT_KEY as treeItemContextKey } from './Tree.constants';
20
29
  // ----- Components ----- //
21
30
  import Button from './Button.svelte';
22
31
  import Checkbox from './Checkbox.svelte';