@cometchat/chat-uikit-angular
Version:
Ready-to-use Chat UI Components for Angular (JavaScript/Web)
125 lines • 20.7 kB
JavaScript
import { DataSourceDecorator } from "../../Shared/Framework/DataSourceDecorator";
import { CometChatMessageEvents, CometChatUIKitConstants, MessageStatus, } from "@cometchat/uikit-resources";
import { CometChatMessageTemplate } from "@cometchat/uikit-resources";
import { CometChat } from "@cometchat/chat-sdk-javascript";
import { localize } from "@cometchat/uikit-resources";
import { CometChatUIKitLoginListener, StickersConfiguration } from "@cometchat/uikit-shared";
import { StickersConstants } from "@cometchat/uikit-shared";
import { CometChatSoundManager, CometChatUIKitUtility, } from "@cometchat/uikit-shared";
import { ChatConfigurator } from "../../Shared/Framework/ChatConfigurator";
import { CometChatException } from "../../Shared/Utils/ComeChatException";
export class StickersExtensionDecorator extends DataSourceDecorator {
constructor(dataSource) {
super(dataSource);
this.sendStickerMessage = (sticker, loggedInUser, user, group, parentMessageid, onError, customSoundForMessages = "", disableSoundForMessages = false) => {
let receiverId = user?.getUid() || group?.getGuid();
let receiverType = user
? CometChatUIKitConstants.MessageReceiverType.user
: CometChatUIKitConstants.MessageReceiverType.group;
try {
const customData = {
sticker_url: sticker.url,
sticker_name: sticker.name,
};
const customType = StickersConstants.sticker;
const customMessage = new CometChat.CustomMessage(receiverId, receiverType, customType, customData);
if (parentMessageid) {
customMessage.setParentMessageId(parentMessageid);
}
customMessage.shouldUpdateConversation(true);
customMessage.setMetadata({ incrementUnreadCount: true });
customMessage.setSentAt(CometChatUIKitUtility.getUnixTimestamp());
customMessage.setMuid(CometChatUIKitUtility.ID());
if (CometChatUIKitLoginListener.getLoggedInUser()) {
customMessage.setSender(CometChatUIKitLoginListener.getLoggedInUser());
}
CometChatMessageEvents.ccMessageSent.next({
message: customMessage,
status: MessageStatus.inprogress,
});
if (!disableSoundForMessages) {
CometChatSoundManager.play(customSoundForMessages ?? CometChatSoundManager.Sound.outgoingMessage);
}
CometChat.sendCustomMessage(customMessage)
.then((message) => {
CometChatMessageEvents.ccMessageSent.next({
message: message,
status: MessageStatus.success,
});
})
.catch((error) => {
customMessage.setMetadata({
error: true,
});
CometChatMessageEvents.ccMessageSent.next({
message: customMessage,
status: MessageStatus.error,
});
});
}
catch (error) {
if (onError) {
onError(CometChatException(error));
}
}
};
this.newDataScorce = dataSource;
this.configuration = new StickersConfiguration({});
this.configuration.ccStickerClicked = this.sendStickerMessage;
}
getDataScorce() {
return this.newDataScorce;
}
getAllMessageTemplates() {
let template = super.getAllMessageTemplates();
if (!this.checkIfTemplateExist(template, StickersConstants.sticker)) {
template.push(this.getStickerTemplate());
return template;
}
return template;
}
getAuxiliaryOptions(id, user, group) {
return { configuration: this.configuration, id: StickersConstants.sticker };
}
getStickerTemplate() {
return new CometChatMessageTemplate({
type: StickersConstants.sticker,
category: CometChatUIKitConstants.MessageCategory.custom,
options: (loggedInUser, messageObject, theme, group) => {
return ChatConfigurator.getDataSource().getCommonOptions(loggedInUser, messageObject, theme, group);
},
});
}
checkIfTemplateExist(template, type) {
return template.some((obj) => obj.type === type);
}
getAllMessageCategories() {
let categories = super.getAllMessageCategories();
if (!categories.some((category) => category === CometChatUIKitConstants.MessageCategory.custom)) {
categories.push(CometChatUIKitConstants.MessageCategory.custom);
}
return categories;
}
getAllMessageTypes() {
let types = super.getAllMessageTypes();
if (!types.some((category) => category === CometChatUIKitConstants.MessageCategory.custom)) {
types.push(StickersConstants.sticker);
}
return types;
}
getId() {
return "stickers";
}
getLastConversationMessage(conversation, loggedInUser, additionalConfigurations) {
const message = conversation.getLastMessage();
if (message != null &&
message.getType() == StickersConstants.sticker &&
message.getCategory() == CometChatUIKitConstants.MessageCategory.custom) {
return localize("CUSTOM_MESSAGE_STICKER");
}
else {
return super.getLastConversationMessage(conversation, loggedInUser, additionalConfigurations);
}
}
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"StickersExtensionDecorator.js","sourceRoot":"","sources":["../../../../../projects/chat-uikit-angular/src/Extensions/Stickers/StickersExtensionDecorator.ts"],"names":[],"mappings":"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","sourcesContent":["import { DataSourceDecorator } from \"../../Shared/Framework/DataSourceDecorator\";\nimport {\n  CometChatMessageEvents,\n  CometChatTheme,\n  CometChatUIKitConstants,\n  MessageStatus,\n} from \"@cometchat/uikit-resources\";\nimport { CometChatMessageTemplate } from \"@cometchat/uikit-resources\";\nimport { CometChat } from \"@cometchat/chat-sdk-javascript\";\nimport { localize } from \"@cometchat/uikit-resources\";\nimport { CometChatUIKitLoginListener, StickersConfiguration } from \"@cometchat/uikit-shared\";\nimport { StickersConstants } from \"@cometchat/uikit-shared\";\nimport { DataSource } from \"../../Shared/Framework/DataSource\";\nimport {\n  CometChatSoundManager,\n  CometChatUIKitUtility,\n} from \"@cometchat/uikit-shared\";\nimport { ChatConfigurator } from \"../../Shared/Framework/ChatConfigurator\";\nimport { ComposerId } from \"../../Shared/Utils/MessageUtils\";\nimport { CometChatException } from \"../../Shared/Utils/ComeChatException\";\nexport class StickersExtensionDecorator extends DataSourceDecorator {\n  public configuration?: StickersConfiguration;\n  public newDataScorce!: DataSource;\n  constructor(dataSource: DataSource) {\n    super(dataSource);\n    this.newDataScorce = dataSource;\n    this.configuration = new StickersConfiguration({});\n    this.configuration!.ccStickerClicked = this.sendStickerMessage;\n\n  }\n  getDataScorce() {\n    return this.newDataScorce;\n  }\n  sendStickerMessage = (\n    sticker: { name: string; url: string },\n    loggedInUser: CometChat.User,\n    user: CometChat.User,\n    group: CometChat.Group,\n    parentMessageid: number,\n    onError: ((error: CometChat.CometChatException) => void) | null | undefined,\n    customSoundForMessages: string = \"\",\n    disableSoundForMessages: boolean = false\n  ) => {\n    let receiverId: string = user?.getUid() || group?.getGuid();\n    let receiverType: string = user\n      ? CometChatUIKitConstants.MessageReceiverType.user\n      : CometChatUIKitConstants.MessageReceiverType.group;\n    try {\n      const customData = {\n        sticker_url: sticker.url,\n        sticker_name: sticker.name,\n      };\n      const customType = StickersConstants.sticker;\n      const customMessage: CometChat.CustomMessage =\n        new CometChat.CustomMessage(\n          receiverId,\n          receiverType,\n          customType,\n          customData\n        );\n      if (parentMessageid) {\n        customMessage.setParentMessageId(parentMessageid);\n      }\n      customMessage.shouldUpdateConversation(true);\n      customMessage.setMetadata({ incrementUnreadCount: true });\n      (customMessage as any).setSentAt(\n        CometChatUIKitUtility.getUnixTimestamp()\n      );\n      customMessage.setMuid(CometChatUIKitUtility.ID());\n      if (CometChatUIKitLoginListener.getLoggedInUser()) {\n        customMessage.setSender(CometChatUIKitLoginListener.getLoggedInUser()!)\n      }\n      CometChatMessageEvents.ccMessageSent.next({\n        message: customMessage,\n        status: MessageStatus.inprogress,\n      });\n      if (!disableSoundForMessages) {\n        CometChatSoundManager.play(\n          customSoundForMessages ?? CometChatSoundManager.Sound.outgoingMessage\n        );\n      }\n      CometChat.sendCustomMessage(customMessage)\n        .then((message) => {\n          CometChatMessageEvents.ccMessageSent.next({\n            message: message,\n            status: MessageStatus.success,\n          });\n        })\n        .catch((error: CometChat.CometChatException) => {\n          customMessage.setMetadata({\n            error: true,\n          });\n          CometChatMessageEvents.ccMessageSent.next({\n            message: customMessage,\n            status: MessageStatus.error,\n          });\n        });\n    } catch (error: any) {\n      if (onError) {\n        onError(CometChatException(error));\n      }\n    }\n  };\n  override getAllMessageTemplates(): CometChatMessageTemplate[] {\n    let template: CometChatMessageTemplate[] = super.getAllMessageTemplates();\n    if (!this.checkIfTemplateExist(template, StickersConstants.sticker)) {\n      template.push(this.getStickerTemplate());\n      return template;\n    }\n    return template;\n  }\n  override getAuxiliaryOptions(\n    id: ComposerId,\n    user?: CometChat.User,\n    group?: CometChat.Group\n  ) {\n    return { configuration: this.configuration, id: StickersConstants.sticker };\n  }\n  getStickerTemplate(): CometChatMessageTemplate {\n    return new CometChatMessageTemplate({\n      type: StickersConstants.sticker,\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  checkIfTemplateExist(\n    template: CometChatMessageTemplate[],\n    type: string\n  ): boolean {\n    return template.some((obj) => obj.type === type);\n  }\n\n  override getAllMessageCategories(): string[] {\n    let categories: string[] = super.getAllMessageCategories();\n    if (\n      !categories.some(\n        (category) =>\n          category === CometChatUIKitConstants.MessageCategory.custom\n      )\n    ) {\n      categories.push(CometChatUIKitConstants.MessageCategory.custom);\n    }\n    return categories;\n  }\n\n  override getAllMessageTypes(): string[] {\n    let types: string[] = super.getAllMessageTypes();\n    if (\n      !types.some(\n        (category) =>\n          category === CometChatUIKitConstants.MessageCategory.custom\n      )\n    ) {\n      types.push(StickersConstants.sticker);\n    }\n    return types;\n  }\n\n  override getId(): string {\n    return \"stickers\";\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() == StickersConstants.sticker &&\n      message.getCategory() == CometChatUIKitConstants.MessageCategory.custom\n    ) {\n      return localize(\"CUSTOM_MESSAGE_STICKER\");\n    } else {\n      return super.getLastConversationMessage(\n        conversation,\n        loggedInUser,\n        additionalConfigurations\n      );\n    }\n  }\n}\n"]}