Univer
Univer Sheet
Features
Thread Comment

Comment / Annotation

📊 Univer Sheet📝 Univer Doc

The Comment / Annotation plugin provides the ability to comment or annotate cells.

Installation

pnpm add @univerjs/sheets-thread-comment-base @univerjs/sheets-thread-comment @univerjs/thread-comment @univerjs/thread-comment-ui

Import

import '@univerjs/thread-comment-ui/lib/index.css';
 
import { IThreadCommentMentionDataService, UniverThreadCommentUIPlugin } from '@univerjs/thread-comment-ui';
import { UniverThreadCommentPlugin } from '@univerjs/thread-comment';
import { UniverSheetsThreadCommentBasePlugin } from '@univerjs/sheets-thread-comment-base';
import { UniverSheetsThreadCommentPlugin } from '@univerjs/sheets-thread-comment';

Internationalization

import { LocaleType, Tools } from '@univerjs/core';
import ThreadCommentUIEnUS from '@univerjs/thread-comment-ui/locale/en-US';
import SheetsThreadCommentEnUS from '@univerjs/sheets-thread-comment/locale/en-US';
 
const univer = new Univer({
  theme: defaultTheme,
  locale: LocaleType.EN_US,
  locales: {
    [LocaleType.EN_US]: Tools.deepMerge(
      ThreadCommentUIEnUS,
      SheetsThreadCommentEnUS
    ),
  },
});

Register

const mockUser = {
  userID: 'mockId',
  name: 'MockUser',
  avatar: '',
  anonymous: false,
  canBindAnonymous: false,
};
 
class CustomMentionDataService implements IThreadCommentMentionDataService {
  dataSource: Nullable<IThreadCommentMentionDataSource>
  trigger: string = '@';
 
  async getMentions(search: string) {
    return [
      {
        id: mockUser.userID,
        label: mockUser.name,
        type: 'user',
        icon: mockUser.avatar,
      },
      {
        id: '2',
        label: 'User2',
        type: 'user',
        icon: mockUser.avatar,
      },
    ];
  }
}
 
univer.registerPlugin(UniverThreadCommentPlugin);
univer.registerPlugin(UniverThreadCommentUIPlugin, {
    overrides: [[IThreadCommentMentionDataService, { useClass: CustomMentionDataService }]],
});
univer.registerPlugin(UniverSheetsThreadCommentBasePlugin);
univer.registerPlugin(UniverSheetsThreadCommentPlugin);

Copyright © 2021-2024 DreamNum Co,Ltd. All Rights Reserved.