UNPKG

com.phloxui

Version:

PhloxUI Ng2+ Framework

202 lines (201 loc) 19.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes} checked by tsc */ import { Component, HostListener, ElementRef } from '@angular/core'; import { DomSanitizer } from '@angular/platform-browser'; import { PhloxAppService } from '../service/PhloxAppService.service'; import { AbstractWizardPane } from './AbstractWizardPane'; const /** @type {?} */ TYPE_NAME = "phx-scroll-pagination-wizard-pane"; const /** @type {?} */ INDEX_Y_0 = "INDEX_Y_0"; const /** @type {?} */ UP = "UP"; const /** @type {?} */ DOWN = "DOWN"; export class ScrollPaginationWizardPane extends AbstractWizardPane { /** * @param {?} appSvc * @param {?} sanitizer * @param {?} elementRef */ constructor(appSvc, sanitizer, elementRef) { super(appSvc, elementRef); this.sanitizer = sanitizer; } /** * @return {?} */ ngOnInit() { super.ngOnInit(); } /** * @param {?} event * @return {?} */ onmousewheel(event) { clearTimeout(this.delayMouseWheelTimer); this.delayMouseWheelTimer = null; this.delayMouseWheelTimer = setTimeout(() => { event = window.event || event; let /** @type {?} */ delta = Math.max(-1, Math.min(1, (event.wheelDelta || -event.detail))); if (delta > -1) { // mouseWheel up if (this.currentStep !== 0) { this.currentStep -= 1; if (this.currentStep === 0) { this.setSafeStyleIndexY(INDEX_Y_0); } else { this.setSafeStyleIndexY(UP); } } } else { // mouseWheel down if (this.getModel().steps.length > 0) { let /** @type {?} */ stepsIndex = this.getModel().steps.length - 1; if (this.currentStep < stepsIndex) { this.currentStep += 1; this.setSafeStyleIndexY(DOWN); } } } event.preventDefault(); }, 250); } /** * @param {?} mouseWheel * @return {?} */ setSafeStyleIndexY(mouseWheel) { let /** @type {?} */ y; let /** @type {?} */ index = this.currentStep; if (mouseWheel === DOWN || mouseWheel === UP) { // set Style translate3d = (0, -(index * 100), 0); y = -(index * 100); } else if (mouseWheel === INDEX_Y_0) { // set Style translate3d = (0, 0, 0); y = 0; } else { // default set Style translate3d = (0, 0, 0); y = 0; } this.safeStyle = this.sanitizer.bypassSecurityTrustStyle("translate3d( 0, " + y + "%, 0 )"); } /** * @return {?} */ getSafeStyle() { return this.safeStyle; } /** * @param {?} index * @return {?} */ showStepContent(index) { let /** @type {?} */ y; if (index !== 0) { // set Style translate3d = (0, -(index * 100), 0); y = -(index * 100); } else if (index === 0) { // set Style translate3d = (0, 0, 0); y = 0; } else { // default set Style translate3d = (0, 0, 0); y = 0; } this.safeStyle = this.sanitizer.bypassSecurityTrustStyle("translate3d( 0, " + y + "%, 0 )"); } /** * @param {?} index * @return {?} */ getStepInstance(index) { } } ScrollPaginationWizardPane.TYPE_NAME = TYPE_NAME; ScrollPaginationWizardPane.decorators = [ { type: Component, args: [{ moduleId: module.id, selector: 'phx-scroll-pagination-wizard-pane', template: `<div class="phx-scroll-pagination-wizard-pane"> <div class="left" [style.padding-top]="getHeaderHeight() + 'pt'" [style.padding-bottom]="getFooterHeight() + 'pt'"> <div class="header" [style.height]="getHeaderHeight() + 'pt'"> <ng-template [ngIf]="getModel() !== null && getModel().header !== null"> <ng-template [ngIf]="getModel().header.type === null"> <div *ngIf="getModel().header.imageURL !== null && getModel().header.imageURL !== ''" class="header-image"> <img src="{{getModel().header.imageURL}}"> </div> <div class="header-label">{{getModel().header.label}}</div> </ng-template> <ng-template [ngIf]="getModel().header.type !== null"> <phx-component-wrapper [type]="getModel().header.type" [data]="getModel().header.model"></phx-component-wrapper> </ng-template> </ng-template> </div> <div class="body"> <ng-template [ngIf]="getModel() !== null && getModel().steps !== null"> <div *ngFor="let item of getModel().steps; let i = index;" class="step" [class.active]="isStepSelected(i)"> <ng-template [ngIf]="item.type === null"> <div (click)="stepSelected(i)"> {{item.label}} </div> </ng-template> <ng-template [ngIf]="item.type !== null"> <phx-component-wrapper [type]="item.type" [data]="item.model" (click)="stepSelected(i)"></phx-component-wrapper> </ng-template> </div> </ng-template> </div> <div class="footer" [style.height]="getFooterHeight() + 'pt'"> <ng-template [ngIf]="getModel() !== null && getModel().footer !== null"> <ng-template [ngIf]="getModel().footer.type === null"> {{getModel().footer.label}} </ng-template> <ng-template [ngIf]="getModel().footer.type !== null"> <phx-component-wrapper [type]="getModel().footer.type" [data]="getModel().footer.model"></phx-component-wrapper> </ng-template> </ng-template> </div> </div> <div class="right"> <div class="scrollpage" [style.transform]="getSafeStyle()"> <div *ngFor="let item of getModel().steps; let i = index;" style="height: 100%;"> <phx-component-wrapper [class.active]="isStepSelected(i)" [type]="item.componentType" [data]="getData()" [model]="item.componentModel" [dataParent]="this" [handler]="getStepsComponentHandler()"> </phx-component-wrapper> </div> </div> </div> </div> `, },] }, ]; /** @nocollapse */ ScrollPaginationWizardPane.ctorParameters = () => [ { type: PhloxAppService, }, { type: DomSanitizer, }, { type: ElementRef, }, ]; ScrollPaginationWizardPane.propDecorators = { "onmousewheel": [{ type: HostListener, args: ['mousewheel', ['$event'],] },], }; function ScrollPaginationWizardPane_tsickle_Closure_declarations() { /** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */ ScrollPaginationWizardPane.decorators; /** * @nocollapse * @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>} */ ScrollPaginationWizardPane.ctorParameters; /** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */ ScrollPaginationWizardPane.propDecorators; /** @type {?} */ ScrollPaginationWizardPane.TYPE_NAME; /** @type {?} */ ScrollPaginationWizardPane.prototype.delayMouseWheelTimer; /** @type {?} */ ScrollPaginationWizardPane.prototype.sanitizer; /** @type {?} */ ScrollPaginationWizardPane.prototype.safeStyle; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ScrollPaginationWizardPane.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/ScrollPaginationWizardPane.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, HostListener, ElementRef } from '@angular/core';\r\nimport { DomSanitizer, SafeStyle } from '@angular/platform-browser';\r\nimport { PhloxAppService } from '../service/PhloxAppService.service';\r\nimport { IHasModel } from './IHasModel';\r\nimport { AbstractWizardPane } from './AbstractWizardPane';\r\nimport { IChangeable } from './IChangeable';\r\n\r\ndeclare var $: any;\r\n\r\nconst TYPE_NAME: string = \"phx-scroll-pagination-wizard-pane\";\r\n\r\nconst INDEX_Y_0: string = \"INDEX_Y_0\";\r\nconst UP: any = \"UP\";\r\nconst DOWN: any = \"DOWN\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: 'phx-scroll-pagination-wizard-pane',\r\n  template: `<div class=\"phx-scroll-pagination-wizard-pane\">\r\n\t<div class=\"left\" [style.padding-top]=\"getHeaderHeight() + 'pt'\" [style.padding-bottom]=\"getFooterHeight() + 'pt'\">\r\n\t\t<div class=\"header\" [style.height]=\"getHeaderHeight() + 'pt'\">\r\n\t\t\t<ng-template [ngIf]=\"getModel() !== null && getModel().header !== null\">\r\n\t\t\t\t<ng-template [ngIf]=\"getModel().header.type === null\">\r\n\t\t\t\t\t<div *ngIf=\"getModel().header.imageURL !== null && getModel().header.imageURL !== ''\" class=\"header-image\">\r\n\t\t\t\t\t\t<img src=\"{{getModel().header.imageURL}}\">\r\n\t\t\t\t\t</div>\r\n\t\t\t\t\t<div class=\"header-label\">{{getModel().header.label}}</div>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template [ngIf]=\"getModel().header.type !== null\">\r\n\t\t\t\t\t<phx-component-wrapper [type]=\"getModel().header.type\" [data]=\"getModel().header.model\"></phx-component-wrapper>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</ng-template>\r\n\t\t</div>\r\n\t\t<div class=\"body\">\r\n\t\t\t<ng-template [ngIf]=\"getModel() !== null && getModel().steps !== null\">\r\n\t\t\t\t<div *ngFor=\"let item of getModel().steps; let i = index;\" class=\"step\" [class.active]=\"isStepSelected(i)\">\r\n\t\t\t\t\t<ng-template [ngIf]=\"item.type === null\">\r\n\t\t\t\t\t\t<div (click)=\"stepSelected(i)\"> {{item.label}} </div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t<ng-template [ngIf]=\"item.type !== null\">\r\n\t\t\t\t\t\t<phx-component-wrapper [type]=\"item.type\" [data]=\"item.model\" (click)=\"stepSelected(i)\"></phx-component-wrapper>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t</div>\r\n\t\t\t</ng-template>\r\n\t\t</div>\r\n\t\t<div class=\"footer\" [style.height]=\"getFooterHeight() + 'pt'\">\r\n\t\t\t<ng-template [ngIf]=\"getModel() !== null && getModel().footer !== null\">\r\n\t\t\t\t<ng-template [ngIf]=\"getModel().footer.type === null\">\r\n\t\t\t\t\t{{getModel().footer.label}}\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<ng-template [ngIf]=\"getModel().footer.type !== null\">\r\n\t\t\t\t\t<phx-component-wrapper [type]=\"getModel().footer.type\" [data]=\"getModel().footer.model\"></phx-component-wrapper>\r\n\t\t\t\t</ng-template>\r\n\t\t\t</ng-template>\r\n\t\t</div>\r\n\t</div>\r\n\t<div class=\"right\">\r\n\t\t<div class=\"scrollpage\" [style.transform]=\"getSafeStyle()\">\r\n\t\t\t<div *ngFor=\"let item of getModel().steps; let i = index;\" style=\"height: 100%;\">\r\n\t\t\t\t<phx-component-wrapper [class.active]=\"isStepSelected(i)\" [type]=\"item.componentType\"\r\n\t\t\t\t\t[data]=\"getData()\" [model]=\"item.componentModel\" [dataParent]=\"this\" [handler]=\"getStepsComponentHandler()\">\r\n\t\t\t\t</phx-component-wrapper>\r\n\t\t\t</div>\r\n\t\t</div>\r\n\t</div>\r\n</div>\r\n`,\r\n})\r\n\r\n\r\nexport class ScrollPaginationWizardPane extends AbstractWizardPane implements OnInit, IHasModel, IChangeable {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  private delayMouseWheelTimer: any;\r\n  private sanitizer: DomSanitizer;\r\n  private safeStyle: SafeStyle;\r\n\r\n  constructor(appSvc: PhloxAppService, sanitizer: DomSanitizer, elementRef: ElementRef) {\r\n    super(appSvc, elementRef);\r\n    this.sanitizer = sanitizer;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n\r\n  @HostListener('mousewheel', ['$event'])\r\n  public onmousewheel(event: any): void {\r\n    clearTimeout(this.delayMouseWheelTimer);\r\n\r\n    this.delayMouseWheelTimer = null;\r\n\r\n    this.delayMouseWheelTimer = setTimeout(() => {\r\n\r\n      event = window.event || event;\r\n\r\n      let delta: number = Math.max(-1, Math.min(1, (event.wheelDelta || -event.detail)));\r\n\r\n      if (delta > -1) { // mouseWheel up\r\n        if (this.currentStep !== 0) {\r\n          this.currentStep -= 1;\r\n\r\n          if (this.currentStep === 0) {\r\n            this.setSafeStyleIndexY(INDEX_Y_0);\r\n          } else {\r\n            this.setSafeStyleIndexY(UP);\r\n          }\r\n        }\r\n      } else {   // mouseWheel down\r\n        if (this.getModel().steps.length > 0) {\r\n          let stepsIndex: number = this.getModel().steps.length - 1;\r\n\r\n          if (this.currentStep < stepsIndex) {\r\n            this.currentStep += 1;\r\n            this.setSafeStyleIndexY(DOWN);\r\n          }\r\n        }\r\n      }\r\n\r\n      event.preventDefault();\r\n    }, 250);\r\n  }\r\n\r\n  public setSafeStyleIndexY(mouseWheel: string): void {\r\n    let y: any;\r\n    let index = this.currentStep;\r\n\r\n    if (mouseWheel === DOWN || mouseWheel === UP) { // set Style translate3d =  (0, -(index * 100), 0);\r\n      y = -(index * 100);\r\n    } else if (mouseWheel === INDEX_Y_0) { // set Style translate3d =  (0, 0, 0);\r\n      y = 0;\r\n    } else { // default  set Style translate3d =  (0, 0, 0);\r\n      y = 0;\r\n    }\r\n\r\n    this.safeStyle = this.sanitizer.bypassSecurityTrustStyle(\"translate3d( 0, \" + y + \"%, 0 )\");\r\n  }\r\n\r\n  public getSafeStyle(): SafeStyle {\r\n    return this.safeStyle;\r\n  }\r\n\r\n  public showStepContent(index: number): void {\r\n    let y: any;\r\n\r\n    if (index !== 0) { // set Style translate3d =  (0, -(index * 100), 0);\r\n      y = -(index * 100);\r\n    } else if (index === 0) { // set Style translate3d =  (0, 0, 0);\r\n      y = 0;\r\n    } else { // default  set Style translate3d =  (0, 0, 0);\r\n      y = 0;\r\n    }\r\n\r\n    this.safeStyle = this.sanitizer.bypassSecurityTrustStyle(\"translate3d( 0, \" + y + \"%, 0 )\");\r\n  }\r\n\r\n  public getStepInstance(index: number): any { }\r\n}\r\n"]}