rimecms 0.24.6 → 0.25.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.
- package/dist/adapter-sqlite/generate-schema/index.server.js +9 -9
- package/dist/adapter-sqlite/generate-schema/root.server.d.ts +5 -0
- package/dist/adapter-sqlite/generate-schema/root.server.js +5 -0
- package/dist/adapter-sqlite/generate-schema/templates.server.js +9 -6
- package/dist/core/collections/upload/upload.d.ts +2 -1
- package/dist/core/collections/upload/util/converter.js +4 -3
- package/dist/core/config/client/augment-directories.d.ts +6 -0
- package/dist/core/config/client/augment-directories.js +11 -0
- package/dist/core/config/client/build-config.d.ts +2 -0
- package/dist/core/config/client/build-config.js +3 -1
- package/dist/core/config/server/augment-directories.server.d.ts +6 -0
- package/dist/core/config/server/augment-directories.server.js +37 -0
- package/dist/core/config/server/build-config.server.d.ts +2 -0
- package/dist/core/config/server/build-config.server.js +4 -6
- package/dist/core/config/shared/upload-directories.d.ts +7 -2
- package/dist/core/config/shared/upload-directories.js +118 -48
- package/dist/core/config/types.d.ts +6 -0
- package/dist/core/naming.d.ts +1 -1
- package/dist/core/naming.js +1 -1
- package/dist/fields/relation/component/Relation.svelte +2 -1
- package/dist/fields/relation/index.d.ts +3 -2
- package/dist/panel/components/fields/RenderFields.svelte +5 -2
- package/dist/panel/components/fields/RenderFields.svelte.d.ts +3 -1
- package/dist/panel/components/sections/collection/grid/CollectionGrid.svelte +6 -14
- package/dist/panel/components/sections/collection/grid/grid-item/FolderEdit.svelte +79 -0
- package/dist/panel/components/sections/collection/grid/grid-item/FolderEdit.svelte.d.ts +10 -0
- package/dist/panel/components/sections/collection/grid/grid-item/FolderWithActions.svelte +11 -44
- package/dist/panel/components/sections/collection/grid/grid-item/FolderWithActions.svelte.d.ts +0 -2
- package/dist/panel/components/sections/collection/header/Header.svelte +1 -1
- package/dist/panel/components/sections/collection/header/create-folder/CreateFolder.svelte +90 -0
- package/dist/panel/components/sections/collection/header/create-folder/CreateFolder.svelte.d.ts +7 -0
- package/dist/panel/components/sections/collection/tree/CollectionTree.svelte +1 -1
- package/dist/panel/components/sections/document/AuthFooter.svelte +11 -2
- package/dist/panel/components/sections/document/Settings.svelte +6 -2
- package/dist/panel/components/ui/dialog/dialog-content.svelte +20 -5
- package/dist/panel/components/ui/dialog/dialog-content.svelte.d.ts +7 -2
- package/dist/panel/context/collection.svelte.js +3 -1
- package/dist/panel/context/documentForm.svelte.d.ts +14 -6
- package/dist/panel/context/documentForm.svelte.js +15 -7
- package/dist/panel/pages/auth/forgot-password/ForgotPassword.svelte +1 -0
- package/dist/util/string.d.ts +14 -0
- package/dist/util/string.js +19 -0
- package/package.json +1 -1
- package/dist/core/collections/upload/directory-input-config.d.ts +0 -2
- package/dist/core/collections/upload/directory-input-config.js +0 -12
- package/dist/panel/components/sections/collection/header/CreateUploadFolder.svelte +0 -68
- package/dist/panel/components/sections/collection/header/CreateUploadFolder.svelte.d.ts +0 -7
|
@@ -1,12 +0,0 @@
|
|
|
1
|
-
export const directoryInput = {
|
|
2
|
-
type: 'text',
|
|
3
|
-
name: 'name',
|
|
4
|
-
isEmpty: (value) => !value,
|
|
5
|
-
validate: (value) => {
|
|
6
|
-
const pattern = /^[a-zA-Z0-9-_ ]+$/;
|
|
7
|
-
if (typeof value !== 'string' || !pattern.test(value)) {
|
|
8
|
-
return 'Incorrect folder name';
|
|
9
|
-
}
|
|
10
|
-
return true;
|
|
11
|
-
}
|
|
12
|
-
};
|
|
@@ -1,68 +0,0 @@
|
|
|
1
|
-
<script lang="ts">
|
|
2
|
-
import { directoryInput } from '../../../../../core/collections/upload/directory-input-config.js';
|
|
3
|
-
import { t__ } from '../../../../../core/i18n/index.js';
|
|
4
|
-
import Input from '../../../../../fields/text/component/Text.svelte';
|
|
5
|
-
import Button from '../../../ui/button/button.svelte';
|
|
6
|
-
import * as Dialog from '../../../ui/dialog/index.js';
|
|
7
|
-
import type { CollectionContext } from '../../../../context/collection.svelte.js';
|
|
8
|
-
import { setFormContext } from '../../../../context/form.svelte.js';
|
|
9
|
-
import { FolderPlus } from '@lucide/svelte';
|
|
10
|
-
import { toast } from 'svelte-sonner';
|
|
11
|
-
|
|
12
|
-
type Props = { collection: CollectionContext };
|
|
13
|
-
const { collection }: Props = $props();
|
|
14
|
-
|
|
15
|
-
const createFolderForm = setFormContext({ name: '' }, 'new-folder');
|
|
16
|
-
let dialogOpen = $state(false);
|
|
17
|
-
const field = createFolderForm.useField('name', directoryInput);
|
|
18
|
-
|
|
19
|
-
async function handleFolderCreation() {
|
|
20
|
-
const url = collection.apiDirectoriesUrl;
|
|
21
|
-
const response = await fetch(url, {
|
|
22
|
-
method: 'POST',
|
|
23
|
-
body: JSON.stringify({
|
|
24
|
-
id: `${collection.upload.currentPath}:${field.value}`
|
|
25
|
-
})
|
|
26
|
-
});
|
|
27
|
-
|
|
28
|
-
if (response.status === 200) {
|
|
29
|
-
const { doc } = await response.json();
|
|
30
|
-
toast.success(t__('common.directory_created'));
|
|
31
|
-
collection.upload.directories.push(doc);
|
|
32
|
-
dialogOpen = false;
|
|
33
|
-
} else if (response.status === 400) {
|
|
34
|
-
let { message } = await response.json();
|
|
35
|
-
if (message === 'errors.unique_field') {
|
|
36
|
-
message = 'errors.folder_already_exists';
|
|
37
|
-
}
|
|
38
|
-
createFolderForm.errors.set('name', message);
|
|
39
|
-
} else {
|
|
40
|
-
toast.error(t__('errors.unknown_error'));
|
|
41
|
-
dialogOpen = false;
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
</script>
|
|
45
|
-
|
|
46
|
-
<Dialog.Root bind:open={dialogOpen}>
|
|
47
|
-
<Dialog.Trigger>
|
|
48
|
-
{#snippet child(props)}
|
|
49
|
-
<Button
|
|
50
|
-
disabled={collection.selectMode}
|
|
51
|
-
onclick={() => (dialogOpen = true)}
|
|
52
|
-
size="icon-sm"
|
|
53
|
-
variant="ghost"
|
|
54
|
-
{...props}
|
|
55
|
-
>
|
|
56
|
-
<FolderPlus size={17} />
|
|
57
|
-
</Button>
|
|
58
|
-
{/snippet}
|
|
59
|
-
</Dialog.Trigger>
|
|
60
|
-
<Dialog.Content class="rz-status-dialog">
|
|
61
|
-
<Dialog.Header>{t__('common.create_folder')}</Dialog.Header>
|
|
62
|
-
<Input form={createFolderForm} config={directoryInput} />
|
|
63
|
-
<Dialog.Footer --rz-justify-content="space-between">
|
|
64
|
-
<Button disabled={!createFolderForm.canSubmit} onclick={handleFolderCreation}>Validate</Button>
|
|
65
|
-
<Button variant="secondary" onclick={() => (dialogOpen = false)}>Cancel</Button>
|
|
66
|
-
</Dialog.Footer>
|
|
67
|
-
</Dialog.Content>
|
|
68
|
-
</Dialog.Root>
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import type { CollectionContext } from '../../../../context/collection.svelte.js';
|
|
2
|
-
type Props = {
|
|
3
|
-
collection: CollectionContext;
|
|
4
|
-
};
|
|
5
|
-
declare const CreateUploadFolder: import("svelte").Component<Props, {}, "">;
|
|
6
|
-
type CreateUploadFolder = ReturnType<typeof CreateUploadFolder>;
|
|
7
|
-
export default CreateUploadFolder;
|