106 lines
3.3 KiB
JavaScript
106 lines
3.3 KiB
JavaScript
/**
|
|
* @copyright Copyright (c) 2022 Julien Veyssier <eneiluj@posteo.net>
|
|
*
|
|
* @author Julien Veyssier <eneiluj@posteo.net>
|
|
*
|
|
* @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 <http://www.gnu.org/licenses/>.
|
|
*/
|
|
|
|
import { registerWidget, registerCustomPickerElement, NcCustomPickerRenderResult } from '@nextcloud/vue/dist/Components/NcRichText.js'
|
|
import { Tooltip } from '@nextcloud/vue'
|
|
import Vue from 'vue'
|
|
import CardReferenceWidget from './views/CardReferenceWidget.vue'
|
|
import BoardReferenceWidget from './views/BoardReferenceWidget.vue'
|
|
import CommentReferenceWidget from './views/CommentReferenceWidget.vue'
|
|
|
|
import { translate, translatePlural } from '@nextcloud/l10n'
|
|
|
|
import './shared-init.js'
|
|
|
|
Vue.prototype.t = translate
|
|
Vue.prototype.n = translatePlural
|
|
Vue.prototype.OC = window.OC
|
|
Vue.prototype.OCA = window.OCA
|
|
Vue.directive('tooltip', Tooltip)
|
|
Vue.directive('focus', {
|
|
inserted(el) {
|
|
el.focus()
|
|
},
|
|
})
|
|
|
|
registerWidget('deck-card', (el, { richObjectType, richObject, accessible }) => {
|
|
// trick to change the wrapper element size, otherwise it always is 100%
|
|
// which is not very nice with a simple card
|
|
el.parentNode.style['max-width'] = '400px'
|
|
el.parentNode.style['margin-left'] = '0'
|
|
el.parentNode.style['margin-right'] = '0'
|
|
|
|
const Widget = Vue.extend(CardReferenceWidget)
|
|
new Widget({
|
|
propsData: {
|
|
richObjectType,
|
|
richObject,
|
|
accessible,
|
|
},
|
|
}).$mount(el)
|
|
})
|
|
|
|
registerWidget('deck-board', (el, { richObjectType, richObject, accessible }) => {
|
|
el.parentNode.style['max-width'] = '400px'
|
|
el.parentNode.style['margin-left'] = '0'
|
|
el.parentNode.style['margin-right'] = '0'
|
|
|
|
const Widget = Vue.extend(BoardReferenceWidget)
|
|
new Widget({
|
|
propsData: {
|
|
richObjectType,
|
|
richObject,
|
|
accessible,
|
|
},
|
|
}).$mount(el)
|
|
})
|
|
|
|
registerWidget('deck-comment', (el, { richObjectType, richObject, accessible }) => {
|
|
el.parentNode.style['max-width'] = '400px'
|
|
el.parentNode.style['margin-left'] = '0'
|
|
el.parentNode.style['margin-right'] = '0'
|
|
|
|
const Widget = Vue.extend(CommentReferenceWidget)
|
|
new Widget({
|
|
propsData: {
|
|
richObjectType,
|
|
richObject,
|
|
accessible,
|
|
},
|
|
}).$mount(el)
|
|
})
|
|
|
|
registerCustomPickerElement('create-new-deck-card', async (el, { providerId, accessible }) => {
|
|
const { default: Vue } = await import(/* webpackChunkName: "reference-picker-lazy" */'vue')
|
|
Vue.mixin({ methods: { t, n } })
|
|
const { default: CreateNewCardCustomPicker } = await import(/* webpackChunkName: "reference-picker-lazy" */'./views/CreateNewCardCustomPicker.vue')
|
|
const Element = Vue.extend(CreateNewCardCustomPicker)
|
|
const vueElement = new Element({
|
|
propsData: {
|
|
providerId,
|
|
accessible,
|
|
},
|
|
}).$mount(el)
|
|
return new NcCustomPickerRenderResult(vueElement.$el, vueElement)
|
|
}, (el, renderResult) => {
|
|
renderResult.object.$destroy()
|
|
}, 'normal')
|