includio-cms 0.0.11 → 0.0.13
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.
|
@@ -11,6 +11,7 @@
|
|
|
11
11
|
import BooleanField from './boolean-field.svelte';
|
|
12
12
|
import RadioField from './radio-field.svelte';
|
|
13
13
|
import FileField from './file-field.svelte';
|
|
14
|
+
import NumberField from './number-field.svelte';
|
|
14
15
|
|
|
15
16
|
type Props = {
|
|
16
17
|
objectFieldType?: 'default' | 'inline';
|
|
@@ -78,6 +79,8 @@
|
|
|
78
79
|
<SlugField {field} {form} {path} {...props} />
|
|
79
80
|
{:else if field.type === 'boolean'}
|
|
80
81
|
<BooleanField {field} {form} {path} {...props} />
|
|
82
|
+
{:else if field.type === 'number'}
|
|
83
|
+
<NumberField {field} {form} {path} {...props} />
|
|
81
84
|
{:else}
|
|
82
85
|
<p>Nieobsługiwany typ pola: {field.type}</p>
|
|
83
86
|
{/if}
|
|
@@ -0,0 +1,34 @@
|
|
|
1
|
+
<script lang="ts" module>
|
|
2
|
+
type T = Record<string, unknown>;
|
|
3
|
+
</script>
|
|
4
|
+
|
|
5
|
+
<script lang="ts" generics="T extends Record<string, unknown>">
|
|
6
|
+
import Input from '../../../components/ui/input/input.svelte';
|
|
7
|
+
import Textarea from '../../../components/ui/textarea/textarea.svelte';
|
|
8
|
+
import type { NumberField } from '../../../types/fields.js';
|
|
9
|
+
import { onMount } from 'svelte';
|
|
10
|
+
import {
|
|
11
|
+
formFieldProxy,
|
|
12
|
+
type FormFieldProxy,
|
|
13
|
+
type FormPathLeaves,
|
|
14
|
+
type SuperForm
|
|
15
|
+
} from 'sveltekit-superforms';
|
|
16
|
+
|
|
17
|
+
type Props = {
|
|
18
|
+
field: NumberField;
|
|
19
|
+
form: SuperForm<T>;
|
|
20
|
+
path: FormPathLeaves<T, number | undefined>;
|
|
21
|
+
};
|
|
22
|
+
|
|
23
|
+
let { field, form, path, ...props }: Props = $props();
|
|
24
|
+
|
|
25
|
+
const { value } = formFieldProxy(form, path) satisfies FormFieldProxy<number | undefined>;
|
|
26
|
+
|
|
27
|
+
onMount(() => {
|
|
28
|
+
if ($value === undefined && field.defaultValue !== undefined) {
|
|
29
|
+
$value = field.defaultValue;
|
|
30
|
+
}
|
|
31
|
+
});
|
|
32
|
+
</script>
|
|
33
|
+
|
|
34
|
+
<Input {...props} bind:value={$value} type="number" />
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import type { NumberField } from '../../../types/fields.js';
|
|
2
|
+
import { type FormPathLeaves, type SuperForm } from 'sveltekit-superforms';
|
|
3
|
+
declare function $$render<T extends Record<string, unknown>>(): {
|
|
4
|
+
props: {
|
|
5
|
+
field: NumberField;
|
|
6
|
+
form: SuperForm<T>;
|
|
7
|
+
path: FormPathLeaves<T, number | undefined>;
|
|
8
|
+
};
|
|
9
|
+
exports: {};
|
|
10
|
+
bindings: "";
|
|
11
|
+
slots: {};
|
|
12
|
+
events: {};
|
|
13
|
+
};
|
|
14
|
+
declare class __sveltets_Render<T extends Record<string, unknown>> {
|
|
15
|
+
props(): ReturnType<typeof $$render<T>>['props'];
|
|
16
|
+
events(): ReturnType<typeof $$render<T>>['events'];
|
|
17
|
+
slots(): ReturnType<typeof $$render<T>>['slots'];
|
|
18
|
+
bindings(): "";
|
|
19
|
+
exports(): {};
|
|
20
|
+
}
|
|
21
|
+
interface $$IsomorphicComponent {
|
|
22
|
+
new <T extends Record<string, unknown>>(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']>> & {
|
|
23
|
+
$$bindings?: ReturnType<__sveltets_Render<T>['bindings']>;
|
|
24
|
+
} & ReturnType<__sveltets_Render<T>['exports']>;
|
|
25
|
+
<T extends Record<string, unknown>>(internal: unknown, props: ReturnType<__sveltets_Render<T>['props']> & {}): ReturnType<__sveltets_Render<T>['exports']>;
|
|
26
|
+
z_$$bindings?: ReturnType<__sveltets_Render<any>['bindings']>;
|
|
27
|
+
}
|
|
28
|
+
declare const NumberField: $$IsomorphicComponent;
|
|
29
|
+
type NumberField<T extends Record<string, unknown>> = InstanceType<typeof NumberField<T>>;
|
|
30
|
+
export default NumberField;
|
|
@@ -35,8 +35,10 @@ export function generateZodSchemaFromField(field, languages, options = {
|
|
|
35
35
|
case 'datetime':
|
|
36
36
|
return z.string().datetime();
|
|
37
37
|
case 'file':
|
|
38
|
-
case 'image':
|
|
39
|
-
|
|
38
|
+
case 'image': {
|
|
39
|
+
const singleSchema = field.required ? z.string().uuid() : z.string();
|
|
40
|
+
return field.multiple ? z.array(singleSchema).default([]) : singleSchema;
|
|
41
|
+
}
|
|
40
42
|
case 'select':
|
|
41
43
|
case 'radio': {
|
|
42
44
|
const enumValues = field.options.map((o) => o.value);
|