firstly 0.0.12 → 0.0.14

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 (120) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/esm/ROUTES.d.ts +2 -0
  3. package/esm/ROUTES.js +1 -0
  4. package/esm/api/index.d.ts +9 -0
  5. package/esm/api/index.js +3 -1
  6. package/esm/auth/AuthController.d.ts +12 -23
  7. package/esm/auth/AuthController.js +12 -31
  8. package/esm/auth/server/AuthController.server.d.ts +11 -11
  9. package/esm/auth/server/AuthController.server.js +99 -34
  10. package/esm/auth/server/handleGuard.d.ts +16 -0
  11. package/esm/auth/server/handleGuard.js +67 -0
  12. package/esm/auth/server/helperFirstly.d.ts +1 -1
  13. package/esm/auth/server/helperFirstly.js +1 -0
  14. package/esm/auth/server/index.d.ts +3 -1
  15. package/esm/auth/server/index.js +3 -1
  16. package/esm/auth/server/module.d.ts +105 -89
  17. package/esm/auth/server/module.js +55 -42
  18. package/esm/auth/server/providers/github.d.ts +4 -2
  19. package/esm/auth/server/providers/github.js +2 -2
  20. package/esm/auth/static/assets/Page-B0XXxe0N.d.ts +6 -0
  21. package/esm/auth/static/assets/Page-B0XXxe0N.js +1 -0
  22. package/esm/auth/static/assets/Page-DdKMiUZn.d.ts +6 -0
  23. package/esm/auth/static/assets/Page-DdKMiUZn.js +20 -0
  24. package/esm/auth/static/assets/Page-UV_hqY7I.d.ts +6 -0
  25. package/esm/auth/static/assets/Page-UV_hqY7I.js +1 -0
  26. package/esm/auth/static/assets/Page-mK42zGEw.css +1 -0
  27. package/esm/auth/static/assets/index-C9jzxOBu.d.ts +151 -0
  28. package/esm/auth/static/assets/index-C9jzxOBu.js +42 -0
  29. package/esm/auth/static/assets/index-DKWpA6v7.css +4 -0
  30. package/esm/auth/static/index.html +11 -11
  31. package/esm/auth/types.d.ts +26 -3
  32. package/esm/bin/cmd.js +423 -152
  33. package/esm/cellsBuildor.js +1 -1
  34. package/esm/common.d.ts +5 -0
  35. package/esm/common.js +8 -0
  36. package/esm/cron/server/index.js +1 -1
  37. package/esm/feedback/FeedbackController.js +58 -53
  38. package/esm/feedback/server/index.d.ts +6 -15
  39. package/esm/feedback/server/index.js +4 -5
  40. package/esm/feedback/types.d.ts +14 -0
  41. package/esm/feedback/types.js +4 -0
  42. package/esm/feedback/ui/DialogIssue.svelte +131 -119
  43. package/esm/feedback/ui/DialogIssue.svelte.d.ts +20 -18
  44. package/esm/feedback/ui/DialogIssues.svelte +108 -99
  45. package/esm/feedback/ui/DialogIssues.svelte.d.ts +20 -18
  46. package/esm/feedback/ui/DialogMilestones.svelte +40 -34
  47. package/esm/feedback/ui/DialogMilestones.svelte.d.ts +18 -16
  48. package/esm/feedback/ui/Feedback.svelte +11 -9
  49. package/esm/feedback/ui/Feedback.svelte.d.ts +16 -14
  50. package/esm/index.d.ts +2 -5
  51. package/esm/index.js +2 -8
  52. package/esm/mail/server/index.d.ts +9 -2
  53. package/esm/mail/server/index.js +3 -1
  54. package/esm/mail/templates/DefaultMail.svelte +81 -61
  55. package/esm/mail/templates/DefaultMail.svelte.d.ts +28 -26
  56. package/esm/server/index.d.ts +0 -0
  57. package/esm/server/index.js +1 -0
  58. package/esm/storeItem.d.ts +1 -4
  59. package/esm/storeItem.js +1 -1
  60. package/esm/storeList.d.ts +1 -4
  61. package/esm/sveltekit/server/index.d.ts +3 -9
  62. package/esm/sveltekit/server/index.js +3 -0
  63. package/esm/ui/Button.svelte +112 -89
  64. package/esm/ui/Button.svelte.d.ts +34 -24
  65. package/esm/ui/Clipboardable.svelte +24 -17
  66. package/esm/ui/Clipboardable.svelte.d.ts +34 -23
  67. package/esm/ui/Field.svelte +328 -285
  68. package/esm/ui/Field.svelte.d.ts +15 -8
  69. package/esm/ui/FieldGroup.svelte +112 -91
  70. package/esm/ui/FieldGroup.svelte.d.ts +17 -6
  71. package/esm/ui/Grid.svelte +322 -308
  72. package/esm/ui/Grid.svelte.d.ts +17 -6
  73. package/esm/ui/GridLoading.svelte +28 -27
  74. package/esm/ui/GridLoading.svelte.d.ts +19 -17
  75. package/esm/ui/GridPaginate.svelte +68 -61
  76. package/esm/ui/GridPaginate.svelte.d.ts +21 -19
  77. package/esm/ui/Icon.svelte +116 -80
  78. package/esm/ui/Icon.svelte.d.ts +52 -43
  79. package/esm/ui/Loading.svelte +10 -8
  80. package/esm/ui/Loading.svelte.d.ts +29 -18
  81. package/esm/ui/Tooltip.svelte +38 -35
  82. package/esm/ui/Tooltip.svelte.d.ts +30 -20
  83. package/esm/ui/dialog/DialogForm.svelte +70 -63
  84. package/esm/ui/dialog/DialogForm.svelte.d.ts +18 -16
  85. package/esm/ui/dialog/DialogManagement.svelte +74 -74
  86. package/esm/ui/dialog/DialogManagement.svelte.d.ts +22 -21
  87. package/esm/ui/dialog/DialogPrimitive.svelte +82 -76
  88. package/esm/ui/dialog/DialogPrimitive.svelte.d.ts +35 -25
  89. package/esm/ui/dialog/FormEditAction.svelte +58 -50
  90. package/esm/ui/dialog/FormEditAction.svelte.d.ts +13 -6
  91. package/esm/ui/dialog/dialog.d.ts +1 -4
  92. package/esm/ui/internals/FieldContainer.svelte +24 -17
  93. package/esm/ui/internals/FieldContainer.svelte.d.ts +37 -28
  94. package/esm/ui/internals/Input.svelte +136 -102
  95. package/esm/ui/internals/Input.svelte.d.ts +34 -32
  96. package/esm/ui/internals/Textarea.svelte +60 -52
  97. package/esm/ui/internals/Textarea.svelte.d.ts +31 -28
  98. package/esm/ui/internals/select/MultiSelectMelt.svelte +243 -199
  99. package/esm/ui/internals/select/MultiSelectMelt.svelte.d.ts +29 -27
  100. package/esm/ui/internals/select/SelectMelt.svelte +254 -219
  101. package/esm/ui/internals/select/SelectMelt.svelte.d.ts +34 -32
  102. package/esm/ui/internals/select/SelectRadio.svelte +39 -33
  103. package/esm/ui/internals/select/SelectRadio.svelte.d.ts +24 -22
  104. package/esm/ui/link/Link.svelte +25 -20
  105. package/esm/ui/link/Link.svelte.d.ts +31 -23
  106. package/esm/ui/link/LinkPlus.svelte +52 -51
  107. package/esm/ui/link/LinkPlus.svelte.d.ts +20 -18
  108. package/esm/vite/index.d.ts +2 -3
  109. package/esm/vite/index.js +33 -26
  110. package/package.json +16 -20
  111. package/esm/auth/static/assets/Page-Bb8bFlrP.d.ts +0 -4
  112. package/esm/auth/static/assets/Page-Bb8bFlrP.js +0 -1
  113. package/esm/auth/static/assets/Page-BxomFlZ8.d.ts +0 -4
  114. package/esm/auth/static/assets/Page-BxomFlZ8.js +0 -1
  115. package/esm/auth/static/assets/Page-CaIYu0-y.d.ts +0 -6
  116. package/esm/auth/static/assets/Page-CaIYu0-y.js +0 -19
  117. package/esm/auth/static/assets/Page-MkYglNtu.css +0 -1
  118. package/esm/auth/static/assets/index-Bl0Bk5u0.d.ts +0 -64
  119. package/esm/auth/static/assets/index-Bl0Bk5u0.js +0 -2
  120. package/esm/auth/static/assets/index-R27C_TlP.css +0 -4
@@ -1,4 +1,3 @@
1
- import { SvelteComponent } from "svelte";
2
1
  import type { HTMLInputAttributes } from 'svelte/elements';
3
2
  import { type Cell } from '../';
4
3
  declare class __sveltets_Render<T extends Record<any, any>> {
@@ -9,9 +8,9 @@ declare class __sveltets_Render<T extends Record<any, any>> {
9
8
  cellsValues?: any;
10
9
  withDedounce?: boolean | undefined;
11
10
  error?: string | undefined;
12
- mode?: ("edit" | "view" | "filtre") | undefined;
11
+ mode?: "edit" | "view" | "filtre" | undefined;
13
12
  focus?: boolean | undefined;
14
- clearable?: boolean | undefined;
13
+ clearable?: boolean | undefined | undefined;
15
14
  disabled?: boolean | undefined;
16
15
  };
17
16
  events(): {
@@ -21,10 +20,18 @@ declare class __sveltets_Render<T extends Record<any, any>> {
21
20
  [evt: string]: CustomEvent<any>;
22
21
  };
23
22
  slots(): {};
23
+ bindings(): string;
24
+ exports(): {};
24
25
  }
25
- export type FieldProps<T extends Record<any, any>> = ReturnType<__sveltets_Render<T>['props']>;
26
- export type FieldEvents<T extends Record<any, any>> = ReturnType<__sveltets_Render<T>['events']>;
27
- export type FieldSlots<T extends Record<any, any>> = ReturnType<__sveltets_Render<T>['slots']>;
28
- export default class Field<T extends Record<any, any>> extends SvelteComponent<FieldProps<T>, FieldEvents<T>, FieldSlots<T>> {
26
+ interface $$IsomorphicComponent {
27
+ new <T extends Record<any, any>>(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']>> & {
28
+ $$bindings?: ReturnType<__sveltets_Render<T>['bindings']>;
29
+ } & ReturnType<__sveltets_Render<T>['exports']>;
30
+ <T extends Record<any, any>>(internal: unknown, props: ReturnType<__sveltets_Render<T>['props']> & {
31
+ $$events?: ReturnType<__sveltets_Render<T>['events']>;
32
+ }): ReturnType<__sveltets_Render<T>['exports']>;
33
+ z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
29
34
  }
30
- export {};
35
+ declare const Field: $$IsomorphicComponent;
36
+ type Field<T extends Record<any, any>> = InstanceType<typeof Field<T>>;
37
+ export default Field;
@@ -1,95 +1,116 @@
1
- <script generics="T extends Record<any, any>">import { createEventDispatcher } from "svelte";
2
- import { getRelationFieldInfo } from "remult/internals";
3
- import { tw } from "../";
4
- import Field from "./Field.svelte";
5
- import FieldContainer from "./internals/FieldContainer.svelte";
6
- import Loading from "./Loading.svelte";
7
- export let mode = "edit";
8
- export let cells;
9
- export let store;
10
- export let focusKey = null;
11
- const getError = (errors, field) => {
12
- const fo = getRelationFieldInfo(field);
13
- const keyToUse = fo?.options?.field;
14
- if (errors && keyToUse && errors[keyToUse]) {
15
- return errors[keyToUse];
16
- } else if (errors && errors[field.key]) {
17
- return errors[field.key];
18
- }
19
- return void 0;
20
- };
21
- const shouldHide = (c, mode2) => {
22
- if (mode2 === "edit" && c.modeEdit === "hide") {
23
- return true;
24
- }
25
- if (mode2 === "view" && c.modeView === "hide") {
26
- return true;
27
- }
28
- return false;
29
- };
30
- const modeToUse = (c, mode2) => {
31
- if (mode2 === "edit" && c.modeEdit === "view") {
32
- return "view";
33
- }
34
- if (mode2 === "view" && c.modeView === "edit") {
35
- return "edit";
36
- }
37
- return mode2;
38
- };
39
- const dispatch = createEventDispatcher();
40
- function dispatchChanged(_data) {
41
- dispatch("changed", _data);
42
- }
43
- $: dispatchChanged($store.item);
44
- let size = ["", "w-1/2", "w-1/3", "w-1/4", "w-1/5", "w-1/6"];
45
- function isToFocus(currentKey, focusKey2, i) {
46
- if (focusKey2 === null || focusKey2 === void 0) {
47
- if (i === 0) {
48
- return true;
49
- }
50
- return false;
51
- }
52
- return focusKey2 === currentKey;
53
- }
1
+ <script lang="ts" generics="T extends Record<any, any>">
2
+ import { createEventDispatcher } from 'svelte'
3
+
4
+ import type { FieldMetadata } from 'remult'
5
+ import { getRelationFieldInfo } from 'remult/internals'
6
+
7
+ import { tw, type StoreItem } from '../'
8
+ import type { Cell } from '../cellsBuildor'
9
+ import Field from './Field.svelte'
10
+ import FieldContainer from './internals/FieldContainer.svelte'
11
+ import Loading from './Loading.svelte'
12
+
13
+ type Mode = 'edit' | 'view' | 'filtre'
14
+ export let mode: Mode = 'edit'
15
+
16
+ export let cells: Cell<T>[]
17
+ export let store: StoreItem<T>
18
+
19
+ export let focusKey: string | null | undefined = null
20
+
21
+ const getError = (errors: any, field: FieldMetadata<any, any>) => {
22
+ const fo = getRelationFieldInfo(field)
23
+ const keyToUse = fo?.options?.field
24
+ if (errors && keyToUse && errors[keyToUse]) {
25
+ return errors[keyToUse]
26
+ } else if (errors && errors[field.key]) {
27
+ return errors[field.key]
28
+ }
29
+ return undefined
30
+ }
31
+
32
+ const shouldHide = (c: Cell<T>, mode: Mode) => {
33
+ if (mode === 'edit' && c.modeEdit === 'hide') {
34
+ return true
35
+ }
36
+ if (mode === 'view' && c.modeView === 'hide') {
37
+ return true
38
+ }
39
+ return false
40
+ }
41
+
42
+ const modeToUse = (c: Cell<T>, mode: Mode) => {
43
+ if (mode === 'edit' && c.modeEdit === 'view') {
44
+ return 'view'
45
+ }
46
+ if (mode === 'view' && c.modeView === 'edit') {
47
+ return 'edit'
48
+ }
49
+ return mode
50
+ }
51
+
52
+ const dispatch = createEventDispatcher()
53
+
54
+ function dispatchChanged(_data: T | undefined) {
55
+ dispatch('changed', _data)
56
+ }
57
+
58
+ $: dispatchChanged($store.item)
59
+
60
+ let size = ['', 'w-1/2', 'w-1/3', 'w-1/4', 'w-1/5', 'w-1/6']
61
+
62
+ function isToFocus(
63
+ currentKey: string | undefined,
64
+ focusKey: string | null | undefined,
65
+ i: number,
66
+ ): boolean {
67
+ if (focusKey === null || focusKey === undefined) {
68
+ if (i === 0) {
69
+ return true
70
+ }
71
+ return false
72
+ }
73
+ return focusKey === currentKey
74
+ }
54
75
  </script>
55
76
 
56
77
  {#each cells as cell, i}
57
- {@const focus = isToFocus(cell.field?.key, focusKey, i)}
58
- {#if shouldHide(cell, mode)}
59
- <!-- Do nothing -->
60
- {:else if cell.field && !cell.field.includedInApi($store.item)}
61
- <!-- Do nothing, but keep the class... -->
62
- <div class={cell.class}></div>
63
- {:else}
64
- <div class={cell.class}>
65
- {#if cell.kind === 'header'}
66
- <span>{cell.header}</span>
67
- {:else if cell.field && (!$store || $store.loading)}
68
- <!-- If the store is not ready mdiYeast, or in loading... -->
69
- <FieldContainer label={cell.field.caption} forId={cell.field.key}>
70
- <Loading
71
- class={tw(
72
- `mx-4 my-3 h-6`,
73
- size[parseInt((((i + 1) * Math.random() * size.length) % size.length).toString())],
74
- )}
75
- />
76
- </FieldContainer>
77
- {:else if cell.kind === 'slot'}
78
- <slot name="field" field={cell.field} {focus} />
79
- {:else if cell.field && $store.item}
80
- <Field
81
- mode={modeToUse(cell, mode)}
82
- {cell}
83
- cellsValues={$store.item}
84
- bind:value={$store.item[cell.field.key]}
85
- error={getError($store.errors, cell.field)}
86
- {focus}
87
- on:createRequest
88
- />
89
- <!-- disabled={isDisableFieldDynamic(cell)} -->
90
- {:else}
91
- FieldGroup : Case not handled
92
- {/if}
93
- </div>
94
- {/if}
78
+ {@const focus = isToFocus(cell.field?.key, focusKey, i)}
79
+ {#if shouldHide(cell, mode)}
80
+ <!-- Do nothing -->
81
+ {:else if cell.field && !cell.field.includedInApi($store.item)}
82
+ <!-- Do nothing, but keep the class... -->
83
+ <div class={cell.class}></div>
84
+ {:else}
85
+ <div class={cell.class}>
86
+ {#if cell.kind === 'header'}
87
+ <span>{cell.header}</span>
88
+ {:else if cell.field && (!$store || $store.loading)}
89
+ <!-- If the store is not ready mdiYeast, or in loading... -->
90
+ <FieldContainer label={cell.field.caption} forId={cell.field.key}>
91
+ <Loading
92
+ class={tw(
93
+ `mx-4 my-3 h-6`,
94
+ size[parseInt((((i + 1) * Math.random() * size.length) % size.length).toString())],
95
+ )}
96
+ />
97
+ </FieldContainer>
98
+ {:else if cell.kind === 'slot'}
99
+ <slot name="field" field={cell.field} {focus} />
100
+ {:else if cell.field && $store.item}
101
+ <Field
102
+ mode={modeToUse(cell, mode)}
103
+ {cell}
104
+ cellsValues={$store.item}
105
+ bind:value={$store.item[cell.field.key]}
106
+ error={getError($store.errors, cell.field)}
107
+ {focus}
108
+ on:createRequest
109
+ />
110
+ <!-- disabled={isDisableFieldDynamic(cell)} -->
111
+ {:else}
112
+ FieldGroup : Case not handled
113
+ {/if}
114
+ </div>
115
+ {/if}
95
116
  {/each}
@@ -1,4 +1,3 @@
1
- import { SvelteComponent } from "svelte";
2
1
  import type { FieldMetadata } from 'remult';
3
2
  import { type StoreItem } from '../';
4
3
  import type { Cell } from '../cellsBuildor';
@@ -21,10 +20,22 @@ declare class __sveltets_Render<T extends Record<any, any>> {
21
20
  focus: typeof focus;
22
21
  };
23
22
  };
23
+ bindings(): string;
24
+ exports(): {};
24
25
  }
25
- export type FieldGroupProps<T extends Record<any, any>> = ReturnType<__sveltets_Render<T>['props']>;
26
- export type FieldGroupEvents<T extends Record<any, any>> = ReturnType<__sveltets_Render<T>['events']>;
27
- export type FieldGroupSlots<T extends Record<any, any>> = ReturnType<__sveltets_Render<T>['slots']>;
28
- export default class FieldGroup<T extends Record<any, any>> extends SvelteComponent<FieldGroupProps<T>, FieldGroupEvents<T>, FieldGroupSlots<T>> {
26
+ interface $$IsomorphicComponent {
27
+ new <T extends Record<any, any>>(options: import('svelte').ComponentConstructorOptions<ReturnType<__sveltets_Render<T>['props']> & {
28
+ children?: any;
29
+ }>): import('svelte').SvelteComponent<ReturnType<__sveltets_Render<T>['props']>, ReturnType<__sveltets_Render<T>['events']>, ReturnType<__sveltets_Render<T>['slots']>> & {
30
+ $$bindings?: ReturnType<__sveltets_Render<T>['bindings']>;
31
+ } & ReturnType<__sveltets_Render<T>['exports']>;
32
+ <T extends Record<any, any>>(internal: unknown, props: ReturnType<__sveltets_Render<T>['props']> & {
33
+ $$events?: ReturnType<__sveltets_Render<T>['events']>;
34
+ $$slots?: ReturnType<__sveltets_Render<T>['slots']>;
35
+ children?: any;
36
+ }): ReturnType<__sveltets_Render<T>['exports']>;
37
+ z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
29
38
  }
30
- export {};
39
+ declare const FieldGroup: $$IsomorphicComponent;
40
+ type FieldGroup<T extends Record<any, any>> = InstanceType<typeof FieldGroup<T>>;
41
+ export default FieldGroup;