diff --git a/l10n/messages.pot b/l10n/messages.pot index 3fadd053..b0f2dbd7 100644 --- a/l10n/messages.pot +++ b/l10n/messages.pot @@ -18,19 +18,27 @@ msgstr "" msgid "All files" msgstr "" -#: lib/filepicker.ts:182 +#: lib/filepicker.ts:188 msgid "Choose" msgstr "" -#: lib/filepicker.ts:170 +#: lib/filepicker.ts:188 +msgid "Choose {file}" +msgstr "" + +#: lib/filepicker.ts:195 msgid "Copy" msgstr "" -#: lib/components/FilePicker/FilePicker.vue:242 +#: lib/filepicker.ts:195 +msgid "Copy to {target}" +msgstr "" + +#: lib/components/FilePicker/FilePicker.vue:249 msgid "Could not create the new folder" msgstr "" -#: lib/components/FilePicker/FilePicker.vue:152 +#: lib/components/FilePicker/FilePicker.vue:159 #: lib/components/FilePicker/FilePickerNavigation.vue:65 msgid "Favorites" msgstr "" @@ -39,11 +47,11 @@ msgstr "" msgid "File name cannot be empty." msgstr "" -#: lib/components/FilePicker/FilePicker.vue:228 +#: lib/components/FilePicker/FilePicker.vue:235 msgid "Files and folders you mark as favorite will show up here." msgstr "" -#: lib/components/FilePicker/FilePicker.vue:226 +#: lib/components/FilePicker/FilePicker.vue:233 msgid "Files and folders you recently modified will show up here." msgstr "" @@ -51,16 +59,19 @@ msgstr "" msgid "Modified" msgstr "" -#: lib/filepicker.ts:176 -#: lib/filepicker.ts:190 +#: lib/filepicker.ts:203 msgid "Move" msgstr "" +#: lib/filepicker.ts:203 +msgid "Move to {target}" +msgstr "" + #: lib/components/FilePicker/FileList.vue:19 msgid "Name" msgstr "" -#: lib/components/FilePicker/FilePicker.vue:152 +#: lib/components/FilePicker/FilePicker.vue:159 #: lib/components/FilePicker/FilePickerNavigation.vue:61 msgid "Recent" msgstr "" @@ -77,6 +88,6 @@ msgstr "" msgid "Undo" msgstr "" -#: lib/components/FilePicker/FilePicker.vue:224 +#: lib/components/FilePicker/FilePicker.vue:231 msgid "Upload some content or sync with your devices!" msgstr "" diff --git a/lib/components/FilePicker/FilePicker.vue b/lib/components/FilePicker/FilePicker.vue index b23e155f..0856aa3b 100644 --- a/lib/components/FilePicker/FilePicker.vue +++ b/lib/components/FilePicker/FilePicker.vue @@ -115,7 +115,7 @@ const props = withDefaults(defineProps<{ }) const emit = defineEmits<{ - (e: 'close'): void + (e: 'close', v?: Node[]): void }>() /** @@ -143,6 +143,7 @@ const dialogButtons = computed(() => { callback: async () => { const nodes = selectedFiles.value.length === 0 && props.allowPickDirectory ? [await getFile(currentPath.value)] : selectedFiles.value as Node[] button.callback(nodes) + emit('close', selectedFiles.value as Node[]) }, } as IFilePickerButton)) }) diff --git a/lib/filepicker.ts b/lib/filepicker.ts index 996533ac..a0769b3e 100644 --- a/lib/filepicker.ts +++ b/lib/filepicker.ts @@ -75,27 +75,22 @@ export class FilePicker { */ public async pick(): Promise { return new Promise((resolve, reject) => { - const buttons = this.buttons.map((button) => ({ - ...button, - callback: (nodes: Node[]) => { - button.callback(nodes) - if (this.multiSelect) { - resolve(nodes.map((node) => node.path) as (IsMultiSelect extends true ? string[] : string)) - } else { - resolve((nodes[0]?.path || '/') as (IsMultiSelect extends true ? string[] : string)) - } - }, - })) - spawnDialog(FilePickerVue, { allowPickDirectory: this.directoriesAllowed, - buttons, + buttons: this.buttons, name: this.title, path: this.path, mimetypeFilter: this.mimeTypeFilter, multiselect: this.multiSelect, filterFn: this.filter, - }, reject) + }, (...nodes: unknown[]) => { + if (!nodes) reject(new Error('Nothing selected')) + if (this.multiSelect) { + resolve((nodes as Node[]).map((node) => node.path) as (IsMultiSelect extends true ? string[] : string)) + } else { + resolve(((nodes as Node[])[0]?.path || '/') as (IsMultiSelect extends true ? string[] : string)) + } + }) }) } diff --git a/lib/utils/dialogs.ts b/lib/utils/dialogs.ts index abe7907b..e6343781 100644 --- a/lib/utils/dialogs.ts +++ b/lib/utils/dialogs.ts @@ -30,7 +30,7 @@ import Vue from 'vue' * @param props Properties to pass to the dialog * @param onClose Callback when the dialog is closed */ -export const spawnDialog = (dialog: Component | AsyncComponent, props: any, onClose: () => void = () => {}) => { +export const spawnDialog = (dialog: Component | AsyncComponent, props: any, onClose: (...rest: unknown[]) => void = () => {}) => { const el = document.createElement('div') const container: HTMLElement = document.querySelector(props?.container) || document.body @@ -43,8 +43,8 @@ export const spawnDialog = (dialog: Component | AsyncComponent, props: any, onCl h(dialog, { props, on: { - close: () => { - onClose() + close: (...rest: unknown[]) => { + onClose(rest) vue.$destroy() }, },