com.phloxui
Version:
PhloxUI Ng2+ Framework
327 lines (326 loc) • 33.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ElementRef, Input, Output, EventEmitter } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
import { PhloxAppService } from '../../service/PhloxAppService.service';
import { AbstractWizardPane } from './AbstractWizardPane';
import { Option } from '../../decorator/Option.decorator';
import { I18N } from '../../decorator/I18N.decorator';
import { WizardModel } from '../model/WizardModel';
const /** @type {?} */ TYPE_NAME = "phx-scroll-wizard-pane";
const /** @type {?} */ CLASS_NAME = "phx-scroll-wizard-pane-div-";
export class ScrollWizardPane extends AbstractWizardPane {
/**
* @param {?} appSvc
* @param {?} sanitizer
* @param {?} elementRef
*/
constructor(appSvc, sanitizer, elementRef) {
super(appSvc, elementRef);
this.className = CLASS_NAME;
this.sanitizer = sanitizer;
}
/**
* @return {?}
*/
ngOnInit() {
super.ngOnInit();
}
/**
* @param {?} event
* @return {?}
*/
onScroll(event) {
if (this.delayScrollTimer !== null && typeof this.delayScrollTimer !== 'undefined') {
clearTimeout(this.delayScrollTimer);
this.delayScrollTimer = null;
}
this.delayScrollTimer = setTimeout(() => {
let /** @type {?} */ anchorIndex = this.currentStep;
let /** @type {?} */ stepsCount = this.getModel().steps.length;
let /** @type {?} */ lastIndex;
if (stepsCount === 0) {
lastIndex = 0;
}
else {
lastIndex = this.getModel().steps.length - 1;
}
let /** @type {?} */ rightDom;
if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane') !== 'undefined') {
if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right') !== 'undefined') {
rightDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right');
}
}
for (let /** @type {?} */ index = 0; index < stepsCount; index++) {
let /** @type {?} */ classNameIndex = this.className + index;
let /** @type {?} */ classNameDom;
if (rightDom !== null && rightDom !== undefined) {
if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex) !== undefined) {
classNameDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex);
if (rightDom.scrollTop() === 0) {
//scrolling start
anchorIndex = 0;
break;
}
if (Math.ceil(rightDom.scrollTop() + rightDom.innerHeight()) >= rightDom[0].scrollHeight) {
//scrolling end
anchorIndex = lastIndex;
break;
}
if ((rightDom.scrollTop() + rightDom.offset().top) >= (rightDom.scrollTop() + classNameDom.offset().top)) {
// find index of stepMenu scrolling
anchorIndex = index;
}
}
}
}
this.currentStep = anchorIndex;
event.preventDefault();
}, 50);
}
/**
* @param {?} index
* @return {?}
*/
getClassName(index) {
return this.className + index;
}
/**
* @param {?} index
* @return {?}
*/
showStepContent(index) {
if (this.delayScrollClickTimer !== null && typeof this.delayScrollClickTimer !== 'undefined') {
clearTimeout(this.delayScrollClickTimer);
this.delayScrollClickTimer = null;
}
let /** @type {?} */ rightDom;
let /** @type {?} */ classNameIndex = this.className + index;
let /** @type {?} */ classNameDom;
if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane') !== 'undefined') {
if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right') !== 'undefined') {
rightDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right');
}
}
if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex) !== 'undefined') {
classNameDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex);
}
this.delayScrollClickTimer = setTimeout(() => {
if ((rightDom !== null && rightDom !== undefined) && (classNameDom !== null && classNameDom !== undefined)) {
if ((classNameDom.offset() !== null && classNameDom.offset() !== undefined) && (rightDom.scrollTop() !== null && rightDom.scrollTop() !== undefined)) {
rightDom.stop().animate({ scrollTop: (classNameDom.offset().top - rightDom.offset().top + rightDom.scrollTop()) + 0.7 }, 'slow');
}
}
}, 5);
}
}
ScrollWizardPane.TYPE_NAME = TYPE_NAME;
ScrollWizardPane.decorators = [
{ type: Component, args: [{
moduleId: module.id,
selector: TYPE_NAME,
template: `<div class="phx-scroll-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" (scroll)="onScroll($event)">
<div *ngFor="let item of getModel().steps; let i = index;" [class]="getClassName(i)">
<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>
`,
},] },
];
/** @nocollapse */
ScrollWizardPane.ctorParameters = () => [
{ type: PhloxAppService, },
{ type: DomSanitizer, },
{ type: ElementRef, },
];
ScrollWizardPane.propDecorators = {
"help": [{ type: Input },],
"dataParent": [{ type: Input },],
"ignoreParentData": [{ type: Input },],
"data": [{ type: Input },],
"ignoreParentDisabled": [{ type: Input },],
"delegateHistory": [{ type: Input },],
"onDisabled": [{ type: Input },],
"onEnabled": [{ type: Input },],
"loadingEnabled": [{ type: Input },],
"i18nKey": [{ type: Input },],
"bypass": [{ type: Input, args: ['i18nBypass',] },],
"options": [{ type: Input },],
"disabled": [{ type: Input },],
"model": [{ type: Input },],
"field": [{ type: Input },],
"loadEvent": [{ type: Output, args: ['phxLoad',] },],
"changeEvent": [{ type: Output, args: ['phxChange',] },],
"beforeChangeEvent": [{ type: Output, args: ['phxBeforeChange',] },],
};
tslib_1.__decorate([
I18N(),
Option(),
tslib_1.__metadata("design:type", Object)
], ScrollWizardPane.prototype, "help", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ScrollWizardPane.prototype, "dataParent", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ScrollWizardPane.prototype, "ignoreParentData", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Object)
], ScrollWizardPane.prototype, "data", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ScrollWizardPane.prototype, "ignoreParentDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ScrollWizardPane.prototype, "delegateHistory", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], ScrollWizardPane.prototype, "onDisabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Function)
], ScrollWizardPane.prototype, "onEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ScrollWizardPane.prototype, "loadingEnabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], ScrollWizardPane.prototype, "i18nKey", void 0);
tslib_1.__decorate([
Option('i18nBypass'),
tslib_1.__metadata("design:type", Boolean)
], ScrollWizardPane.prototype, "bypass", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", Boolean)
], ScrollWizardPane.prototype, "disabled", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", WizardModel)
], ScrollWizardPane.prototype, "model", void 0);
tslib_1.__decorate([
Option(),
tslib_1.__metadata("design:type", String)
], ScrollWizardPane.prototype, "field", void 0);
tslib_1.__decorate([
Option('load'),
tslib_1.__metadata("design:type", EventEmitter)
], ScrollWizardPane.prototype, "loadEvent", void 0);
tslib_1.__decorate([
Option('change'),
tslib_1.__metadata("design:type", EventEmitter)
], ScrollWizardPane.prototype, "changeEvent", void 0);
tslib_1.__decorate([
Option('beforeChange'),
tslib_1.__metadata("design:type", EventEmitter)
], ScrollWizardPane.prototype, "beforeChangeEvent", void 0);
function ScrollWizardPane_tsickle_Closure_declarations() {
/** @type {!Array<{type: !Function, args: (undefined|!Array<?>)}>} */
ScrollWizardPane.decorators;
/**
* @nocollapse
* @type {function(): !Array<(null|{type: ?, decorators: (undefined|!Array<{type: !Function, args: (undefined|!Array<?>)}>)})>}
*/
ScrollWizardPane.ctorParameters;
/** @type {!Object<string,!Array<{type: !Function, args: (undefined|!Array<?>)}>>} */
ScrollWizardPane.propDecorators;
/** @type {?} */
ScrollWizardPane.TYPE_NAME;
/** @type {?} */
ScrollWizardPane.prototype.help;
/** @type {?} */
ScrollWizardPane.prototype.dataParent;
/** @type {?} */
ScrollWizardPane.prototype.ignoreParentData;
/** @type {?} */
ScrollWizardPane.prototype.data;
/** @type {?} */
ScrollWizardPane.prototype.ignoreParentDisabled;
/** @type {?} */
ScrollWizardPane.prototype.delegateHistory;
/** @type {?} */
ScrollWizardPane.prototype.onDisabled;
/** @type {?} */
ScrollWizardPane.prototype.onEnabled;
/** @type {?} */
ScrollWizardPane.prototype.loadingEnabled;
/** @type {?} */
ScrollWizardPane.prototype.i18nKey;
/** @type {?} */
ScrollWizardPane.prototype.bypass;
/** @type {?} */
ScrollWizardPane.prototype.options;
/** @type {?} */
ScrollWizardPane.prototype.disabled;
/** @type {?} */
ScrollWizardPane.prototype.model;
/** @type {?} */
ScrollWizardPane.prototype.field;
/** @type {?} */
ScrollWizardPane.prototype.loadEvent;
/** @type {?} */
ScrollWizardPane.prototype.changeEvent;
/** @type {?} */
ScrollWizardPane.prototype.beforeChangeEvent;
/** @type {?} */
ScrollWizardPane.prototype.delayScrollTimer;
/** @type {?} */
ScrollWizardPane.prototype.delayScrollClickTimer;
/** @type {?} */
ScrollWizardPane.prototype.sanitizer;
/** @type {?} */
ScrollWizardPane.prototype.className;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ScrollWizardPane.component.js","sourceRoot":"ng://com.phloxui/","sources":["lib/component/dataview/ScrollWizardPane.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, HostListener, ElementRef, Input, Output, EventEmitter } 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\nimport { Option } from '../../decorator/Option.decorator';\r\nimport { I18N } from '../../decorator/I18N.decorator';\r\nimport { IHasData } from '../../component/IHasData';\r\nimport { WizardModel } from '../model/WizardModel';\r\n\r\ndeclare var $: any;\r\n\r\nconst TYPE_NAME: string = \"phx-scroll-wizard-pane\";\r\n\r\nconst CLASS_NAME: any = \"phx-scroll-wizard-pane-div-\";\r\n\r\n@Component({\r\n  moduleId: module.id,\r\n  selector: TYPE_NAME,\r\n  template: `<div class=\"phx-scroll-wizard-pane\">\n\t<div class=\"left\" [style.padding-top]=\"getHeaderHeight() + 'pt'\" [style.padding-bottom]=\"getFooterHeight() + 'pt'\">\n\t\t<div class=\"header\" [style.height]=\"getHeaderHeight() + 'pt'\">\n\t\t\t<ng-template [ngIf]=\"getModel() !== null && getModel().header !== null\">\n\t\t\t\t<ng-template [ngIf]=\"getModel().header.type === null\">\n\t\t\t\t\t<div *ngIf=\"getModel().header.imageURL !== null && getModel().header.imageURL !== ''\" class=\"header-image\">\n\t\t\t\t\t\t<img src=\"{{getModel().header.imageURL}}\">\n\t\t\t\t\t</div>\n\t\t\t\t\t<div class=\"header-label\">{{getModel().header.label}}</div>\n\t\t\t\t</ng-template>\n\t\t\t\t<ng-template [ngIf]=\"getModel().header.type !== null\">\n\t\t\t\t\t<phx-component-wrapper [type]=\"getModel().header.type\" [data]=\"getModel().header.model\"></phx-component-wrapper>\n\t\t\t\t</ng-template>\n\t\t\t</ng-template>\n\t\t</div>\n\t\t<div class=\"body\">\n\t\t\t<ng-template [ngIf]=\"getModel() !== null && getModel().steps !== null\">\n\t\t\t\t<div *ngFor=\"let item of getModel().steps; let i = index;\" class=\"step\" [class.active]=\"isStepSelected(i)\">\n\t\t\t\t\t<ng-template [ngIf]=\"item.type === null\">\n\t\t\t\t\t\t<div (click)=\"stepSelected(i)\"> {{item.label}} </div>\n\t\t\t\t\t</ng-template>\n\t\t\t\t\t<ng-template [ngIf]=\"item.type !== null\">\n\t\t\t\t\t\t<phx-component-wrapper [type]=\"item.type\" [data]=\"item.model\" (click)=\"stepSelected(i)\"></phx-component-wrapper>\n\t\t\t\t\t</ng-template>\n\t\t\t\t</div>\n\t\t\t</ng-template>\n\t\t</div>\n\t\t<div class=\"footer\" [style.height]=\"getFooterHeight() + 'pt'\">\n\t\t\t<ng-template [ngIf]=\"getModel() !== null && getModel().footer !== null\">\n\t\t\t\t<ng-template [ngIf]=\"getModel().footer.type === null\">\n\t\t\t\t\t{{getModel().footer.label}}\n\t\t\t\t</ng-template>\n\t\t\t\t<ng-template [ngIf]=\"getModel().footer.type !== null\">\n\t\t\t\t\t<phx-component-wrapper [type]=\"getModel().footer.type\" [data]=\"getModel().footer.model\"></phx-component-wrapper>\n\t\t\t\t</ng-template>\n\t\t\t</ng-template>\n\t\t</div>\n\t</div>\n\t<div class=\"right\" (scroll)=\"onScroll($event)\">\n\t\t\t<div *ngFor=\"let item of getModel().steps; let i = index;\" [class]=\"getClassName(i)\">\n\t\t\t\t<phx-component-wrapper [class.active]=\"isStepSelected(i)\" [type]=\"item.componentType\"\n\t\t\t\t\t[data]=\"getData()\" [model]=\"item.componentModel\" [dataParent]=\"this\" [handler]=\"getStepsComponentHandler()\">\n\t\t\t\t</phx-component-wrapper>\n\t\t\t</div>\n\t</div>\n</div>\n`,\n})\r\n\r\nexport class ScrollWizardPane extends AbstractWizardPane implements OnInit, IHasModel, IChangeable {\r\n\r\n  public static readonly TYPE_NAME: string = TYPE_NAME;\r\n\r\n  // Re-declare field to declare ng @Input.\r\n  // --- from AbstractHasDataHelp\r\n  @Input()\r\n  @I18N()\r\n  @Option()\r\n  protected help: any;\r\n  // --- from AbstractHasData\r\n  @Input()\r\n  @Option()\r\n  protected dataParent: IHasData;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentData: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected data: any;\r\n  @Input()\r\n  @Option()\r\n  protected ignoreParentDisabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected delegateHistory: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected onDisabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected onEnabled: Function;\r\n  @Input()\r\n  @Option()\r\n  protected loadingEnabled: boolean;\r\n  @Input()\r\n  @Option()\r\n  protected i18nKey: string;\r\n  @Input('i18nBypass')\r\n  @Option('i18nBypass')\r\n  protected bypass: boolean;\r\n  @Input()\r\n  protected options: any;\r\n  @Input()\r\n  @Option()\r\n  protected disabled: boolean;\r\n  // --- from AbstractWizardPane\r\n  @Input()\r\n  @Option()\r\n  protected model: WizardModel;\r\n  // --- from AbstractDataView\r\n  @Input()\r\n  @Option()\r\n  protected field: string;\r\n\r\n  // Re-declare field to declare ng @Output.\r\n  // --- from AbstractHasData\r\n  @Output('phxLoad')\r\n  @Option('load')\r\n  protected loadEvent: EventEmitter<any>;\r\n  // --- from AbstractWizardPane\r\n  @Output('phxChange')\r\n  @Option('change')\r\n  protected changeEvent: EventEmitter<any>;\r\n  @Output('phxBeforeChange')\r\n  @Option('beforeChange')\r\n  protected beforeChangeEvent: EventEmitter<any>;\r\n\r\n  private delayScrollTimer: any;\r\n  private delayScrollClickTimer: any;\r\n  private sanitizer: DomSanitizer;\n\n  private className: string = CLASS_NAME;\n\n  constructor(appSvc: PhloxAppService, sanitizer: DomSanitizer, elementRef: ElementRef) {\r\n    super(appSvc, elementRef);\r\n\r\n    this.sanitizer = sanitizer;\r\n  }\r\n\r\n  public ngOnInit(): void {\r\n    super.ngOnInit();\r\n  }\r\n\n  public onScroll(event: any): void {\n    if (this.delayScrollTimer !== null && typeof this.delayScrollTimer !== 'undefined') {\n      clearTimeout(this.delayScrollTimer);\n      this.delayScrollTimer = null;\n    }\n\n    this.delayScrollTimer = setTimeout(() => {\n      let anchorIndex: any = this.currentStep;\n      let stepsCount: number = this.getModel().steps.length;\n      let lastIndex: number;\n\n      if (stepsCount === 0) {\n        lastIndex = 0;\n      } else {\n        lastIndex = this.getModel().steps.length - 1;\n      }\n\n      let rightDom: any;\n\n      if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane') !== 'undefined') {\n        if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right') !== 'undefined') {\n          rightDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right');\n        }\n      }\n\n      for (let index = 0; index < stepsCount; index++) {\n        let classNameIndex: any = this.className + index;\n        let classNameDom: any;\n\n        if (rightDom !== null && rightDom !== undefined) {\n          if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex) !== undefined) {\n            classNameDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex);\n\n            if (rightDom.scrollTop() === 0) { //scrolling start\n              anchorIndex = 0;\n              break;\n            }\n\n            if (Math.ceil(rightDom.scrollTop() + rightDom.innerHeight()) >= rightDom[0].scrollHeight) { //scrolling end\n              anchorIndex = lastIndex;\n              break;\n            }\n\n            if ((rightDom.scrollTop() + rightDom.offset().top) >= (rightDom.scrollTop() + classNameDom.offset().top)) { // find index of stepMenu  scrolling\n              anchorIndex = index;\n            }\n          }\n        }\n      }\n\n      this.currentStep = anchorIndex;\n\n      event.preventDefault();\n    }, 50);\n  }\n\n  public getClassName(index: number): string {\n    return this.className + index;\n  }\n\n  public showStepContent(index: number): void {\r\n    if (this.delayScrollClickTimer !== null && typeof this.delayScrollClickTimer !== 'undefined') {\r\n      clearTimeout(this.delayScrollClickTimer);\r\n      this.delayScrollClickTimer = null;\r\n    }\r\n\r\n    let rightDom: any;\r\n    let classNameIndex: any = this.className + index;\r\n    let classNameDom: any;\r\n\r\n    if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane') !== 'undefined') {\r\n      if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right') !== 'undefined') {\r\n        rightDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right');\r\n      }\r\n    }\r\n\r\n    if (typeof $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex) !== 'undefined') {\r\n      classNameDom = $(this.elementRef.nativeElement).find('.phx-scroll-wizard-pane').find('.right').find('.' + classNameIndex);\r\n    }\r\n\r\n    this.delayScrollClickTimer = setTimeout(() => {\r\n      if ((rightDom !== null && rightDom !== undefined) && (classNameDom !== null && classNameDom !== undefined)) {\r\n        if ((classNameDom.offset() !== null && classNameDom.offset() !== undefined) && (rightDom.scrollTop() !== null && rightDom.scrollTop() !== undefined)) {\r\n          rightDom.stop().animate({ scrollTop: (classNameDom.offset().top - rightDom.offset().top + rightDom.scrollTop()) + 0.7 }, 'slow');\r\n        }\r\n      }\r\n    }, 5);\r\n  }\r\n}\r\n"]}