kwikid-components
Version:
KwikID's Components Library
200 lines • 27 kB
JavaScript
import { __decorate } from "tslib";
import { Component, EventEmitter, Input, Output } from "@angular/core";
import { logMethod, mergeObjects } from "kwikid-toolkit";
import { INSTRUCTIONS_CONFIG } from "./instruction.config";
import * as i0 from "@angular/core";
import * as i1 from "../../components/page-header/page-header.component";
import * as i2 from "kwikui";
import * as i3 from "kwikid-forms";
import * as i4 from "../../components/schedule-later-button/schedule-later-button.component";
import * as i5 from "../../components/page-footer/page-footer.component";
import * as i6 from "@angular/common";
export class KwikIDInstructionComponent {
constructor() {
this.config = INSTRUCTIONS_CONFIG;
this.headerConfig = undefined;
this.footerConfig = undefined;
this.scheduleLaterConfig = undefined;
this.onClickStart = new EventEmitter();
this.onClickScheduleLater = new EventEmitter();
}
ngOnInit() {
this.initInstructionsConfig();
}
initInstructionsConfig() {
var _a, _b, _c, _d;
this.config = mergeObjects(INSTRUCTIONS_CONFIG, this.config);
this.headerConfig = (_a = this.config) === null || _a === void 0 ? void 0 : _a.headerConfig;
this.footerConfig = (_b = this.config) === null || _b === void 0 ? void 0 : _b.footerConfig;
this.scheduleLaterConfig = this.config.scheduleLaterConfig;
const formConfig = {
title: "Instructions",
key: "INSTRUCTIONS",
fields: [],
properties: {
header: {
logo: {
hidden: true
},
backButton: {
hidden: true
},
title: {
hidden: true
},
steps: {
hidden: true
}
},
main: {
styles: ""
},
footer: {
viewFormsButton: {
hidden: true
},
saveButton: {
hidden: false,
label: this.config.startButtonLabel
}
}
}
};
if (this.config &&
this.config.consents &&
this.config.consents.length !== 0) {
let variant = "block";
if (this.config.consents.length > 1) {
variant = "labeled";
}
this.config.consents.forEach((item, i) => {
const field = this.initInstructionConsentsConfig(item, i, variant);
formConfig.fields.push(field);
});
}
this.formConfig = formConfig;
this.animation = {
path: (_d = (_c = this.config) === null || _c === void 0 ? void 0 : _c.animation) !== null && _d !== void 0 ? _d : "assets/instructions.json"
};
}
initInstructionConsentsConfig(item, i, variant) {
var _a, _b;
return {
label: `Consent ${i + 1}`,
key: `consent_${i + 1}`,
type: "checkbox",
default: {
value: {
sources: [
{
validation: {
is_valid: false,
triggers: ["ON_INIT"],
rules: [],
actions: [
{
id: "1",
key: "SET_FIELD_DEFAULT_VALUE",
condition: "true",
props: {
value: {
source: {
key: "PREDEFINED",
props: {
predefinedValue: (_a = item === null || item === void 0 ? void 0 : item.checked) !== null && _a !== void 0 ? _a : true
}
}
}
}
}
]
}
}
]
}
},
validators: {
required: (_b = !(item === null || item === void 0 ? void 0 : item.isOptional)) !== null && _b !== void 0 ? _b : true
},
validation: {
is_valid: false,
triggers: ["ON_CHANGE"],
rules: [
{
id: "1",
key: "VALUE_CHECK",
props: {
value: {
source: {
key: "OBJECT",
props: {
object: {
key: "FORM_DATA",
path: `$.consent_${i + 1}`
}
}
}
},
pattern: {
key: "IS_TRUE"
}
}
}
],
actions: [
{
key: "FIELD_ERROR_HIDE",
condition: "1",
props: {
fieldKey: `consent_${i + 1}`,
message: {
type: "error",
message: ""
}
}
}
]
},
properties: {
placeholder: item.content,
variant,
containerStyles: ""
}
};
}
handleOnClickStart() {
this.onClickStart.emit("Start");
}
handleOnClickScheduleLater() {
this.onClickScheduleLater.emit("Schedule Later");
}
}
/** @nocollapse */ KwikIDInstructionComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDInstructionComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
/** @nocollapse */ KwikIDInstructionComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: KwikIDInstructionComponent, selector: "kwikid-components-instruction", inputs: { config: "config" }, outputs: { onClickStart: "onClickStart", onClickScheduleLater: "onClickScheduleLater" }, ngImport: i0, template: "<div class=\"container\">\n <kwikid-components-page-header [config]=\"headerConfig\">\n </kwikid-components-page-header>\n <main>\n <kwikui-animation-player\n *ngIf=\"config?.showAnimation\"\n [config]=\"animation\"\n id=\"animation\"\n ></kwikui-animation-player>\n\n <div\n *ngIf=\"config?.html?.before\"\n [innerHtml]=\"config?.html?.before | kwikuiSafeHtml\"\n >\n </div>\n\n <ul *ngIf=\"config.instructions && config.instructions.length !== 0\">\n <div *ngFor=\"let instruction of config.instructions\">\n <ng-container\n *ngIf=\"instruction?.text\"\n [ngSwitch]=\"instruction.type\"\n >\n <div *ngSwitchCase=\"'title'\">{{ instruction.text }}</div>\n <div *ngSwitchCase=\"'list-title'\">{{ instruction.text }}</div>\n <li *ngSwitchCase=\"'list-item'\">{{ instruction.text }}</li>\n </ng-container>\n <li\n *ngIf=\"!instruction?.text\"\n [innerHtml]=\"instruction | kwikuiSafeHtml\"\n >\n </li>\n </div>\n </ul>\n\n <div\n *ngIf=\"config?.html?.after\"\n [innerHtml]=\"config?.html?.after | kwikuiSafeHtml\"\n >\n </div>\n\n <div id=\"checklist\">\n <div>\n <kwikid-form-view\n [formConfig]=\"formConfig\"\n [allFormsData]=\"{}\"\n (onClickSaveForm)=\"handleOnClickStart()\"\n ></kwikid-form-view\n ></div>\n </div>\n\n <kwikid-schedule-later-button\n [config]=\"scheduleLaterConfig\"\n (onClickScheduleLater)=\"handleOnClickScheduleLater()\"\n >\n </kwikid-schedule-later-button>\n </main>\n\n <kwikid-components-page-footer\n *ngIf=\"footerConfig.show\"\n [config]=\"footerConfig\"\n >\n </kwikid-components-page-footer>\n</div>\n", styles: ["@charset \"UTF-8\";:host{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;width:100%}.container{display:flex;flex-direction:column;justify-content:flex-start;align-items:center;overflow:auto}.container>*:not(:last-child){margin-bottom:1rem}.container main{display:flex;flex-direction:column;align-content:center;justify-content:flex-start;align-items:center;padding:0 1rem}.container main>*:not(:last-child){margin-bottom:1rem}.container main #animation{max-width:320px;margin:auto}.container main ul{list-style:none;padding-left:0;font-size:1rem;width:100%}.container main ul div{position:relative;margin-bottom:.5rem}.container main li{position:relative;padding-left:1.5em;margin-bottom:.5rem;white-space:pre-line}.container main li:before{content:\"\\2713\";position:absolute;left:0;width:1em;height:1em}.container main #checklist{width:100%}.container main #checklist div{margin:-1rem}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{border-radius:10px}::-webkit-scrollbar-thumb{background:lightgray;border-radius:10px}::-webkit-scrollbar-thumb:hover{background:gray}\n"], components: [{ type: i1.KwikIDPageHeaderComponent, selector: "kwikid-components-page-header", inputs: ["config"] }, { type: i2.KwikUIAnimationPlayerComponent, selector: "kwikui-animation-player", inputs: ["config", "id", "player"] }, { type: i3.KwikIDFormViewComponent, selector: "kwikid-form-view", inputs: ["allFormsData", "extraData", "apiCallResponse", "buttonClickResponse", "formConfig", "formData", "isMobileView", "popupFormCallback", "userConfig", "stepConfig"], outputs: ["getLogs", "getUnsavedDataState", "onActionShowPopupForm", "onClickApiCall", "onClickViewFile", "onClickFormFieldButton", "onClickGoBack", "onClickSaveForm", "onClickViewForms"] }, { type: i4.KwikIDScheduleLaterButtonComponent, selector: "kwikid-schedule-later-button", inputs: ["config"], outputs: ["onClickScheduleLater"] }, { type: i5.KwikIDPageFooterComponent, selector: "kwikid-components-page-footer", inputs: ["config"] }], directives: [{ type: i6.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i6.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i6.NgSwitch, selector: "[ngSwitch]", inputs: ["ngSwitch"] }, { type: i6.NgSwitchCase, selector: "[ngSwitchCase]", inputs: ["ngSwitchCase"] }], pipes: { "kwikuiSafeHtml": i2.KwikUISafeHtmlPipe } });
__decorate([
logMethod
], KwikIDInstructionComponent.prototype, "initInstructionsConfig", null);
__decorate([
logMethod
], KwikIDInstructionComponent.prototype, "initInstructionConsentsConfig", null);
__decorate([
logMethod
], KwikIDInstructionComponent.prototype, "handleOnClickStart", null);
__decorate([
logMethod
], KwikIDInstructionComponent.prototype, "handleOnClickScheduleLater", null);
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: KwikIDInstructionComponent, decorators: [{
type: Component,
args: [{
selector: "kwikid-components-instruction",
templateUrl: "./instruction.component.html",
styleUrls: ["./instruction.component.scss"]
}]
}], ctorParameters: function () { return []; }, propDecorators: { config: [{
type: Input
}], onClickStart: [{
type: Output
}], onClickScheduleLater: [{
type: Output
}], initInstructionsConfig: [], initInstructionConsentsConfig: [], handleOnClickStart: [], handleOnClickScheduleLater: [] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"instruction.component.js","sourceRoot":"","sources":["../../../../../../projects/kwikid-components/src/lib/pages/instruction/instruction.component.ts","../../../../../../projects/kwikid-components/src/lib/pages/instruction/instruction.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnInit, Output } from \"@angular/core\";\nimport { logMethod, mergeObjects } from \"kwikid-toolkit\";\nimport { INSTRUCTIONS_CONFIG } from \"./instruction.config\";\n\n@Component({\n  selector: \"kwikid-components-instruction\",\n  templateUrl: \"./instruction.component.html\",\n  styleUrls: [\"./instruction.component.scss\"]\n})\nexport class KwikIDInstructionComponent implements OnInit {\n  @Input()\n  config: any = INSTRUCTIONS_CONFIG;\n\n  animation: any;\n\n  formConfig: any;\n\n  headerConfig: any = undefined;\n\n  footerConfig: any = undefined;\n\n  scheduleLaterConfig: any = undefined;\n\n  @Output()\n  onClickStart: EventEmitter<any> = new EventEmitter();\n\n  @Output()\n  onClickScheduleLater: EventEmitter<any> = new EventEmitter();\n\n  constructor() {}\n\n  ngOnInit(): void {\n    this.initInstructionsConfig();\n  }\n\n  @logMethod\n  initInstructionsConfig(): void {\n    this.config = mergeObjects(INSTRUCTIONS_CONFIG, this.config);\n    this.headerConfig = this.config?.headerConfig;\n    this.footerConfig = this.config?.footerConfig;\n    this.scheduleLaterConfig = this.config.scheduleLaterConfig;\n\n    const formConfig = {\n      title: \"Instructions\",\n      key: \"INSTRUCTIONS\",\n      fields: [],\n      properties: {\n        header: {\n          logo: {\n            hidden: true\n          },\n          backButton: {\n            hidden: true\n          },\n          title: {\n            hidden: true\n          },\n          steps: {\n            hidden: true\n          }\n        },\n        main: {\n          styles: \"\"\n        },\n        footer: {\n          viewFormsButton: {\n            hidden: true\n          },\n          saveButton: {\n            hidden: false,\n            label: this.config.startButtonLabel\n          }\n        }\n      }\n    };\n\n    if (\n      this.config &&\n      this.config.consents &&\n      this.config.consents.length !== 0\n    ) {\n      let variant = \"block\";\n      if (this.config.consents.length > 1) {\n        variant = \"labeled\";\n      }\n\n      this.config.consents.forEach((item, i) => {\n        const field = this.initInstructionConsentsConfig(item, i, variant);\n        formConfig.fields.push(field);\n      });\n    }\n\n    this.formConfig = formConfig;\n    this.animation = {\n      path: this.config?.animation ?? \"assets/instructions.json\"\n    };\n  }\n\n  @logMethod\n  initInstructionConsentsConfig(item: any, i: number, variant: string): any {\n    return {\n      label: `Consent ${i + 1}`,\n      key: `consent_${i + 1}`,\n      type: \"checkbox\",\n      default: {\n        value: {\n          sources: [\n            {\n              validation: {\n                is_valid: false,\n                triggers: [\"ON_INIT\"],\n                rules: [],\n                actions: [\n                  {\n                    id: \"1\",\n                    key: \"SET_FIELD_DEFAULT_VALUE\",\n                    condition: \"true\",\n                    props: {\n                      value: {\n                        source: {\n                          key: \"PREDEFINED\",\n                          props: {\n                            predefinedValue: item?.checked ?? true\n                          }\n                        }\n                      }\n                    }\n                  }\n                ]\n              }\n            }\n          ]\n        }\n      },\n      validators: {\n        required: !item?.isOptional ?? true\n      },\n      validation: {\n        is_valid: false,\n        triggers: [\"ON_CHANGE\"],\n        rules: [\n          {\n            id: \"1\",\n            key: \"VALUE_CHECK\",\n            props: {\n              value: {\n                source: {\n                  key: \"OBJECT\",\n                  props: {\n                    object: {\n                      key: \"FORM_DATA\",\n                      path: `$.consent_${i + 1}`\n                    }\n                  }\n                }\n              },\n              pattern: {\n                key: \"IS_TRUE\"\n              }\n            }\n          }\n        ],\n        actions: [\n          {\n            key: \"FIELD_ERROR_HIDE\",\n            condition: \"1\",\n            props: {\n              fieldKey: `consent_${i + 1}`,\n              message: {\n                type: \"error\",\n                message: \"\"\n              }\n            }\n          }\n        ]\n      },\n      properties: {\n        placeholder: item.content,\n        variant,\n        containerStyles: \"\"\n      }\n    };\n  }\n\n  @logMethod\n  handleOnClickStart(): void {\n    this.onClickStart.emit(\"Start\");\n  }\n\n  @logMethod\n  handleOnClickScheduleLater(): void {\n    this.onClickScheduleLater.emit(\"Schedule Later\");\n  }\n}\n","<div class=\"container\">\n  <kwikid-components-page-header [config]=\"headerConfig\">\n  </kwikid-components-page-header>\n  <main>\n    <kwikui-animation-player\n      *ngIf=\"config?.showAnimation\"\n      [config]=\"animation\"\n      id=\"animation\"\n    ></kwikui-animation-player>\n\n    <div\n      *ngIf=\"config?.html?.before\"\n      [innerHtml]=\"config?.html?.before | kwikuiSafeHtml\"\n    >\n    </div>\n\n    <ul *ngIf=\"config.instructions && config.instructions.length !== 0\">\n      <div *ngFor=\"let instruction of config.instructions\">\n        <ng-container\n          *ngIf=\"instruction?.text\"\n          [ngSwitch]=\"instruction.type\"\n        >\n          <div *ngSwitchCase=\"'title'\">{{ instruction.text }}</div>\n          <div *ngSwitchCase=\"'list-title'\">{{ instruction.text }}</div>\n          <li *ngSwitchCase=\"'list-item'\">{{ instruction.text }}</li>\n        </ng-container>\n        <li\n          *ngIf=\"!instruction?.text\"\n          [innerHtml]=\"instruction | kwikuiSafeHtml\"\n        >\n        </li>\n      </div>\n    </ul>\n\n    <div\n      *ngIf=\"config?.html?.after\"\n      [innerHtml]=\"config?.html?.after | kwikuiSafeHtml\"\n    >\n    </div>\n\n    <div id=\"checklist\">\n      <div>\n        <kwikid-form-view\n          [formConfig]=\"formConfig\"\n          [allFormsData]=\"{}\"\n          (onClickSaveForm)=\"handleOnClickStart()\"\n        ></kwikid-form-view\n      ></div>\n    </div>\n\n    <kwikid-schedule-later-button\n      [config]=\"scheduleLaterConfig\"\n      (onClickScheduleLater)=\"handleOnClickScheduleLater()\"\n    >\n    </kwikid-schedule-later-button>\n  </main>\n\n  <kwikid-components-page-footer\n    *ngIf=\"footerConfig.show\"\n    [config]=\"footerConfig\"\n  >\n  </kwikid-components-page-footer>\n</div>\n"]}