@zohoim/client-sdk 1.0.0-poc99 → 1.0.0-replyAreaPoc1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (76) hide show
  1. package/es/application/services/cannedMessages/CannedMessageService.js +51 -0
  2. package/es/application/services/cannedMessages/index.js +2 -0
  3. package/es/application/services/index.js +3 -1
  4. package/es/application/services/templateMessages/TemplateMessageService.js +26 -0
  5. package/es/application/services/templateMessages/index.js +2 -0
  6. package/es/core/constants/ModuleNames.js +4 -1
  7. package/es/domain/dto/cannedMessages/createCannedMessageRequest.js +13 -0
  8. package/es/domain/dto/cannedMessages/deleteCannedMessageRequest.js +13 -0
  9. package/es/domain/dto/cannedMessages/disableCannedMessageRequest.js +13 -0
  10. package/es/domain/dto/cannedMessages/enableCannedMessageRequest.js +13 -0
  11. package/es/domain/dto/cannedMessages/getCannedMessageRequest.js +13 -0
  12. package/es/domain/dto/cannedMessages/getCannedMessagesRequest.js +18 -0
  13. package/es/domain/dto/cannedMessages/index.js +7 -0
  14. package/es/domain/dto/cannedMessages/updateCannedMessageRequest.js +13 -0
  15. package/es/domain/dto/index.js +3 -1
  16. package/es/domain/dto/messages/sendMessageRequest.js +1 -1
  17. package/es/domain/dto/templateMessages/getTemplateCreditExhaustStatusRequest.js +11 -0
  18. package/es/domain/dto/templateMessages/getTemplateLanguagesRequest.js +7 -0
  19. package/es/domain/dto/templateMessages/index.js +2 -0
  20. package/es/domain/entities/CannedMessage/CannedMessage.js +52 -0
  21. package/es/domain/entities/CannedMessage/index.js +2 -0
  22. package/es/domain/entities/CustomReplyExtension/CustomReplyExtension.js +22 -0
  23. package/es/domain/entities/CustomReplyExtension/index.js +2 -0
  24. package/es/domain/entities/TemplateMessage/TemplateCreditExhaustStatus.js +24 -0
  25. package/es/domain/entities/TemplateMessage/TemplateLanguage.js +18 -0
  26. package/es/domain/entities/TemplateMessage/index.js +3 -0
  27. package/es/domain/entities/index.js +4 -1
  28. package/es/domain/enum/cannedMessage/CannedMessageStatus.js +6 -0
  29. package/es/domain/enum/cannedMessage/index.js +2 -0
  30. package/es/domain/enum/index.js +3 -1
  31. package/es/domain/enum/templateMessage/TemplateCreditExhaustStatusCode.js +4 -0
  32. package/es/domain/enum/templateMessage/TemplateLanguage.js +74 -0
  33. package/es/domain/enum/templateMessage/index.js +3 -0
  34. package/es/domain/interfaces/repositories/cannedMessages/ICannedMessageRepository.js +47 -0
  35. package/es/domain/interfaces/repositories/cannedMessages/index.js +2 -0
  36. package/es/domain/interfaces/repositories/index.js +3 -1
  37. package/es/domain/interfaces/repositories/templateMessages/ITemplateMessageRepository.js +21 -0
  38. package/es/domain/interfaces/repositories/templateMessages/index.js +2 -0
  39. package/es/domain/schema/cannedMessage/CannedMessageSchema.js +54 -0
  40. package/es/domain/schema/cannedMessage/index.js +2 -0
  41. package/es/domain/schema/customReplyExtension/CustomReplyExtensionSchema.js +28 -0
  42. package/es/domain/schema/customReplyExtension/index.js +2 -0
  43. package/es/domain/schema/index.js +4 -1
  44. package/es/domain/schema/templateMessage/TemplateCreditExhaustStatusSchema.js +13 -0
  45. package/es/domain/schema/templateMessage/TemplateLanguageSchema.js +13 -0
  46. package/es/domain/schema/templateMessage/index.js +3 -0
  47. package/es/frameworks/managers/ModuleFactory.js +18 -0
  48. package/es/frameworks/managers/ModuleManager.js +1 -1
  49. package/es/frameworks/sdk/IMSDK.js +10 -0
  50. package/es/frameworks/sdk/cannedMessages/CannedMessageSDK.js +30 -0
  51. package/es/frameworks/sdk/cannedMessages/index.js +2 -0
  52. package/es/frameworks/sdk/templateMessages/TemplateMessageSDK.js +30 -0
  53. package/es/frameworks/sdk/templateMessages/index.js +2 -0
  54. package/es/infrastructure/adapters/cannedMessages/CannedMessageAdapter.js +28 -0
  55. package/es/infrastructure/adapters/cannedMessages/index.js +2 -0
  56. package/es/infrastructure/adapters/customReplyExtension/CustomReplyExtensionAdapter.js +24 -0
  57. package/es/infrastructure/adapters/customReplyExtension/index.js +2 -0
  58. package/es/infrastructure/adapters/index.js +4 -1
  59. package/es/infrastructure/adapters/templateMessages/TemplateCreditExhaustStatusAdapter.js +21 -0
  60. package/es/infrastructure/adapters/templateMessages/TemplateLanguageAdapter.js +20 -0
  61. package/es/infrastructure/adapters/templateMessages/index.js +3 -0
  62. package/es/infrastructure/api/cannedMessages/CannedMessageAPI.js +74 -0
  63. package/es/infrastructure/api/cannedMessages/index.js +2 -0
  64. package/es/infrastructure/api/index.js +3 -1
  65. package/es/infrastructure/api/registry/cannedMessages/cannedMessageAPIRegistry.js +48 -0
  66. package/es/infrastructure/api/registry/cannedMessages/constructCannedMessageEndPoint.js +10 -0
  67. package/es/infrastructure/api/registry/cannedMessages/index.js +2 -0
  68. package/es/infrastructure/api/registry/getRegistryConfig.js +3 -1
  69. package/es/infrastructure/api/templateMessages/TemplateMessageAPI.js +24 -0
  70. package/es/infrastructure/api/templateMessages/index.js +2 -0
  71. package/es/infrastructure/repositories/cannedMessages/CannedMessageRepository.js +97 -0
  72. package/es/infrastructure/repositories/cannedMessages/index.js +2 -0
  73. package/es/infrastructure/repositories/index.js +3 -1
  74. package/es/infrastructure/repositories/templateMessages/TemplateMessageRepository.js +77 -0
  75. package/es/infrastructure/repositories/templateMessages/index.js +2 -0
  76. package/package.json +1 -1
@@ -0,0 +1,51 @@
1
+ import { ICannedMessageRepository } from '../../../domain/interfaces/repositories';
2
+ export default class CannedMessageService extends ICannedMessageRepository {
3
+ constructor(_ref) {
4
+ let {
5
+ cannedMessageRepository
6
+ } = _ref;
7
+ super();
8
+ this.cannedMessageRepository = cannedMessageRepository;
9
+ }
10
+
11
+ async getCannedMessages(request) {
12
+ return this.cannedMessageRepository.getCannedMessages(request);
13
+ }
14
+
15
+ async getCannedMessage(request) {
16
+ return this.cannedMessageRepository.getCannedMessage(request);
17
+ }
18
+
19
+ async createCannedMessage(request) {
20
+ return this.cannedMessageRepository.createCannedMessage(request);
21
+ }
22
+
23
+ async deleteCannedMessage(request) {
24
+ return this.cannedMessageRepository.deleteCannedMessage(request);
25
+ }
26
+
27
+ async updateCannedMessage(request) {
28
+ return this.cannedMessageRepository.updateCannedMessage(request);
29
+ }
30
+
31
+ async enableCannedMessage(request) {
32
+ return this.cannedMessageRepository.enableCannedMessage(request);
33
+ }
34
+
35
+ async disableCannedMessage(request) {
36
+ return this.cannedMessageRepository.disableCannedMessage(request);
37
+ }
38
+
39
+ toJSON() {
40
+ return {
41
+ getCannedMessages: this.getCannedMessages.bind(this),
42
+ getCannedMessage: this.getCannedMessage.bind(this),
43
+ createCannedMessage: this.createCannedMessage.bind(this),
44
+ deleteCannedMessage: this.deleteCannedMessage.bind(this),
45
+ updateCannedMessage: this.updateCannedMessage.bind(this),
46
+ enableCannedMessage: this.enableCannedMessage.bind(this),
47
+ disableCannedMessage: this.disableCannedMessage.bind(this)
48
+ };
49
+ }
50
+
51
+ }
@@ -0,0 +1,2 @@
1
+ import CannedMessageService from './CannedMessageService';
2
+ export { CannedMessageService };
@@ -3,4 +3,6 @@ export * from './sessions';
3
3
  export * from './bots';
4
4
  export * from './messages';
5
5
  export * from './agents';
6
- export * from './contacts';
6
+ export * from './contacts';
7
+ export * from './cannedMessages';
8
+ export * from './templateMessages';
@@ -0,0 +1,26 @@
1
+ import { ITemplateMessageRepository } from '../../../domain/interfaces/repositories';
2
+ export default class TemplateMessageService extends ITemplateMessageRepository {
3
+ constructor(_ref) {
4
+ let {
5
+ templateMessageRepository
6
+ } = _ref;
7
+ super();
8
+ this.templateMessageRepository = templateMessageRepository;
9
+ }
10
+
11
+ async getTemplateLanguages(request) {
12
+ return this.templateMessageRepository.getTemplateLanguages(request);
13
+ }
14
+
15
+ async getWhatsAppTemplateCreditExhaustStatus(request) {
16
+ return this.templateMessageRepository.getWhatsAppTemplateCreditExhaustStatus(request);
17
+ }
18
+
19
+ toJSON() {
20
+ return {
21
+ getTemplateLanguages: this.getTemplateLanguages.bind(this),
22
+ getWhatsAppTemplateCreditExhaustStatus: this.getWhatsAppTemplateCreditExhaustStatus.bind(this)
23
+ };
24
+ }
25
+
26
+ }
@@ -0,0 +1,2 @@
1
+ import TemplateMessageService from './TemplateMessageService';
2
+ export { TemplateMessageService };
@@ -4,6 +4,9 @@ const ModuleNames = {
4
4
  BOTS: 'bots',
5
5
  MESSAGES: 'messages',
6
6
  CONTACTS: 'contacts',
7
- AGENTS: 'agents'
7
+ AGENTS: 'agents',
8
+ CANNED_MESSAGES: 'cannedMessages',
9
+ TEMPLATE_MESSAGES: 'templateMessages',
10
+ CUSTOM_REPLY_EXTENSIONS: 'articles'
8
11
  };
9
12
  export default ModuleNames;
@@ -0,0 +1,13 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function createCannedMessageRequest() {
4
+ let {
5
+ params = {},
6
+ body = {}
7
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
8
+ return new RequestBuilder().withParams({ ...params
9
+ }).withBody({ ...body
10
+ }).build();
11
+ }
12
+
13
+ export default createCannedMessageRequest;
@@ -0,0 +1,13 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function deleteCannedMessageRequest() {
4
+ let {
5
+ params = {}
6
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ return new RequestBuilder().withParams({
8
+ messageId: null,
9
+ ...params
10
+ }).build();
11
+ }
12
+
13
+ export default deleteCannedMessageRequest;
@@ -0,0 +1,13 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function disableCannedMessageRequest() {
4
+ let {
5
+ params = {}
6
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ return new RequestBuilder().withParams({
8
+ messageId: null,
9
+ ...params
10
+ }).build();
11
+ }
12
+
13
+ export default disableCannedMessageRequest;
@@ -0,0 +1,13 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function enableCannedMessageRequest() {
4
+ let {
5
+ params = {}
6
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ return new RequestBuilder().withParams({
8
+ messageId: null,
9
+ ...params
10
+ }).build();
11
+ }
12
+
13
+ export default enableCannedMessageRequest;
@@ -0,0 +1,13 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function getCannedMessageRequest() {
4
+ let {
5
+ params = {}
6
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ return new RequestBuilder().withParams({
8
+ messageId: null,
9
+ ...params
10
+ }).build();
11
+ }
12
+
13
+ export default getCannedMessageRequest;
@@ -0,0 +1,18 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function getCannedMessagesRequest() {
4
+ let {
5
+ query = {},
6
+ params = {}
7
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
8
+ return new RequestBuilder().withParams({ ...params
9
+ }).withQuery({
10
+ from: 0,
11
+ limit: 10,
12
+ modifiedAfter: null,
13
+ type: null,
14
+ ...query
15
+ }).build();
16
+ }
17
+
18
+ export default getCannedMessagesRequest;
@@ -0,0 +1,7 @@
1
+ export { default as getCannedMessagesRequest } from './getCannedMessagesRequest';
2
+ export { default as getCannedMessageRequest } from './getCannedMessageRequest';
3
+ export { default as deleteCannedMessageRequest } from './deleteCannedMessageRequest';
4
+ export { default as createCannedMessageRequest } from './createCannedMessageRequest';
5
+ export { default as enableCannedMessageRequest } from './enableCannedMessageRequest';
6
+ export { default as disableCannedMessageRequest } from './disableCannedMessageRequest';
7
+ export { default as updateCannedMessageRequest } from './updateCannedMessageRequest';
@@ -0,0 +1,13 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function updateCannedMessageRequest() {
4
+ let {
5
+ params = {}
6
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ return new RequestBuilder().withParams({
8
+ messageId: null,
9
+ ...params
10
+ }).build();
11
+ }
12
+
13
+ export default updateCannedMessageRequest;
@@ -3,4 +3,6 @@ export * from './sessions';
3
3
  export * from './bots';
4
4
  export * from './messages';
5
5
  export * from './agents';
6
- export * from './contacts';
6
+ export * from './contacts';
7
+ export * from './cannedMessages';
8
+ export * from './templateMessages';
@@ -11,7 +11,7 @@ function sendMessageRequest() {
11
11
  }).withBody({
12
12
  message: null,
13
13
  replyToMessageId: null,
14
- meta: null,
14
+ additionalData: null,
15
15
  ...body
16
16
  }).build();
17
17
  }
@@ -0,0 +1,11 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function getTemplateCreditExhaustStatusRequest() {
4
+ let {
5
+ params = {}
6
+ } = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ return new RequestBuilder().withParams({ ...params
8
+ }).build();
9
+ }
10
+
11
+ export default getTemplateCreditExhaustStatusRequest;
@@ -0,0 +1,7 @@
1
+ import RequestBuilder from '../RequestBuilder';
2
+
3
+ function getTemplateLanguagesRequest() {
4
+ return new RequestBuilder().build();
5
+ }
6
+
7
+ export default getTemplateLanguagesRequest;
@@ -0,0 +1,2 @@
1
+ export { default as getTemplateLanguagesRequest } from './getTemplateLanguagesRequest';
2
+ export { default as getTemplateCreditExhaustStatusRequest } from './getTemplateCreditExhaustStatusRequest';
@@ -0,0 +1,52 @@
1
+ import { validateSchema } from '../../../core/utils';
2
+ import { CannedMessageStatus } from '../../enum/cannedMessage';
3
+ import { CannedMessageSchema } from '../../schema';
4
+ export default class Message {
5
+ constructor() {
6
+ let data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ const validatedData = validateSchema(CannedMessageSchema, data);
8
+ this.data = {
9
+ id: validatedData.id,
10
+ title: validatedData.title,
11
+ message: validatedData.message,
12
+ tags: validatedData.tags,
13
+ status: validatedData.status,
14
+ uuid: validatedData.uuid,
15
+ createdBy: validatedData.createdBy,
16
+ displayMessage: validatedData.displayMessage,
17
+ type: validatedData.type,
18
+ kind: validatedData.kind,
19
+ isActive: validatedData.isActive,
20
+ meta: validatedData.meta,
21
+ isPrivate: validatedData.isPrivate,
22
+ rejectionReason: validatedData.rejectionReason,
23
+ modifiedTime: validatedData.modifiedTime,
24
+ translations: validatedData.translations
25
+ };
26
+ }
27
+
28
+ static isApproved(status) {
29
+ return status === CannedMessageStatus.APPROVED;
30
+ }
31
+
32
+ static isRejected(status) {
33
+ return status === CannedMessageStatus.REJECTED;
34
+ }
35
+
36
+ static isPending(status) {
37
+ return status === CannedMessageStatus.PENDING;
38
+ }
39
+
40
+ static getMetaValue() {
41
+ let meta = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : [];
42
+ let key = arguments.length > 1 ? arguments[1] : undefined;
43
+ const item = meta.find(item => item.name === key);
44
+ return item ? item.value : '';
45
+ }
46
+
47
+ toJSON() {
48
+ return { ...this.data
49
+ };
50
+ }
51
+
52
+ }
@@ -0,0 +1,2 @@
1
+ import CannedMessage from './CannedMessage';
2
+ export { CannedMessage };
@@ -0,0 +1,22 @@
1
+ import { validateSchema } from '../../../core/utils';
2
+ import { CustomReplyExtensionSchema } from '../../schema';
3
+ export default class CustomReplyExtension {
4
+ constructor() {
5
+ let data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
6
+ const validatedData = validateSchema(CustomReplyExtensionSchema, data);
7
+ this.data = {
8
+ id: validatedData.id,
9
+ title: validatedData.title,
10
+ message: validatedData.message,
11
+ displayMessage: validatedData.displayMessage,
12
+ webUrl: validatedData.webUrl || '',
13
+ categoryName: validatedData.categoryName
14
+ };
15
+ }
16
+
17
+ toJSON() {
18
+ return { ...this.data
19
+ };
20
+ }
21
+
22
+ }
@@ -0,0 +1,2 @@
1
+ import CustomReplyExtension from './CustomReplyExtension';
2
+ export { CustomReplyExtension };
@@ -0,0 +1,24 @@
1
+ import { validateSchema } from '../../../core/utils';
2
+ import { TemplateCreditExhaustStatusCode } from '../../enum';
3
+ import { TemplateCreditExhaustStatusSchema } from '../../schema';
4
+ export default class TemplateCreditExhaustStatus {
5
+ constructor() {
6
+ let data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
7
+ const validatedData = validateSchema(TemplateCreditExhaustStatusSchema, data);
8
+ this.data = {
9
+ code: validatedData.code,
10
+ message: validatedData.message,
11
+ error: validatedData.error
12
+ };
13
+ }
14
+
15
+ static isInSufficientCredits(code) {
16
+ return code === TemplateCreditExhaustStatusCode.INSUFFICIENT_CREDITS;
17
+ }
18
+
19
+ toJSON() {
20
+ return { ...this.data
21
+ };
22
+ }
23
+
24
+ }
@@ -0,0 +1,18 @@
1
+ import { validateSchema } from '../../../core/utils';
2
+ import { TemplateLanguageSchema } from '../../schema';
3
+ export default class TemplateLanguage {
4
+ constructor() {
5
+ let data = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : {};
6
+ const validatedData = validateSchema(TemplateLanguageSchema, data);
7
+ this.data = {
8
+ code: validatedData.code,
9
+ language: validatedData.language
10
+ };
11
+ }
12
+
13
+ toJSON() {
14
+ return { ...this.data
15
+ };
16
+ }
17
+
18
+ }
@@ -0,0 +1,3 @@
1
+ import TemplateLanguage from './TemplateLanguage';
2
+ import TemplateCreditExhaustStatus from './TemplateCreditExhaustStatus';
3
+ export { TemplateLanguage, TemplateCreditExhaustStatus };
@@ -6,4 +6,7 @@ export * from './Attachment';
6
6
  export * from './Message';
7
7
  export * from './Channel';
8
8
  export * from './Contact';
9
- export * from './IntegrationService';
9
+ export * from './IntegrationService';
10
+ export * from './CannedMessage';
11
+ export * from './TemplateMessage';
12
+ export * from './CustomReplyExtension';
@@ -0,0 +1,6 @@
1
+ const CannedMessageStatus = {
2
+ APPROVED: 'APPROVED',
3
+ PENDING: 'PENDING',
4
+ REJECTED: 'REJECTED'
5
+ };
6
+ export default CannedMessageStatus;
@@ -0,0 +1,2 @@
1
+ import CannedMessageStatus from './CannedMessageStatus';
2
+ export { CannedMessageStatus };
@@ -3,4 +3,6 @@ export * from './session';
3
3
  export * from './actor';
4
4
  export * from './bot';
5
5
  export * from './message';
6
- export * from './attachment';
6
+ export * from './attachment';
7
+ export * from './cannedMessage';
8
+ export * from './templateMessage';
@@ -0,0 +1,4 @@
1
+ const TemplateCreditExhaustStatusCode = {
2
+ INSUFFICIENT_CREDITS: 'INSUFFICIENT_CREDITS'
3
+ };
4
+ export default TemplateCreditExhaustStatusCode;
@@ -0,0 +1,74 @@
1
+ const TemplateLanguage = {
2
+ Afrikaans: 'Afrikaans',
3
+ Albanian: 'Albanian',
4
+ Arabic: 'Arabic',
5
+ Azerbaijani: 'Azerbaijani',
6
+ Bengali: 'Bengali',
7
+ Bulgarian: 'Bulgarian',
8
+ Catalan: 'Catalan',
9
+ 'Chinese (CHN)': 'Chinese (CHN)',
10
+ 'Chinese (HKG)': 'Chinese (HKG)',
11
+ 'Chinese (TAI)': 'Chinese (TAI)',
12
+ Croatian: 'Croatian',
13
+ Czech: 'Czech',
14
+ Danish: 'Danish',
15
+ Dutch: 'Dutch',
16
+ English: 'English',
17
+ 'English (UK)': 'English (UK)',
18
+ 'English (US)': 'English (US)',
19
+ Estonian: 'Estonian',
20
+ Filipino: 'Filipino',
21
+ Finnish: 'Finnish',
22
+ French: 'French',
23
+ Georgian: 'Georgian',
24
+ German: 'German',
25
+ Greek: 'Greek',
26
+ Gujarati: 'Gujarati',
27
+ Hausa: 'Hausa',
28
+ Hebrew: 'Hebrew',
29
+ Hindi: 'Hindi',
30
+ Hungarian: 'Hungarian',
31
+ Indonesian: 'Indonesian',
32
+ Irish: 'Irish',
33
+ Italian: 'Italian',
34
+ Japanese: 'Japanese',
35
+ Kannada: 'Kannada',
36
+ Kazakh: 'Kazakh',
37
+ Kinyarwanda: 'Kinyarwanda',
38
+ Korean: 'Korean',
39
+ 'Kyrgyz (Kyrgyzstan)': 'Kyrgyz (Kyrgyzstan)',
40
+ Lao: 'Lao',
41
+ Latvian: 'Latvian',
42
+ Lithuanian: 'Lithuanian',
43
+ Macedonian: 'Macedonian',
44
+ Malay: 'Malay',
45
+ Malayalam: 'Malayalam',
46
+ Marathi: 'Marathi',
47
+ Norwegian: 'Norwegian',
48
+ Persian: 'Persian',
49
+ Polish: 'Polish',
50
+ 'Portuguese (BR)': 'Portuguese (BR)',
51
+ 'Portuguese (POR)': 'Portuguese (POR)',
52
+ Punjabi: 'Punjabi',
53
+ Romanian: 'Romanian',
54
+ Russian: 'Russian',
55
+ Serbian: 'Serbian',
56
+ Slovak: 'Slovak',
57
+ Slovenian: 'Slovenian',
58
+ Spanish: 'Spanish',
59
+ 'Spanish (ARG)': 'Spanish (ARG)',
60
+ 'Spanish (SPA)': 'Spanish (SPA)',
61
+ 'Spanish (MEX)': 'Spanish (MEX)',
62
+ Swahili: 'Swahili',
63
+ Swedish: 'Swedish',
64
+ Tamil: 'Tamil',
65
+ Telugu: 'Telugu',
66
+ Thai: 'Thai',
67
+ Turkish: 'Turkish',
68
+ Ukrainian: 'Ukrainian',
69
+ Urdu: 'Urdu',
70
+ Uzbek: 'Uzbek',
71
+ Vietnamese: 'Vietnamese',
72
+ Zulu: 'Zulu'
73
+ };
74
+ export default TemplateLanguage;
@@ -0,0 +1,3 @@
1
+ import TemplateLanguage from './TemplateLanguage';
2
+ import TemplateCreditExhaustStatusCode from './TemplateCreditExhaustStatusCode';
3
+ export { TemplateLanguage, TemplateCreditExhaustStatusCode };
@@ -0,0 +1,47 @@
1
+ /* eslint-disable no-unused-vars */
2
+ import { ModuleNames } from '../../../../core/constants';
3
+ import BaseAPI from '../../../../infrastructure/api/BaseAPI';
4
+ import { getCannedMessageRequest, getCannedMessagesRequest, createCannedMessageRequest, updateCannedMessageRequest, deleteCannedMessageRequest, disableCannedMessageRequest, enableCannedMessageRequest } from '../../../dto';
5
+ export default class ITemplateMessageRepository extends BaseAPI {
6
+ constructor() {
7
+ super({
8
+ module: ModuleNames.CANNED_MESSAGES
9
+ });
10
+ }
11
+
12
+ getCannedMessages() {
13
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getCannedMessagesRequest();
14
+ throw new Error('Method not implemented.');
15
+ }
16
+
17
+ getCannedMessage() {
18
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getCannedMessageRequest();
19
+ throw new Error('Method not implemented.');
20
+ }
21
+
22
+ createCannedMessage() {
23
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : createCannedMessageRequest();
24
+ throw new Error('Method not implemented.');
25
+ }
26
+
27
+ updateCannedMessage() {
28
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : updateCannedMessageRequest();
29
+ throw new Error('Method not implemented.');
30
+ }
31
+
32
+ deleteCannedMessage() {
33
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : deleteCannedMessageRequest();
34
+ throw new Error('Method not implemented.');
35
+ }
36
+
37
+ enableCannedMessage() {
38
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : enableCannedMessageRequest();
39
+ throw new Error('Method not implemented.');
40
+ }
41
+
42
+ disableCannedMessage() {
43
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : disableCannedMessageRequest();
44
+ throw new Error('Method not implemented.');
45
+ }
46
+
47
+ }
@@ -0,0 +1,2 @@
1
+ import ICannedMessageRepository from './ICannedMessageRepository';
2
+ export { ICannedMessageRepository };
@@ -3,4 +3,6 @@ export * from './sessions';
3
3
  export * from './bots';
4
4
  export * from './messages';
5
5
  export * from './agents';
6
- export * from './contacts';
6
+ export * from './contacts';
7
+ export * from './cannedMessages';
8
+ export * from './templateMessages';
@@ -0,0 +1,21 @@
1
+ import { ModuleNames } from '../../../../core/constants';
2
+ import BaseAPI from '../../../../infrastructure/api/BaseAPI';
3
+ import { getTemplateCreditExhaustStatusRequest, getTemplateLanguagesRequest } from '../../../dto';
4
+ export default class ITemplateMessageRepository extends BaseAPI {
5
+ constructor() {
6
+ super({
7
+ module: ModuleNames.TEMPLATE_MESSAGES
8
+ });
9
+ }
10
+
11
+ async getTemplateLanguages() {
12
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getTemplateLanguagesRequest();
13
+ throw new Error('Method not implemented');
14
+ }
15
+
16
+ async getWhatsAppTemplateCreditExhaustStatus() {
17
+ let request = arguments.length > 0 && arguments[0] !== undefined ? arguments[0] : getTemplateCreditExhaustStatusRequest();
18
+ throw new Error('Method not implemented');
19
+ }
20
+
21
+ }
@@ -0,0 +1,2 @@
1
+ import ITemplateMessageRepository from './ITemplateMessageRepository';
2
+ export { ITemplateMessageRepository };
@@ -0,0 +1,54 @@
1
+ import '../../enum';
2
+ import { ActorSchema } from '../actor';
3
+ const CannedMessageSchema = {
4
+ id: {
5
+ type: 'string',
6
+ required: true
7
+ },
8
+ title: {
9
+ type: 'string',
10
+ required: true
11
+ },
12
+ tags: {
13
+ type: 'string',
14
+ required: false
15
+ },
16
+ status: {
17
+ type: 'string',
18
+ required: false
19
+ },
20
+ createdBy: {
21
+ type: 'object',
22
+ required: true,
23
+ schema: ActorSchema
24
+ },
25
+ uuid: {
26
+ type: 'string',
27
+ required: false
28
+ },
29
+ displayMessage: {
30
+ type: 'string',
31
+ required: true
32
+ },
33
+ type: {
34
+ type: 'string',
35
+ required: true
36
+ },
37
+ translations: {
38
+ type: 'array',
39
+ required: false
40
+ },
41
+ isPrivate: {
42
+ type: 'bool',
43
+ required: false
44
+ },
45
+ isActive: {
46
+ type: 'bool',
47
+ required: true
48
+ },
49
+ meta: {
50
+ type: 'array',
51
+ required: false
52
+ }
53
+ };
54
+ export default CannedMessageSchema;