UNPKG

@cometchat/chat-uikit-angular

Version:

Ready-to-use Chat UI Components for Angular (JavaScript/Web)

93 lines 15.7 kB
import { CometChat } from "@cometchat/chat-sdk-javascript"; import { CometChatTheme, CometChatMessageTemplate, CometChatMessageComposerAction, fontHelper, CometChatUIKitConstants, localize, } from "@cometchat/uikit-resources"; import { CollaborativeDocumentConstants, } from "@cometchat/uikit-shared"; import { ChatConfigurator } from "../../Shared/Framework/ChatConfigurator"; import { DataSourceDecorator } from "../../Shared/Framework/DataSourceDecorator"; export class CollaborativeDocumentExtensionDecorator extends DataSourceDecorator { constructor(dataSource) { super(dataSource); } getAllMessageTypes() { const types = super.getAllMessageTypes(); if (!types.includes(CollaborativeDocumentConstants.extension_document)) { types.push(CollaborativeDocumentConstants.extension_document); } return types; } getId() { return "collaborativedocument"; } getAllMessageCategories() { const categories = super.getAllMessageCategories(); if (!categories.includes(CometChatUIKitConstants.MessageCategory.custom)) { categories.push(CometChatUIKitConstants.MessageCategory.custom); } return categories; } checkIfTemplateExist(template, type) { return template.some((obj) => obj.type === type); } getAllMessageTemplates() { const templates = super.getAllMessageTemplates(); if (!this.checkIfTemplateExist(templates, CollaborativeDocumentConstants.extension_document)) { templates.push(this.getDocumentTemplate()); } return templates; } getDocumentTemplate() { return new CometChatMessageTemplate({ type: CollaborativeDocumentConstants.extension_document, category: CometChatUIKitConstants.MessageCategory.custom, options: (loggedInUser, messageObject, theme, group) => { return ChatConfigurator.getDataSource().getCommonOptions(loggedInUser, messageObject, theme, group); }, }); } getAttachmentOptions(theme = new CometChatTheme({}), user, group, id) { if (!id?.parentMessageId) { let receiverType = user ? CometChatUIKitConstants.MessageReceiverType.user : CometChatUIKitConstants.MessageReceiverType.group; let receiverId = user ? user.getUid() : group?.getGuid(); const messageComposerActions = super.getAttachmentOptions(theme, user, group, id); let newAction = new CometChatMessageComposerAction({ id: CollaborativeDocumentConstants.document, title: localize("COLLABORATIVE_DOCUMENT"), iconURL: "assets/collaborativedocument.svg", iconTint: theme.palette.getAccent700(), titleColor: theme.palette.getAccent600(), titleFont: fontHelper(theme.typography.subtitle1), background: theme.palette.getAccent100(), onClick: () => { CometChat.callExtension(CollaborativeDocumentConstants.document, CollaborativeDocumentConstants.post, CollaborativeDocumentConstants.v1_create, { receiver: receiverId, receiverType: receiverType, }) .then((res) => { }) .catch((error) => { console.log(error); }); }, }); messageComposerActions.push(newAction); return messageComposerActions; } else { return super.getAttachmentOptions(theme, user, group, id); } } getLastConversationMessage(conversation, loggedInUser, additionalConfigurations) { const message = conversation.getLastMessage(); if (message != null && message.getType() == CollaborativeDocumentConstants.extension_document && message.getCategory() == CometChatUIKitConstants.MessageCategory.custom) { return localize("CUSTOM_MESSAGE_DOCUMENT"); } else { return super.getLastConversationMessage(conversation, loggedInUser, additionalConfigurations); } } } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"CollaborativeDocumentExtensionDecorator.js","sourceRoot":"","sources":["../../../../../projects/chat-uikit-angular/src/Extensions/CollaborativeDocument/CollaborativeDocumentExtensionDecorator.ts"],"names":[],"mappings":"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","sourcesContent":["import { CometChat } from \"@cometchat/chat-sdk-javascript\";\nimport {\n  CometChatTheme,\n  CometChatMessageTemplate,\n  CometChatMessageComposerAction,\n  fontHelper,\n  CometChatUIKitConstants,\n  localize,\n} from \"@cometchat/uikit-resources\";\nimport {\n  CollaborativeDocumentConfiguration,\n  CollaborativeDocumentConstants,\n} from \"@cometchat/uikit-shared\";\nimport { ChatConfigurator } from \"../../Shared/Framework/ChatConfigurator\";\nimport { DataSource } from \"../../Shared/Framework/DataSource\";\nimport { DataSourceDecorator } from \"../../Shared/Framework/DataSourceDecorator\";\nexport class CollaborativeDocumentExtensionDecorator extends DataSourceDecorator {\n  constructor(dataSource: DataSource) {\n    super(dataSource);\n  }\n  override getAllMessageTypes(): string[] {\n    const types = super.getAllMessageTypes();\n    if (!types.includes(CollaborativeDocumentConstants.extension_document)) {\n      types.push(CollaborativeDocumentConstants.extension_document);\n    }\n    return types;\n  }\n  override getId(): string {\n    return \"collaborativedocument\";\n  }\n  override getAllMessageCategories(): string[] {\n    const categories = super.getAllMessageCategories();\n    if (!categories.includes(CometChatUIKitConstants.MessageCategory.custom)) {\n      categories.push(CometChatUIKitConstants.MessageCategory.custom);\n    }\n    return categories;\n  }\n  checkIfTemplateExist(\n    template: CometChatMessageTemplate[],\n    type: string\n  ): boolean {\n    return template.some((obj) => obj.type === type);\n  }\n  override getAllMessageTemplates(): CometChatMessageTemplate[] {\n    const templates = super.getAllMessageTemplates();\n    if (\n      !this.checkIfTemplateExist(\n        templates,\n        CollaborativeDocumentConstants.extension_document\n      )\n    ) {\n      templates.push(this.getDocumentTemplate());\n    }\n\n    return templates;\n  }\n  getDocumentTemplate(): CometChatMessageTemplate {\n    return new CometChatMessageTemplate({\n      type: CollaborativeDocumentConstants.extension_document,\n      category: CometChatUIKitConstants.MessageCategory.custom,\n      options: (\n        loggedInUser: CometChat.User,\n        messageObject: CometChat.BaseMessage,\n        theme: CometChatTheme,\n        group?: CometChat.Group\n      ) => {\n        return ChatConfigurator.getDataSource().getCommonOptions(\n          loggedInUser,\n          messageObject,\n          theme,\n          group\n        );\n      },\n    });\n  }\n  override getAttachmentOptions(\n    theme: CometChatTheme = new CometChatTheme({}),\n    user?: CometChat.User,\n    group?: CometChat.Group,\n    id?: any\n  ) {\n    if (!id?.parentMessageId) {\n      let receiverType: string = user\n        ? CometChatUIKitConstants.MessageReceiverType.user\n        : CometChatUIKitConstants.MessageReceiverType.group;\n      let receiverId: string | undefined = user\n        ? user.getUid()\n        : group?.getGuid();\n      const messageComposerActions: CometChatMessageComposerAction[] =\n        super.getAttachmentOptions(theme, user, group, id);\n      let newAction: CometChatMessageComposerAction =\n        new CometChatMessageComposerAction({\n          id: CollaborativeDocumentConstants.document,\n          title: localize(\"COLLABORATIVE_DOCUMENT\"),\n          iconURL: \"assets/collaborativedocument.svg\",\n          iconTint: theme.palette.getAccent700(),\n          titleColor: theme.palette.getAccent600(),\n          titleFont: fontHelper(theme.typography.subtitle1),\n          background: theme.palette.getAccent100(),\n          onClick: () => {\n            CometChat.callExtension(\n              CollaborativeDocumentConstants.document,\n              CollaborativeDocumentConstants.post,\n              CollaborativeDocumentConstants.v1_create,\n              {\n                receiver: receiverId,\n                receiverType: receiverType,\n              }\n            )\n              .then((res: any) => {})\n              .catch((error: CometChat.CometChatException) => {\n                console.log(error);\n              });\n          },\n        });\n      messageComposerActions.push(newAction);\n      return messageComposerActions;\n    } else {\n      return super.getAttachmentOptions(theme, user, group, id);\n    }\n  }\n  override getLastConversationMessage(\n    conversation: CometChat.Conversation,\n    loggedInUser: CometChat.User,\n    additionalConfigurations: any\n  ): string {\n    const message: CometChat.BaseMessage | undefined =\n      conversation.getLastMessage();\n    if (\n      message != null &&\n      message.getType() == CollaborativeDocumentConstants.extension_document &&\n      message.getCategory() == CometChatUIKitConstants.MessageCategory.custom\n    ) {\n      return localize(\"CUSTOM_MESSAGE_DOCUMENT\");\n    } else {\n      return super.getLastConversationMessage(\n        conversation,\n        loggedInUser,\n        additionalConfigurations\n      );\n    }\n  }\n}\n"]}