@docuseal/angular 1.0.0 → 1.0.1

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.
@@ -0,0 +1,290 @@
1
+ import { Component, Input, HostListener } from "@angular/core";
2
+ import * as i0 from "@angular/core";
3
+ export class DocusealFormComponent {
4
+ el;
5
+ src = "";
6
+ host = "cdn.docuseal.co";
7
+ role = "";
8
+ submitter = ""; // Backward compatibility
9
+ expand = true;
10
+ preview = false;
11
+ email = "";
12
+ applicationKey = "";
13
+ externalId = "";
14
+ backgroundColor = "";
15
+ logo = "";
16
+ language = "";
17
+ completedRedirectUrl = "";
18
+ completedButton = { title: "", url: "" };
19
+ goToLast = true;
20
+ skipFields = false;
21
+ withTitle = true;
22
+ withFieldNames = true;
23
+ withDownloadButton = true;
24
+ withSendCopyButton = true;
25
+ allowToResubmit = true;
26
+ allowTypedSignature = true;
27
+ sendCopyEmail = false;
28
+ values = {};
29
+ metadata = {};
30
+ i18n = {};
31
+ fields = [];
32
+ readonlyFields = [];
33
+ onComplete = () => { };
34
+ onInit = () => { };
35
+ onLoad = () => { };
36
+ customCss = "";
37
+ constructor(el) {
38
+ this.el = el;
39
+ }
40
+ get attributes() {
41
+ return {
42
+ src: {
43
+ name: "data-src",
44
+ value: () => this.src
45
+ },
46
+ email: {
47
+ name: "data-email",
48
+ value: () => this.email
49
+ },
50
+ role: {
51
+ name: "data-role",
52
+ value: () => this.role || this.submitter
53
+ },
54
+ externalId: {
55
+ name: "data-external-id",
56
+ value: () => this.externalId || this.applicationKey
57
+ },
58
+ expand: {
59
+ name: "data-expand",
60
+ value: () => this.expand
61
+ },
62
+ preview: {
63
+ name: "data-preview",
64
+ value: () => this.preview
65
+ },
66
+ goToLast: {
67
+ name: "data-go-to-last",
68
+ value: () => this.goToLast
69
+ },
70
+ skipFields: {
71
+ name: "data-skip-fields",
72
+ value: () => this.skipFields
73
+ },
74
+ sendCopyEmail: {
75
+ name: "data-send-copy-email",
76
+ value: () => this.sendCopyEmail
77
+ },
78
+ withTitle: {
79
+ name: "data-with-title",
80
+ value: () => this.withTitle
81
+ },
82
+ logo: {
83
+ name: "data-logo",
84
+ value: () => this.logo
85
+ },
86
+ language: {
87
+ name: "data-language",
88
+ value: () => this.language
89
+ },
90
+ withFieldNames: {
91
+ name: "data-with-field-names",
92
+ value: () => this.withFieldNames
93
+ },
94
+ withDownloadButton: {
95
+ name: "data-with-download-button",
96
+ value: () => this.withDownloadButton
97
+ },
98
+ allowToResubmit: {
99
+ name: "data-allow-to-resubmit",
100
+ value: () => this.allowToResubmit
101
+ },
102
+ allowTypedSignature: {
103
+ name: "data-allow-typed-signature",
104
+ value: () => this.allowTypedSignature
105
+ },
106
+ completedRedirectUrl: {
107
+ name: "data-completed-redirect-url",
108
+ value: () => this.completedRedirectUrl
109
+ },
110
+ withSendCopyButton: {
111
+ name: "data-with-send-copy-button",
112
+ value: () => this.withSendCopyButton
113
+ },
114
+ values: {
115
+ name: "data-values",
116
+ value: () => JSON.stringify(this.values)
117
+ },
118
+ metadata: {
119
+ name: "data-metadata",
120
+ value: () => JSON.stringify(this.metadata)
121
+ },
122
+ fields: {
123
+ name: "data-fields",
124
+ value: () => JSON.stringify(this.fields)
125
+ },
126
+ i18n: {
127
+ name: "data-i18n",
128
+ value: () => JSON.stringify(this.i18n)
129
+ },
130
+ readonlyFields: {
131
+ name: "data-readonly-fields",
132
+ value: () => this.readonlyFields.join(',')
133
+ },
134
+ completedButton: [
135
+ {
136
+ name: "data-completed-button-title",
137
+ value: () => this.completedButton.title
138
+ },
139
+ {
140
+ name: "data-completed-button-url",
141
+ value: () => this.completedButton.url
142
+ }
143
+ ],
144
+ backgroundColor: {
145
+ name: "data-background-color",
146
+ value: () => this.backgroundColor
147
+ },
148
+ customCss: {
149
+ name: "data-custom-css",
150
+ value: () => this.customCss
151
+ }
152
+ };
153
+ }
154
+ ngAfterViewInit() {
155
+ const form = this.el.nativeElement;
156
+ Object.entries(this.attributes).forEach(([_, attribute]) => {
157
+ if (Array.isArray(attribute)) {
158
+ attribute.forEach((attr) => {
159
+ form.setAttribute(attr.name, attr.value());
160
+ });
161
+ }
162
+ else {
163
+ form.setAttribute(attribute.name, attribute.value());
164
+ }
165
+ });
166
+ this.loadScript();
167
+ }
168
+ ngOnChanges(changes) {
169
+ const form = this.el.nativeElement;
170
+ const attributes = this.attributes;
171
+ Object.entries(changes).forEach(([key, change]) => {
172
+ const attribute = attributes[key];
173
+ if (Array.isArray(attribute)) {
174
+ attribute.forEach((attr) => {
175
+ form.setAttribute(attr.name, attr.value());
176
+ });
177
+ }
178
+ else if (attribute) {
179
+ form.setAttribute(attribute.name, change.currentValue);
180
+ }
181
+ });
182
+ }
183
+ onCompleteEvent(event) {
184
+ if (this.onComplete) {
185
+ this.onComplete(event.detail);
186
+ }
187
+ }
188
+ onInitEvent(event) {
189
+ if (this.onInit) {
190
+ this.onInit(event.detail);
191
+ }
192
+ }
193
+ onLoadEvent(event) {
194
+ if (this.onLoad) {
195
+ this.onLoad(event.detail);
196
+ }
197
+ }
198
+ loadScript() {
199
+ const scriptId = "docuseal-form-script";
200
+ const scriptSrc = `https://${this.host}/js/form.js`;
201
+ const script = document.createElement("script");
202
+ script.id = scriptId;
203
+ script.async = true;
204
+ script.src = scriptSrc;
205
+ document.head.appendChild(script);
206
+ }
207
+ static ɵfac = function DocusealFormComponent_Factory(t) { return new (t || DocusealFormComponent)(i0.ɵɵdirectiveInject(i0.ElementRef)); };
208
+ static ɵcmp = /*@__PURE__*/ i0.ɵɵdefineComponent({ type: DocusealFormComponent, selectors: [["docuseal-form"]], hostBindings: function DocusealFormComponent_HostBindings(rf, ctx) { if (rf & 1) {
209
+ i0.ɵɵlistener("completed", function DocusealFormComponent_completed_HostBindingHandler($event) { return ctx.onCompleteEvent($event); })("init", function DocusealFormComponent_init_HostBindingHandler($event) { return ctx.onInitEvent($event); })("load", function DocusealFormComponent_load_HostBindingHandler($event) { return ctx.onLoadEvent($event); });
210
+ } }, inputs: { src: "src", host: "host", role: "role", submitter: "submitter", expand: "expand", preview: "preview", email: "email", applicationKey: "applicationKey", externalId: "externalId", backgroundColor: "backgroundColor", logo: "logo", language: "language", completedRedirectUrl: "completedRedirectUrl", completedButton: "completedButton", goToLast: "goToLast", skipFields: "skipFields", withTitle: "withTitle", withFieldNames: "withFieldNames", withDownloadButton: "withDownloadButton", withSendCopyButton: "withSendCopyButton", allowToResubmit: "allowToResubmit", allowTypedSignature: "allowTypedSignature", sendCopyEmail: "sendCopyEmail", values: "values", metadata: "metadata", i18n: "i18n", fields: "fields", readonlyFields: "readonlyFields", onComplete: "onComplete", onInit: "onInit", onLoad: "onLoad", customCss: "customCss" }, standalone: true, features: [i0.ɵɵNgOnChangesFeature, i0.ɵɵStandaloneFeature], decls: 0, vars: 0, template: function DocusealFormComponent_Template(rf, ctx) { }, encapsulation: 2 });
211
+ }
212
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(DocusealFormComponent, [{
213
+ type: Component,
214
+ args: [{ selector: "docuseal-form", standalone: true, template: "" }]
215
+ }], () => [{ type: i0.ElementRef }], { src: [{
216
+ type: Input
217
+ }], host: [{
218
+ type: Input
219
+ }], role: [{
220
+ type: Input
221
+ }], submitter: [{
222
+ type: Input
223
+ }], expand: [{
224
+ type: Input
225
+ }], preview: [{
226
+ type: Input
227
+ }], email: [{
228
+ type: Input
229
+ }], applicationKey: [{
230
+ type: Input
231
+ }], externalId: [{
232
+ type: Input
233
+ }], backgroundColor: [{
234
+ type: Input
235
+ }], logo: [{
236
+ type: Input
237
+ }], language: [{
238
+ type: Input
239
+ }], completedRedirectUrl: [{
240
+ type: Input
241
+ }], completedButton: [{
242
+ type: Input
243
+ }], goToLast: [{
244
+ type: Input
245
+ }], skipFields: [{
246
+ type: Input
247
+ }], withTitle: [{
248
+ type: Input
249
+ }], withFieldNames: [{
250
+ type: Input
251
+ }], withDownloadButton: [{
252
+ type: Input
253
+ }], withSendCopyButton: [{
254
+ type: Input
255
+ }], allowToResubmit: [{
256
+ type: Input
257
+ }], allowTypedSignature: [{
258
+ type: Input
259
+ }], sendCopyEmail: [{
260
+ type: Input
261
+ }], values: [{
262
+ type: Input
263
+ }], metadata: [{
264
+ type: Input
265
+ }], i18n: [{
266
+ type: Input
267
+ }], fields: [{
268
+ type: Input
269
+ }], readonlyFields: [{
270
+ type: Input
271
+ }], onComplete: [{
272
+ type: Input
273
+ }], onInit: [{
274
+ type: Input
275
+ }], onLoad: [{
276
+ type: Input
277
+ }], customCss: [{
278
+ type: Input
279
+ }], onCompleteEvent: [{
280
+ type: HostListener,
281
+ args: ['completed', ['$event']]
282
+ }], onInitEvent: [{
283
+ type: HostListener,
284
+ args: ['init', ['$event']]
285
+ }], onLoadEvent: [{
286
+ type: HostListener,
287
+ args: ['load', ['$event']]
288
+ }] }); })();
289
+ (() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassDebugInfo(DocusealFormComponent, { className: "DocusealFormComponent" }); })();
290
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../src/form.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  title?: string,\n  type?: string,\n  position?: number,\n  required?: boolean,\n}\n\ninterface AfterViewInit {\n  ngAfterViewInit(): void\n}\ninterface OnChanges {\n  ngOnChanges(changes: SimpleChanges): void\n}\n@Component({\n  selector: \"docuseal-form\",\n  standalone: true,\n  template: \"\",\n  styles: []\n})\n\nexport class DocusealFormComponent implements AfterViewInit, OnChanges {\n  @Input() src: string = \"\"\n  @Input() host: string = \"cdn.docuseal.co\"\n  @Input() role: string = \"\"\n  @Input() submitter: string = \"\" // Backward compatibility\n  @Input() expand: boolean = true\n  @Input() preview: boolean = false\n  @Input() email: string = \"\"\n  @Input() applicationKey: string = \"\"\n  @Input() externalId: string = \"\"\n  @Input() backgroundColor: string = \"\"\n  @Input() logo: string = \"\"\n  @Input() language: string = \"\"\n  @Input() completedRedirectUrl: string = \"\"\n  @Input() completedButton: { title: string, url: string } = { title: \"\", url: \"\" }\n  @Input() goToLast: boolean = true\n  @Input() skipFields: boolean = false\n  @Input() withTitle: boolean = true\n  @Input() withFieldNames: boolean = true\n  @Input() withDownloadButton: boolean = true\n  @Input() withSendCopyButton: boolean = true\n  @Input() allowToResubmit: boolean = true\n  @Input() allowTypedSignature: boolean = true\n  @Input() sendCopyEmail: boolean = false\n  @Input() values: object = {}\n  @Input() metadata: object = {}\n  @Input() i18n: object = {}\n  @Input() fields: DocusealField[] = []\n  @Input() readonlyFields: string[] = []\n  @Input() onComplete: (detail: any) => void = () => {}\n  @Input() onInit: (detail: any) => void = () => {}\n  @Input() onLoad: (detail: any) => void = () => {}\n  @Input() customCss: string = \"\"\n\n  constructor(private el: ElementRef) {}\n\n  get attributes (): { [key: string]: any } {\n    return {\n      src: {\n        name: \"data-src\",\n        value: () => this.src\n      },\n      email: {\n        name: \"data-email\",\n        value: () => this.email\n      },\n      role: {\n        name: \"data-role\",\n        value: () => this.role || this.submitter\n      },\n      externalId: {\n        name: \"data-external-id\",\n        value: () => this.externalId || this.applicationKey\n      },\n      expand: {\n        name: \"data-expand\",\n        value: () => this.expand\n      },\n      preview: {\n        name: \"data-preview\",\n        value: () => this.preview\n      },\n      goToLast: {\n        name: \"data-go-to-last\",\n        value: () => this.goToLast\n      },\n      skipFields: {\n        name: \"data-skip-fields\",\n        value: () => this.skipFields\n      },\n      sendCopyEmail: {\n        name: \"data-send-copy-email\",\n        value: () => this.sendCopyEmail\n      },\n      withTitle: {\n        name: \"data-with-title\",\n        value: () => this.withTitle\n      },\n      logo: {\n        name: \"data-logo\",\n        value: () => this.logo\n      },\n      language: {\n        name: \"data-language\",\n        value: () => this.language\n      },\n      withFieldNames: {\n        name: \"data-with-field-names\",\n        value: () => this.withFieldNames\n      },\n      withDownloadButton: {\n        name: \"data-with-download-button\",\n        value: () => this.withDownloadButton\n      },\n      allowToResubmit: {\n        name: \"data-allow-to-resubmit\",\n        value: () => this.allowToResubmit\n      },\n      allowTypedSignature: {\n        name: \"data-allow-typed-signature\",\n        value: () => this.allowTypedSignature\n      },\n      completedRedirectUrl: {\n        name: \"data-completed-redirect-url\",\n        value: () => this.completedRedirectUrl\n      },\n      withSendCopyButton: {\n        name: \"data-with-send-copy-button\",\n        value: () => this.withSendCopyButton\n      },\n      values: {\n        name: \"data-values\",\n        value: () => JSON.stringify(this.values)\n      },\n      metadata: {\n        name: \"data-metadata\",\n        value: () => JSON.stringify(this.metadata)\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      readonlyFields: {\n        name: \"data-readonly-fields\",\n        value: () => this.readonlyFields.join(',')\n      },\n      completedButton: [\n        {\n          name: \"data-completed-button-title\",\n          value: () => this.completedButton.title\n        },\n        {\n          name: \"data-completed-button-url\",\n          value: () => this.completedButton.url\n        }\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 form = this.el.nativeElement;\n\n    Object.entries(this.attributes).forEach(([_, attribute]) => {\n      if (Array.isArray(attribute)) {\n        attribute.forEach((attr) => {\n          form.setAttribute(attr.name, attr.value())\n        })\n      } else {\n        form.setAttribute(attribute.name, attribute.value())\n      }\n    })\n\n    this.loadScript()\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    const form = 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          form.setAttribute(attr.name, attr.value())\n        })\n      } else if (attribute) {\n        form.setAttribute(attribute.name, change.currentValue)\n      }\n    })\n  }\n\n  @HostListener('completed', ['$event'])\n  onCompleteEvent(event: CustomEvent): void {\n    if (this.onComplete) {\n      this.onComplete(event.detail)\n    }\n  }\n\n  @HostListener('init', ['$event'])\n  onInitEvent(event: CustomEvent): void {\n    if (this.onInit) {\n      this.onInit(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  loadScript(): void {\n    const scriptId = \"docuseal-form-script\"\n    const scriptSrc = `https://${this.host}/js/form.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"]}
@@ -0,0 +1,3 @@
1
+ export * from "./form.component";
2
+ export * from "./builder.component";
3
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uL3NyYy9wdWJsaWMtYXBpLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLGNBQWMsa0JBQWtCLENBQUM7QUFDakMsY0FBYyxxQkFBcUIsQ0FBQyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCAqIGZyb20gXCIuL2Zvcm0uY29tcG9uZW50XCI7XG5leHBvcnQgKiBmcm9tIFwiLi9idWlsZGVyLmNvbXBvbmVudFwiO1xuIl19