UNPKG

survey-angular-ui

Version:

survey.js is a JavaScript Survey Library. It is a modern way to add a survey to your website. It uses JSON for survey metadata and results.

69 lines 14.9 kB
import { Component, Input, ViewChild } from "@angular/core"; import { ProgressButtonsResponsivityManager } from "survey-core"; import { AngularComponentFactory } from "../../../component-factory"; import * as i0 from "@angular/core"; import * as i1 from "../../../survey-string.component"; import * as i2 from "@angular/common"; export class ProgressButtonsComponent { constructor(changeDetectorRef) { this.changeDetectorRef = changeDetectorRef; this.hasScroller = false; this.canShowHeader = false; this.canShowFooter = false; this.canShowItemTitles = true; } onResize(canShowItemTitles) { this.canShowItemTitles = canShowItemTitles; this.canShowHeader = !this.canShowItemTitles; this.changeDetectorRef.detectChanges(); } onUpdateScroller(hasScroller) { this.hasScroller = hasScroller; this.changeDetectorRef.detectChanges(); } onUpdateSettings() { this.canShowItemTitles = this.model.showItemTitles; this.canShowFooter = !this.model.showItemTitles; this.changeDetectorRef.detectChanges(); } ngOnInit() { } ngOnChanges(changes) { } clickScrollButton(isLeftScroll) { if (this.progressButtonsListContainer) { this.progressButtonsListContainer.nativeElement.scrollLeft += (isLeftScroll ? -1 : 1) * 70; } } ngAfterViewInit() { var _a; if (!!((_a = this.progressButtonsListContainer) === null || _a === void 0 ? void 0 : _a.nativeElement)) { const element = this.progressButtonsListContainer.nativeElement; this.respManager = new ProgressButtonsResponsivityManager(this.model, element, this); } } ngOnDestroy() { var _a; (_a = this.respManager) === null || _a === void 0 ? void 0 : _a.dispose(); } } ProgressButtonsComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ProgressButtonsComponent, deps: [{ token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Component }); ProgressButtonsComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "12.2.17", type: ProgressButtonsComponent, selector: "sv-ng-progress-buttons", inputs: { model: "model", survey: "survey", container: "container" }, viewQueries: [{ propertyName: "progressButtonsListContainer", first: true, predicate: ["progressButtonsListContainer"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div [class]=\"model.getRootCss(container)\" [style.maxWidth]=\"model.progressWidth\" \nrole=\"progressbar\" aria-valuemin=\"0\" aria-valuemax=\"100\" [attr.aria-label]=\"model.progressBarAriaLabel\"\n>\n <div *ngIf=\"canShowHeader\" [class]=\"survey.css.progressButtonsHeader\">\n <div [class]=\"survey.css.progressButtonsPageTitle\" [title]=\"model.headerText\">{{ model.headerText }}</div>\n </div>\n <div [class]=\"survey.css.progressButtonsContainer\">\n <div\n [class]=\"model.getScrollButtonCss(hasScroller, true)\"\n (click)=\"clickScrollButton(true)\"\n role=\"button\"\n ></div>\n <div\n [class]=\"survey.css.progressButtonsListContainer\" #progressButtonsListContainer>\n <ul [class]=\"survey.css.progressButtonsList\">\n <li\n *ngFor=\"let page of survey.visiblePages; index as index\"\n [class]=\"model.getListElementCss(index)\"\n (click)=\"model.isListElementClickable(index) ? model.clickListElement(page) : null\"\n [attr.data-page-number]=\"model.getItemNumber(page)\">\n <div [class]=\"survey.css.progressButtonsConnector\"></div>\n <div *ngIf=\"canShowItemTitles\"\n [class]=\"survey.css.progressButtonsPageTitle\"\n [title]=\"page.renderedNavigationTitle\"\n >\n <sv-ng-string [model]=\"page.locNavigationTitle\"></sv-ng-string>\n </div>\n <div *ngIf=\"canShowItemTitles\"\n [class]=\"survey.css.progressButtonsPageDescription\"\n [title]=\"page.locNavigationDescription.renderedHtml\"\n >\n {{ page.locNavigationDescription.renderedHtml }}\n </div>\n <div [class]=\"survey.css.progressButtonsButton\"><div [class]=\"survey.css.progressButtonsButtonBackground\"></div><div [class]=\"survey.css.progressButtonsButtonContent\"></div><span>{{model.getItemNumber(page)}}</span></div>\n </li>\n </ul>\n </div>\n <div\n [class]=\"model.getScrollButtonCss(hasScroller, false)\"\n (click)=\"clickScrollButton(false)\"\n role=\"button\"\n ></div>\n </div>\n <div *ngIf=\"canShowFooter\" [class]=\"survey.css.progressButtonsFooter\">\n <div [class]=\"survey.css.progressButtonsPageTitle\" [title]=\"model.footerText\">{{ model.footerText }}</div>\n </div>\n</div>", components: [{ type: i1.SurveyStringComponent, selector: "sv-ng-string, '[sv-ng-string]'", inputs: ["model"] }], directives: [{ type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }] }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "12.2.17", ngImport: i0, type: ProgressButtonsComponent, decorators: [{ type: Component, args: [{ selector: "sv-ng-progress-buttons", templateUrl: "./progress.component.html" }] }], ctorParameters: function () { return [{ type: i0.ChangeDetectorRef }]; }, propDecorators: { model: [{ type: Input }], survey: [{ type: Input }], container: [{ type: Input }], progressButtonsListContainer: [{ type: ViewChild, args: ["progressButtonsListContainer"] }] } }); AngularComponentFactory.Instance.registerComponent("sv-progress-buttons", ProgressButtonsComponent); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"progress.component.js","sourceRoot":"","sources":["../../../../../src/components/progress/buttons/progress.component.ts","../../../../../src/components/progress/buttons/progress.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAoC,SAAS,EAAc,KAAK,EAA+C,SAAS,EAAE,MAAM,eAAe,CAAC;AACvJ,OAAO,EAAgC,kCAAkC,EAA6B,MAAM,aAAa,CAAC;AAC1H,OAAO,EAAE,uBAAuB,EAAE,MAAM,4BAA4B,CAAC;;;;AAMrE,MAAM,OAAO,wBAAwB;IAUnC,YAAoB,iBAAoC;QAApC,sBAAiB,GAAjB,iBAAiB,CAAmB;QALjD,gBAAW,GAAY,KAAK,CAAC;QAC7B,kBAAa,GAAY,KAAK,CAAC;QAC/B,kBAAa,GAAY,KAAK,CAAC;QAC/B,sBAAiB,GAAY,IAAI,CAAC;IAGzC,CAAC;IACD,QAAQ,CAAC,iBAA0B;QACjC,IAAI,CAAC,iBAAiB,GAAG,iBAAiB,CAAC;QAC3C,IAAI,CAAC,aAAa,GAAG,CAAC,IAAI,CAAC,iBAAiB,CAAC;QAC7C,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC;IACD,gBAAgB,CAAC,WAAoB;QACnC,IAAI,CAAC,WAAW,GAAG,WAAW,CAAC;QAC/B,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC;IACD,gBAAgB;QACd,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC;QACnD,IAAI,CAAC,aAAa,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,cAAc,CAAC;QAChD,IAAI,CAAC,iBAAiB,CAAC,aAAa,EAAE,CAAC;IACzC,CAAC;IACD,QAAQ;IACR,CAAC;IACD,WAAW,CAAC,OAAsB;IAClC,CAAC;IACM,iBAAiB,CACtB,YAAqB;QAErB,IAAI,IAAI,CAAC,4BAA4B,EAAE;YACrC,IAAI,CAAC,4BAA4B,CAAC,aAAa,CAAC,UAAU,IAAI,CAAC,YAAY,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,EAAE,CAAC;SAC5F;IACH,CAAC;IACM,eAAe;;QACpB,IAAI,CAAC,CAAC,CAAA,MAAA,IAAI,CAAC,4BAA4B,0CAAE,aAAa,CAAA,EAAE;YACtD,MAAM,OAAO,GAAG,IAAI,CAAC,4BAA4B,CAAC,aAAa,CAAC;YAChE,IAAI,CAAC,WAAW,GAAG,IAAI,kCAAkC,CAAC,IAAI,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,CAAC;SACtF;IACH,CAAC;IACM,WAAW;;QAChB,MAAA,IAAI,CAAC,WAAW,0CAAE,OAAO,EAAE,CAAC;IAC9B,CAAC;;sHA7CU,wBAAwB;0GAAxB,wBAAwB,uSCRrC,myEA8CM;4FDtCO,wBAAwB;kBAJpC,SAAS;mBAAC;oBACT,QAAQ,EAAE,wBAAwB;oBAClC,WAAW,EAAE,2BAA2B;iBACzC;wGAEU,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACqC,4BAA4B;sBAAtE,SAAS;uBAAC,8BAA8B;;AA2C3C,uBAAuB,CAAC,QAAQ,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,wBAAwB,CAAC,CAAC","sourcesContent":["import { AfterViewInit, ChangeDetectorRef, Component, ElementRef, Input, OnChanges, OnDestroy, OnInit, SimpleChanges, ViewChild } from \"@angular/core\";\nimport { SurveyModel, ProgressButtons, ProgressButtonsResponsivityManager, IProgressButtonsViewModel } from \"survey-core\";\nimport { AngularComponentFactory } from \"../../../component-factory\";\n\n@Component({\n  selector: \"sv-ng-progress-buttons\",\n  templateUrl: \"./progress.component.html\"\n})\nexport class ProgressButtonsComponent implements OnDestroy, AfterViewInit, OnChanges, OnInit, IProgressButtonsViewModel {\n  @Input() model!: ProgressButtons;\n  @Input() survey!: SurveyModel;\n  @Input() container!: string;\n  @ViewChild(\"progressButtonsListContainer\") progressButtonsListContainer!: ElementRef<HTMLDivElement>;\n  public hasScroller: boolean = false;\n  public canShowHeader: boolean = false;\n  public canShowFooter: boolean = false;\n  public canShowItemTitles: boolean = true;\n  private respManager?: ProgressButtonsResponsivityManager;\n  constructor(private changeDetectorRef: ChangeDetectorRef) {\n  }\n  onResize(canShowItemTitles: boolean): void {\n    this.canShowItemTitles = canShowItemTitles;\n    this.canShowHeader = !this.canShowItemTitles;\n    this.changeDetectorRef.detectChanges();\n  }\n  onUpdateScroller(hasScroller: boolean): void {\n    this.hasScroller = hasScroller;\n    this.changeDetectorRef.detectChanges();\n  }\n  onUpdateSettings(): void {\n    this.canShowItemTitles = this.model.showItemTitles;\n    this.canShowFooter = !this.model.showItemTitles;\n    this.changeDetectorRef.detectChanges();\n  }\n  ngOnInit(): void {\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n  }\n  public clickScrollButton(\n    isLeftScroll: boolean\n  ): void {\n    if (this.progressButtonsListContainer) {\n      this.progressButtonsListContainer.nativeElement.scrollLeft += (isLeftScroll ? -1 : 1) * 70;\n    }\n  }\n  public ngAfterViewInit(): void {\n    if (!!this.progressButtonsListContainer?.nativeElement) {\n      const element = this.progressButtonsListContainer.nativeElement;\n      this.respManager = new ProgressButtonsResponsivityManager(this.model, element, this);\n    }\n  }\n  public ngOnDestroy(): void {\n    this.respManager?.dispose();\n  }\n}\nAngularComponentFactory.Instance.registerComponent(\"sv-progress-buttons\", ProgressButtonsComponent);\n","<div [class]=\"model.getRootCss(container)\" [style.maxWidth]=\"model.progressWidth\" \nrole=\"progressbar\" aria-valuemin=\"0\" aria-valuemax=\"100\" [attr.aria-label]=\"model.progressBarAriaLabel\"\n>\n  <div *ngIf=\"canShowHeader\" [class]=\"survey.css.progressButtonsHeader\">\n    <div [class]=\"survey.css.progressButtonsPageTitle\" [title]=\"model.headerText\">{{ model.headerText }}</div>\n  </div>\n  <div [class]=\"survey.css.progressButtonsContainer\">\n    <div\n      [class]=\"model.getScrollButtonCss(hasScroller, true)\"\n      (click)=\"clickScrollButton(true)\"\n      role=\"button\"\n    ></div>\n    <div\n      [class]=\"survey.css.progressButtonsListContainer\" #progressButtonsListContainer>\n      <ul [class]=\"survey.css.progressButtonsList\">\n        <li\n          *ngFor=\"let page of survey.visiblePages; index as index\"\n          [class]=\"model.getListElementCss(index)\"\n          (click)=\"model.isListElementClickable(index) ? model.clickListElement(page) : null\"\n          [attr.data-page-number]=\"model.getItemNumber(page)\">\n          <div [class]=\"survey.css.progressButtonsConnector\"></div>\n          <div *ngIf=\"canShowItemTitles\"\n            [class]=\"survey.css.progressButtonsPageTitle\"\n            [title]=\"page.renderedNavigationTitle\"\n          >\n            <sv-ng-string [model]=\"page.locNavigationTitle\"></sv-ng-string>\n          </div>\n          <div *ngIf=\"canShowItemTitles\"\n            [class]=\"survey.css.progressButtonsPageDescription\"\n            [title]=\"page.locNavigationDescription.renderedHtml\"\n          >\n            {{ page.locNavigationDescription.renderedHtml }}\n          </div>\n          <div [class]=\"survey.css.progressButtonsButton\"><div [class]=\"survey.css.progressButtonsButtonBackground\"></div><div [class]=\"survey.css.progressButtonsButtonContent\"></div><span>{{model.getItemNumber(page)}}</span></div>\n        </li>\n      </ul>\n    </div>\n    <div\n      [class]=\"model.getScrollButtonCss(hasScroller, false)\"\n      (click)=\"clickScrollButton(false)\"\n      role=\"button\"\n    ></div>\n  </div>\n  <div *ngIf=\"canShowFooter\" [class]=\"survey.css.progressButtonsFooter\">\n    <div [class]=\"survey.css.progressButtonsPageTitle\" [title]=\"model.footerText\">{{ model.footerText }}</div>\n  </div>\n</div>"]}