mirror of
https://github.com/nextcloud/server.git
synced 2026-02-03 20:41:22 -05:00
The activity app integration was changed to use the files Node API instead of the legacy FileInfo API. So the comments app needs to be adjusted for it. Signed-off-by: Ferdinand Thiessen <opensource@fthiessen.de>
86 lines
2.6 KiB
TypeScript
86 lines
2.6 KiB
TypeScript
/*!
|
|
* SPDX-FileCopyrightText: 2023 Nextcloud GmbH and Nextcloud contributors
|
|
* SPDX-License-Identifier: AGPL-3.0-or-later
|
|
*/
|
|
|
|
import type { INode } from '@nextcloud/files'
|
|
|
|
import moment from '@nextcloud/moment'
|
|
import { createPinia, PiniaVuePlugin } from 'pinia'
|
|
import Vue, { type ComponentPublicInstance } from 'vue'
|
|
import logger from './logger.js'
|
|
import { getComments } from './services/GetComments.js'
|
|
|
|
Vue.use(PiniaVuePlugin)
|
|
|
|
let ActivityTabPluginView
|
|
let ActivityTabPluginInstance
|
|
|
|
/**
|
|
* Register the comments plugins for the Activity sidebar
|
|
*/
|
|
export function registerCommentsPlugins() {
|
|
window.OCA.Activity.registerSidebarAction({
|
|
mount: async (el: HTMLElement, { node, reload }: { node: INode, reload: () => void }) => {
|
|
const pinia = createPinia()
|
|
|
|
if (!ActivityTabPluginView) {
|
|
const { default: ActivityCommentAction } = await import('./views/ActivityCommentAction.vue')
|
|
// @ts-expect-error Types are broken for Vue2
|
|
ActivityTabPluginView = Vue.extend(ActivityCommentAction)
|
|
}
|
|
ActivityTabPluginInstance = new ActivityTabPluginView({
|
|
el,
|
|
pinia,
|
|
propsData: {
|
|
reloadCallback: reload,
|
|
resourceId: node.fileid,
|
|
},
|
|
})
|
|
logger.info('Comments plugin mounted in Activity sidebar action', { node })
|
|
},
|
|
unmount: () => {
|
|
// destroy previous instance if available
|
|
if (ActivityTabPluginInstance) {
|
|
ActivityTabPluginInstance.$destroy()
|
|
}
|
|
},
|
|
})
|
|
|
|
window.OCA.Activity.registerSidebarEntries(async ({ node, limit, offset }: { node: INode, limit?: number, offset?: number }) => {
|
|
const { data: comments } = await getComments(
|
|
{ resourceType: 'files', resourceId: node.fileid },
|
|
{
|
|
limit,
|
|
offset: offset ?? 0,
|
|
},
|
|
)
|
|
logger.debug('Loaded comments', { node, comments })
|
|
const { default: CommentView } = await import('./views/ActivityCommentEntry.vue')
|
|
// @ts-expect-error Types are broken for Vue2
|
|
const CommentsViewObject = Vue.extend(CommentView)
|
|
|
|
return comments.map((comment) => ({
|
|
_CommentsViewInstance: undefined as ComponentPublicInstance | undefined,
|
|
|
|
timestamp: moment(comment.props?.creationDateTime).toDate().getTime(),
|
|
|
|
mount(element: HTMLElement, { reload }) {
|
|
this._CommentsViewInstance = new CommentsViewObject({
|
|
el: element,
|
|
propsData: {
|
|
comment,
|
|
resourceId: node.fileid,
|
|
reloadCallback: reload,
|
|
},
|
|
})
|
|
},
|
|
unmount() {
|
|
this._CommentsViewInstance?.$destroy()
|
|
},
|
|
}))
|
|
})
|
|
|
|
window.OCA.Activity.registerSidebarFilter((activity) => activity.type !== 'comments')
|
|
logger.info('Comments plugin registered for Activity sidebar action')
|
|
}
|