@docuseal/angular 1.0.1 → 1.0.3

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.
package/README.md CHANGED
@@ -21,7 +21,7 @@ For detailed documentation, please click [here](https://www.docuseal.co/docs/emb
21
21
  Copy public DocuSeal form URL from [https://docuseal.co](https://docuseal.co) and use it in the `src` component prop:
22
22
 
23
23
  ```typescript
24
- import { Component, } from '@angular/core';
24
+ import { Component } from '@angular/core';
25
25
  import { DocusealFormComponent } from '@docuseal/angular';
26
26
 
27
27
  @Component({
package/dist/README.md CHANGED
@@ -21,7 +21,7 @@ For detailed documentation, please click [here](https://www.docuseal.co/docs/emb
21
21
  Copy public DocuSeal form URL from [https://docuseal.co](https://docuseal.co) and use it in the `src` component prop:
22
22
 
23
23
  ```typescript
24
- import { Component, } from '@angular/core';
24
+ import { Component } from '@angular/core';
25
25
  import { DocusealFormComponent } from '@docuseal/angular';
26
26
 
27
27
  @Component({
@@ -1,4 +1,4 @@
1
- import { ElementRef, SimpleChanges } from "@angular/core";
1
+ import { EventEmitter } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  interface DocusealField {
4
4
  name: string;
@@ -9,11 +9,7 @@ interface DocusealField {
9
9
  interface AfterViewInit {
10
10
  ngAfterViewInit(): void;
11
11
  }
12
- interface OnChanges {
13
- ngOnChanges(changes: SimpleChanges): void;
14
- }
15
- export declare class DocusealBuilderComponent implements AfterViewInit, OnChanges {
16
- private el;
12
+ export declare class DocusealBuilderComponent implements AfterViewInit {
17
13
  token: string;
18
14
  host: string;
19
15
  language: string;
@@ -37,25 +33,43 @@ export declare class DocusealBuilderComponent implements AfterViewInit, OnChange
37
33
  url: string;
38
34
  };
39
35
  backgroundColor: string;
40
- onLoad: (detail: any) => void;
41
- onUpload: (detail: any) => void;
42
- onSend: (detail: any) => void;
43
- onSave: (detail: any) => void;
44
36
  sendButtonText: string;
45
37
  saveButtonText: string;
46
38
  customCss: string;
47
- constructor(el: ElementRef);
48
- get attributes(): {
49
- [key: string]: any;
50
- };
39
+ onLoad: EventEmitter<any>;
40
+ onUpload: EventEmitter<any>;
41
+ onSend: EventEmitter<any>;
42
+ onSave: EventEmitter<any>;
43
+ get dataToken(): string;
44
+ get dataPreview(): boolean;
45
+ get dataLanguage(): string;
46
+ get dataAutosave(): boolean;
47
+ get dataSendButtonText(): string;
48
+ get dataSaveButtonText(): string;
49
+ get dataRoles(): string;
50
+ get dataFieldTypes(): string;
51
+ get dataDrawFieldType(): string;
52
+ get dataFields(): string;
53
+ get dataI18n(): string;
54
+ get dataCustomButtonTitle(): string;
55
+ get dataCustomButtonUrl(): string;
56
+ get dataWithRecipientsButton(): boolean;
57
+ get dataWithSendButton(): boolean;
58
+ get dataWithDocumentsList(): boolean;
59
+ get dataWithFieldsList(): boolean;
60
+ get dataWithTitle(): boolean;
61
+ get dataOnlyDefinedFields(): boolean;
62
+ get dataWithUploadButton(): boolean;
63
+ get dataWithSignYourselfButton(): boolean;
64
+ get dataBackgroundColor(): string;
65
+ get dataCustomCss(): string;
51
66
  ngAfterViewInit(): void;
52
- ngOnChanges(changes: SimpleChanges): void;
53
67
  onSendEvent(event: CustomEvent): void;
54
68
  onLoadEvent(event: CustomEvent): void;
55
69
  onUploadEvent(event: CustomEvent): void;
56
70
  onSaveEvent(event: CustomEvent): void;
57
71
  loadScript(): void;
58
72
  static ɵfac: i0.ɵɵFactoryDeclaration<DocusealBuilderComponent, never>;
59
- static ɵcmp: i0.ɵɵComponentDeclaration<DocusealBuilderComponent, "docuseal-builder", never, { "token": { "alias": "token"; "required": false; }; "host": { "alias": "host"; "required": false; }; "language": { "alias": "language"; "required": false; }; "preview": { "alias": "preview"; "required": false; }; "autosave": { "alias": "autosave"; "required": false; }; "withRecipientsButton": { "alias": "withRecipientsButton"; "required": false; }; "withDocumentsList": { "alias": "withDocumentsList"; "required": false; }; "withFieldsList": { "alias": "withFieldsList"; "required": false; }; "withSendButton": { "alias": "withSendButton"; "required": false; }; "withTitle": { "alias": "withTitle"; "required": false; }; "onlyDefinedFields": { "alias": "onlyDefinedFields"; "required": false; }; "withSignYourselfButton": { "alias": "withSignYourselfButton"; "required": false; }; "withUploadButton": { "alias": "withUploadButton"; "required": false; }; "roles": { "alias": "roles"; "required": false; }; "fields": { "alias": "fields"; "required": false; }; "i18n": { "alias": "i18n"; "required": false; }; "fieldTypes": { "alias": "fieldTypes"; "required": false; }; "drawFieldType": { "alias": "drawFieldType"; "required": false; }; "customButton": { "alias": "customButton"; "required": false; }; "backgroundColor": { "alias": "backgroundColor"; "required": false; }; "onLoad": { "alias": "onLoad"; "required": false; }; "onUpload": { "alias": "onUpload"; "required": false; }; "onSend": { "alias": "onSend"; "required": false; }; "onSave": { "alias": "onSave"; "required": false; }; "sendButtonText": { "alias": "sendButtonText"; "required": false; }; "saveButtonText": { "alias": "saveButtonText"; "required": false; }; "customCss": { "alias": "customCss"; "required": false; }; }, {}, never, never, true, never>;
73
+ static ɵcmp: i0.ɵɵComponentDeclaration<DocusealBuilderComponent, "docuseal-builder", never, { "token": { "alias": "token"; "required": false; }; "host": { "alias": "host"; "required": false; }; "language": { "alias": "language"; "required": false; }; "preview": { "alias": "preview"; "required": false; }; "autosave": { "alias": "autosave"; "required": false; }; "withRecipientsButton": { "alias": "withRecipientsButton"; "required": false; }; "withDocumentsList": { "alias": "withDocumentsList"; "required": false; }; "withFieldsList": { "alias": "withFieldsList"; "required": false; }; "withSendButton": { "alias": "withSendButton"; "required": false; }; "withTitle": { "alias": "withTitle"; "required": false; }; "onlyDefinedFields": { "alias": "onlyDefinedFields"; "required": false; }; "withSignYourselfButton": { "alias": "withSignYourselfButton"; "required": false; }; "withUploadButton": { "alias": "withUploadButton"; "required": false; }; "roles": { "alias": "roles"; "required": false; }; "fields": { "alias": "fields"; "required": false; }; "i18n": { "alias": "i18n"; "required": false; }; "fieldTypes": { "alias": "fieldTypes"; "required": false; }; "drawFieldType": { "alias": "drawFieldType"; "required": false; }; "customButton": { "alias": "customButton"; "required": false; }; "backgroundColor": { "alias": "backgroundColor"; "required": false; }; "sendButtonText": { "alias": "sendButtonText"; "required": false; }; "saveButtonText": { "alias": "saveButtonText"; "required": false; }; "customCss": { "alias": "customCss"; "required": false; }; }, { "onLoad": "onLoad"; "onUpload": "onUpload"; "onSend": "onSend"; "onSave": "onSave"; }, never, never, true, never>;
60
74
  }
61
75
  export {};
@@ -1,7 +1,6 @@
1
- import { Component, Input, HostListener } from "@angular/core";
1
+ import { Component, Input, HostListener, HostBinding, Output, EventEmitter } from "@angular/core";
2
2
  import * as i0 from "@angular/core";
3
3
  export class DocusealBuilderComponent {
4
- el;
5
4
  token = "";
6
5
  host = "cdn.docuseal.co";
7
6
  language = "en";
@@ -22,161 +21,57 @@ export class DocusealBuilderComponent {
22
21
  drawFieldType = "text";
23
22
  customButton = { title: "", url: "" };
24
23
  backgroundColor = "";
25
- onLoad = () => { };
26
- onUpload = () => { };
27
- onSend = () => { };
28
- onSave = () => { };
29
24
  sendButtonText = "";
30
25
  saveButtonText = "";
31
26
  customCss = "";
32
- constructor(el) {
33
- this.el = el;
34
- }
35
- get attributes() {
36
- return {
37
- src: {
38
- name: "data-token",
39
- value: () => this.token
40
- },
41
- preview: {
42
- name: "data-preview",
43
- value: () => this.preview
44
- },
45
- language: {
46
- name: "data-language",
47
- value: () => this.language
48
- },
49
- autosave: {
50
- name: "data-autosave",
51
- value: () => this.autosave
52
- },
53
- sendButtonText: {
54
- name: "data-send-button-text",
55
- value: () => this.sendButtonText
56
- },
57
- saveButtonText: {
58
- name: "data-save-button-text",
59
- value: () => this.saveButtonText
60
- },
61
- roles: {
62
- name: "data-roles",
63
- value: () => this.roles.join(',')
64
- },
65
- fieldTypes: {
66
- name: "data-field-types",
67
- value: () => this.fieldTypes.join(',')
68
- },
69
- drawFieldType: {
70
- name: "data-draw-field-type",
71
- value: () => this.drawFieldType
72
- },
73
- fields: {
74
- name: "data-fields",
75
- value: () => JSON.stringify(this.fields)
76
- },
77
- i18n: {
78
- name: "data-i18n",
79
- value: () => JSON.stringify(this.i18n)
80
- },
81
- customButton: [
82
- {
83
- name: "data-custom-button-title",
84
- value: () => this.customButton.title
85
- },
86
- {
87
- name: "data-custom-button-url",
88
- value: () => this.customButton.url
89
- }
90
- ],
91
- withRecipientsButton: {
92
- name: "data-with-recipients-button",
93
- value: () => this.withRecipientsButton
94
- },
95
- withSendButton: {
96
- name: "data-with-send-button",
97
- value: () => this.withSendButton
98
- },
99
- withDocumentsList: {
100
- name: "data-with-documents-list",
101
- value: () => this.withDocumentsList
102
- },
103
- withFieldsList: {
104
- name: "data-with-fields-list",
105
- value: () => this.withFieldsList
106
- },
107
- withTitle: {
108
- name: "data-with-title",
109
- value: () => this.withTitle
110
- },
111
- onlyDefinedFields: {
112
- name: "data-only-defined-fields",
113
- value: () => this.onlyDefinedFields
114
- },
115
- withUploadButton: {
116
- name: "data-with-upload-button",
117
- value: () => this.withUploadButton
118
- },
119
- withSignYourselfButton: {
120
- name: "data-with-sign-yourself-button",
121
- value: () => this.withSignYourselfButton
122
- },
123
- backgroundColor: {
124
- name: "data-background-color",
125
- value: () => this.backgroundColor
126
- },
127
- customCss: {
128
- name: "data-custom-css",
129
- value: () => this.customCss
130
- }
131
- };
132
- }
27
+ onLoad = new EventEmitter();
28
+ onUpload = new EventEmitter();
29
+ onSend = new EventEmitter();
30
+ onSave = new EventEmitter();
31
+ get dataToken() { return this.token; }
32
+ get dataPreview() { return this.preview; }
33
+ get dataLanguage() { return this.language; }
34
+ get dataAutosave() { return this.autosave; }
35
+ get dataSendButtonText() { return this.sendButtonText; }
36
+ get dataSaveButtonText() { return this.saveButtonText; }
37
+ get dataRoles() { return this.roles.join(','); }
38
+ get dataFieldTypes() { return this.fieldTypes.join(','); }
39
+ get dataDrawFieldType() { return this.drawFieldType; }
40
+ get dataFields() { return JSON.stringify(this.fields); }
41
+ get dataI18n() { return JSON.stringify(this.i18n); }
42
+ get dataCustomButtonTitle() { return this.customButton.title; }
43
+ get dataCustomButtonUrl() { return this.customButton.url; }
44
+ get dataWithRecipientsButton() { return this.withRecipientsButton; }
45
+ get dataWithSendButton() { return this.withSendButton; }
46
+ get dataWithDocumentsList() { return this.withDocumentsList; }
47
+ get dataWithFieldsList() { return this.withFieldsList; }
48
+ get dataWithTitle() { return this.withTitle; }
49
+ get dataOnlyDefinedFields() { return this.onlyDefinedFields; }
50
+ get dataWithUploadButton() { return this.withUploadButton; }
51
+ get dataWithSignYourselfButton() { return this.withSignYourselfButton; }
52
+ get dataBackgroundColor() { return this.backgroundColor; }
53
+ get dataCustomCss() { return this.customCss; }
133
54
  ngAfterViewInit() {
134
- const builder = this.el.nativeElement;
135
- Object.entries(this.attributes).forEach(([_, attribute]) => {
136
- if (Array.isArray(attribute)) {
137
- attribute.forEach((attr) => {
138
- builder.setAttribute(attr.name, attr.value());
139
- });
140
- }
141
- else if (attribute) {
142
- builder.setAttribute(attribute.name, attribute.value());
143
- }
144
- });
145
55
  this.loadScript();
146
56
  }
147
- ngOnChanges(changes) {
148
- const builder = this.el.nativeElement;
149
- const attributes = this.attributes;
150
- Object.entries(changes).forEach(([key, change]) => {
151
- const attribute = attributes[key];
152
- if (Array.isArray(attribute)) {
153
- attribute.forEach((attr) => {
154
- builder.setAttribute(attr.name, attr.value());
155
- });
156
- }
157
- else if (attribute) {
158
- builder.setAttribute(attribute.name, change.currentValue);
159
- }
160
- });
161
- }
162
57
  onSendEvent(event) {
163
58
  if (this.onSend) {
164
- this.onSend(event.detail);
59
+ this.onSend.emit(event.detail);
165
60
  }
166
61
  }
167
62
  onLoadEvent(event) {
168
63
  if (this.onLoad) {
169
- this.onLoad(event.detail);
64
+ this.onLoad.emit(event.detail);
170
65
  }
171
66
  }
172
67
  onUploadEvent(event) {
173
68
  if (this.onUpload) {
174
- this.onUpload(event.detail);
69
+ this.onUpload.emit(event.detail);
175
70
  }
176
71
  }
177
72
  onSaveEvent(event) {
178
73
  if (this.onSave) {
179
- this.onSave(event.detail);
74
+ this.onSave.emit(event.detail);
180
75
  }
181
76
  }
182
77
  loadScript() {
@@ -188,15 +83,17 @@ export class DocusealBuilderComponent {
188
83
  script.src = scriptSrc;
189
84
  document.head.appendChild(script);
190
85
  }
191
- static ɵfac = function DocusealBuilderComponent_Factory(t) { return new (t || DocusealBuilderComponent)(i0.ɵɵdirectiveInject(i0.ElementRef)); };
192
- static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DocusealBuilderComponent, selectors: [["docuseal-builder"]], hostBindings: function DocusealBuilderComponent_HostBindings(rf, ctx) { if (rf & 1) {
86
+ static ɵfac = function DocusealBuilderComponent_Factory(t) { return new (t || DocusealBuilderComponent)(); };
87
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DocusealBuilderComponent, selectors: [["docuseal-builder"]], hostVars: 23, hostBindings: function DocusealBuilderComponent_HostBindings(rf, ctx) { if (rf & 1) {
193
88
  i0.ɵɵlistener("send", function DocusealBuilderComponent_send_HostBindingHandler($event) { return ctx.onSendEvent($event); })("load", function DocusealBuilderComponent_load_HostBindingHandler($event) { return ctx.onLoadEvent($event); })("upload", function DocusealBuilderComponent_upload_HostBindingHandler($event) { return ctx.onUploadEvent($event); })("save", function DocusealBuilderComponent_save_HostBindingHandler($event) { return ctx.onSaveEvent($event); });
194
- } }, inputs: { token: "token", host: "host", language: "language", preview: "preview", autosave: "autosave", withRecipientsButton: "withRecipientsButton", withDocumentsList: "withDocumentsList", withFieldsList: "withFieldsList", withSendButton: "withSendButton", withTitle: "withTitle", onlyDefinedFields: "onlyDefinedFields", withSignYourselfButton: "withSignYourselfButton", withUploadButton: "withUploadButton", roles: "roles", fields: "fields", i18n: "i18n", fieldTypes: "fieldTypes", drawFieldType: "drawFieldType", customButton: "customButton", backgroundColor: "backgroundColor", onLoad: "onLoad", onUpload: "onUpload", onSend: "onSend", onSave: "onSave", sendButtonText: "sendButtonText", saveButtonText: "saveButtonText", customCss: "customCss" }, standalone: true, features: [i0.ɵɵNgOnChangesFeature, i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function DocusealBuilderComponent_Template(rf, ctx) { }, encapsulation: 2 });
89
+ } if (rf & 2) {
90
+ i0.ɵɵattribute("data-token", ctx.dataToken)("data-preview", ctx.dataPreview)("data-language", ctx.dataLanguage)("data-autosave", ctx.dataAutosave)("data-send-button-text", ctx.dataSendButtonText)("data-save-button-text", ctx.dataSaveButtonText)("data-roles", ctx.dataRoles)("data-field-types", ctx.dataFieldTypes)("data-draw-field-type", ctx.dataDrawFieldType)("data-fields", ctx.dataFields)("data-i18n", ctx.dataI18n)("data-custom-button-title", ctx.dataCustomButtonTitle)("data-custom-button-url", ctx.dataCustomButtonUrl)("data-with-recipients-button", ctx.dataWithRecipientsButton)("data-with-send-button", ctx.dataWithSendButton)("data-with-documents-list", ctx.dataWithDocumentsList)("data-with-fields-list", ctx.dataWithFieldsList)("data-with-title", ctx.dataWithTitle)("data-only-defined-fields", ctx.dataOnlyDefinedFields)("data-with-upload-button", ctx.dataWithUploadButton)("data-with-sign-yourself-button", ctx.dataWithSignYourselfButton)("data-background-color", ctx.dataBackgroundColor)("data-custom-css", ctx.dataCustomCss);
91
+ } }, inputs: { token: "token", host: "host", language: "language", preview: "preview", autosave: "autosave", withRecipientsButton: "withRecipientsButton", withDocumentsList: "withDocumentsList", withFieldsList: "withFieldsList", withSendButton: "withSendButton", withTitle: "withTitle", onlyDefinedFields: "onlyDefinedFields", withSignYourselfButton: "withSignYourselfButton", withUploadButton: "withUploadButton", roles: "roles", fields: "fields", i18n: "i18n", fieldTypes: "fieldTypes", drawFieldType: "drawFieldType", customButton: "customButton", backgroundColor: "backgroundColor", sendButtonText: "sendButtonText", saveButtonText: "saveButtonText", customCss: "customCss" }, outputs: { onLoad: "onLoad", onUpload: "onUpload", onSend: "onSend", onSave: "onSave" }, standalone: true, features: [i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function DocusealBuilderComponent_Template(rf, ctx) { }, encapsulation: 2 });
195
92
  }
196
93
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DocusealBuilderComponent, [{
197
94
  type: Component,
198
95
  args: [{ selector: "docuseal-builder", standalone: true, template: "" }]
199
- }], () => [{ type: i0.ElementRef }], { token: [{
96
+ }], null, { token: [{
200
97
  type: Input
201
98
  }], host: [{
202
99
  type: Input
@@ -236,20 +133,89 @@ export class DocusealBuilderComponent {
236
133
  type: Input
237
134
  }], backgroundColor: [{
238
135
  type: Input
239
- }], onLoad: [{
240
- type: Input
241
- }], onUpload: [{
242
- type: Input
243
- }], onSend: [{
244
- type: Input
245
- }], onSave: [{
246
- type: Input
247
136
  }], sendButtonText: [{
248
137
  type: Input
249
138
  }], saveButtonText: [{
250
139
  type: Input
251
140
  }], customCss: [{
252
141
  type: Input
142
+ }], onLoad: [{
143
+ type: Output
144
+ }], onUpload: [{
145
+ type: Output
146
+ }], onSend: [{
147
+ type: Output
148
+ }], onSave: [{
149
+ type: Output
150
+ }], dataToken: [{
151
+ type: HostBinding,
152
+ args: ["attr.data-token"]
153
+ }], dataPreview: [{
154
+ type: HostBinding,
155
+ args: ["attr.data-preview"]
156
+ }], dataLanguage: [{
157
+ type: HostBinding,
158
+ args: ["attr.data-language"]
159
+ }], dataAutosave: [{
160
+ type: HostBinding,
161
+ args: ["attr.data-autosave"]
162
+ }], dataSendButtonText: [{
163
+ type: HostBinding,
164
+ args: ["attr.data-send-button-text"]
165
+ }], dataSaveButtonText: [{
166
+ type: HostBinding,
167
+ args: ["attr.data-save-button-text"]
168
+ }], dataRoles: [{
169
+ type: HostBinding,
170
+ args: ["attr.data-roles"]
171
+ }], dataFieldTypes: [{
172
+ type: HostBinding,
173
+ args: ["attr.data-field-types"]
174
+ }], dataDrawFieldType: [{
175
+ type: HostBinding,
176
+ args: ["attr.data-draw-field-type"]
177
+ }], dataFields: [{
178
+ type: HostBinding,
179
+ args: ["attr.data-fields"]
180
+ }], dataI18n: [{
181
+ type: HostBinding,
182
+ args: ["attr.data-i18n"]
183
+ }], dataCustomButtonTitle: [{
184
+ type: HostBinding,
185
+ args: ["attr.data-custom-button-title"]
186
+ }], dataCustomButtonUrl: [{
187
+ type: HostBinding,
188
+ args: ["attr.data-custom-button-url"]
189
+ }], dataWithRecipientsButton: [{
190
+ type: HostBinding,
191
+ args: ["attr.data-with-recipients-button"]
192
+ }], dataWithSendButton: [{
193
+ type: HostBinding,
194
+ args: ["attr.data-with-send-button"]
195
+ }], dataWithDocumentsList: [{
196
+ type: HostBinding,
197
+ args: ["attr.data-with-documents-list"]
198
+ }], dataWithFieldsList: [{
199
+ type: HostBinding,
200
+ args: ["attr.data-with-fields-list"]
201
+ }], dataWithTitle: [{
202
+ type: HostBinding,
203
+ args: ["attr.data-with-title"]
204
+ }], dataOnlyDefinedFields: [{
205
+ type: HostBinding,
206
+ args: ["attr.data-only-defined-fields"]
207
+ }], dataWithUploadButton: [{
208
+ type: HostBinding,
209
+ args: ["attr.data-with-upload-button"]
210
+ }], dataWithSignYourselfButton: [{
211
+ type: HostBinding,
212
+ args: ["attr.data-with-sign-yourself-button"]
213
+ }], dataBackgroundColor: [{
214
+ type: HostBinding,
215
+ args: ["attr.data-background-color"]
216
+ }], dataCustomCss: [{
217
+ type: HostBinding,
218
+ args: ["attr.data-custom-css"]
253
219
  }], onSendEvent: [{
254
220
  type: HostListener,
255
221
  args: ['send', ['$event']]
@@ -264,4 +230,4 @@ export class DocusealBuilderComponent {
264
230
  args: ['save', ['$event']]
265
231
  }] }); })();
266
232
  (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DocusealBuilderComponent, { className: "DocusealBuilderComponent" }); })();
267
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.component.js","sourceRoot":"","sources":["../../src/builder.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, ElementRef, HostListener, SimpleChanges } from \"@angular/core\"\n\ninterface DocusealField {\n  name: string,\n  type?: string,\n  role?: string,\n  default_value?: string,\n}\n\ninterface AfterViewInit {\n  ngAfterViewInit(): void\n}\ninterface OnChanges {\n  ngOnChanges(changes: SimpleChanges): void\n}\n@Component({\n  selector: \"docuseal-builder\",\n  standalone: true,\n  template: \"\",\n  styles: []\n})\n\nexport class DocusealBuilderComponent implements AfterViewInit, OnChanges {\n  @Input() token: string = \"\"\n  @Input() host: string = \"cdn.docuseal.co\"\n  @Input() language: string = \"en\"\n  @Input() preview: boolean = false\n  @Input() autosave: boolean = true\n  @Input() withRecipientsButton: boolean = true\n  @Input() withDocumentsList: boolean = true\n  @Input() withFieldsList: boolean = true\n  @Input() withSendButton: boolean = true\n  @Input() withTitle: boolean = true\n  @Input() onlyDefinedFields: boolean = false\n  @Input() withSignYourselfButton: boolean = true\n  @Input() withUploadButton: boolean = true\n  @Input() roles: string[] = []\n  @Input() fields: DocusealField[] = []\n  @Input() i18n: object = {}\n  @Input() fieldTypes: string[] = []\n  @Input() drawFieldType: string = \"text\"\n  @Input() customButton: { title: string, url: string } = { title: \"\", url: \"\" }\n  @Input() backgroundColor: string = \"\"\n  @Input() onLoad: (detail: any) => void = () => {}\n  @Input() onUpload: (detail: any) => void = () => {}\n  @Input() onSend: (detail: any) => void = () => {}\n  @Input() onSave: (detail: any) => void = () => {}\n  @Input() sendButtonText: string = \"\"\n  @Input() saveButtonText: string = \"\"\n  @Input() customCss: string = \"\"\n\n  constructor(private el: ElementRef) {}\n\n  get attributes (): { [key: string]: any } {\n    return {\n      src: {\n        name: \"data-token\",\n        value: () => this.token\n      },\n      preview: {\n        name: \"data-preview\",\n        value: () => this.preview\n      },\n      language: {\n        name: \"data-language\",\n        value: () => this.language\n      },\n      autosave: {\n        name: \"data-autosave\",\n        value: () => this.autosave\n      },\n      sendButtonText: {\n        name: \"data-send-button-text\",\n        value: () => this.sendButtonText\n      },\n      saveButtonText: {\n        name: \"data-save-button-text\",\n        value: () => this.saveButtonText\n      },\n      roles: {\n        name: \"data-roles\",\n        value: () => this.roles.join(',')\n      },\n      fieldTypes: {\n        name: \"data-field-types\",\n        value: () => this.fieldTypes.join(',')\n      },\n      drawFieldType: {\n        name: \"data-draw-field-type\",\n        value: () => this.drawFieldType\n      },\n      fields: {\n        name: \"data-fields\",\n        value: () => JSON.stringify(this.fields)\n      },\n      i18n: {\n        name: \"data-i18n\",\n        value: () => JSON.stringify(this.i18n)\n      },\n      customButton: [\n        {\n          name: \"data-custom-button-title\",\n          value: () => this.customButton.title\n        },\n        {\n          name: \"data-custom-button-url\",\n          value: () => this.customButton.url\n        }\n      ],\n      withRecipientsButton: {\n        name: \"data-with-recipients-button\",\n        value: () => this.withRecipientsButton\n      },\n      withSendButton: {\n        name: \"data-with-send-button\",\n        value: () => this.withSendButton\n      },\n      withDocumentsList: {\n        name: \"data-with-documents-list\",\n        value: () => this.withDocumentsList\n      },\n      withFieldsList: {\n        name: \"data-with-fields-list\",\n        value: () => this.withFieldsList\n      },\n      withTitle: {\n        name: \"data-with-title\",\n        value: () => this.withTitle\n      },\n      onlyDefinedFields: {\n        name: \"data-only-defined-fields\",\n        value: () => this.onlyDefinedFields\n      },\n      withUploadButton: {\n        name: \"data-with-upload-button\",\n        value: () => this.withUploadButton\n      },\n      withSignYourselfButton: {\n        name: \"data-with-sign-yourself-button\",\n        value: () => this.withSignYourselfButton\n      },\n      backgroundColor: {\n        name: \"data-background-color\",\n        value: () => this.backgroundColor\n      },\n      customCss: {\n        name: \"data-custom-css\",\n        value: () => this.customCss\n      }\n    }\n  }\n\n  ngAfterViewInit(): void {\n    const builder = this.el.nativeElement;\n\n    Object.entries(this.attributes).forEach(([_, attribute]) => {\n      if (Array.isArray(attribute)) {\n        attribute.forEach((attr) => {\n          builder.setAttribute(attr.name, attr.value())\n        })\n      } else if (attribute) {\n        builder.setAttribute(attribute.name, attribute.value())\n      }\n    })\n\n    this.loadScript()\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const builder = this.el.nativeElement;\n    const attributes = this.attributes\n\n    Object.entries(changes).forEach(([key, change]) => {\n      const attribute = attributes[key]\n\n      if (Array.isArray(attribute)) {\n        attribute.forEach((attr) => {\n          builder.setAttribute(attr.name, attr.value())\n        })\n      } else if (attribute) {\n        builder.setAttribute(attribute.name, change.currentValue)\n      }\n    })\n  }\n\n  @HostListener('send', ['$event'])\n  onSendEvent(event: CustomEvent): void {\n    if (this.onSend) {\n      this.onSend(event.detail)\n    }\n  }\n\n  @HostListener('load', ['$event'])\n  onLoadEvent(event: CustomEvent): void {\n    if (this.onLoad) {\n      this.onLoad(event.detail)\n    }\n  }\n\n  @HostListener('upload', ['$event'])\n  onUploadEvent(event: CustomEvent): void {\n    if (this.onUpload) {\n      this.onUpload(event.detail)\n    }\n  }\n\n  @HostListener('save', ['$event'])\n  onSaveEvent(event: CustomEvent): void {\n    if (this.onSave) {\n      this.onSave(event.detail)\n    }\n  }\n\n  loadScript(): void {\n    const scriptId = 'docuseal-builder-script'\n    const scriptSrc = `https://${this.host}/js/builder.js`\n    const script = document.createElement(\"script\")\n\n    script.id = scriptId\n    script.async = true\n    script.src = scriptSrc\n\n    document.head.appendChild(script)\n  }\n}\n"]}
233
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"builder.component.js","sourceRoot":"","sources":["../../src/builder.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, HostListener, HostBinding, Output, EventEmitter } from \"@angular/core\"\n\ninterface DocusealField {\n  name: string,\n  type?: string,\n  role?: string,\n  default_value?: string,\n}\n\ninterface AfterViewInit {\n  ngAfterViewInit(): void\n}\n\n@Component({\n  selector: \"docuseal-builder\",\n  standalone: true,\n  template: \"\",\n  styles: []\n})\n\nexport class DocusealBuilderComponent implements AfterViewInit {\n  @Input() token: string = \"\"\n  @Input() host: string = \"cdn.docuseal.co\"\n  @Input() language: string = \"en\"\n  @Input() preview: boolean = false\n  @Input() autosave: boolean = true\n  @Input() withRecipientsButton: boolean = true\n  @Input() withDocumentsList: boolean = true\n  @Input() withFieldsList: boolean = true\n  @Input() withSendButton: boolean = true\n  @Input() withTitle: boolean = true\n  @Input() onlyDefinedFields: boolean = false\n  @Input() withSignYourselfButton: boolean = true\n  @Input() withUploadButton: boolean = true\n  @Input() roles: string[] = []\n  @Input() fields: DocusealField[] = []\n  @Input() i18n: object = {}\n  @Input() fieldTypes: string[] = []\n  @Input() drawFieldType: string = \"text\"\n  @Input() customButton: { title: string, url: string } = { title: \"\", url: \"\" }\n  @Input() backgroundColor: string = \"\"\n  @Input() sendButtonText: string = \"\"\n  @Input() saveButtonText: string = \"\"\n  @Input() customCss: string = \"\"\n\n  @Output() onLoad = new EventEmitter<any>()\n  @Output() onUpload = new EventEmitter<any>()\n  @Output() onSend = new EventEmitter<any>()\n  @Output() onSave = new EventEmitter<any>()\n\n  @HostBinding(\"attr.data-token\") get dataToken(): string { return this.token }\n  @HostBinding(\"attr.data-preview\") get dataPreview(): boolean { return this.preview }\n  @HostBinding(\"attr.data-language\") get dataLanguage(): string { return this.language }\n  @HostBinding(\"attr.data-autosave\") get dataAutosave(): boolean { return this.autosave }\n  @HostBinding(\"attr.data-send-button-text\") get dataSendButtonText(): string { return this.sendButtonText }\n  @HostBinding(\"attr.data-save-button-text\") get dataSaveButtonText(): string { return this.saveButtonText }\n  @HostBinding(\"attr.data-roles\") get dataRoles(): string { return this.roles.join(',') }\n  @HostBinding(\"attr.data-field-types\") get dataFieldTypes(): string { return this.fieldTypes.join(',') }\n  @HostBinding(\"attr.data-draw-field-type\") get dataDrawFieldType(): string { return this.drawFieldType }\n  @HostBinding(\"attr.data-fields\") get dataFields(): string { return JSON.stringify(this.fields) }\n  @HostBinding(\"attr.data-i18n\") get dataI18n(): string { return JSON.stringify(this.i18n) }\n  @HostBinding(\"attr.data-custom-button-title\") get dataCustomButtonTitle(): string { return this.customButton.title }\n  @HostBinding(\"attr.data-custom-button-url\") get dataCustomButtonUrl(): string { return this.customButton.url }\n  @HostBinding(\"attr.data-with-recipients-button\") get dataWithRecipientsButton(): boolean { return this.withRecipientsButton }\n  @HostBinding(\"attr.data-with-send-button\") get dataWithSendButton(): boolean { return this.withSendButton }\n  @HostBinding(\"attr.data-with-documents-list\") get dataWithDocumentsList(): boolean { return this.withDocumentsList }\n  @HostBinding(\"attr.data-with-fields-list\") get dataWithFieldsList(): boolean { return this.withFieldsList }\n  @HostBinding(\"attr.data-with-title\") get dataWithTitle(): boolean { return this.withTitle }\n  @HostBinding(\"attr.data-only-defined-fields\") get dataOnlyDefinedFields(): boolean { return this.onlyDefinedFields }\n  @HostBinding(\"attr.data-with-upload-button\") get dataWithUploadButton(): boolean { return this.withUploadButton }\n  @HostBinding(\"attr.data-with-sign-yourself-button\") get dataWithSignYourselfButton(): boolean { return this.withSignYourselfButton }\n  @HostBinding(\"attr.data-background-color\") get dataBackgroundColor(): string { return this.backgroundColor }\n  @HostBinding(\"attr.data-custom-css\") get dataCustomCss(): string { return this.customCss }\n\n  ngAfterViewInit(): void {\n    this.loadScript()\n  }\n\n  @HostListener('send', ['$event'])\n  onSendEvent(event: CustomEvent): void {\n    if (this.onSend) {\n      this.onSend.emit(event.detail)\n    }\n  }\n\n  @HostListener('load', ['$event'])\n  onLoadEvent(event: CustomEvent): void {\n    if (this.onLoad) {\n      this.onLoad.emit(event.detail)\n    }\n  }\n\n  @HostListener('upload', ['$event'])\n  onUploadEvent(event: CustomEvent): void {\n    if (this.onUpload) {\n      this.onUpload.emit(event.detail)\n    }\n  }\n\n  @HostListener('save', ['$event'])\n  onSaveEvent(event: CustomEvent): void {\n    if (this.onSave) {\n      this.onSave.emit(event.detail)\n    }\n  }\n\n  loadScript(): void {\n    const scriptId = 'docuseal-builder-script'\n    const scriptSrc = `https://${this.host}/js/builder.js`\n    const script = document.createElement(\"script\")\n\n    script.id = scriptId\n    script.async = true\n    script.src = scriptSrc\n\n    document.head.appendChild(script)\n  }\n}\n"]}