diff options
-rw-r--r-- | apps/files/src/views/FileReferencePickerElement.vue | 124 |
1 files changed, 57 insertions, 67 deletions
diff --git a/apps/files/src/views/FileReferencePickerElement.vue b/apps/files/src/views/FileReferencePickerElement.vue index 0aa6678f121..a6c1522d010 100644 --- a/apps/files/src/views/FileReferencePickerElement.vue +++ b/apps/files/src/views/FileReferencePickerElement.vue @@ -20,15 +20,24 @@ --> <template> - <div ref="picker" class="reference-file-picker" /> + <div :id="containerId"> + <FilePicker v-bind="filepickerOptions" @close="onClose" /> + </div> </template> -<script> -import { FilePickerType } from '@nextcloud/dialogs' +<script lang="ts"> +import type { Node as NcNode } from '@nextcloud/files' +import type { IFilePickerButton } from '@nextcloud/dialogs' + +import { FilePickerVue as FilePicker } from '@nextcloud/dialogs/filepicker.js' +import { translate as t } from '@nextcloud/l10n' import { generateUrl } from '@nextcloud/router' -export default { +import { defineComponent } from 'vue' + +export default defineComponent({ name: 'FileReferencePickerElement', components: { + FilePicker, }, props: { providerId: { @@ -40,74 +49,55 @@ export default { default: false, }, }, - mounted() { - this.openFilePicker() - window.addEventListener('click', this.onWindowClick) - }, - beforeDestroy() { - window.removeEventListener('click', this.onWindowClick) + computed: { + containerId() { + return `filepicker-${Math.random().toString(36).slice(7)}` + }, + filepickerOptions() { + return { + allowPickDirectory: false, + buttons: this.buttonFactory, + container: `#${this.containerId}`, + multiselect: false, + name: t('files', 'Select file or folder to link to'), + } + }, }, methods: { - onWindowClick(e) { - if (e.target.tagName === 'A' && e.target.classList.contains('oc-dialog-close')) { - this.$emit('cancel') + t, + + buttonFactory(selected: NcNode[]): IFilePickerButton[] { + const buttons = [] as IFilePickerButton[] + if (selected.length === 0) { + buttons.push({ + label: t('files', 'Choose file'), + type: 'tertiary' as never, + callback: this.onClose, + }) + } else { + buttons.push({ + label: t('files', 'Choose {file}', { file: selected[0].basename }), + type: 'primary', + callback: this.onClose, + }) } + return buttons }, - async openFilePicker() { - OC.dialogs.filepicker( - t('files', 'Select file or folder to link to'), - (file) => { - const client = OC.Files.getClient() - client.getFileInfo(file).then((_status, fileInfo) => { - this.submit(fileInfo.id) - }) - }, - false, // multiselect - [], // mime filter - false, // modal - FilePickerType.Choose, // type - '', - { - target: this.$refs.picker, - }, - ) + + onClose(nodes?: NcNode[]) { + if (nodes === undefined || nodes.length === 0) { + this.$emit('cancel') + } else { + this.onSubmit(nodes[0]) + } }, - submit(fileId) { - const fileLink = window.location.protocol + '//' + window.location.host - + generateUrl('/f/{fileId}', { fileId }) - this.$emit('submit', fileLink) + + onSubmit(node: NcNode) { + const url = new URL(window.location.href) + url.pathname = generateUrl('/f/{fileId}', { fileId: node.fileid! }) + url.search = '' + this.$emit('submit', url.href) }, }, -} +}) </script> - -<style scoped lang="scss"> -.reference-file-picker { - flex-grow: 1; - padding: 12px 16px 16px 16px; - - &:deep(.oc-dialog) { - transform: none !important; - box-shadow: none !important; - flex-grow: 1 !important; - position: static !important; - width: 100% !important; - height: auto !important; - padding: 0 !important; - max-width: initial; - - .oc-dialog-close { - display: none; - } - - .oc-dialog-buttonrow.onebutton.aside { - position: absolute; - padding: 12px 32px; - } - - .oc-dialog-content { - max-width: 100% !important; - } - } -} -</style> |