summaryrefslogtreecommitdiffstats
path: root/apps/files/src/reference-files.js
diff options
context:
space:
mode:
authorJulius Härtl <jus@bitgrid.net>2022-09-01 20:09:33 +0200
committerJulius Härtl <jus@bitgrid.net>2023-03-02 21:01:44 +0100
commit6130f1a78ea4f7fba3e3690528f2b53a0d9f5b82 (patch)
tree404bcf6ad7790b7ecda2eed0efb3a9d4618fddbb /apps/files/src/reference-files.js
parentb6d8fc97afe28bc1b017026447264ba37ed37caa (diff)
downloadnextcloud-server-6130f1a78ea4f7fba3e3690528f2b53a0d9f5b82.tar.gz
nextcloud-server-6130f1a78ea4f7fba3e3690528f2b53a0d9f5b82.zip
Implement file reference wiget
Signed-off-by: Julius Härtl <jus@bitgrid.net>
Diffstat (limited to 'apps/files/src/reference-files.js')
-rw-r--r--apps/files/src/reference-files.js58
1 files changed, 58 insertions, 0 deletions
diff --git a/apps/files/src/reference-files.js b/apps/files/src/reference-files.js
new file mode 100644
index 00000000000..db563200cd0
--- /dev/null
+++ b/apps/files/src/reference-files.js
@@ -0,0 +1,58 @@
+/**
+ * @copyright Copyright (c) 2022 Julius Härtl <jus@bitgrid.net>
+ *
+ * @author Julius Härtl <jus@bitgrid.net>
+ *
+ * @license GNU AGPL version 3 or any later version
+ *
+ * This program is free software: you can redistribute it and/or modify
+ * it under the terms of the GNU Affero General Public License as
+ * published by the Free Software Foundation, either version 3 of the
+ * License, or (at your option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU Affero General Public License for more details.
+ *
+ * You should have received a copy of the GNU Affero General Public License
+ * along with this program. If not, see <http://www.gnu.org/licenses/>.
+ */
+
+import Vue from 'vue'
+import { translate as t } from '@nextcloud/l10n'
+
+import { registerWidget, registerCustomPickerElement, NcCustomPickerRenderResult } from '@nextcloud/vue/dist/Components/NcRichText.js'
+
+import FileWidget from './views/ReferenceFileWidget.vue'
+import FileReferencePickerElement from './views/FileReferencePickerElement.vue'
+
+Vue.mixin({
+ methods: {
+ t,
+ },
+})
+
+registerWidget('file', (el, { richObjectType, richObject, accessible }) => {
+ const Widget = Vue.extend(FileWidget)
+ new Widget({
+ propsData: {
+ richObjectType,
+ richObject,
+ accessible,
+ },
+ }).$mount(el)
+})
+
+registerCustomPickerElement('files', (el, { providerId, accessible }) => {
+ const Element = Vue.extend(FileReferencePickerElement)
+ const vueElement = new Element({
+ propsData: {
+ providerId,
+ accessible,
+ },
+ }).$mount(el)
+ return new NcCustomPickerRenderResult(vueElement.$el, vueElement)
+}, (el, renderResult) => {
+ renderResult.object.$destroy()
+})