@tripetto/runner-autoscroll
Version:
Autoscroll UI for running Tripetto forms and surveys.
449 lines (448 loc) • 42.3 kB
JavaScript
import { ChangeDetectionStrategy, Component, EventEmitter, Input, Output } from "@angular/core";
import { isPromise } from "@tripetto/runner";
import { run } from "@tripetto/runner-autoscroll";
import * as i0 from "@angular/core";
export class TripettoAutoscrollComponent {
/** Retrieves a reference to the runner instance. */
get controller() {
return this.runnerController;
}
/** Retrieves the running definition. */
get definition() {
return this.runnerController?.definition || this.initialDefinition;
}
/** Specifies the definition to run. */
set definition(definition) {
if (this.runnerController && definition) {
this.zone.runOutsideAngular(() => {
if (isPromise(definition)) {
definition.then((value) => {
if (value) {
this.runnerController.definition = value;
}
});
} else if (definition) {
this.runnerController.l10n = definition;
}
});
return;
}
this.initialDefinition = definition;
}
/** Retrieves the view mode of the runner. */
get view() {
return this.runnerController?.view || this.initialView || "live";
}
/** Specifies the view mode of the runner. */
set view(view) {
if (this.runnerController) {
this.zone.runOutsideAngular(() => {
this.runnerController.view = view;
});
return;
}
this.initialView = view;
}
/** Retrieves the styles (colors, font, size, etc.) for the runner. */
get styles() {
return this.runnerController?.styles || this.initialStyles;
}
/** Specifies the styles (colors, font, size, etc.) for the runner. */
set styles(styles) {
if (this.runnerController) {
this.zone.runOutsideAngular(() => {
if (isPromise(styles)) {
styles.then((value) => {
if (value) {
this.runnerController.styles = value;
}
});
} else if (styles) {
this.runnerController.styles = styles;
}
});
return;
}
this.initialStyles = styles;
}
/** Retrieves the localization (locale and translation) information. */
get l10n() {
return this.runnerController?.l10n || this.initialL10n;
}
/** Specifies the localization (locale and translation) information. */
set l10n(l10n) {
if (this.runnerController) {
this.zone.runOutsideAngular(() => {
if (isPromise(l10n)) {
l10n.then((value) => {
if (value) {
this.runnerController.l10n = value;
}
});
} else if (l10n) {
this.runnerController.l10n = l10n;
}
});
return;
}
this.initialL10n = l10n;
}
/** Reference to a builder instance to enable live preview for the builder. */
set builder(ref) {
if (!ref) {
this.builderController = undefined;
} else {
new Promise((resolve) => {
const fnAwait = () => {
if (typeof ref === "function") {
const builder = ref();
if (builder) {
return resolve(builder.controller);
}
} else if (ref.controller) {
return resolve(ref.controller);
}
requestAnimationFrame(fnAwait);
};
fnAwait();
}).then((controller) => {
this.builderController = controller;
controller.hook("OnChange", "synchronous", (changeEvent) => {
if (this.runnerController) {
this.runnerController.definition = changeEvent.definition;
}
});
controller.hook("OnEdit", "synchronous", (editEvent) => {
this.runnerController?.doPreview(editEvent.data);
});
});
}
}
get builder() {
return (
this.builderController && {
controller: this.builderController,
}
);
}
constructor(element, zone) {
this.element = element;
this.zone = zone;
/** Invoked when the runner is ready. */
this.onReady = new EventEmitter();
/** Invoked when the runner processed a change. */
this.onChange = new EventEmitter();
/** Invoked when data can be imported into the instance. */
this.onImport = new EventEmitter();
/** Invoked when the data in the runner is changed. */
this.onData = new EventEmitter();
/** Specifies a function that is invoked when the user performs an action. */
this.onAction = new EventEmitter();
/** Invoked when the runner is about to end and submits data. */
this.onSubmit = new EventEmitter();
/** Invoked when the runner is completed (after the data is submitted). */
this.onComplete = new EventEmitter();
/** Specifies a function that is invoked when an edit action is requested. */
this.onEdit = new EventEmitter();
/** Specifies a function that is invoked when the runner is "touched" by a user. */
this.onTouch = new EventEmitter();
/** Invoked when the runner is destroyed. */
this.onDestroy = new EventEmitter();
}
ngOnInit() {
this.zone.runOutsideAngular(async () => {
this.runnerController = await run({
element: this.element.nativeElement,
definition: this.definition,
view: this.initialView,
display: this.display,
snapshot: this.snapshot,
styles: this.styles,
persistent: this.persistent,
license: this.license,
removeBranding: this.removeBranding,
attachments: this.attachments,
className: this.className,
customStyle: this.customStyle,
customCSS: this.customCSS,
l10n: this.l10n,
language: this.language,
locale: this.locale,
translations: this.translations,
onReady: (instance) => this.onReady.emit(instance),
onChange: (instance) => this.onChange.emit(instance),
onImport: (instance) => this.onImport.emit(instance),
onData: (instance) => this.onData.emit(instance),
onAction: (type, definition, block) =>
this.onAction.emit({
type,
definition,
block,
}),
onSubmit: (instance, language, locale, namespace) =>
this.onSubmit.emit({
instance,
language,
locale,
namespace,
}),
onComplete: (instance, id) =>
this.onComplete.emit({
instance,
id,
}),
onEdit: (type, id) => {
if (this.builderController) {
switch (type) {
case "prologue":
this.builderController.edit("prologue");
break;
case "epilogue":
this.builderController.edit("epilogue", id);
break;
case "block":
if (id) {
this.builderController.edit("node", id);
}
break;
}
}
this.onEdit.emit({
type,
id,
});
},
onReload: this.onReload,
onPause: this.onPause,
onTouch: () => this.onTouch.emit(),
onDestroy: () => this.onDestroy.emit(),
});
});
}
ngOnDestroy() {
if (this.runnerController) {
this.runnerController.destroy();
this.runnerController = this.builderController = undefined;
}
}
}
TripettoAutoscrollComponent.ɵfac = i0.ɵɵngDeclareFactory({
minVersion: "12.0.0",
version: "15.2.1",
ngImport: i0,
type: TripettoAutoscrollComponent,
deps: [{ token: i0.ElementRef }, { token: i0.NgZone }],
target: i0.ɵɵFactoryTarget.Component,
});
TripettoAutoscrollComponent.ɵcmp = i0.ɵɵngDeclareComponent({
minVersion: "14.0.0",
version: "15.2.1",
type: TripettoAutoscrollComponent,
selector: "tripetto-runner-autoscroll",
inputs: {
definition: "definition",
view: "view",
styles: "styles",
l10n: "l10n",
display: "display",
snapshot: "snapshot",
persistent: "persistent",
license: "license",
removeBranding: "removeBranding",
attachments: "attachments",
className: "className",
customStyle: "customStyle",
customCSS: "customCSS",
language: "language",
locale: "locale",
translations: "translations",
onReload: "onReload",
onPause: "onPause",
builder: "builder",
},
outputs: {
onReady: "onReady",
onChange: "onChange",
onImport: "onImport",
onData: "onData",
onAction: "onAction",
onSubmit: "onSubmit",
onComplete: "onComplete",
onEdit: "onEdit",
onTouch: "onTouch",
onDestroy: "onDestroy",
},
ngImport: i0,
template: "",
isInline: true,
changeDetection: i0.ChangeDetectionStrategy.OnPush,
});
i0.ɵɵngDeclareClassMetadata({
minVersion: "12.0.0",
version: "15.2.1",
ngImport: i0,
type: TripettoAutoscrollComponent,
decorators: [
{
type: Component,
args: [
{
selector: "tripetto-runner-autoscroll",
template: "",
changeDetection: ChangeDetectionStrategy.OnPush,
},
],
},
],
ctorParameters: function () {
return [{ type: i0.ElementRef }, { type: i0.NgZone }];
},
propDecorators: {
definition: [
{
type: Input,
},
],
view: [
{
type: Input,
},
],
styles: [
{
type: Input,
},
],
l10n: [
{
type: Input,
},
],
display: [
{
type: Input,
},
],
snapshot: [
{
type: Input,
},
],
persistent: [
{
type: Input,
},
],
license: [
{
type: Input,
},
],
removeBranding: [
{
type: Input,
},
],
attachments: [
{
type: Input,
},
],
className: [
{
type: Input,
},
],
customStyle: [
{
type: Input,
},
],
customCSS: [
{
type: Input,
},
],
language: [
{
type: Input,
},
],
locale: [
{
type: Input,
},
],
translations: [
{
type: Input,
},
],
onReady: [
{
type: Output,
},
],
onChange: [
{
type: Output,
},
],
onImport: [
{
type: Output,
},
],
onData: [
{
type: Output,
},
],
onAction: [
{
type: Output,
},
],
onSubmit: [
{
type: Output,
},
],
onComplete: [
{
type: Output,
},
],
onEdit: [
{
type: Output,
},
],
onTouch: [
{
type: Output,
},
],
onDestroy: [
{
type: Output,
},
],
onReload: [
{
type: Input,
},
],
onPause: [
{
type: Input,
},
],
builder: [
{
type: Input,
},
],
},
});
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"runner.component.js","sourceRoot":"","sources":["../../../src/angular/projects/runner/src/lib/runner.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,uBAAuB,EAAE,SAAS,EAAc,YAAY,EAAE,KAAK,EAA6B,MAAM,EAAE,MAAM,eAAe,CAAC;AACvI,OAAO,EAA+D,SAAS,EAAE,MAAM,kBAAkB,CAAC;AAC1G,OAAO,EAOH,GAAG,GACN,MAAM,6BAA6B,CAAC;;AASrC,MAAM,OAAO,2BAA2B;IAQpC,oDAAoD;IACpD,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,gBAAgB,CAAC;IACjC,CAAC;IAED,wCAAwC;IACxC,IAAI,UAAU;QACV,OAAO,IAAI,CAAC,gBAAgB,EAAE,UAAU,IAAI,IAAI,CAAC,iBAAiB,CAAC;IACvE,CAAC;IAED,uCAAuC;IACvC,IAAa,UAAU,CAAC,UAAsE;QAC1F,IAAI,IAAI,CAAC,gBAAgB,IAAI,UAAU,EAAE;YACrC,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAC7B,IAAI,SAAS,CAAC,UAAU,CAAC,EAAE;oBACvB,UAAU,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;wBACtB,IAAI,KAAK,EAAE;4BACP,IAAI,CAAC,gBAAiB,CAAC,UAAU,GAAG,KAAK,CAAC;yBAC7C;oBACL,CAAC,CAAC,CAAC;iBACN;qBAAM,IAAI,UAAU,EAAE;oBACnB,IAAI,CAAC,gBAAiB,CAAC,IAAI,GAAG,UAAU,CAAC;iBAC5C;YACL,CAAC,CAAC,CAAC;YAEH,OAAO;SACV;QAED,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC;IACxC,CAAC;IAED,6CAA6C;IAC7C,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,IAAI,CAAC,WAAW,IAAI,MAAM,CAAC;IACrE,CAAC;IAED,6CAA6C;IAC7C,IAAa,IAAI,CAAC,IAAkB;QAChC,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAC7B,IAAI,CAAC,gBAAiB,CAAC,IAAI,GAAG,IAAI,CAAC;YACvC,CAAC,CAAC,CAAC;YAEH,OAAO;SACV;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC5B,CAAC;IAED,sEAAsE;IACtE,IAAI,MAAM;QACN,OAAO,IAAI,CAAC,gBAAgB,EAAE,MAAM,IAAI,IAAI,CAAC,aAAa,CAAC;IAC/D,CAAC;IAED,sEAAsE;IACtE,IAAa,MAAM,CAAC,MAA8E;QAC9F,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAC7B,IAAI,SAAS,CAAC,MAAM,CAAC,EAAE;oBACnB,MAAM,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;wBAClB,IAAI,KAAK,EAAE;4BACP,IAAI,CAAC,gBAAiB,CAAC,MAAM,GAAG,KAAK,CAAC;yBACzC;oBACL,CAAC,CAAC,CAAC;iBACN;qBAAM,IAAI,MAAM,EAAE;oBACf,IAAI,CAAC,gBAAiB,CAAC,MAAM,GAAG,MAAM,CAAC;iBAC1C;YACL,CAAC,CAAC,CAAC;YAEH,OAAO;SACV;QAED,IAAI,CAAC,aAAa,GAAG,MAAM,CAAC;IAChC,CAAC;IAED,uEAAuE;IACvE,IAAI,IAAI;QACJ,OAAO,IAAI,CAAC,gBAAgB,EAAE,IAAI,IAAI,IAAI,CAAC,WAAW,CAAC;IAC3D,CAAC;IAED,uEAAuE;IACvE,IAAa,IAAI,CAAC,IAAoD;QAClE,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,GAAG,EAAE;gBAC7B,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE;oBACjB,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,EAAE,EAAE;wBAChB,IAAI,KAAK,EAAE;4BACP,IAAI,CAAC,gBAAiB,CAAC,IAAI,GAAG,KAAK,CAAC;yBACvC;oBACL,CAAC,CAAC,CAAC;iBACN;qBAAM,IAAI,IAAI,EAAE;oBACb,IAAI,CAAC,gBAAiB,CAAC,IAAI,GAAG,IAAI,CAAC;iBACtC;YACL,CAAC,CAAC,CAAC;YAEH,OAAO;SACV;QAED,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC;IAC5B,CAAC;IAyGD,8EAA8E;IAC9E,IAAa,OAAO,CAChB,GAOe;QAEf,IAAI,CAAC,GAAG,EAAE;YACN,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;SACtC;aAAM;YACH,IAAI,OAAO,CAAC,CAAC,OAA+C,EAAE,EAAE;gBAC5D,MAAM,OAAO,GAAG,GAAG,EAAE;oBACjB,IAAI,OAAO,GAAG,KAAK,UAAU,EAAE;wBAC3B,MAAM,OAAO,GAAG,GAAG,EAAE,CAAC;wBAEtB,IAAI,OAAO,EAAE;4BACT,OAAO,OAAO,CAAC,OAAO,CAAC,UAAU,CAAC,CAAC;yBACtC;qBACJ;yBAAM,IAAI,GAAG,CAAC,UAAU,EAAE;wBACvB,OAAO,OAAO,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;qBAClC;oBAED,qBAAqB,CAAC,OAAO,CAAC,CAAC;gBACnC,CAAC,CAAC;gBAEF,OAAO,EAAE,CAAC;YACd,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,UAAU,EAAE,EAAE;gBACnB,IAAI,CAAC,iBAAiB,GAAG,UAAU,CAAC;gBAEpC,UAAU,CAAC,IAAI,CAKb,UAAU,EAAE,aAAa,EAAE,CAAC,WAAW,EAAE,EAAE;oBACzC,IAAI,IAAI,CAAC,gBAAgB,EAAE;wBACvB,IAAI,CAAC,gBAAgB,CAAC,UAAU,GAAG,WAAW,CAAC,UAAU,CAAC;qBAC7D;gBACL,CAAC,CAAC,CAAC;gBAEH,UAAU,CAAC,IAAI,CACX,QAAQ,EACR,aAAa,EACb,CAAC,SAAS,EAAE,EAAE;oBACV,IAAI,CAAC,gBAAgB,EAAE,SAAS,CAAC,SAAS,CAAC,IAAI,CAAC,CAAC;gBACrD,CAAC,CACJ,CAAC;YACN,CAAC,CAAC,CAAC;SACN;IACL,CAAC;IAED,IAAI,OAAO;QACP,OAAO,CACH,IAAI,CAAC,iBAAiB,IAAI;YACtB,UAAU,EAAE,IAAI,CAAC,iBAAiB;SACrC,CACJ,CAAC;IACN,CAAC;IAED,YACY,OAAmB,EACnB,IAAY;QADZ,YAAO,GAAP,OAAO,CAAY;QACnB,SAAI,GAAJ,IAAI,CAAQ;QA1HxB,wCAAwC;QAC9B,YAAO,GAAG,IAAI,YAAY,EAAY,CAAC;QAEjD,kDAAkD;QACxC,aAAQ,GAAG,IAAI,YAAY,EAAY,CAAC;QAElD,2DAA2D;QACjD,aAAQ,GAAG,IAAI,YAAY,EAAY,CAAC;QAElD,sDAAsD;QAC5C,WAAM,GAAG,IAAI,YAAY,EAAY,CAAC;QAEhD,6EAA6E;QACnE,aAAQ,GAAG,IAAI,YAAY,EAUjC,CAAC;QAEL,gEAAgE;QACtD,aAAQ,GAAG,IAAI,YAAY,EAKjC,CAAC;QAEL,0EAA0E;QAChE,eAAU,GAAG,IAAI,YAAY,EAGnC,CAAC;QAEL,6EAA6E;QACnE,WAAM,GAAG,IAAI,YAAY,EAG/B,CAAC;QAEL,mFAAmF;QACzE,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;QAE7C,4CAA4C;QAClC,cAAS,GAAG,IAAI,YAAY,EAAQ,CAAC;IA0E5C,CAAC;IAEJ,QAAQ;QACJ,IAAI,CAAC,IAAI,CAAC,iBAAiB,CAAC,KAAK,IAAI,EAAE;YACnC,IAAI,CAAC,gBAAgB,GAAG,MAAM,GAAG,CAAC;gBAC9B,OAAO,EAAE,IAAI,CAAC,OAAO,CAAC,aAAa;gBACnC,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,IAAI,EAAE,IAAI,CAAC,WAAW;gBACtB,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,UAAU,EAAE,IAAI,CAAC,UAAU;gBAC3B,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,cAAc,EAAE,IAAI,CAAC,cAAc;gBACnC,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,WAAW,EAAE,IAAI,CAAC,WAAW;gBAC7B,SAAS,EAAE,IAAI,CAAC,SAAS;gBACzB,IAAI,EAAE,IAAI,CAAC,IAAI;gBACf,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,MAAM,EAAE,IAAI,CAAC,MAAM;gBACnB,YAAY,EAAE,IAAI,CAAC,YAAY;gBAC/B,OAAO,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC;gBAClD,QAAQ,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC;gBACpD,QAAQ,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC;gBACpD,MAAM,EAAE,CAAC,QAAQ,EAAE,EAAE,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC;gBAChD,QAAQ,EAAE,CAAC,IAAI,EAAE,UAAU,EAAE,KAAK,EAAE,EAAE,CAClC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACf,IAAI;oBACJ,UAAU;oBACV,KAAK;iBACR,CAAC;gBACN,QAAQ,EAAE,CAAC,QAAQ,EAAE,QAAQ,EAAE,MAAM,EAAE,SAAS,EAAE,EAAE,CAChD,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC;oBACf,QAAQ;oBACR,QAAQ;oBACR,MAAM;oBACN,SAAS;iBACZ,CAAC;gBACN,UAAU,EAAE,CAAC,QAAQ,EAAE,EAAE,EAAE,EAAE,CACzB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC;oBACjB,QAAQ;oBACR,EAAE;iBACL,CAAC;gBACN,MAAM,EAAE,CAAC,IAAI,EAAE,EAAE,EAAE,EAAE;oBACjB,IAAI,IAAI,CAAC,iBAAiB,EAAE;wBACxB,QAAQ,IAAI,EAAE;4BACV,KAAK,UAAU;gCACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;gCACxC,MAAM;4BACV,KAAK,UAAU;gCACX,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,UAAU,EAAE,EAAE,CAAC,CAAC;gCAC5C,MAAM;4BACV,KAAK,OAAO;gCACR,IAAI,EAAE,EAAE;oCACJ,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,MAAM,EAAE,EAAE,CAAC,CAAC;iCAC3C;gCACD,MAAM;yBACb;qBACJ;oBAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC;wBACb,IAAI;wBACJ,EAAE;qBACL,CAAC,CAAC;gBACP,CAAC;gBACD,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,OAAO,EAAE,IAAI,CAAC,OAAO;gBACrB,OAAO,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE;gBAClC,SAAS,EAAE,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE;aACzC,CAAC,CAAC;QACP,CAAC,CAAC,CAAC;IACP,CAAC;IAED,WAAW;QACP,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACvB,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;YAChC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,iBAAiB,GAAG,SAAS,CAAC;SAC9D;IACL,CAAC;;wHArWQ,2BAA2B;4GAA3B,2BAA2B,+tBAH1B,EAAE;2FAGH,2BAA2B;kBALvC,SAAS;mBAAC;oBACP,QAAQ,EAAE,4BAA4B;oBACtC,QAAQ,EAAE,EAAE;oBACZ,eAAe,EAAE,uBAAuB,CAAC,MAAM;iBAClD;sHAoBgB,UAAU;sBAAtB,KAAK;gBA0BO,IAAI;sBAAhB,KAAK;gBAkBO,MAAM;sBAAlB,KAAK;gBA0BO,IAAI;sBAAhB,KAAK;gBAqBG,OAAO;sBAAf,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,UAAU;sBAAlB,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGG,cAAc;sBAAtB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAGG,SAAS;sBAAjB,KAAK;gBAGG,WAAW;sBAAnB,KAAK;gBAMG,SAAS;sBAAjB,KAAK;gBAGG,QAAQ;sBAAhB,KAAK;gBAGG,MAAM;sBAAd,KAAK;gBAGG,YAAY;sBAApB,KAAK;gBAUI,OAAO;sBAAhB,MAAM;gBAGG,QAAQ;sBAAjB,MAAM;gBAGG,QAAQ;sBAAjB,MAAM;gBAGG,MAAM;sBAAf,MAAM;gBAGG,QAAQ;sBAAjB,MAAM;gBAaG,QAAQ;sBAAjB,MAAM;gBAQG,UAAU;sBAAnB,MAAM;gBAMG,MAAM;sBAAf,MAAM;gBAMG,OAAO;sBAAhB,MAAM;gBAGG,SAAS;sBAAlB,MAAM;gBAGE,QAAQ;sBAAhB,KAAK;gBAGG,OAAO;sBAAf,KAAK;gBAGO,OAAO;sBAAnB,KAAK","sourcesContent":["import { ChangeDetectionStrategy, Component, ElementRef, EventEmitter, Input, NgZone, OnDestroy, OnInit, Output } from \"@angular/core\";\nimport { IDefinition, IHookPayload, ISnapshot, Instance, L10n, TL10n, isPromise } from \"@tripetto/runner\";\nimport {\n    IAutoscrollRunner,\n    IAutoscrollSnapshot,\n    IAutoscrollStyles,\n    IBuilderInstance,\n    TAutoscrollDisplay,\n    TAutoscrollPause,\n    run,\n} from \"@tripetto/runner-autoscroll\";\nimport { IRunnerAttachments, TRunnerPreviewData, TRunnerViews } from \"@tripetto/runner-react-hook\";\nimport { CSSProperties } from \"react\";\n\n@Component({\n    selector: \"tripetto-runner-autoscroll\",\n    template: \"\",\n    changeDetection: ChangeDetectionStrategy.OnPush,\n})\nexport class TripettoAutoscrollComponent implements OnInit, OnDestroy {\n    private runnerController?: IAutoscrollRunner;\n    private builderController?: IBuilderInstance;\n    private initialDefinition?: IDefinition | Promise<IDefinition | undefined>;\n    private initialView?: TRunnerViews | undefined;\n    private initialStyles?: IAutoscrollStyles | Promise<IAutoscrollStyles | undefined>;\n    private initialL10n?: TL10n | Promise<TL10n | undefined>;\n\n    /** Retrieves a reference to the runner instance. */\n    get controller(): IAutoscrollRunner | undefined {\n        return this.runnerController;\n    }\n\n    /** Retrieves the running definition. */\n    get definition(): IDefinition | Promise<IDefinition | undefined> | undefined {\n        return this.runnerController?.definition || this.initialDefinition;\n    }\n\n    /** Specifies the definition to run. */\n    @Input() set definition(definition: IDefinition | Promise<IDefinition | undefined> | undefined) {\n        if (this.runnerController && definition) {\n            this.zone.runOutsideAngular(() => {\n                if (isPromise(definition)) {\n                    definition.then((value) => {\n                        if (value) {\n                            this.runnerController!.definition = value;\n                        }\n                    });\n                } else if (definition) {\n                    this.runnerController!.l10n = definition;\n                }\n            });\n\n            return;\n        }\n\n        this.initialDefinition = definition;\n    }\n\n    /** Retrieves the view mode of the runner. */\n    get view(): TRunnerViews {\n        return this.runnerController?.view || this.initialView || \"live\";\n    }\n\n    /** Specifies the view mode of the runner. */\n    @Input() set view(view: TRunnerViews) {\n        if (this.runnerController) {\n            this.zone.runOutsideAngular(() => {\n                this.runnerController!.view = view;\n            });\n\n            return;\n        }\n\n        this.initialView = view;\n    }\n\n    /** Retrieves the styles (colors, font, size, etc.) for the runner. */\n    get styles(): IAutoscrollStyles | Promise<IAutoscrollStyles | undefined> | undefined {\n        return this.runnerController?.styles || this.initialStyles;\n    }\n\n    /** Specifies the styles (colors, font, size, etc.) for the runner. */\n    @Input() set styles(styles: IAutoscrollStyles | Promise<IAutoscrollStyles | undefined> | undefined) {\n        if (this.runnerController) {\n            this.zone.runOutsideAngular(() => {\n                if (isPromise(styles)) {\n                    styles.then((value) => {\n                        if (value) {\n                            this.runnerController!.styles = value;\n                        }\n                    });\n                } else if (styles) {\n                    this.runnerController!.styles = styles;\n                }\n            });\n\n            return;\n        }\n\n        this.initialStyles = styles;\n    }\n\n    /** Retrieves the localization (locale and translation) information. */\n    get l10n(): TL10n | Promise<TL10n | undefined> | undefined {\n        return this.runnerController?.l10n || this.initialL10n;\n    }\n\n    /** Specifies the localization (locale and translation) information. */\n    @Input() set l10n(l10n: TL10n | Promise<TL10n | undefined> | undefined) {\n        if (this.runnerController) {\n            this.zone.runOutsideAngular(() => {\n                if (isPromise(l10n)) {\n                    l10n.then((value) => {\n                        if (value) {\n                            this.runnerController!.l10n = value;\n                        }\n                    });\n                } else if (l10n) {\n                    this.runnerController!.l10n = l10n;\n                }\n            });\n\n            return;\n        }\n\n        this.initialL10n = l10n;\n    }\n\n    /** Specifies the display mode of the runner. */\n    @Input() display?: TAutoscrollDisplay;\n\n    /** Specifies the snapshot that should be restored. */\n    @Input() snapshot?: ISnapshot<IAutoscrollSnapshot> | Promise<ISnapshot<IAutoscrollSnapshot> | undefined>;\n\n    /** Try to store sessions in the local store to preserve persistency on navigation between multiple pages that host the runner. */\n    @Input() persistent?: boolean;\n\n    /** Specifies a license code for the runner. */\n    @Input() license?: string | Promise<string | undefined>;\n\n    /** Removes all Tripetto branding when a valid license is supplied. */\n    @Input() removeBranding?: boolean;\n\n    /** Specifies the attachments handler. */\n    @Input() attachments?: IRunnerAttachments;\n\n    /** Specifies a custom class name for the HTML element that holds the runner. */\n    @Input() className?: string;\n\n    /** Specifies the inline style for the HTML element that holds the runner. */\n    @Input() customStyle?: CSSProperties;\n\n    /**\n     * Specifies custom CSS rules.\n     * To specify rules for a specific block, use this selector: [data-block=\"<block identifier>\"] { ... }\n     */\n    @Input() customCSS?: string;\n\n    /** Specifies the preferred language (when no language is specified in the definition). */\n    @Input() language?: string;\n\n    /** Provides locale information. */\n    @Input() locale?: L10n.ILocale | ((locale: string) => L10n.ILocale | Promise<L10n.ILocale | undefined> | undefined);\n\n    /** Provides translations. */\n    @Input() translations?:\n        | L10n.TTranslation\n        | L10n.TTranslation[]\n        | ((\n              language: string,\n              name: string,\n              version: string\n          ) => L10n.TTranslation | L10n.TTranslation[] | Promise<L10n.TTranslation | L10n.TTranslation[] | undefined> | undefined);\n\n    /** Invoked when the runner is ready. */\n    @Output() onReady = new EventEmitter<Instance>();\n\n    /** Invoked when the runner processed a change. */\n    @Output() onChange = new EventEmitter<Instance>();\n\n    /** Invoked when data can be imported into the instance. */\n    @Output() onImport = new EventEmitter<Instance>();\n\n    /** Invoked when the data in the runner is changed. */\n    @Output() onData = new EventEmitter<Instance>();\n\n    /** Specifies a function that is invoked when the user performs an action. */\n    @Output() onAction = new EventEmitter<{\n        readonly type: \"start\" | \"stage\" | \"unstage\" | \"focus\" | \"blur\" | \"pause\" | \"complete\";\n        readonly definition: {\n            readonly fingerprint: string;\n            readonly name: string;\n        };\n        readonly block?: {\n            readonly id: string;\n            readonly name: string;\n        };\n    }>();\n\n    /** Invoked when the runner is about to end and submits data. */\n    @Output() onSubmit = new EventEmitter<{\n        readonly instance: Instance;\n        readonly language: string;\n        readonly locale: string;\n        readonly namespace: string | undefined;\n    }>();\n\n    /** Invoked when the runner is completed (after the data is submitted). */\n    @Output() onComplete = new EventEmitter<{\n        readonly instance: Instance;\n        readonly id?: string;\n    }>();\n\n    /** Specifies a function that is invoked when an edit action is requested. */\n    @Output() onEdit = new EventEmitter<{\n        readonly type: \"prologue\" | \"epilogue\" | \"styles\" | \"l10n\" | \"block\";\n        readonly id?: string;\n    }>();\n\n    /** Specifies a function that is invoked when the runner is \"touched\" by a user. */\n    @Output() onTouch = new EventEmitter<void>();\n\n    /** Invoked when the runner is destroyed. */\n    @Output() onDestroy = new EventEmitter<void>();\n\n    /** Specifies a function that is invoked when the runner wants to reload the definition. */\n    @Input() onReload?: () => IDefinition | Promise<IDefinition>;\n\n    /** Specifies a function or recipe that is invoked when the runner wants to pause. */\n    @Input() onPause?: TAutoscrollPause;\n\n    /** Reference to a builder instance to enable live preview for the builder. */\n    @Input() set builder(\n        ref:\n            | {\n                  readonly controller: IBuilderInstance;\n              }\n            | (() => {\n                  readonly controller: IBuilderInstance;\n              })\n            | undefined\n    ) {\n        if (!ref) {\n            this.builderController = undefined;\n        } else {\n            new Promise((resolve: (controller: IBuilderInstance) => void) => {\n                const fnAwait = () => {\n                    if (typeof ref === \"function\") {\n                        const builder = ref();\n\n                        if (builder) {\n                            return resolve(builder.controller);\n                        }\n                    } else if (ref.controller) {\n                        return resolve(ref.controller);\n                    }\n\n                    requestAnimationFrame(fnAwait);\n                };\n\n                fnAwait();\n            }).then((controller) => {\n                this.builderController = controller;\n\n                controller.hook<\n                    \"OnChange\",\n                    IHookPayload<\"OnChange\"> & {\n                        readonly definition: IDefinition;\n                    }\n                >(\"OnChange\", \"synchronous\", (changeEvent) => {\n                    if (this.runnerController) {\n                        this.runnerController.definition = changeEvent.definition;\n                    }\n                });\n\n                controller.hook<\"OnEdit\", IHookPayload<\"OnEdit\"> & { readonly data: TRunnerPreviewData }>(\n                    \"OnEdit\",\n                    \"synchronous\",\n                    (editEvent) => {\n                        this.runnerController?.doPreview(editEvent.data);\n                    }\n                );\n            });\n        }\n    }\n\n    get builder() {\n        return (\n            this.builderController && {\n                controller: this.builderController,\n            }\n        );\n    }\n\n    constructor(\n        private element: ElementRef,\n        private zone: NgZone\n    ) {}\n\n    ngOnInit() {\n        this.zone.runOutsideAngular(async () => {\n            this.runnerController = await run({\n                element: this.element.nativeElement,\n                definition: this.definition,\n                view: this.initialView,\n                display: this.display,\n                snapshot: this.snapshot,\n                styles: this.styles,\n                persistent: this.persistent,\n                license: this.license,\n                removeBranding: this.removeBranding,\n                attachments: this.attachments,\n                className: this.className,\n                customStyle: this.customStyle,\n                customCSS: this.customCSS,\n                l10n: this.l10n,\n                language: this.language,\n                locale: this.locale,\n                translations: this.translations,\n                onReady: (instance) => this.onReady.emit(instance),\n                onChange: (instance) => this.onChange.emit(instance),\n                onImport: (instance) => this.onImport.emit(instance),\n                onData: (instance) => this.onData.emit(instance),\n                onAction: (type, definition, block) =>\n                    this.onAction.emit({\n                        type,\n                        definition,\n                        block,\n                    }),\n                onSubmit: (instance, language, locale, namespace) =>\n                    this.onSubmit.emit({\n                        instance,\n                        language,\n                        locale,\n                        namespace,\n                    }),\n                onComplete: (instance, id) =>\n                    this.onComplete.emit({\n                        instance,\n                        id,\n                    }),\n                onEdit: (type, id) => {\n                    if (this.builderController) {\n                        switch (type) {\n                            case \"prologue\":\n                                this.builderController.edit(\"prologue\");\n                                break;\n                            case \"epilogue\":\n                                this.builderController.edit(\"epilogue\", id);\n                                break;\n                            case \"block\":\n                                if (id) {\n                                    this.builderController.edit(\"node\", id);\n                                }\n                                break;\n                        }\n                    }\n\n                    this.onEdit.emit({\n                        type,\n                        id,\n                    });\n                },\n                onReload: this.onReload,\n                onPause: this.onPause,\n                onTouch: () => this.onTouch.emit(),\n                onDestroy: () => this.onDestroy.emit(),\n            });\n        });\n    }\n\n    ngOnDestroy() {\n        if (this.runnerController) {\n            this.runnerController.destroy();\n            this.runnerController = this.builderController = undefined;\n        }\n    }\n}\n"]}