intelliwaketssveltekitv25 0.1.61 → 0.1.63

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.
@@ -104,7 +104,7 @@ export declare const MasterDetailSubItemBuild: (item: TListGroupItem, items: TLi
104
104
  disabled?: boolean | null;
105
105
  search?: string;
106
106
  feature?: string | null;
107
- otherFilter?: ((item: TListGroupItem) => boolean);
107
+ otherFilter?: (item: TListGroupItem) => boolean;
108
108
  }) => TListGroupItem;
109
109
  export interface ITabHref {
110
110
  faProps?: IFAProps;
@@ -159,3 +159,7 @@ export declare const ShowMessageBox: Pick<Writable<IMessageBoxStore[]>, "subscri
159
159
  export type TChatBubblePosition = 'Right' | 'Left' | 'Top' | 'Bottom';
160
160
  export type TDropDownControlPosition = 'Right' | 'Left' | 'Center' | 'CenterForce' | null;
161
161
  export type TDropDownControlDrop = 'Up' | 'Down' | null;
162
+ export type TGenericMultiSelect = {
163
+ name?: string | null;
164
+ id?: string | number | null;
165
+ } & Record<string, any>;
@@ -5,30 +5,31 @@ export const MasterDetailSubItemBuild = (item, items, collapsedValues, options)
5
5
  ...item,
6
6
  collapsed: (collapsedValues ?? []).includes(item.value),
7
7
  subs: items
8
- .filter(sub_item => !!sub_item.parent_value && sub_item.parent_value === item.value)
8
+ .filter((sub_item) => !!sub_item.parent_value && sub_item.parent_value === item.value)
9
9
  .sort((a, b) => SortCompareNull(!b.disabled, !a.disabled) ??
10
10
  SortCompareNull(a.title, b.title) ??
11
11
  SortCompare(a.value, b.value))
12
- .map(sub_item => MasterDetailSubItemBuild(sub_item, items, collapsedValues, options))
13
- .filter(sub_item => SearchRow(sub_item, options?.search ?? '') &&
12
+ .map((sub_item) => MasterDetailSubItemBuild(sub_item, items, collapsedValues, options))
13
+ .filter((sub_item) => SearchRow(sub_item, options?.search ?? '') &&
14
14
  (!!(sub_item.subs ?? []).length ||
15
- ((options?.disabled === undefined ?
16
- (!!options?.start_date && !!options?.end_date) ?
17
- ((!sub_item.start_date || DateCompare(sub_item.start_date, 'IsSameOrBefore', options.end_date, 'day')) &&
18
- (!sub_item.end_date || DateCompare(sub_item.end_date, 'IsSameOrAfter', options.start_date, 'day')))
19
- :
20
- ((options?.disabled ?? null) === null || sub_item.disabled === options?.disabled) :
21
- ((options?.disabled ?? null) === null || sub_item.disabled === options?.disabled)) &&
15
+ ((options?.disabled === undefined
16
+ ? !!options?.start_date && !!options?.end_date
17
+ ? (!sub_item.start_date ||
18
+ DateCompare(sub_item.start_date, 'IsSameOrBefore', options.end_date, 'day')) &&
19
+ (!sub_item.end_date ||
20
+ DateCompare(sub_item.end_date, 'IsSameOrAfter', options.start_date, 'day'))
21
+ : (options?.disabled ?? null) === null || sub_item.disabled === options?.disabled
22
+ : (options?.disabled ?? null) === null || sub_item.disabled === options?.disabled) &&
22
23
  (!options?.feature || ToArray(sub_item.feature).includes(options.feature)))))
23
- .filter(user => !options?.otherFilter || options.otherFilter(user))
24
+ .filter((user) => !options?.otherFilter || options.otherFilter(user))
24
25
  };
25
26
  };
26
27
  const storeActivityOverlay = () => {
27
28
  const { subscribe, set, update } = writable(0);
28
29
  return {
29
30
  subscribe,
30
- show: () => update(prevState => prevState < 0 ? 1 : prevState + 1),
31
- hide: () => update(prevState => prevState < 2 ? 0 : prevState - 1),
31
+ show: () => update((prevState) => (prevState < 0 ? 1 : prevState + 1)),
32
+ hide: () => update((prevState) => (prevState < 2 ? 0 : prevState - 1)),
32
33
  reset: () => set(0)
33
34
  };
34
35
  };
@@ -37,16 +38,18 @@ const storeMessageBox = () => {
37
38
  const { subscribe, set, update } = writable([]);
38
39
  return {
39
40
  subscribe,
40
- show: (message) => update(prevState => [
41
- ...prevState.filter(pS => pS.message !== (typeof message === 'object' ? message.message : message)),
42
- typeof message === 'object' ?
43
- {
41
+ show: (message) => update((prevState) => [
42
+ ...prevState.filter((pS) => pS.message !== (typeof message === 'object' ? message.message : message)),
43
+ typeof message === 'object'
44
+ ? {
44
45
  ...message,
45
- dismissAt: message.dismissAt === undefined ? DateParseTS('now', { seconds: 3 }) : message.dismissAt
46
- } :
47
- { message: message, dismissAt: DateParseTS('now', { seconds: 3 }) }
46
+ dismissAt: message.dismissAt === undefined
47
+ ? DateParseTS('now', { seconds: 3 })
48
+ : message.dismissAt
49
+ }
50
+ : { message: message, dismissAt: DateParseTS('now', { seconds: 3 }) }
48
51
  ]),
49
- hide: (message) => update(prevState => prevState.filter(pS => !ToArray(message).includes(pS.message))),
52
+ hide: (message) => update((prevState) => prevState.filter((pS) => !ToArray(message).includes(pS.message))),
50
53
  reset: () => set([])
51
54
  };
52
55
  };
@@ -1,17 +1,15 @@
1
+ <!--suppress JSDeprecatedSymbols -->
1
2
  <script lang='ts'>
2
3
  import { DeepEqual, SearchRows } from '@solidbasisventures/intelliwaketsfoundation'
3
4
  import DropDownControl from './DropDownControl.svelte'
4
5
  import { onMount, tick } from 'svelte'
5
- import { ShowMessageBox } from './Definitions'
6
+ import { ShowMessageBox, type TGenericMultiSelect } from './Definitions'
6
7
  import DisplayHTML from './DisplayHTML.svelte'
7
8
  import { type ActionArray, useActions } from './useActions'
8
9
 
9
- // eslint-disable-next-line no-undef
10
- type T = globalThis.$$Generic<{
11
- name?: string | null,
12
- id?: string | number | null
13
- } & Record<string, any>>
10
+ type T = $$Generic<TGenericMultiSelect>
14
11
 
12
+ // eslint-disable-next-line no-undef
15
13
  let {
16
14
  show = $bindable(false),
17
15
  use = [],
@@ -1,40 +1,50 @@
1
+ import { type TGenericMultiSelect } from './Definitions';
1
2
  import { type ActionArray } from './useActions';
2
- type T = globalThis.$$Generic<{
3
- name?: string | null;
4
- id?: string | number | null;
5
- } & Record<string, any>>;
6
- type $$ComponentProps = {
7
- show?: boolean;
8
- use?: ActionArray;
9
- possibles: T[];
10
- selected?: T[];
11
- selectedIDs?: (number | string)[] | undefined;
12
- created?: T[];
13
- existing?: T[];
14
- name?: string | null;
15
- placeholder?: string;
16
- disabled?: boolean;
17
- readonly?: boolean;
18
- required?: boolean;
19
- invalid?: boolean;
20
- isMulti?: boolean;
21
- allowClearAll?: boolean;
22
- createPrefix?: string;
23
- create?: undefined | ((value: string) => T | null);
24
- createValid?: undefined | ((value: string) => boolean | string);
25
- displayValue?: ((item: T) => string | number);
26
- idValue?: ((item: T) => any);
27
- /** Compute the value of the "key" in the "each" statements to make them unique */
28
- keyValue?: ((item: T, idx?: number) => any);
29
- inputValue?: ((item: T) => any);
30
- sameSize?: boolean;
31
- resizeTS?: number;
32
- autoFocus?: boolean;
33
- zIndex?: number;
34
- bodyClass?: string;
35
- parentDivElement?: HTMLDivElement | null;
36
- form?: string | undefined;
37
- };
38
- declare const MultiSelect: import("svelte").Component<$$ComponentProps, {}, "show" | "selected" | "selectedIDs" | "created" | "existing">;
39
- type MultiSelect = ReturnType<typeof MultiSelect>;
3
+ declare class __sveltets_Render<T extends TGenericMultiSelect> {
4
+ props(): {
5
+ show?: boolean;
6
+ use?: ActionArray;
7
+ possibles: T[];
8
+ selected?: T[] | undefined;
9
+ selectedIDs?: (number | string)[] | undefined;
10
+ created?: T[] | undefined;
11
+ existing?: T[] | undefined;
12
+ name?: string | null;
13
+ placeholder?: string;
14
+ disabled?: boolean;
15
+ readonly?: boolean;
16
+ required?: boolean;
17
+ invalid?: boolean;
18
+ isMulti?: boolean;
19
+ allowClearAll?: boolean;
20
+ createPrefix?: string;
21
+ create?: ((value: string) => T | null) | undefined;
22
+ createValid?: ((value: string) => boolean | string) | undefined;
23
+ displayValue?: ((item: T) => string | number) | undefined;
24
+ idValue?: ((item: T) => any) | undefined;
25
+ /** Compute the value of the "key" in the "each" statements to make them unique */
26
+ keyValue?: ((item: T, idx?: number) => any) | undefined;
27
+ inputValue?: ((item: T) => any) | undefined;
28
+ sameSize?: boolean;
29
+ resizeTS?: number;
30
+ autoFocus?: boolean;
31
+ zIndex?: number;
32
+ bodyClass?: string;
33
+ parentDivElement?: HTMLDivElement | null;
34
+ form?: string | undefined;
35
+ };
36
+ events(): {};
37
+ slots(): {};
38
+ bindings(): "show" | "selected" | "selectedIDs" | "created" | "existing";
39
+ exports(): {};
40
+ }
41
+ interface $$IsomorphicComponent {
42
+ new <T extends TGenericMultiSelect>(options: import('svelte').ComponentConstructorOptions<ReturnType<__sveltets_Render<T>['props']>>): import('svelte').SvelteComponent<ReturnType<__sveltets_Render<T>['props']>, ReturnType<__sveltets_Render<T>['events']>, ReturnType<__sveltets_Render<T>['slots']>> & {
43
+ $$bindings?: ReturnType<__sveltets_Render<T>['bindings']>;
44
+ } & ReturnType<__sveltets_Render<T>['exports']>;
45
+ <T extends TGenericMultiSelect>(internal: unknown, props: ReturnType<__sveltets_Render<T>['props']> & {}): ReturnType<__sveltets_Render<T>['exports']>;
46
+ z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
47
+ }
48
+ declare const MultiSelect: $$IsomorphicComponent;
49
+ type MultiSelect<T extends TGenericMultiSelect> = InstanceType<typeof MultiSelect<T>>;
40
50
  export default MultiSelect;
@@ -15,7 +15,7 @@
15
15
  hidden = false,
16
16
  displayCheckInverse = false,
17
17
  class: clazz = '',
18
- onCheck = () => {
18
+ oncheck = () => {
19
19
  },
20
20
  children
21
21
  }: {
@@ -31,7 +31,7 @@
31
31
  hidden?: boolean
32
32
  displayCheckInverse?: boolean
33
33
  class?: string
34
- onCheck?: (val: boolean) => void,
34
+ oncheck?: (val: boolean) => void,
35
35
  children?: Snippet
36
36
  } = $props()
37
37
 
@@ -51,17 +51,30 @@
51
51
 
52
52
  let useValue = $derived(getValue(checked))
53
53
 
54
- $effect(() => {
54
+ function doCheck() {
55
55
  if (!disabled && !readonly) {
56
+ checked = !checked
56
57
  tick().then(() => {
57
- onCheck(checked)
58
+ oncheck(checked)
58
59
  if (inputControl) {
59
60
  inputControl.dispatchEvent(new Event('change', { bubbles: true, cancelable: true }))
60
61
  inputControl.dispatchEvent(new Event('input', { bubbles: true, cancelable: true }))
61
62
  }
62
63
  })
63
64
  }
64
- })
65
+ }
66
+
67
+ // $effect(() => {
68
+ // if (!disabled && !readonly) {
69
+ // tick().then(() => {
70
+ // oncheck(checked)
71
+ // if (inputControl) {
72
+ // inputControl.dispatchEvent(new Event('change', { bubbles: true, cancelable: true }))
73
+ // inputControl.dispatchEvent(new Event('input', { bubbles: true, cancelable: true }))
74
+ // }
75
+ // })
76
+ // }
77
+ // })
65
78
 
66
79
  let displayChecked = $derived(displayCheckInverse ? !checked : checked)
67
80
 
@@ -73,10 +86,10 @@
73
86
  use:useActions={use}
74
87
  class='[&_*]:cursor-pointer mt-1 select-none focus:ring-0 focus:outline-none group {clazz ?? ""}'
75
88
  role='button'
76
- onclick={() => checked = !checked}
89
+ onclick={() => doCheck()}
77
90
  onkeydown={e => {
78
91
  if (e.key === ' ') {
79
- checked = !checked
92
+ doCheck()
80
93
  }
81
94
  }}
82
95
  tabindex={-1}>
@@ -13,7 +13,7 @@ type $$ComponentProps = {
13
13
  hidden?: boolean;
14
14
  displayCheckInverse?: boolean;
15
15
  class?: string;
16
- onCheck?: (val: boolean) => void;
16
+ oncheck?: (val: boolean) => void;
17
17
  children?: Snippet;
18
18
  };
19
19
  declare const Switch: import("svelte").Component<$$ComponentProps, {}, "checked">;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "intelliwaketssveltekitv25",
3
- "version": "0.1.61",
3
+ "version": "0.1.63",
4
4
  "exports": {
5
5
  ".": {
6
6
  "types": "./dist/index.d.ts",