@metigan/angular 1.0.0

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 (48) hide show
  1. package/LICENSE +22 -0
  2. package/README.md +581 -0
  3. package/dist/LICENSE +22 -0
  4. package/dist/README.md +581 -0
  5. package/dist/esm2022/metigan-angular.mjs +5 -0
  6. package/dist/esm2022/public-api.mjs +21 -0
  7. package/dist/esm2022/src/lib/audiences.service.mjs +157 -0
  8. package/dist/esm2022/src/lib/config.mjs +30 -0
  9. package/dist/esm2022/src/lib/contacts.service.mjs +267 -0
  10. package/dist/esm2022/src/lib/email.service.mjs +267 -0
  11. package/dist/esm2022/src/lib/errors.mjs +40 -0
  12. package/dist/esm2022/src/lib/forms.service.mjs +180 -0
  13. package/dist/esm2022/src/lib/http-client.service.mjs +111 -0
  14. package/dist/esm2022/src/lib/metigan.module.mjs +67 -0
  15. package/dist/esm2022/src/lib/metigan.service.mjs +72 -0
  16. package/dist/esm2022/src/lib/templates.service.mjs +85 -0
  17. package/dist/esm2022/src/lib/types.mjs +6 -0
  18. package/dist/fesm2022/metigan-angular.mjs +1241 -0
  19. package/dist/fesm2022/metigan-angular.mjs.map +1 -0
  20. package/dist/index.d.ts +5 -0
  21. package/dist/public-api.d.ts +15 -0
  22. package/dist/src/lib/audiences.service.d.ts +62 -0
  23. package/dist/src/lib/config.d.ts +28 -0
  24. package/dist/src/lib/contacts.service.d.ts +80 -0
  25. package/dist/src/lib/email.service.d.ts +44 -0
  26. package/dist/src/lib/errors.d.ts +24 -0
  27. package/dist/src/lib/forms.service.d.ts +67 -0
  28. package/dist/src/lib/http-client.service.d.ts +46 -0
  29. package/dist/src/lib/metigan.module.d.ts +27 -0
  30. package/dist/src/lib/metigan.service.d.ts +27 -0
  31. package/dist/src/lib/templates.service.d.ts +36 -0
  32. package/dist/src/lib/types.d.ts +329 -0
  33. package/examples/basic.component.ts +113 -0
  34. package/ng-package.json +8 -0
  35. package/package.json +68 -0
  36. package/public-api.ts +26 -0
  37. package/src/lib/audiences.service.ts +230 -0
  38. package/src/lib/config.ts +35 -0
  39. package/src/lib/contacts.service.ts +377 -0
  40. package/src/lib/email.service.ts +286 -0
  41. package/src/lib/errors.ts +45 -0
  42. package/src/lib/forms.service.ts +263 -0
  43. package/src/lib/http-client.service.ts +156 -0
  44. package/src/lib/metigan.module.ts +55 -0
  45. package/src/lib/metigan.service.ts +80 -0
  46. package/src/lib/templates.service.ts +103 -0
  47. package/src/lib/types.ts +398 -0
  48. package/tsconfig.json +38 -0
@@ -0,0 +1,111 @@
1
+ /**
2
+ * HTTP Client Service for Metigan SDK
3
+ * Wraps Angular HttpClient with retry logic and error handling
4
+ */
5
+ import { Injectable } from '@angular/core';
6
+ import { throwError, timer } from 'rxjs';
7
+ import { catchError, retryWhen, mergeMap, map } from 'rxjs/operators';
8
+ import { ApiError, MetiganError } from './errors';
9
+ import * as i0 from "@angular/core";
10
+ import * as i1 from "@angular/common/http";
11
+ export class MetiganHttpClient {
12
+ http;
13
+ constructor(http) {
14
+ this.http = http;
15
+ }
16
+ /**
17
+ * Make GET request with retry logic
18
+ */
19
+ get(url, options, retryCount = 3, retryDelay = 1000) {
20
+ const opts = this.buildOptions(options);
21
+ return this.http.get(url, opts).pipe(map((response) => response), retryWhen(errors => errors.pipe(mergeMap((error, index) => {
22
+ if (index < retryCount && this.shouldRetry(error)) {
23
+ return timer(retryDelay * (index + 1));
24
+ }
25
+ return throwError(() => error);
26
+ }))), catchError(this.handleError));
27
+ }
28
+ /**
29
+ * Make POST request with retry logic
30
+ */
31
+ post(url, body, options, retryCount = 3, retryDelay = 1000) {
32
+ const opts = this.buildOptions(options);
33
+ return this.http.post(url, body, opts).pipe(map((response) => response), retryWhen(errors => errors.pipe(mergeMap((error, index) => {
34
+ if (index < retryCount && this.shouldRetry(error)) {
35
+ return timer(retryDelay * (index + 1));
36
+ }
37
+ return throwError(() => error);
38
+ }))), catchError(this.handleError));
39
+ }
40
+ /**
41
+ * Make PUT request with retry logic
42
+ */
43
+ put(url, body, options, retryCount = 3, retryDelay = 1000) {
44
+ const opts = this.buildOptions(options);
45
+ return this.http.put(url, body, opts).pipe(map((response) => response), retryWhen(errors => errors.pipe(mergeMap((error, index) => {
46
+ if (index < retryCount && this.shouldRetry(error)) {
47
+ return timer(retryDelay * (index + 1));
48
+ }
49
+ return throwError(() => error);
50
+ }))), catchError(this.handleError));
51
+ }
52
+ /**
53
+ * Make DELETE request with retry logic
54
+ */
55
+ delete(url, options, retryCount = 3, retryDelay = 1000) {
56
+ const opts = this.buildOptions(options);
57
+ return this.http.delete(url, opts).pipe(map((response) => response), retryWhen(errors => errors.pipe(mergeMap((error, index) => {
58
+ if (index < retryCount && this.shouldRetry(error)) {
59
+ return timer(retryDelay * (index + 1));
60
+ }
61
+ return throwError(() => error);
62
+ }))), catchError(this.handleError));
63
+ }
64
+ /**
65
+ * Build HTTP options with timeout
66
+ */
67
+ buildOptions(options) {
68
+ const opts = {
69
+ observe: 'body'
70
+ };
71
+ if (options?.headers) {
72
+ opts.headers = options.headers;
73
+ }
74
+ if (options?.params) {
75
+ opts.params = options.params;
76
+ }
77
+ // Angular HttpClient doesn't support timeout directly
78
+ // Timeout should be handled at the interceptor level if needed
79
+ return opts;
80
+ }
81
+ /**
82
+ * Determine if error should trigger retry
83
+ */
84
+ shouldRetry(error) {
85
+ // Retry on server errors (5xx) or network errors
86
+ return error.status >= 500 || error.status === 0 || !error.status;
87
+ }
88
+ /**
89
+ * Handle HTTP errors
90
+ */
91
+ handleError = (error) => {
92
+ if (error.error instanceof ErrorEvent) {
93
+ // Client-side error
94
+ return throwError(() => new MetiganError(`Network error: ${error.error.message}`));
95
+ }
96
+ else {
97
+ // Server-side error
98
+ const message = error.error?.message || error.error?.error || `Request failed with status ${error.status}`;
99
+ return throwError(() => new ApiError(message, error.status));
100
+ }
101
+ };
102
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganHttpClient, deps: [{ token: i1.HttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
103
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganHttpClient, providedIn: 'root' });
104
+ }
105
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganHttpClient, decorators: [{
106
+ type: Injectable,
107
+ args: [{
108
+ providedIn: 'root'
109
+ }]
110
+ }], ctorParameters: () => [{ type: i1.HttpClient }] });
111
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"http-client.service.js","sourceRoot":"","sources":["../../../../src/lib/http-client.service.ts"],"names":[],"mappings":"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","sourcesContent":["/**\r\n * HTTP Client Service for Metigan SDK\r\n * Wraps Angular HttpClient with retry logic and error handling\r\n */\r\n\r\nimport { Injectable } from '@angular/core';\r\nimport { HttpClient, HttpHeaders, HttpParams, HttpErrorResponse } from '@angular/common/http';\r\nimport { Observable, throwError, timer } from 'rxjs';\r\nimport { catchError, retryWhen, mergeMap, map } from 'rxjs/operators';\r\nimport { ApiError, MetiganError } from './errors';\r\n\r\nexport interface HttpOptions {\r\n  headers?: HttpHeaders | { [header: string]: string | string[] };\r\n  params?: HttpParams | { [param: string]: any };\r\n  timeout?: number;\r\n}\r\n\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class MetiganHttpClient {\r\n  constructor(private http: HttpClient) {}\r\n\r\n  /**\r\n   * Make GET request with retry logic\r\n   */\r\n  get<T>(url: string, options?: HttpOptions, retryCount: number = 3, retryDelay: number = 1000): Observable<T> {\r\n    const opts = this.buildOptions(options);\r\n    \r\n    return (this.http.get<T>(url, opts) as Observable<T>).pipe(\r\n      map((response: T) => response),\r\n      retryWhen(errors =>\r\n        errors.pipe(\r\n          mergeMap((error: HttpErrorResponse, index: number) => {\r\n            if (index < retryCount && this.shouldRetry(error)) {\r\n              return timer(retryDelay * (index + 1));\r\n            }\r\n            return throwError(() => error);\r\n          })\r\n        )\r\n      ),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Make POST request with retry logic\r\n   */\r\n  post<T>(url: string, body: any, options?: HttpOptions, retryCount: number = 3, retryDelay: number = 1000): Observable<T> {\r\n    const opts = this.buildOptions(options);\r\n    \r\n    return (this.http.post<T>(url, body, opts) as Observable<T>).pipe(\r\n      map((response: T) => response),\r\n      retryWhen(errors =>\r\n        errors.pipe(\r\n          mergeMap((error: HttpErrorResponse, index: number) => {\r\n            if (index < retryCount && this.shouldRetry(error)) {\r\n              return timer(retryDelay * (index + 1));\r\n            }\r\n            return throwError(() => error);\r\n          })\r\n        )\r\n      ),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Make PUT request with retry logic\r\n   */\r\n  put<T>(url: string, body: any, options?: HttpOptions, retryCount: number = 3, retryDelay: number = 1000): Observable<T> {\r\n    const opts = this.buildOptions(options);\r\n    \r\n    return (this.http.put<T>(url, body, opts) as Observable<T>).pipe(\r\n      map((response: T) => response),\r\n      retryWhen(errors =>\r\n        errors.pipe(\r\n          mergeMap((error: HttpErrorResponse, index: number) => {\r\n            if (index < retryCount && this.shouldRetry(error)) {\r\n              return timer(retryDelay * (index + 1));\r\n            }\r\n            return throwError(() => error);\r\n          })\r\n        )\r\n      ),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Make DELETE request with retry logic\r\n   */\r\n  delete<T>(url: string, options?: HttpOptions, retryCount: number = 3, retryDelay: number = 1000): Observable<T> {\r\n    const opts = this.buildOptions(options);\r\n    \r\n    return (this.http.delete<T>(url, opts) as Observable<T>).pipe(\r\n      map((response: T) => response),\r\n      retryWhen(errors =>\r\n        errors.pipe(\r\n          mergeMap((error: HttpErrorResponse, index: number) => {\r\n            if (index < retryCount && this.shouldRetry(error)) {\r\n              return timer(retryDelay * (index + 1));\r\n            }\r\n            return throwError(() => error);\r\n          })\r\n        )\r\n      ),\r\n      catchError(this.handleError)\r\n    );\r\n  }\r\n\r\n  /**\r\n   * Build HTTP options with timeout\r\n   */\r\n  private buildOptions(options?: HttpOptions): any {\r\n    const opts: any = {\r\n      observe: 'body' as const\r\n    };\r\n    \r\n    if (options?.headers) {\r\n      opts.headers = options.headers;\r\n    }\r\n    \r\n    if (options?.params) {\r\n      opts.params = options.params;\r\n    }\r\n\r\n    // Angular HttpClient doesn't support timeout directly\r\n    // Timeout should be handled at the interceptor level if needed\r\n    \r\n    return opts;\r\n  }\r\n\r\n  /**\r\n   * Determine if error should trigger retry\r\n   */\r\n  private shouldRetry(error: HttpErrorResponse): boolean {\r\n    // Retry on server errors (5xx) or network errors\r\n    return error.status >= 500 || error.status === 0 || !error.status;\r\n  }\r\n\r\n  /**\r\n   * Handle HTTP errors\r\n   */\r\n  private handleError = (error: HttpErrorResponse): Observable<never> => {\r\n    if (error.error instanceof ErrorEvent) {\r\n      // Client-side error\r\n      return throwError(() => new MetiganError(`Network error: ${error.error.message}`));\r\n    } else {\r\n      // Server-side error\r\n      const message = error.error?.message || error.error?.error || `Request failed with status ${error.status}`;\r\n      return throwError(() => new ApiError(message, error.status));\r\n    }\r\n  };\r\n}\r\n\r\n"]}
@@ -0,0 +1,67 @@
1
+ /**
2
+ * Metigan Angular Module
3
+ * Import this module in your Angular app to use Metigan services
4
+ */
5
+ import { NgModule } from '@angular/core';
6
+ import { HttpClientModule } from '@angular/common/http';
7
+ import { MetiganService, METIGAN_CONFIG } from './metigan.service';
8
+ import { MetiganHttpClient } from './http-client.service';
9
+ import { MetiganEmailService } from './email.service';
10
+ import { MetiganFormsService } from './forms.service';
11
+ import { MetiganContactsService } from './contacts.service';
12
+ import { MetiganAudiencesService } from './audiences.service';
13
+ import { MetiganTemplatesService } from './templates.service';
14
+ import * as i0 from "@angular/core";
15
+ export class MetiganModule {
16
+ /**
17
+ * Configure Metigan with API key and options
18
+ * Call this in your root module's imports
19
+ *
20
+ * @example
21
+ * ```typescript
22
+ * imports: [
23
+ * MetiganModule.forRoot({
24
+ * apiKey: 'your-api-key'
25
+ * })
26
+ * ]
27
+ * ```
28
+ */
29
+ static forRoot(config) {
30
+ return {
31
+ ngModule: MetiganModule,
32
+ providers: [
33
+ {
34
+ provide: METIGAN_CONFIG,
35
+ useValue: config
36
+ }
37
+ ]
38
+ };
39
+ }
40
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
41
+ static ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.12", ngImport: i0, type: MetiganModule, imports: [HttpClientModule] });
42
+ static ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganModule, providers: [
43
+ MetiganHttpClient,
44
+ MetiganEmailService,
45
+ MetiganFormsService,
46
+ MetiganContactsService,
47
+ MetiganAudiencesService,
48
+ MetiganTemplatesService,
49
+ MetiganService
50
+ ], imports: [HttpClientModule] });
51
+ }
52
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganModule, decorators: [{
53
+ type: NgModule,
54
+ args: [{
55
+ imports: [HttpClientModule],
56
+ providers: [
57
+ MetiganHttpClient,
58
+ MetiganEmailService,
59
+ MetiganFormsService,
60
+ MetiganContactsService,
61
+ MetiganAudiencesService,
62
+ MetiganTemplatesService,
63
+ MetiganService
64
+ ]
65
+ }]
66
+ }] });
67
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWV0aWdhbi5tb2R1bGUuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL21ldGlnYW4ubW9kdWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxRQUFRLEVBQXVCLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLHNCQUFzQixDQUFDO0FBQ3hELE9BQU8sRUFBRSxjQUFjLEVBQUUsY0FBYyxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFDbkUsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDMUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdEQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDdEQsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDNUQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0scUJBQXFCLENBQUM7QUFDOUQsT0FBTyxFQUFFLHVCQUF1QixFQUFFLE1BQU0scUJBQXFCLENBQUM7O0FBZTlELE1BQU0sT0FBTyxhQUFhO0lBQ3hCOzs7Ozs7Ozs7Ozs7T0FZRztJQUNILE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBNEI7UUFDekMsT0FBTztZQUNMLFFBQVEsRUFBRSxhQUFhO1lBQ3ZCLFNBQVMsRUFBRTtnQkFDVDtvQkFDRSxPQUFPLEVBQUUsY0FBYztvQkFDdkIsUUFBUSxFQUFFLE1BQU07aUJBQ2pCO2FBQ0Y7U0FDRixDQUFDO0lBQ0osQ0FBQzt3R0F4QlUsYUFBYTt5R0FBYixhQUFhLFlBWGQsZ0JBQWdCO3lHQVdmLGFBQWEsYUFWYjtZQUNULGlCQUFpQjtZQUNqQixtQkFBbUI7WUFDbkIsbUJBQW1CO1lBQ25CLHNCQUFzQjtZQUN0Qix1QkFBdUI7WUFDdkIsdUJBQXVCO1lBQ3ZCLGNBQWM7U0FDZixZQVRTLGdCQUFnQjs7NEZBV2YsYUFBYTtrQkFaekIsUUFBUTttQkFBQztvQkFDUixPQUFPLEVBQUUsQ0FBQyxnQkFBZ0IsQ0FBQztvQkFDM0IsU0FBUyxFQUFFO3dCQUNULGlCQUFpQjt3QkFDakIsbUJBQW1CO3dCQUNuQixtQkFBbUI7d0JBQ25CLHNCQUFzQjt3QkFDdEIsdUJBQXVCO3dCQUN2Qix1QkFBdUI7d0JBQ3ZCLGNBQWM7cUJBQ2Y7aUJBQ0YiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogTWV0aWdhbiBBbmd1bGFyIE1vZHVsZVxyXG4gKiBJbXBvcnQgdGhpcyBtb2R1bGUgaW4geW91ciBBbmd1bGFyIGFwcCB0byB1c2UgTWV0aWdhbiBzZXJ2aWNlc1xyXG4gKi9cclxuXHJcbmltcG9ydCB7IE5nTW9kdWxlLCBNb2R1bGVXaXRoUHJvdmlkZXJzIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IEh0dHBDbGllbnRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcbmltcG9ydCB7IE1ldGlnYW5TZXJ2aWNlLCBNRVRJR0FOX0NPTkZJRyB9IGZyb20gJy4vbWV0aWdhbi5zZXJ2aWNlJztcclxuaW1wb3J0IHsgTWV0aWdhbkh0dHBDbGllbnQgfSBmcm9tICcuL2h0dHAtY2xpZW50LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuRW1haWxTZXJ2aWNlIH0gZnJvbSAnLi9lbWFpbC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgTWV0aWdhbkZvcm1zU2VydmljZSB9IGZyb20gJy4vZm9ybXMuc2VydmljZSc7XHJcbmltcG9ydCB7IE1ldGlnYW5Db250YWN0c1NlcnZpY2UgfSBmcm9tICcuL2NvbnRhY3RzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuQXVkaWVuY2VzU2VydmljZSB9IGZyb20gJy4vYXVkaWVuY2VzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuVGVtcGxhdGVzU2VydmljZSB9IGZyb20gJy4vdGVtcGxhdGVzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuQ2xpZW50T3B0aW9ucyB9IGZyb20gJy4vdHlwZXMnO1xyXG5cclxuQE5nTW9kdWxlKHtcclxuICBpbXBvcnRzOiBbSHR0cENsaWVudE1vZHVsZV0sXHJcbiAgcHJvdmlkZXJzOiBbXHJcbiAgICBNZXRpZ2FuSHR0cENsaWVudCxcclxuICAgIE1ldGlnYW5FbWFpbFNlcnZpY2UsXHJcbiAgICBNZXRpZ2FuRm9ybXNTZXJ2aWNlLFxyXG4gICAgTWV0aWdhbkNvbnRhY3RzU2VydmljZSxcclxuICAgIE1ldGlnYW5BdWRpZW5jZXNTZXJ2aWNlLFxyXG4gICAgTWV0aWdhblRlbXBsYXRlc1NlcnZpY2UsXHJcbiAgICBNZXRpZ2FuU2VydmljZVxyXG4gIF1cclxufSlcclxuZXhwb3J0IGNsYXNzIE1ldGlnYW5Nb2R1bGUge1xyXG4gIC8qKlxyXG4gICAqIENvbmZpZ3VyZSBNZXRpZ2FuIHdpdGggQVBJIGtleSBhbmQgb3B0aW9uc1xyXG4gICAqIENhbGwgdGhpcyBpbiB5b3VyIHJvb3QgbW9kdWxlJ3MgaW1wb3J0c1xyXG4gICAqIFxyXG4gICAqIEBleGFtcGxlXHJcbiAgICogYGBgdHlwZXNjcmlwdFxyXG4gICAqIGltcG9ydHM6IFtcclxuICAgKiAgIE1ldGlnYW5Nb2R1bGUuZm9yUm9vdCh7XHJcbiAgICogICAgIGFwaUtleTogJ3lvdXItYXBpLWtleSdcclxuICAgKiAgIH0pXHJcbiAgICogXVxyXG4gICAqIGBgYFxyXG4gICAqL1xyXG4gIHN0YXRpYyBmb3JSb290KGNvbmZpZzogTWV0aWdhbkNsaWVudE9wdGlvbnMpOiBNb2R1bGVXaXRoUHJvdmlkZXJzPE1ldGlnYW5Nb2R1bGU+IHtcclxuICAgIHJldHVybiB7XHJcbiAgICAgIG5nTW9kdWxlOiBNZXRpZ2FuTW9kdWxlLFxyXG4gICAgICBwcm92aWRlcnM6IFtcclxuICAgICAgICB7XHJcbiAgICAgICAgICBwcm92aWRlOiBNRVRJR0FOX0NPTkZJRyxcclxuICAgICAgICAgIHVzZVZhbHVlOiBjb25maWdcclxuICAgICAgICB9XHJcbiAgICAgIF1cclxuICAgIH07XHJcbiAgfVxyXG59XHJcblxyXG4iXX0=
@@ -0,0 +1,72 @@
1
+ /**
2
+ * Main Metigan Service
3
+ * Unified service that provides access to all Metigan modules
4
+ */
5
+ import { Injectable, Inject, Optional } from '@angular/core';
6
+ import { MetiganError } from './errors';
7
+ import * as i0 from "@angular/core";
8
+ import * as i1 from "./email.service";
9
+ import * as i2 from "./forms.service";
10
+ import * as i3 from "./contacts.service";
11
+ import * as i4 from "./audiences.service";
12
+ import * as i5 from "./templates.service";
13
+ export const METIGAN_CONFIG = 'METIGAN_CONFIG';
14
+ export class MetiganService {
15
+ email;
16
+ forms;
17
+ contacts;
18
+ audiences;
19
+ templates;
20
+ initialized = false;
21
+ constructor(emailService, formsService, contactsService, audiencesService, templatesService, config) {
22
+ this.email = emailService;
23
+ this.forms = formsService;
24
+ this.contacts = contactsService;
25
+ this.audiences = audiencesService;
26
+ this.templates = templatesService;
27
+ // Auto-initialize if config is provided via injection
28
+ if (config) {
29
+ this.initialize(config);
30
+ }
31
+ }
32
+ /**
33
+ * Initialize all services with API key and options
34
+ */
35
+ initialize(options) {
36
+ if (!options.apiKey) {
37
+ throw new MetiganError('API key is required');
38
+ }
39
+ const serviceOptions = {
40
+ apiUrl: options.apiUrl,
41
+ timeout: options.timeout,
42
+ retryCount: options.retryCount,
43
+ retryDelay: options.retryDelay
44
+ };
45
+ this.email.initialize(options.apiKey, serviceOptions);
46
+ this.forms.initialize(options.apiKey, serviceOptions);
47
+ this.contacts.initialize(options.apiKey, serviceOptions);
48
+ this.audiences.initialize(options.apiKey, serviceOptions);
49
+ this.templates.initialize(options.apiKey, serviceOptions);
50
+ this.initialized = true;
51
+ }
52
+ /**
53
+ * Check if services are initialized
54
+ */
55
+ isInitialized() {
56
+ return this.initialized;
57
+ }
58
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganService, deps: [{ token: i1.MetiganEmailService }, { token: i2.MetiganFormsService }, { token: i3.MetiganContactsService }, { token: i4.MetiganAudiencesService }, { token: i5.MetiganTemplatesService }, { token: METIGAN_CONFIG, optional: true }], target: i0.ɵɵFactoryTarget.Injectable });
59
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganService, providedIn: 'root' });
60
+ }
61
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganService, decorators: [{
62
+ type: Injectable,
63
+ args: [{
64
+ providedIn: 'root'
65
+ }]
66
+ }], ctorParameters: () => [{ type: i1.MetiganEmailService }, { type: i2.MetiganFormsService }, { type: i3.MetiganContactsService }, { type: i4.MetiganAudiencesService }, { type: i5.MetiganTemplatesService }, { type: undefined, decorators: [{
67
+ type: Optional
68
+ }, {
69
+ type: Inject,
70
+ args: [METIGAN_CONFIG]
71
+ }] }] });
72
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWV0aWdhbi5zZXJ2aWNlLmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2xpYi9tZXRpZ2FuLnNlcnZpY2UudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUE7OztHQUdHO0FBRUgsT0FBTyxFQUFFLFVBQVUsRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBTTdELE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxVQUFVLENBQUM7Ozs7Ozs7QUFHeEMsTUFBTSxDQUFDLE1BQU0sY0FBYyxHQUFHLGdCQUFnQixDQUFDO0FBSy9DLE1BQU0sT0FBTyxjQUFjO0lBQ1QsS0FBSyxDQUFzQjtJQUMzQixLQUFLLENBQXNCO0lBQzNCLFFBQVEsQ0FBeUI7SUFDakMsU0FBUyxDQUEwQjtJQUNuQyxTQUFTLENBQTBCO0lBRTNDLFdBQVcsR0FBWSxLQUFLLENBQUM7SUFFckMsWUFDRSxZQUFpQyxFQUNqQyxZQUFpQyxFQUNqQyxlQUF1QyxFQUN2QyxnQkFBeUMsRUFDekMsZ0JBQXlDLEVBQ0wsTUFBNkI7UUFFakUsSUFBSSxDQUFDLEtBQUssR0FBRyxZQUFZLENBQUM7UUFDMUIsSUFBSSxDQUFDLEtBQUssR0FBRyxZQUFZLENBQUM7UUFDMUIsSUFBSSxDQUFDLFFBQVEsR0FBRyxlQUFlLENBQUM7UUFDaEMsSUFBSSxDQUFDLFNBQVMsR0FBRyxnQkFBZ0IsQ0FBQztRQUNsQyxJQUFJLENBQUMsU0FBUyxHQUFHLGdCQUFnQixDQUFDO1FBRWxDLHNEQUFzRDtRQUN0RCxJQUFJLE1BQU0sRUFBRSxDQUFDO1lBQ1gsSUFBSSxDQUFDLFVBQVUsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMxQixDQUFDO0lBQ0gsQ0FBQztJQUVEOztPQUVHO0lBQ0gsVUFBVSxDQUFDLE9BQTZCO1FBQ3RDLElBQUksQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDcEIsTUFBTSxJQUFJLFlBQVksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ2hELENBQUM7UUFFRCxNQUFNLGNBQWMsR0FBRztZQUNyQixNQUFNLEVBQUUsT0FBTyxDQUFDLE1BQU07WUFDdEIsT0FBTyxFQUFFLE9BQU8sQ0FBQyxPQUFPO1lBQ3hCLFVBQVUsRUFBRSxPQUFPLENBQUMsVUFBVTtZQUM5QixVQUFVLEVBQUUsT0FBTyxDQUFDLFVBQVU7U0FDL0IsQ0FBQztRQUVGLElBQUksQ0FBQyxLQUFLLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFDdEQsSUFBSSxDQUFDLEtBQUssQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxjQUFjLENBQUMsQ0FBQztRQUN0RCxJQUFJLENBQUMsUUFBUSxDQUFDLFVBQVUsQ0FBQyxPQUFPLENBQUMsTUFBTSxFQUFFLGNBQWMsQ0FBQyxDQUFDO1FBQ3pELElBQUksQ0FBQyxTQUFTLENBQUMsVUFBVSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUUsY0FBYyxDQUFDLENBQUM7UUFDMUQsSUFBSSxDQUFDLFNBQVMsQ0FBQyxVQUFVLENBQUMsT0FBTyxDQUFDLE1BQU0sRUFBRSxjQUFjLENBQUMsQ0FBQztRQUUxRCxJQUFJLENBQUMsV0FBVyxHQUFHLElBQUksQ0FBQztJQUMxQixDQUFDO0lBRUQ7O09BRUc7SUFDSCxhQUFhO1FBQ1gsT0FBTyxJQUFJLENBQUMsV0FBVyxDQUFDO0lBQzFCLENBQUM7d0dBMURVLGNBQWMsNE1BZUgsY0FBYzs0R0FmekIsY0FBYyxjQUZiLE1BQU07OzRGQUVQLGNBQWM7a0JBSDFCLFVBQVU7bUJBQUM7b0JBQ1YsVUFBVSxFQUFFLE1BQU07aUJBQ25COzswQkFnQkksUUFBUTs7MEJBQUksTUFBTTsyQkFBQyxjQUFjIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXHJcbiAqIE1haW4gTWV0aWdhbiBTZXJ2aWNlXHJcbiAqIFVuaWZpZWQgc2VydmljZSB0aGF0IHByb3ZpZGVzIGFjY2VzcyB0byBhbGwgTWV0aWdhbiBtb2R1bGVzXHJcbiAqL1xyXG5cclxuaW1wb3J0IHsgSW5qZWN0YWJsZSwgSW5qZWN0LCBPcHRpb25hbCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuRW1haWxTZXJ2aWNlIH0gZnJvbSAnLi9lbWFpbC5zZXJ2aWNlJztcclxuaW1wb3J0IHsgTWV0aWdhbkZvcm1zU2VydmljZSB9IGZyb20gJy4vZm9ybXMuc2VydmljZSc7XHJcbmltcG9ydCB7IE1ldGlnYW5Db250YWN0c1NlcnZpY2UgfSBmcm9tICcuL2NvbnRhY3RzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuQXVkaWVuY2VzU2VydmljZSB9IGZyb20gJy4vYXVkaWVuY2VzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuVGVtcGxhdGVzU2VydmljZSB9IGZyb20gJy4vdGVtcGxhdGVzLnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBNZXRpZ2FuRXJyb3IgfSBmcm9tICcuL2Vycm9ycyc7XHJcbmltcG9ydCB7IE1ldGlnYW5DbGllbnRPcHRpb25zIH0gZnJvbSAnLi90eXBlcyc7XHJcblxyXG5leHBvcnQgY29uc3QgTUVUSUdBTl9DT05GSUcgPSAnTUVUSUdBTl9DT05GSUcnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTWV0aWdhblNlcnZpY2Uge1xyXG4gIHB1YmxpYyByZWFkb25seSBlbWFpbDogTWV0aWdhbkVtYWlsU2VydmljZTtcclxuICBwdWJsaWMgcmVhZG9ubHkgZm9ybXM6IE1ldGlnYW5Gb3Jtc1NlcnZpY2U7XHJcbiAgcHVibGljIHJlYWRvbmx5IGNvbnRhY3RzOiBNZXRpZ2FuQ29udGFjdHNTZXJ2aWNlO1xyXG4gIHB1YmxpYyByZWFkb25seSBhdWRpZW5jZXM6IE1ldGlnYW5BdWRpZW5jZXNTZXJ2aWNlO1xyXG4gIHB1YmxpYyByZWFkb25seSB0ZW1wbGF0ZXM6IE1ldGlnYW5UZW1wbGF0ZXNTZXJ2aWNlO1xyXG5cclxuICBwcml2YXRlIGluaXRpYWxpemVkOiBib29sZWFuID0gZmFsc2U7XHJcblxyXG4gIGNvbnN0cnVjdG9yKFxyXG4gICAgZW1haWxTZXJ2aWNlOiBNZXRpZ2FuRW1haWxTZXJ2aWNlLFxyXG4gICAgZm9ybXNTZXJ2aWNlOiBNZXRpZ2FuRm9ybXNTZXJ2aWNlLFxyXG4gICAgY29udGFjdHNTZXJ2aWNlOiBNZXRpZ2FuQ29udGFjdHNTZXJ2aWNlLFxyXG4gICAgYXVkaWVuY2VzU2VydmljZTogTWV0aWdhbkF1ZGllbmNlc1NlcnZpY2UsXHJcbiAgICB0ZW1wbGF0ZXNTZXJ2aWNlOiBNZXRpZ2FuVGVtcGxhdGVzU2VydmljZSxcclxuICAgIEBPcHRpb25hbCgpIEBJbmplY3QoTUVUSUdBTl9DT05GSUcpIGNvbmZpZz86IE1ldGlnYW5DbGllbnRPcHRpb25zXHJcbiAgKSB7XHJcbiAgICB0aGlzLmVtYWlsID0gZW1haWxTZXJ2aWNlO1xyXG4gICAgdGhpcy5mb3JtcyA9IGZvcm1zU2VydmljZTtcclxuICAgIHRoaXMuY29udGFjdHMgPSBjb250YWN0c1NlcnZpY2U7XHJcbiAgICB0aGlzLmF1ZGllbmNlcyA9IGF1ZGllbmNlc1NlcnZpY2U7XHJcbiAgICB0aGlzLnRlbXBsYXRlcyA9IHRlbXBsYXRlc1NlcnZpY2U7XHJcblxyXG4gICAgLy8gQXV0by1pbml0aWFsaXplIGlmIGNvbmZpZyBpcyBwcm92aWRlZCB2aWEgaW5qZWN0aW9uXHJcbiAgICBpZiAoY29uZmlnKSB7XHJcbiAgICAgIHRoaXMuaW5pdGlhbGl6ZShjb25maWcpO1xyXG4gICAgfVxyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogSW5pdGlhbGl6ZSBhbGwgc2VydmljZXMgd2l0aCBBUEkga2V5IGFuZCBvcHRpb25zXHJcbiAgICovXHJcbiAgaW5pdGlhbGl6ZShvcHRpb25zOiBNZXRpZ2FuQ2xpZW50T3B0aW9ucyk6IHZvaWQge1xyXG4gICAgaWYgKCFvcHRpb25zLmFwaUtleSkge1xyXG4gICAgICB0aHJvdyBuZXcgTWV0aWdhbkVycm9yKCdBUEkga2V5IGlzIHJlcXVpcmVkJyk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3Qgc2VydmljZU9wdGlvbnMgPSB7XHJcbiAgICAgIGFwaVVybDogb3B0aW9ucy5hcGlVcmwsXHJcbiAgICAgIHRpbWVvdXQ6IG9wdGlvbnMudGltZW91dCxcclxuICAgICAgcmV0cnlDb3VudDogb3B0aW9ucy5yZXRyeUNvdW50LFxyXG4gICAgICByZXRyeURlbGF5OiBvcHRpb25zLnJldHJ5RGVsYXlcclxuICAgIH07XHJcblxyXG4gICAgdGhpcy5lbWFpbC5pbml0aWFsaXplKG9wdGlvbnMuYXBpS2V5LCBzZXJ2aWNlT3B0aW9ucyk7XHJcbiAgICB0aGlzLmZvcm1zLmluaXRpYWxpemUob3B0aW9ucy5hcGlLZXksIHNlcnZpY2VPcHRpb25zKTtcclxuICAgIHRoaXMuY29udGFjdHMuaW5pdGlhbGl6ZShvcHRpb25zLmFwaUtleSwgc2VydmljZU9wdGlvbnMpO1xyXG4gICAgdGhpcy5hdWRpZW5jZXMuaW5pdGlhbGl6ZShvcHRpb25zLmFwaUtleSwgc2VydmljZU9wdGlvbnMpO1xyXG4gICAgdGhpcy50ZW1wbGF0ZXMuaW5pdGlhbGl6ZShvcHRpb25zLmFwaUtleSwgc2VydmljZU9wdGlvbnMpO1xyXG5cclxuICAgIHRoaXMuaW5pdGlhbGl6ZWQgPSB0cnVlO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogQ2hlY2sgaWYgc2VydmljZXMgYXJlIGluaXRpYWxpemVkXHJcbiAgICovXHJcbiAgaXNJbml0aWFsaXplZCgpOiBib29sZWFuIHtcclxuICAgIHJldHVybiB0aGlzLmluaXRpYWxpemVkO1xyXG4gIH1cclxufVxyXG5cclxuIl19
@@ -0,0 +1,85 @@
1
+ /**
2
+ * Metigan Templates Service
3
+ * Service for managing email templates
4
+ */
5
+ import { Injectable } from '@angular/core';
6
+ import { throwError } from 'rxjs';
7
+ import { HttpParams } from '@angular/common/http';
8
+ import { API_URL, DEFAULT_TIMEOUT, DEFAULT_RETRY_COUNT, DEFAULT_RETRY_DELAY } from './config';
9
+ import { ValidationError, MetiganError } from './errors';
10
+ import * as i0 from "@angular/core";
11
+ import * as i1 from "./http-client.service";
12
+ export class MetiganTemplatesService {
13
+ http;
14
+ apiKey = '';
15
+ apiUrl = API_URL;
16
+ timeout = DEFAULT_TIMEOUT;
17
+ retryCount = DEFAULT_RETRY_COUNT;
18
+ retryDelay = DEFAULT_RETRY_DELAY;
19
+ constructor(http) {
20
+ this.http = http;
21
+ }
22
+ /**
23
+ * Initialize the service with API key and options
24
+ */
25
+ initialize(apiKey, options) {
26
+ if (!apiKey) {
27
+ throw new MetiganError('API key is required');
28
+ }
29
+ this.apiKey = apiKey;
30
+ this.apiUrl = options?.apiUrl || API_URL;
31
+ this.timeout = options?.timeout || DEFAULT_TIMEOUT;
32
+ this.retryCount = options?.retryCount || DEFAULT_RETRY_COUNT;
33
+ this.retryDelay = options?.retryDelay || DEFAULT_RETRY_DELAY;
34
+ }
35
+ /**
36
+ * Get default headers
37
+ */
38
+ getHeaders() {
39
+ return {
40
+ 'Content-Type': 'application/json',
41
+ 'x-api-key': this.apiKey,
42
+ 'User-Agent': 'AngularSDK/1.0'
43
+ };
44
+ }
45
+ /**
46
+ * List all templates
47
+ */
48
+ list(options) {
49
+ if (!this.apiKey) {
50
+ return throwError(() => new MetiganError('Service not initialized. Call initialize() first.'));
51
+ }
52
+ let params = new HttpParams();
53
+ if (options?.page) {
54
+ params = params.set('page', options.page.toString());
55
+ }
56
+ if (options?.limit) {
57
+ params = params.set('limit', options.limit.toString());
58
+ }
59
+ return this.http.get(`${this.apiUrl}/api/templates`, {
60
+ headers: this.getHeaders(),
61
+ params: params
62
+ }, this.retryCount, this.retryDelay);
63
+ }
64
+ /**
65
+ * Get template by ID
66
+ */
67
+ get(templateId) {
68
+ if (!this.apiKey) {
69
+ return throwError(() => new MetiganError('Service not initialized. Call initialize() first.'));
70
+ }
71
+ if (!templateId) {
72
+ return throwError(() => new ValidationError('Template ID is required'));
73
+ }
74
+ return this.http.get(`${this.apiUrl}/api/templates/${templateId}`, { headers: this.getHeaders() }, this.retryCount, this.retryDelay);
75
+ }
76
+ static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganTemplatesService, deps: [{ token: i1.MetiganHttpClient }], target: i0.ɵɵFactoryTarget.Injectable });
77
+ static ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganTemplatesService, providedIn: 'root' });
78
+ }
79
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImport: i0, type: MetiganTemplatesService, decorators: [{
80
+ type: Injectable,
81
+ args: [{
82
+ providedIn: 'root'
83
+ }]
84
+ }], ctorParameters: () => [{ type: i1.MetiganHttpClient }] });
85
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVtcGxhdGVzLnNlcnZpY2UuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGliL3RlbXBsYXRlcy5zZXJ2aWNlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBOzs7R0FHRztBQUVILE9BQU8sRUFBRSxVQUFVLEVBQUUsTUFBTSxlQUFlLENBQUM7QUFDM0MsT0FBTyxFQUFjLFVBQVUsRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUM5QyxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFbEQsT0FBTyxFQUFFLE9BQU8sRUFBRSxlQUFlLEVBQUUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSxVQUFVLENBQUM7QUFDOUYsT0FBTyxFQUFFLGVBQWUsRUFBRSxZQUFZLEVBQUUsTUFBTSxVQUFVLENBQUM7OztBQVV6RCxNQUFNLE9BQU8sdUJBQXVCO0lBT2Q7SUFOWixNQUFNLEdBQVcsRUFBRSxDQUFDO0lBQ3BCLE1BQU0sR0FBVyxPQUFPLENBQUM7SUFDekIsT0FBTyxHQUFXLGVBQWUsQ0FBQztJQUNsQyxVQUFVLEdBQVcsbUJBQW1CLENBQUM7SUFDekMsVUFBVSxHQUFXLG1CQUFtQixDQUFDO0lBRWpELFlBQW9CLElBQXVCO1FBQXZCLFNBQUksR0FBSixJQUFJLENBQW1CO0lBQUcsQ0FBQztJQUUvQzs7T0FFRztJQUNILFVBQVUsQ0FBQyxNQUFjLEVBQUUsT0FBeUY7UUFDbEgsSUFBSSxDQUFDLE1BQU0sRUFBRSxDQUFDO1lBQ1osTUFBTSxJQUFJLFlBQVksQ0FBQyxxQkFBcUIsQ0FBQyxDQUFDO1FBQ2hELENBQUM7UUFFRCxJQUFJLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQztRQUNyQixJQUFJLENBQUMsTUFBTSxHQUFHLE9BQU8sRUFBRSxNQUFNLElBQUksT0FBTyxDQUFDO1FBQ3pDLElBQUksQ0FBQyxPQUFPLEdBQUcsT0FBTyxFQUFFLE9BQU8sSUFBSSxlQUFlLENBQUM7UUFDbkQsSUFBSSxDQUFDLFVBQVUsR0FBRyxPQUFPLEVBQUUsVUFBVSxJQUFJLG1CQUFtQixDQUFDO1FBQzdELElBQUksQ0FBQyxVQUFVLEdBQUcsT0FBTyxFQUFFLFVBQVUsSUFBSSxtQkFBbUIsQ0FBQztJQUMvRCxDQUFDO0lBRUQ7O09BRUc7SUFDSyxVQUFVO1FBQ2hCLE9BQU87WUFDTCxjQUFjLEVBQUUsa0JBQWtCO1lBQ2xDLFdBQVcsRUFBRSxJQUFJLENBQUMsTUFBTTtZQUN4QixZQUFZLEVBQUUsZ0JBQWdCO1NBQy9CLENBQUM7SUFDSixDQUFDO0lBRUQ7O09BRUc7SUFDSCxJQUFJLENBQUMsT0FBMkI7UUFDOUIsSUFBSSxDQUFDLElBQUksQ0FBQyxNQUFNLEVBQUUsQ0FBQztZQUNqQixPQUFPLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLFlBQVksQ0FBQyxtREFBbUQsQ0FBQyxDQUFDLENBQUM7UUFDakcsQ0FBQztRQUVELElBQUksTUFBTSxHQUFHLElBQUksVUFBVSxFQUFFLENBQUM7UUFDOUIsSUFBSSxPQUFPLEVBQUUsSUFBSSxFQUFFLENBQUM7WUFDbEIsTUFBTSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsTUFBTSxFQUFFLE9BQU8sQ0FBQyxJQUFJLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUN2RCxDQUFDO1FBQ0QsSUFBSSxPQUFPLEVBQUUsS0FBSyxFQUFFLENBQUM7WUFDbkIsTUFBTSxHQUFHLE1BQU0sQ0FBQyxHQUFHLENBQUMsT0FBTyxFQUFFLE9BQU8sQ0FBQyxLQUFLLENBQUMsUUFBUSxFQUFFLENBQUMsQ0FBQztRQUN6RCxDQUFDO1FBRUQsT0FBTyxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FDbEIsR0FBRyxJQUFJLENBQUMsTUFBTSxnQkFBZ0IsRUFDOUI7WUFDRSxPQUFPLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRTtZQUMxQixNQUFNLEVBQUUsTUFBTTtTQUNmLEVBQ0QsSUFBSSxDQUFDLFVBQVUsRUFDZixJQUFJLENBQUMsVUFBVSxDQUNoQixDQUFDO0lBQ0osQ0FBQztJQUVEOztPQUVHO0lBQ0gsR0FBRyxDQUFDLFVBQWtCO1FBQ3BCLElBQUksQ0FBQyxJQUFJLENBQUMsTUFBTSxFQUFFLENBQUM7WUFDakIsT0FBTyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxZQUFZLENBQUMsbURBQW1ELENBQUMsQ0FBQyxDQUFDO1FBQ2pHLENBQUM7UUFFRCxJQUFJLENBQUMsVUFBVSxFQUFFLENBQUM7WUFDaEIsT0FBTyxVQUFVLENBQUMsR0FBRyxFQUFFLENBQUMsSUFBSSxlQUFlLENBQUMseUJBQXlCLENBQUMsQ0FBQyxDQUFDO1FBQzFFLENBQUM7UUFFRCxPQUFPLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUNsQixHQUFHLElBQUksQ0FBQyxNQUFNLGtCQUFrQixVQUFVLEVBQUUsRUFDNUMsRUFBRSxPQUFPLEVBQUUsSUFBSSxDQUFDLFVBQVUsRUFBRSxFQUFFLEVBQzlCLElBQUksQ0FBQyxVQUFVLEVBQ2YsSUFBSSxDQUFDLFVBQVUsQ0FDaEIsQ0FBQztJQUNKLENBQUM7d0dBaEZVLHVCQUF1Qjs0R0FBdkIsdUJBQXVCLGNBRnRCLE1BQU07OzRGQUVQLHVCQUF1QjtrQkFIbkMsVUFBVTttQkFBQztvQkFDVixVQUFVLEVBQUUsTUFBTTtpQkFDbkIiLCJzb3VyY2VzQ29udGVudCI6WyIvKipcclxuICogTWV0aWdhbiBUZW1wbGF0ZXMgU2VydmljZVxyXG4gKiBTZXJ2aWNlIGZvciBtYW5hZ2luZyBlbWFpbCB0ZW1wbGF0ZXNcclxuICovXHJcblxyXG5pbXBvcnQgeyBJbmplY3RhYmxlIH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7IE9ic2VydmFibGUsIHRocm93RXJyb3IgfSBmcm9tICdyeGpzJztcclxuaW1wb3J0IHsgSHR0cFBhcmFtcyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuaW1wb3J0IHsgTWV0aWdhbkh0dHBDbGllbnQgfSBmcm9tICcuL2h0dHAtY2xpZW50LnNlcnZpY2UnO1xyXG5pbXBvcnQgeyBBUElfVVJMLCBERUZBVUxUX1RJTUVPVVQsIERFRkFVTFRfUkVUUllfQ09VTlQsIERFRkFVTFRfUkVUUllfREVMQVkgfSBmcm9tICcuL2NvbmZpZyc7XHJcbmltcG9ydCB7IFZhbGlkYXRpb25FcnJvciwgTWV0aWdhbkVycm9yIH0gZnJvbSAnLi9lcnJvcnMnO1xyXG5pbXBvcnQge1xyXG4gIEVtYWlsVGVtcGxhdGUsXHJcbiAgRW1haWxUZW1wbGF0ZUxpc3RSZXNwb25zZSxcclxuICBQYWdpbmF0aW9uT3B0aW9uc1xyXG59IGZyb20gJy4vdHlwZXMnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gIHByb3ZpZGVkSW46ICdyb290J1xyXG59KVxyXG5leHBvcnQgY2xhc3MgTWV0aWdhblRlbXBsYXRlc1NlcnZpY2Uge1xyXG4gIHByaXZhdGUgYXBpS2V5OiBzdHJpbmcgPSAnJztcclxuICBwcml2YXRlIGFwaVVybDogc3RyaW5nID0gQVBJX1VSTDtcclxuICBwcml2YXRlIHRpbWVvdXQ6IG51bWJlciA9IERFRkFVTFRfVElNRU9VVDtcclxuICBwcml2YXRlIHJldHJ5Q291bnQ6IG51bWJlciA9IERFRkFVTFRfUkVUUllfQ09VTlQ7XHJcbiAgcHJpdmF0ZSByZXRyeURlbGF5OiBudW1iZXIgPSBERUZBVUxUX1JFVFJZX0RFTEFZO1xyXG5cclxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGh0dHA6IE1ldGlnYW5IdHRwQ2xpZW50KSB7fVxyXG5cclxuICAvKipcclxuICAgKiBJbml0aWFsaXplIHRoZSBzZXJ2aWNlIHdpdGggQVBJIGtleSBhbmQgb3B0aW9uc1xyXG4gICAqL1xyXG4gIGluaXRpYWxpemUoYXBpS2V5OiBzdHJpbmcsIG9wdGlvbnM/OiB7IGFwaVVybD86IHN0cmluZzsgdGltZW91dD86IG51bWJlcjsgcmV0cnlDb3VudD86IG51bWJlcjsgcmV0cnlEZWxheT86IG51bWJlciB9KTogdm9pZCB7XHJcbiAgICBpZiAoIWFwaUtleSkge1xyXG4gICAgICB0aHJvdyBuZXcgTWV0aWdhbkVycm9yKCdBUEkga2V5IGlzIHJlcXVpcmVkJyk7XHJcbiAgICB9XHJcblxyXG4gICAgdGhpcy5hcGlLZXkgPSBhcGlLZXk7XHJcbiAgICB0aGlzLmFwaVVybCA9IG9wdGlvbnM/LmFwaVVybCB8fCBBUElfVVJMO1xyXG4gICAgdGhpcy50aW1lb3V0ID0gb3B0aW9ucz8udGltZW91dCB8fCBERUZBVUxUX1RJTUVPVVQ7XHJcbiAgICB0aGlzLnJldHJ5Q291bnQgPSBvcHRpb25zPy5yZXRyeUNvdW50IHx8IERFRkFVTFRfUkVUUllfQ09VTlQ7XHJcbiAgICB0aGlzLnJldHJ5RGVsYXkgPSBvcHRpb25zPy5yZXRyeURlbGF5IHx8IERFRkFVTFRfUkVUUllfREVMQVk7XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBHZXQgZGVmYXVsdCBoZWFkZXJzXHJcbiAgICovXHJcbiAgcHJpdmF0ZSBnZXRIZWFkZXJzKCkge1xyXG4gICAgcmV0dXJuIHtcclxuICAgICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcclxuICAgICAgJ3gtYXBpLWtleSc6IHRoaXMuYXBpS2V5LFxyXG4gICAgICAnVXNlci1BZ2VudCc6ICdBbmd1bGFyU0RLLzEuMCdcclxuICAgIH07XHJcbiAgfVxyXG5cclxuICAvKipcclxuICAgKiBMaXN0IGFsbCB0ZW1wbGF0ZXNcclxuICAgKi9cclxuICBsaXN0KG9wdGlvbnM/OiBQYWdpbmF0aW9uT3B0aW9ucyk6IE9ic2VydmFibGU8RW1haWxUZW1wbGF0ZUxpc3RSZXNwb25zZT4ge1xyXG4gICAgaWYgKCF0aGlzLmFwaUtleSkge1xyXG4gICAgICByZXR1cm4gdGhyb3dFcnJvcigoKSA9PiBuZXcgTWV0aWdhbkVycm9yKCdTZXJ2aWNlIG5vdCBpbml0aWFsaXplZC4gQ2FsbCBpbml0aWFsaXplKCkgZmlyc3QuJykpO1xyXG4gICAgfVxyXG5cclxuICAgIGxldCBwYXJhbXMgPSBuZXcgSHR0cFBhcmFtcygpO1xyXG4gICAgaWYgKG9wdGlvbnM/LnBhZ2UpIHtcclxuICAgICAgcGFyYW1zID0gcGFyYW1zLnNldCgncGFnZScsIG9wdGlvbnMucGFnZS50b1N0cmluZygpKTtcclxuICAgIH1cclxuICAgIGlmIChvcHRpb25zPy5saW1pdCkge1xyXG4gICAgICBwYXJhbXMgPSBwYXJhbXMuc2V0KCdsaW1pdCcsIG9wdGlvbnMubGltaXQudG9TdHJpbmcoKSk7XHJcbiAgICB9XHJcblxyXG4gICAgcmV0dXJuIHRoaXMuaHR0cC5nZXQ8RW1haWxUZW1wbGF0ZUxpc3RSZXNwb25zZT4oXHJcbiAgICAgIGAke3RoaXMuYXBpVXJsfS9hcGkvdGVtcGxhdGVzYCxcclxuICAgICAge1xyXG4gICAgICAgIGhlYWRlcnM6IHRoaXMuZ2V0SGVhZGVycygpLFxyXG4gICAgICAgIHBhcmFtczogcGFyYW1zXHJcbiAgICAgIH0sXHJcbiAgICAgIHRoaXMucmV0cnlDb3VudCxcclxuICAgICAgdGhpcy5yZXRyeURlbGF5XHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgLyoqXHJcbiAgICogR2V0IHRlbXBsYXRlIGJ5IElEXHJcbiAgICovXHJcbiAgZ2V0KHRlbXBsYXRlSWQ6IHN0cmluZyk6IE9ic2VydmFibGU8RW1haWxUZW1wbGF0ZT4ge1xyXG4gICAgaWYgKCF0aGlzLmFwaUtleSkge1xyXG4gICAgICByZXR1cm4gdGhyb3dFcnJvcigoKSA9PiBuZXcgTWV0aWdhbkVycm9yKCdTZXJ2aWNlIG5vdCBpbml0aWFsaXplZC4gQ2FsbCBpbml0aWFsaXplKCkgZmlyc3QuJykpO1xyXG4gICAgfVxyXG5cclxuICAgIGlmICghdGVtcGxhdGVJZCkge1xyXG4gICAgICByZXR1cm4gdGhyb3dFcnJvcigoKSA9PiBuZXcgVmFsaWRhdGlvbkVycm9yKCdUZW1wbGF0ZSBJRCBpcyByZXF1aXJlZCcpKTtcclxuICAgIH1cclxuXHJcbiAgICByZXR1cm4gdGhpcy5odHRwLmdldDxFbWFpbFRlbXBsYXRlPihcclxuICAgICAgYCR7dGhpcy5hcGlVcmx9L2FwaS90ZW1wbGF0ZXMvJHt0ZW1wbGF0ZUlkfWAsXHJcbiAgICAgIHsgaGVhZGVyczogdGhpcy5nZXRIZWFkZXJzKCkgfSxcclxuICAgICAgdGhpcy5yZXRyeUNvdW50LFxyXG4gICAgICB0aGlzLnJldHJ5RGVsYXlcclxuICAgICk7XHJcbiAgfVxyXG59XHJcblxyXG4iXX0=
@@ -0,0 +1,6 @@
1
+ /**
2
+ * Type definitions for Metigan Angular SDK
3
+ * @version 1.0.0
4
+ */
5
+ export {};
6
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"types.js","sourceRoot":"","sources":["../../../../src/lib/types.ts"],"names":[],"mappings":"AAAA;;;GAGG","sourcesContent":["/**\r\n * Type definitions for Metigan Angular SDK\r\n * @version 1.0.0\r\n */\r\n\r\n// ============================================\r\n// EMAIL TYPES\r\n// ============================================\r\n\r\n/**\r\n * Email attachment interface for Angular\r\n */\r\nexport interface EmailAttachment {\r\n  content: ArrayBuffer | Uint8Array | string;\r\n  filename: string;\r\n  contentType: string;\r\n}\r\n\r\n/**\r\n * Email options interface\r\n */\r\nexport interface EmailOptions {\r\n  /** Sender email address (or Name <email>) */\r\n  from: string;\r\n  /** List of recipient email addresses */\r\n  recipients: string[];\r\n  /** Email subject */\r\n  subject: string;\r\n  /** Email content (HTML supported) - Required if not using templateId */\r\n  content?: string;\r\n  /** Template ID for using pre-created templates (optional) */\r\n  templateId?: string;\r\n  /** Optional file attachments */\r\n  attachments?: File[] | EmailAttachment[];\r\n  /** Optional CC recipients */\r\n  cc?: string[];\r\n  /** Optional BCC recipients */\r\n  bcc?: string[];\r\n  /** Optional reply-to address */\r\n  replyTo?: string;\r\n}\r\n\r\n/**\r\n * API response interface for successful email\r\n */\r\nexport interface EmailSuccessResponse {\r\n  success: true;\r\n  message: string;\r\n  successfulEmails: {\r\n    recipient: string;\r\n    trackingId: string;\r\n  }[];\r\n  failedEmails: {\r\n    recipient: string;\r\n    error: string;\r\n  }[];\r\n  recipientCount: number;\r\n  emailsRemaining: number;\r\n}\r\n\r\n/**\r\n * API error response interfaces\r\n */\r\nexport interface EmailErrorResponse {\r\n  error: string;\r\n  message: string;\r\n}\r\n\r\n/**\r\n * Union type for all possible API responses\r\n */\r\nexport type EmailApiResponse = EmailSuccessResponse | EmailErrorResponse;\r\n\r\n// ============================================\r\n// FORM TYPES\r\n// ============================================\r\n\r\n/**\r\n * Form field types\r\n */\r\nexport type FormFieldType = \r\n  | 'text'\r\n  | 'email'\r\n  | 'number'\r\n  | 'textarea'\r\n  | 'select'\r\n  | 'checkbox'\r\n  | 'radio'\r\n  | 'date'\r\n  | 'phone'\r\n  | 'url'\r\n  | 'file'\r\n  | 'step'\r\n  | 'password'\r\n  | 'rating'\r\n  | 'slider'\r\n  | 'heading'\r\n  | 'image-choice'\r\n  | 'matrix';\r\n\r\n/**\r\n * Form field configuration\r\n */\r\nexport interface FormFieldConfig {\r\n  id: string;\r\n  type: FormFieldType;\r\n  label: string;\r\n  placeholder?: string;\r\n  required?: boolean;\r\n  helpText?: string;\r\n  options?: string[];\r\n  imageUrls?: string[];\r\n  defaultValue?: string | number | boolean;\r\n}\r\n\r\n/**\r\n * Form settings\r\n */\r\nexport interface FormSettings {\r\n  successMessage?: string;\r\n  processingMessage?: string;\r\n  redirectUrl?: string;\r\n  notifyEmail?: string;\r\n  enableCaptcha?: boolean;\r\n  storeResponses?: boolean;\r\n  allowMultipleSubmissions?: boolean;\r\n  showProgressBar?: boolean;\r\n}\r\n\r\n/**\r\n * Complete form configuration\r\n */\r\nexport interface FormConfig {\r\n  id?: string;\r\n  title: string;\r\n  description?: string;\r\n  coverImage?: string;\r\n  fields: FormFieldConfig[];\r\n  audienceId?: string;\r\n  settings?: FormSettings;\r\n  published?: boolean;\r\n  publishedUrl?: string;\r\n  slug?: string;\r\n  analytics?: {\r\n    views: number;\r\n    submissions: number;\r\n    conversionRate?: number;\r\n  };\r\n  createdAt?: Date;\r\n  updatedAt?: Date;\r\n}\r\n\r\n/**\r\n * Form submission data\r\n */\r\nexport interface FormSubmissionData {\r\n  [fieldId: string]: any;\r\n}\r\n\r\n/**\r\n * Form submission options\r\n */\r\nexport interface FormSubmissionOptions {\r\n  formId: string;\r\n  data: FormSubmissionData;\r\n}\r\n\r\n/**\r\n * Form submission response\r\n */\r\nexport interface FormSubmissionResponse {\r\n  success: boolean;\r\n  message: string;\r\n  submissionId?: string;\r\n}\r\n\r\n/**\r\n * Form list response\r\n */\r\nexport interface FormListResponse {\r\n  forms: FormConfig[];\r\n  pagination: {\r\n    total: number;\r\n    page: number;\r\n    limit: number;\r\n    pages: number;\r\n  };\r\n}\r\n\r\n// ============================================\r\n// CONTACT TYPES\r\n// ============================================\r\n\r\n/**\r\n * Contact status\r\n */\r\nexport type ContactStatus = 'subscribed' | 'unsubscribed' | 'pending' | 'bounced' | 'complained';\r\n\r\n/**\r\n * Contact data\r\n */\r\nexport interface Contact {\r\n  id?: string;\r\n  email: string;\r\n  firstName?: string;\r\n  lastName?: string;\r\n  phone?: string;\r\n  status: ContactStatus;\r\n  audienceId: string;\r\n  tags?: string[];\r\n  customFields?: Record<string, any>;\r\n  createdAt?: Date;\r\n  updatedAt?: Date;\r\n}\r\n\r\n/**\r\n * Contact creation options\r\n */\r\nexport interface CreateContactOptions {\r\n  email: string;\r\n  firstName?: string;\r\n  lastName?: string;\r\n  phone?: string;\r\n  audienceId: string;\r\n  tags?: string[];\r\n  customFields?: Record<string, any>;\r\n  status?: ContactStatus;\r\n}\r\n\r\n/**\r\n * Contact update options\r\n */\r\nexport interface UpdateContactOptions {\r\n  firstName?: string;\r\n  lastName?: string;\r\n  phone?: string;\r\n  tags?: string[];\r\n  customFields?: Record<string, any>;\r\n  status?: ContactStatus;\r\n}\r\n\r\n/**\r\n * Contact list filters\r\n */\r\nexport interface ContactListFilters {\r\n  audienceId?: string;\r\n  status?: ContactStatus;\r\n  tag?: string;\r\n  search?: string;\r\n  page?: number;\r\n  limit?: number;\r\n}\r\n\r\n/**\r\n * Contact list response\r\n */\r\nexport interface ContactListResponse {\r\n  contacts: Contact[];\r\n  pagination: {\r\n    total: number;\r\n    page: number;\r\n    limit: number;\r\n    pages: number;\r\n  };\r\n}\r\n\r\n/**\r\n * Bulk contact operation result\r\n */\r\nexport interface BulkContactResult {\r\n  success: boolean;\r\n  imported: number;\r\n  failed: number;\r\n  errors?: { email: string; error: string }[];\r\n}\r\n\r\n// ============================================\r\n// AUDIENCE TYPES\r\n// ============================================\r\n\r\n/**\r\n * Audience data\r\n */\r\nexport interface Audience {\r\n  id?: string;\r\n  name: string;\r\n  description?: string;\r\n  count: number;\r\n  createdAt?: Date;\r\n  updatedAt?: Date;\r\n}\r\n\r\n/**\r\n * Audience creation options\r\n */\r\nexport interface CreateAudienceOptions {\r\n  name: string;\r\n  description?: string;\r\n}\r\n\r\n/**\r\n * Audience update options\r\n */\r\nexport interface UpdateAudienceOptions {\r\n  name?: string;\r\n  description?: string;\r\n}\r\n\r\n/**\r\n * Audience list response\r\n */\r\nexport interface AudienceListResponse {\r\n  audiences: Audience[];\r\n  pagination: {\r\n    total: number;\r\n    page: number;\r\n    limit: number;\r\n    pages: number;\r\n  };\r\n}\r\n\r\n/**\r\n * Audience statistics\r\n */\r\nexport interface AudienceStats {\r\n  total: number;\r\n  subscribed: number;\r\n  unsubscribed: number;\r\n  pending: number;\r\n  bounced: number;\r\n  complained: number;\r\n  growthRate?: number;\r\n}\r\n\r\n// ============================================\r\n// TEMPLATE TYPES\r\n// ============================================\r\n\r\n/**\r\n * Email template data\r\n */\r\nexport interface EmailTemplate {\r\n  id: string;\r\n  name: string;\r\n  subject: string;\r\n  components?: any[];\r\n  styles?: any;\r\n  createdAt?: Date;\r\n  updatedAt?: Date;\r\n}\r\n\r\n/**\r\n * Email template list response\r\n */\r\nexport interface EmailTemplateListResponse {\r\n  templates: EmailTemplate[];\r\n  pagination: {\r\n    total: number;\r\n    page: number;\r\n    limit: number;\r\n    pages: number;\r\n  };\r\n}\r\n\r\n// ============================================\r\n// COMMON TYPES\r\n// ============================================\r\n\r\n/**\r\n * Pagination options\r\n */\r\nexport interface PaginationOptions {\r\n  page?: number;\r\n  limit?: number;\r\n}\r\n\r\n/**\r\n * Client options for Metigan\r\n */\r\nexport interface MetiganClientOptions {\r\n  /** API Key */\r\n  apiKey: string;\r\n  /** User ID for logging */\r\n  userId?: string;\r\n  /** Disable logging */\r\n  disableLogs?: boolean;\r\n  /** Request timeout in ms */\r\n  timeout?: number;\r\n  /** Number of retries */\r\n  retryCount?: number;\r\n  /** Delay between retries in ms */\r\n  retryDelay?: number;\r\n  /** Enable debug mode */\r\n  debug?: boolean;\r\n  /** Custom API URL */\r\n  apiUrl?: string;\r\n}\r\n\r\n"]}