/** * @copyright Copyright (c) 2019 John Molakvoæ * * @author John Molakvoæ * @author Julius Härtl * * @license AGPL-3.0-or-later * * 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 . * */ import Vue from 'vue' import VueClipboard from 'vue-clipboard2' import { translate as t, translatePlural as n } from '@nextcloud/l10n' import SharingTab from './views/SharingTab' import ShareSearch from './services/ShareSearch' import ExternalLinkActions from './services/ExternalLinkActions' import ExternalShareActions from './services/ExternalShareActions' import TabSections from './services/TabSections' // Init Sharing Tab Service if (!window.OCA.Sharing) { window.OCA.Sharing = {} } Object.assign(window.OCA.Sharing, { ShareSearch: new ShareSearch() }) Object.assign(window.OCA.Sharing, { ExternalLinkActions: new ExternalLinkActions() }) Object.assign(window.OCA.Sharing, { ExternalShareActions: new ExternalShareActions() }) Object.assign(window.OCA.Sharing, { ShareTabSections: new TabSections() }) Vue.prototype.t = t Vue.prototype.n = n Vue.use(VueClipboard) // Init Sharing tab component const View = Vue.extend(SharingTab) let TabInstance = null window.addEventListener('DOMContentLoaded', function() { if (OCA.Files && OCA.Files.Sidebar) { OCA.Files.Sidebar.registerTab(new OCA.Files.Sidebar.Tab({ id: 'sharing', name: t('files_sharing', 'Sharing'), icon: 'icon-share', async mount(el, fileInfo, context) { if (TabInstance) { TabInstance.$destroy() } TabInstance = new View({ // Better integration with vue parent component parent: context, }) // Only mount after we have all the info we need await TabInstance.update(fileInfo) TabInstance.$mount(el) }, update(fileInfo) { TabInstance.update(fileInfo) }, destroy() { TabInstance.$destroy() TabInstance = null }, })) } })