@cometchat/chat-uikit-angular
Version:
Ready-to-use Chat UI Components for Angular (JavaScript/Web)
93 lines • 15.7 kB
JavaScript
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"]}