@colijnit/corecomponents_v12 12.2.13 → 12.2.14
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/bundles/colijnit-corecomponents_v12.umd.js +702 -260
- package/bundles/colijnit-corecomponents_v12.umd.js.map +1 -1
- package/colijnit-corecomponents_v12.d.ts +9 -5
- package/colijnit-corecomponents_v12.metadata.json +1 -1
- package/esm2015/colijnit-corecomponents_v12.js +10 -6
- package/esm2015/lib/components/base/dialog-base.component.js +6 -0
- package/esm2015/lib/components/core-dialog/confirmation-dialog/confirmation-dialog.component.js +79 -0
- package/esm2015/lib/components/core-dialog/core-dialog.module.js +39 -0
- package/esm2015/lib/components/core-dialog/core-dialog.service.js +67 -0
- package/esm2015/lib/components/core-dialog/core-dynamic-component.service.js +93 -0
- package/esm2015/lib/components/input-scanner/bar-code-scanner.js +23 -0
- package/esm2015/lib/components/input-scanner/input-scanner.component.js +69 -0
- package/esm2015/lib/components/input-scanner/input-scanner.module.js +21 -0
- package/esm2015/lib/components/input-scanner/scanner.service.js +28 -0
- package/esm2015/lib/components/input-search/input-search.component.js +2 -1
- package/esm2015/lib/components/input-text/input-text.component.js +2 -1
- package/esm2015/lib/components/simple-grid/simple-grid-cell.component.js +37 -27
- package/esm2015/lib/components/simple-grid/simple-grid.component.js +55 -35
- package/esm2015/lib/components/simple-grid/simple-grid.module.js +4 -2
- package/esm2015/lib/core/enum/core-components-icon.enum.js +2 -1
- package/esm2015/lib/core/model/core-components-icon-svg.js +2 -1
- package/esm2015/lib/interfaces/dialog-response.interface.js +2 -0
- package/esm2015/lib/interfaces/scanner-input.interface.js +2 -0
- package/esm2015/lib/model/enum/app-button-type.enum.js +11 -0
- package/esm2015/lib/model/enum/app-popup-type.enum.js +8 -0
- package/esm2015/public-api.js +16 -11
- package/fesm2015/colijnit-corecomponents_v12.js +715 -270
- package/fesm2015/colijnit-corecomponents_v12.js.map +1 -1
- package/lib/components/base/dialog-base.component.d.ts +4 -0
- package/lib/components/core-dialog/confirmation-dialog/confirmation-dialog.component.d.ts +20 -0
- package/lib/components/core-dialog/confirmation-dialog/style/_layout.scss +30 -0
- package/lib/components/core-dialog/confirmation-dialog/style/_material-definition.scss +2 -0
- package/lib/components/core-dialog/confirmation-dialog/style/_theme.scss +6 -0
- package/lib/components/core-dialog/confirmation-dialog/style/material.scss +4 -0
- package/lib/components/core-dialog/core-dialog.module.d.ts +4 -0
- package/lib/components/core-dialog/core-dialog.service.d.ts +15 -0
- package/lib/components/core-dialog/core-dynamic-component.service.d.ts +12 -0
- package/lib/components/core-dialog/style/_layout.scss +6 -0
- package/lib/components/core-dialog/style/_material-definition.scss +0 -0
- package/lib/components/core-dialog/style/_theme.scss +6 -0
- package/lib/components/core-dialog/style/material.scss +4 -0
- package/lib/components/input-scanner/bar-code-scanner.d.ts +7 -0
- package/lib/components/input-scanner/input-scanner.component.d.ts +23 -0
- package/lib/components/input-scanner/input-scanner.module.d.ts +2 -0
- package/lib/components/input-scanner/scanner.service.d.ts +11 -0
- package/lib/components/input-scanner/style/_layout.scss +4 -0
- package/lib/components/input-scanner/style/_material-definition.scss +0 -0
- package/lib/components/input-scanner/style/_theme.scss +4 -0
- package/lib/components/input-scanner/style/material.scss +4 -0
- package/lib/components/simple-grid/simple-grid-cell.component.d.ts +4 -2
- package/lib/components/simple-grid/simple-grid.component.d.ts +5 -3
- package/lib/components/simple-grid/style/_layout.scss +30 -4
- package/lib/components/simple-grid/style/_material-definition.scss +9 -2
- package/lib/components/simple-grid/style/_theme.scss +3 -0
- package/lib/core/enum/core-components-icon.enum.d.ts +1 -0
- package/lib/interfaces/dialog-response.interface.d.ts +6 -0
- package/lib/interfaces/scanner-input.interface.d.ts +3 -0
- package/lib/model/enum/app-button-type.enum.d.ts +9 -0
- package/lib/model/enum/app-popup-type.enum.d.ts +6 -0
- package/package.json +1 -1
- package/public-api.d.ts +15 -10
|
@@ -142,6 +142,7 @@ InputTextComponent.decorators = [
|
|
|
142
142
|
[required]="required"
|
|
143
143
|
(ngModelChange)="modelChange.emit($event)"
|
|
144
144
|
(keydown)="digitsOnly ? excludeNonDigitChars($event) : true"
|
|
145
|
+
(keyup)="keyUp.emit($event)"
|
|
145
146
|
>
|
|
146
147
|
<ng-container *ngIf="useContent">
|
|
147
148
|
<div class="input-content-wrapper">
|
|
@@ -220,4 +221,4 @@ InputTextComponent.propDecorators = {
|
|
|
220
221
|
handleDocumentMouseUp: [{ type: HostListener, args: ['document:mouseup', ['$event'],] }],
|
|
221
222
|
model: [{ type: Input }]
|
|
222
223
|
};
|
|
223
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-text/input-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ElementRef, EventEmitter,\r\n  forwardRef,\r\n  HostBinding, HostListener,\r\n  Input,\r\n  Optional, Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\r\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\r\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\r\nimport {FormComponent} from '../form/form.component';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {OverlayService} from '../../service/overlay.service';\r\n\r\n@Component({\r\n  selector: 'co-input-text',\r\n  template: `\r\n    <div class=\"input-text-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n      <co-icon *ngIf=\"leftIcon || leftIconData\" class=\"input-text-left-icon\" [icon]=\"leftIcon\" [iconData]=\"leftIconData\"\r\n               (click)=\"handleLeftIconClick($event)\" (mousedown)=\"handleLeftIconMouseDown($event)\"\r\n               (mouseup)=\"handleLeftIconMouseUp($event)\"></co-icon>\r\n      <div *ngIf=\"leftIcon || leftIconData\" class=\"spacer left-icon\"></div>\r\n      <div class=\"input-wrapper\">\r\n        <label *ngIf=\"showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)\"\r\n               [textContent]=\"placeholder\"></label>\r\n        <input #input\r\n               [class.input-input-hidden]=\"useContent\"\r\n               [ngClass]=\"align\"\r\n               [type]=\"digitsOnly ? 'number' : type\"\r\n               [pattern]=\"type === 'date' ? pattern : undefined\"\r\n               [ngModel]=\"model\"\r\n               [min]=\"(type === 'number' || type === 'date') && this.min ? this.min : undefined\"\r\n               [max]=\"(type === 'number' || type === 'date') && this.max ? this.max : undefined\"\r\n               [readonly]=\"readonly\"\r\n               [required]=\"required\"\r\n               (ngModelChange)=\"modelChange.emit($event)\"\r\n               (keydown)=\"digitsOnly ? excludeNonDigitChars($event) : true\"\r\n        >\r\n        <ng-container *ngIf=\"useContent\">\r\n          <div class=\"input-content-wrapper\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n        </ng-container>\r\n        <co-icon [class.show]=\"showClearButton && hasValue && focused && !readonly\" class=\"input-text-clear-button\" [icon]=\"icons.CrossSkinny\" (click)=\"clearInput($event)\"></co-icon>\r\n        <div class=\"required-indicator\"></div>\r\n      </div>\r\n      <div *ngIf=\"rightIcon || rightIconData\" class=\"spacer right-icon\"></div>\r\n      <co-icon *ngIf=\"rightIcon || rightIconData\" class=\"input-text-right-icon\" [icon]=\"rightIcon\" [iconData]=\"rightIconData\"\r\n               (click)=\"handleRightIconClick($event)\" (mousedown)=\"handleRightIconMouseDown($event)\" (mouseup)=\"handleRightIconMouseUp($event)\"></co-icon>\r\n    </div>\r\n    <!--\r\n            <co-commit-buttons *ngIf=\"showSaveCancel && focused && canSaveOrCancel\"\r\n                               [committing]=\"committing\"\r\n                               [commitFinished]=\"commitFinished\"\r\n                               (commitClick)=\"commitClick($event)\"\r\n                               (cancelClick)=\"cancelClick($event)\"\r\n            >\r\n            </co-commit-buttons>\r\n    -->\r\n  `,\r\n  providers: [\r\n    OverlayService, {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => InputTextComponent)\r\n    }, {\r\n      provide: BaseInputComponent,\r\n      useExisting: InputTextComponent\r\n    }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputTextComponent extends BaseInputComponent<any> implements AfterViewInit {\r\n\r\n  @Input()\r\n  public useContent: boolean = false;\r\n\r\n  @Input()\r\n  public placeholder: string = '';\r\n\r\n  @Input()\r\n  public align: string = 'left';\r\n\r\n  @Input()\r\n  public type: string = 'text';\r\n\r\n  @Input()\r\n  public min: number;\r\n\r\n  @Input()\r\n  public max: number;\r\n\r\n  @Input()\r\n  public pattern: string = 'dd-MM-yyyy';\r\n\r\n  @Input()\r\n  public digitsOnly: boolean = false;\r\n\r\n  @Input()\r\n  public excludePlusMinus: boolean = true;\r\n\r\n  @Input()\r\n  public showClearButton: boolean = true;\r\n\r\n  @Input()\r\n  public keyDownWhiteList: KeyboardCode[];\r\n\r\n  @Input()\r\n  public showPlaceholderOnFocus: boolean = true;\r\n\r\n  @Input()\r\n  public leftIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public rightIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public leftIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public rightIconData: SafeHtml | undefined;\r\n\r\n  @HostBinding('class.no-style')\r\n  @Input()\r\n  public noStyle: boolean = false;\r\n\r\n  @Input()\r\n  @HostBinding('class.hide-arrows')\r\n  public hideArrowButtons: boolean = false;\r\n\r\n  @HostBinding(\"class.isDate\")\r\n  public get isDate(): boolean {\r\n    return this.type === \"date\";\r\n  }\r\n\r\n  @Output()\r\n  public leftIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public clearIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding('class.co-input-text')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostBinding('class.has-left-icon')\r\n  public get hasLeftIcon(): boolean {\r\n    return this.leftIcon !== undefined && this.leftIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-right-icon')\r\n  public get hasRightIcon(): boolean {\r\n    return this.rightIcon !== undefined && this.rightIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-own-label')\r\n  public hasOwnLabel: boolean = true;\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  public handleDocumentMouseUp(event: MouseEvent) {\r\n    if (this._isLeftIconMouseDown) {\r\n      this.leftIconMouseUp.next(event);\r\n    }\r\n    if (this._isRightIconMouseDown) {\r\n      this.rightIconMouseUp.next(event);\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set model(value: any) {\r\n    if (this.type === 'number' && !isNaN(value)) {\r\n      if (this.min && value < this.min || this.max && value > this.max) {\r\n        super.model = this._initialModel;\r\n      } else {\r\n        super.model = value;\r\n      }\r\n    } else {\r\n      super.model = value;\r\n    }\r\n  }\r\n\r\n  public get model() {\r\n    return super.model;\r\n  }\r\n\r\n  private _isLeftIconMouseDown: boolean = false;\r\n  private _isRightIconMouseDown: boolean = false;\r\n\r\n  constructor(\r\n    @Optional() public formComponent: FormComponent,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected overlayService: OverlayService,\r\n    protected componentFactoryResolver: ComponentFactoryResolver,\r\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n    protected ngZoneWrapper?: NgZoneWrapperService,\r\n    public elementRef?: ElementRef,\r\n  ) {\r\n    super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\r\n    super._markAsOnPush();\r\n  }\r\n\r\n  // exclude some non-digit characters, since input type 'number' still allows the characters -, + and e\r\n  public excludeNonDigitChars(event): boolean {\r\n    const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];\r\n\r\n    return !excludedKeys.includes(event.key);\r\n  }\r\n\r\n  public handleLeftIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.leftIconClick.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = true;\r\n    this.leftIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = false;\r\n    this.leftIconMouseUp.emit(event);\r\n  }\r\n\r\n  public handleRightIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.rightIconClick.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = true;\r\n    this.rightIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = false;\r\n    this.rightIconMouseUp.emit(event);\r\n  }\r\n\r\n  public clearInput(event: MouseEvent) {\r\n    this.setModel(null);\r\n    this.clearIconClick.emit(event);\r\n  }\r\n}\r\n"]}
|
|
224
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/input-text/input-text.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ComponentFactoryResolver,\r\n  ElementRef, EventEmitter,\r\n  forwardRef,\r\n  HostBinding, HostListener,\r\n  Input,\r\n  Optional, Output,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport {BaseInputComponent} from '../base/base-input.component';\r\nimport {SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME} from '../../interfaces/screen-config-adapter-component-interface-name';\r\nimport {CoreComponentsIcon} from '../../core/enum/core-components-icon.enum';\r\nimport {KeyboardCode} from '../../core/enum/keyboard-code.enum';\r\nimport {FormInputUserModelChangeListenerService} from '../../core/service/form-input-user-change-listener.service';\r\nimport {NgZoneWrapperService} from '../../core/service/ng-zone-wrapper.service';\r\nimport {FormComponent} from '../form/form.component';\r\nimport {SafeHtml} from '@angular/platform-browser';\r\nimport {OverlayService} from '../../service/overlay.service';\r\n\r\n@Component({\r\n  selector: 'co-input-text',\r\n  template: `\r\n    <div class=\"input-text-wrapper\" overlayParent #parentForOverlay=\"overlayParent\">\r\n      <co-icon *ngIf=\"leftIcon || leftIconData\" class=\"input-text-left-icon\" [icon]=\"leftIcon\" [iconData]=\"leftIconData\"\r\n               (click)=\"handleLeftIconClick($event)\" (mousedown)=\"handleLeftIconMouseDown($event)\"\r\n               (mouseup)=\"handleLeftIconMouseUp($event)\"></co-icon>\r\n      <div *ngIf=\"leftIcon || leftIconData\" class=\"spacer left-icon\"></div>\r\n      <div class=\"input-wrapper\">\r\n        <label *ngIf=\"showPlaceholderOnFocus || (!showPlaceholderOnFocus && !hasValue && !focused)\"\r\n               [textContent]=\"placeholder\"></label>\r\n        <input #input\r\n               [class.input-input-hidden]=\"useContent\"\r\n               [ngClass]=\"align\"\r\n               [type]=\"digitsOnly ? 'number' : type\"\r\n               [pattern]=\"type === 'date' ? pattern : undefined\"\r\n               [ngModel]=\"model\"\r\n               [min]=\"(type === 'number' || type === 'date') && this.min ? this.min : undefined\"\r\n               [max]=\"(type === 'number' || type === 'date') && this.max ? this.max : undefined\"\r\n               [readonly]=\"readonly\"\r\n               [required]=\"required\"\r\n               (ngModelChange)=\"modelChange.emit($event)\"\r\n               (keydown)=\"digitsOnly ? excludeNonDigitChars($event) : true\"\r\n               (keyup)=\"keyUp.emit($event)\"\r\n        >\r\n        <ng-container *ngIf=\"useContent\">\r\n          <div class=\"input-content-wrapper\">\r\n            <ng-content></ng-content>\r\n          </div>\r\n        </ng-container>\r\n        <co-icon [class.show]=\"showClearButton && hasValue && focused && !readonly\" class=\"input-text-clear-button\" [icon]=\"icons.CrossSkinny\" (click)=\"clearInput($event)\"></co-icon>\r\n        <div class=\"required-indicator\"></div>\r\n      </div>\r\n      <div *ngIf=\"rightIcon || rightIconData\" class=\"spacer right-icon\"></div>\r\n      <co-icon *ngIf=\"rightIcon || rightIconData\" class=\"input-text-right-icon\" [icon]=\"rightIcon\" [iconData]=\"rightIconData\"\r\n               (click)=\"handleRightIconClick($event)\" (mousedown)=\"handleRightIconMouseDown($event)\" (mouseup)=\"handleRightIconMouseUp($event)\"></co-icon>\r\n    </div>\r\n    <!--\r\n            <co-commit-buttons *ngIf=\"showSaveCancel && focused && canSaveOrCancel\"\r\n                               [committing]=\"committing\"\r\n                               [commitFinished]=\"commitFinished\"\r\n                               (commitClick)=\"commitClick($event)\"\r\n                               (cancelClick)=\"cancelClick($event)\"\r\n            >\r\n            </co-commit-buttons>\r\n    -->\r\n  `,\r\n  providers: [\r\n    OverlayService, {\r\n      provide: SCREEN_CONFIG_ADAPTER_COMPONENT_INTERFACE_NAME,\r\n      useExisting: forwardRef(() => InputTextComponent)\r\n    }, {\r\n      provide: BaseInputComponent,\r\n      useExisting: InputTextComponent\r\n    }],\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class InputTextComponent extends BaseInputComponent<any> implements AfterViewInit {\r\n\r\n  @Input()\r\n  public useContent: boolean = false;\r\n\r\n  @Input()\r\n  public placeholder: string = '';\r\n\r\n  @Input()\r\n  public align: string = 'left';\r\n\r\n  @Input()\r\n  public type: string = 'text';\r\n\r\n  @Input()\r\n  public min: number;\r\n\r\n  @Input()\r\n  public max: number;\r\n\r\n  @Input()\r\n  public pattern: string = 'dd-MM-yyyy';\r\n\r\n  @Input()\r\n  public digitsOnly: boolean = false;\r\n\r\n  @Input()\r\n  public excludePlusMinus: boolean = true;\r\n\r\n  @Input()\r\n  public showClearButton: boolean = true;\r\n\r\n  @Input()\r\n  public keyDownWhiteList: KeyboardCode[];\r\n\r\n  @Input()\r\n  public showPlaceholderOnFocus: boolean = true;\r\n\r\n  @Input()\r\n  public leftIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public rightIcon: CoreComponentsIcon;\r\n\r\n  @Input()\r\n  public leftIconData: SafeHtml | undefined;\r\n\r\n  @Input()\r\n  public rightIconData: SafeHtml | undefined;\r\n\r\n  @HostBinding('class.no-style')\r\n  @Input()\r\n  public noStyle: boolean = false;\r\n\r\n  @Input()\r\n  @HostBinding('class.hide-arrows')\r\n  public hideArrowButtons: boolean = false;\r\n\r\n  @HostBinding(\"class.isDate\")\r\n  public get isDate(): boolean {\r\n    return this.type === \"date\";\r\n  }\r\n\r\n  @Output()\r\n  public leftIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public leftIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseDown: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public rightIconMouseUp: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @Output()\r\n  public clearIconClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding('class.co-input-text')\r\n  public showClass() {\r\n    return true;\r\n  }\r\n\r\n  @HostBinding('class.has-left-icon')\r\n  public get hasLeftIcon(): boolean {\r\n    return this.leftIcon !== undefined && this.leftIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-right-icon')\r\n  public get hasRightIcon(): boolean {\r\n    return this.rightIcon !== undefined && this.rightIcon !== null;\r\n  }\r\n\r\n  @HostBinding('class.has-own-label')\r\n  public hasOwnLabel: boolean = true;\r\n\r\n  @HostListener('document:mouseup', ['$event'])\r\n  public handleDocumentMouseUp(event: MouseEvent) {\r\n    if (this._isLeftIconMouseDown) {\r\n      this.leftIconMouseUp.next(event);\r\n    }\r\n    if (this._isRightIconMouseDown) {\r\n      this.rightIconMouseUp.next(event);\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public set model(value: any) {\r\n    if (this.type === 'number' && !isNaN(value)) {\r\n      if (this.min && value < this.min || this.max && value > this.max) {\r\n        super.model = this._initialModel;\r\n      } else {\r\n        super.model = value;\r\n      }\r\n    } else {\r\n      super.model = value;\r\n    }\r\n  }\r\n\r\n  public get model() {\r\n    return super.model;\r\n  }\r\n\r\n  private _isLeftIconMouseDown: boolean = false;\r\n  private _isRightIconMouseDown: boolean = false;\r\n\r\n  constructor(\r\n    @Optional() public formComponent: FormComponent,\r\n    protected changeDetector: ChangeDetectorRef,\r\n    protected overlayService: OverlayService,\r\n    protected componentFactoryResolver: ComponentFactoryResolver,\r\n    protected formUserChangeListener?: FormInputUserModelChangeListenerService,\r\n    protected ngZoneWrapper?: NgZoneWrapperService,\r\n    public elementRef?: ElementRef,\r\n  ) {\r\n    super(changeDetector, componentFactoryResolver, overlayService, formUserChangeListener, ngZoneWrapper, elementRef);\r\n    super._markAsOnPush();\r\n  }\r\n\r\n  // exclude some non-digit characters, since input type 'number' still allows the characters -, + and e\r\n  public excludeNonDigitChars(event): boolean {\r\n    const excludedKeys = this.excludePlusMinus ? ['e', '-', '+'] : ['e'];\r\n\r\n    return !excludedKeys.includes(event.key);\r\n  }\r\n\r\n  public handleLeftIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.leftIconClick.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = true;\r\n    this.leftIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleLeftIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isLeftIconMouseDown = false;\r\n    this.leftIconMouseUp.emit(event);\r\n  }\r\n\r\n  public handleRightIconClick(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this.rightIconClick.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseDown(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = true;\r\n    this.rightIconMouseDown.emit(event);\r\n  }\r\n\r\n  public handleRightIconMouseUp(event: MouseEvent): void {\r\n    event.preventDefault();\r\n    event.stopPropagation();\r\n    this._isRightIconMouseDown = false;\r\n    this.rightIconMouseUp.emit(event);\r\n  }\r\n\r\n  public clearInput(event: MouseEvent) {\r\n    this.setModel(null);\r\n    this.clearIconClick.emit(event);\r\n  }\r\n}\r\n"]}
|
|
@@ -5,11 +5,17 @@ export class SimpleGridCellComponent {
|
|
|
5
5
|
constructor(_changeDetector) {
|
|
6
6
|
this._changeDetector = _changeDetector;
|
|
7
7
|
this.defaultTextAlign = ColumnAlign.Left;
|
|
8
|
-
this.
|
|
8
|
+
this._editMode = false;
|
|
9
9
|
this.cellClick = new EventEmitter();
|
|
10
10
|
this._fieldEditMode = false;
|
|
11
11
|
this._focused = false;
|
|
12
12
|
}
|
|
13
|
+
get editMode() {
|
|
14
|
+
return this._editMode;
|
|
15
|
+
}
|
|
16
|
+
set editMode(value) {
|
|
17
|
+
this._editMode = value;
|
|
18
|
+
}
|
|
13
19
|
set editTemplateContent(template) {
|
|
14
20
|
if (template) {
|
|
15
21
|
this._editTemplate = template;
|
|
@@ -44,7 +50,7 @@ export class SimpleGridCellComponent {
|
|
|
44
50
|
}
|
|
45
51
|
}
|
|
46
52
|
_setFocusComponent() {
|
|
47
|
-
if (this.
|
|
53
|
+
if (this._editMode && this.fieldEditMode) {
|
|
48
54
|
const element = this._getElement();
|
|
49
55
|
if (element) {
|
|
50
56
|
const focusEvent = this._createNewEvent(element, 'focus');
|
|
@@ -115,31 +121,35 @@ SimpleGridCellComponent.decorators = [
|
|
|
115
121
|
{ type: Component, args: [{
|
|
116
122
|
selector: "co-simple-grid-cell",
|
|
117
123
|
template: `
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
124
|
+
<div class="simple-grid-column-cell-value" [ngClass]="column.textAlign ? column.textAlign : defaultTextAlign">
|
|
125
|
+
<ng-container *ngIf="editMode; else noInlineEdit">
|
|
126
|
+
<div class="simple-grid-column-cell-field">
|
|
127
|
+
<ng-container #editTemplate *ngIf="column.editTemplate; else noEditTemplate"
|
|
128
|
+
[ngTemplateOutlet]="column.editTemplate"
|
|
129
|
+
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
130
|
+
<ng-template #noEditTemplate>
|
|
131
|
+
<ng-container *ngIf="column.template; else noTemplate">
|
|
132
|
+
<ng-container [ngTemplateOutlet]="column.template"
|
|
133
|
+
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
134
|
+
</ng-container>
|
|
135
|
+
<ng-template #noTemplate>
|
|
136
|
+
<co-input-text [(model)]="row[column.field]" [required]="column.required"></co-input-text>
|
|
137
|
+
</ng-template>
|
|
138
|
+
</ng-template>
|
|
139
|
+
</div>
|
|
127
140
|
</ng-container>
|
|
128
|
-
<ng-template #
|
|
129
|
-
|
|
141
|
+
<ng-template #noInlineEdit>
|
|
142
|
+
<div class="simple-grid-column-cell-field">
|
|
143
|
+
<ng-container *ngIf="column.template; else noTemplate">
|
|
144
|
+
<ng-container [ngTemplateOutlet]="column.template"
|
|
145
|
+
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
146
|
+
</ng-container>
|
|
147
|
+
<ng-template #noTemplate>
|
|
148
|
+
<span [textContent]="column.getFieldValue(row[column.field])"></span>
|
|
149
|
+
</ng-template>
|
|
150
|
+
</div>
|
|
130
151
|
</ng-template>
|
|
131
|
-
|
|
132
|
-
</ng-container>
|
|
133
|
-
<ng-template #noInlineEdit>
|
|
134
|
-
<ng-container *ngIf="column.template; else noTemplate">
|
|
135
|
-
<ng-container [ngTemplateOutlet]="column.template"
|
|
136
|
-
[ngTemplateOutletContext]="{value: row[column.field], row: row}"></ng-container>
|
|
137
|
-
</ng-container>
|
|
138
|
-
<ng-template #noTemplate>
|
|
139
|
-
<span [textContent]="column.getFieldValue(row[column.field])"></span>
|
|
140
|
-
</ng-template>
|
|
141
|
-
</ng-template>
|
|
142
|
-
</div>
|
|
152
|
+
</div>
|
|
143
153
|
`,
|
|
144
154
|
encapsulation: ViewEncapsulation.None
|
|
145
155
|
},] }
|
|
@@ -148,15 +158,15 @@ SimpleGridCellComponent.ctorParameters = () => [
|
|
|
148
158
|
{ type: ChangeDetectorRef }
|
|
149
159
|
];
|
|
150
160
|
SimpleGridCellComponent.propDecorators = {
|
|
161
|
+
editMode: [{ type: Input }],
|
|
151
162
|
editTemplateContent: [{ type: ViewChild, args: ["editTemplate", { read: BaseInputComponent },] }],
|
|
152
163
|
noEditTemplateContent: [{ type: ViewChild, args: ["noEditTemplate",] }],
|
|
153
164
|
noTemplateContent: [{ type: ViewChild, args: ["noTemplate",] }],
|
|
154
165
|
column: [{ type: Input }],
|
|
155
166
|
row: [{ type: Input }],
|
|
156
|
-
editMode: [{ type: Input }],
|
|
157
167
|
fieldEditMode: [{ type: Input }],
|
|
158
168
|
cellClick: [{ type: Output }],
|
|
159
169
|
showClass: [{ type: HostBinding, args: ["class.co-simple-grid-cell",] }],
|
|
160
170
|
handleClick: [{ type: HostListener, args: ['click', ['$event'],] }]
|
|
161
171
|
};
|
|
162
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid-cell.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid-cell.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EACjB,SAAS,EACT,YAAY,EACZ,WAAW,EACX,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,SAAS,EACT,iBAAiB,EAClB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,WAAW,EAA6B,MAAM,gCAAgC,CAAC;AACxF,OAAO,EAAE,kBAAkB,EAAE,MAAM,8BAA8B,CAAC;AAiClE,MAAM,OAAO,uBAAuB;IAgElC,YAAoB,eAAkC;QAAlC,oBAAe,GAAf,eAAe,CAAmB;QA/DtC,qBAAgB,GAAgB,WAAW,CAAC,IAAI,CAAC;QA8B1D,aAAQ,GAAY,KAAK,CAAC;QAa1B,cAAS,GAAuB,IAAI,YAAY,EAAQ,CAAC;QAcxD,mBAAc,GAAY,KAAK,CAAC;QAChC,aAAQ,GAAY,KAAK,CAAC;IAMlC,CAAC;IA9DD,IAA2D,mBAAmB,CAAC,QAAQ;QACrF,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC;YAC9B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAAiC,qBAAqB,CAAC,QAAQ;QAC7D,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC1B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAED,IAA6B,iBAAiB,CAAC,QAAQ;QACrD,IAAI,QAAQ,EAAE;YACZ,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC;YAC/B,IAAI,CAAC,kBAAkB,EAAE,CAAC;SAC3B;IACH,CAAC;IAWD,IACW,aAAa,CAAC,KAAc;QACrC,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;QAC5B,IAAI,CAAC,kBAAkB,EAAE,CAAC;IAC5B,CAAC;IAED,IAAW,aAAa;QACtB,OAAO,IAAI,CAAC,cAAc,CAAC;IAC7B,CAAC;IAMM,SAAS;QACd,OAAO,IAAI,CAAC;IACd,CAAC;IAGM,WAAW,CAAC,KAAiB;QAClC,IAAI,IAAI,CAAC,MAAM,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,QAAQ,EAAE;YACxC,IAAI,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;SACvB;IACH,CAAC;IAWO,kBAAkB;QACxB,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,aAAa,EAAE;YACvC,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;YACnC,IAAI,OAAO,EAAE;gBACX,MAAM,UAAU,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC;gBAC1D,OAAO,CAAC,KAAK,EAAE,CAAC;gBAChB,OAAO,CAAC,aAAa,CAAC,UAAU,CAAC,CAAC;gBAClC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;aACtB;SACF;aAAM;YACL,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,MAAM,OAAO,GAAG,IAAI,CAAC,WAAW,EAAE,CAAC;gBACnC,IAAI,OAAO,EAAE;oBACX,MAAM,SAAS,GAAG,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;oBACxD,OAAO,CAAC,IAAI,EAAE,CAAC;oBACf,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC;iBAClC;gBACD,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;aACvB;SACF;QACD,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAEO,kBAAkB,CAAC,MAAW;QACpC,IAAI,MAAM,EAAE;YACV,MAAM,UAAU,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,OAAO,CAAC,CAAC,CAAC;YACpE,MAAM,eAAe,GAAG,KAAK,CAAC,IAAI,CAAC,MAAM,CAAC,oBAAoB,CAAC,UAAU,CAAC,CAAC,CAAC;YAC5E,eAAe,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,CAAC;YAC7C,IAAI,UAAU,CAAC,MAAM,GAAG,CAAC,EAAE;gBACzB,OAAO,UAAU,CAAC,CAAC,CAAC,CAAC;aACtB;SACF;IACH,CAAC;IAEO,eAAe,CAAC,OAAY,EAAE,SAAiB;QACrD,IAAI,KAAK,CAAC;QACV,IAAI,aAAa,IAAI,QAAQ,EAAE;YAC7B,KAAK,GAAG,QAAQ,CAAC,WAAW,CAAC,OAAO,CAAC,CAAC;YACtC,KAAK,CAAC,SAAS,CAAC,SAAS,EAAE,IAAI,EAAE,IAAI,CAAC,CAAC;SACxC;aAAM,IAAI,OAAO,IAAI,MAAM,EAAE;YAC5B,KAAK,GAAG,IAAI,KAAK,CAAC,SAAS,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,CAAC;SACnE;QACD,OAAO,KAAK,CAAC;IACf,CAAC;IAEO,WAAW;QACjB,IAAI,KAAuB,CAAC;QAC5B,IAAI,IAAI,CAAC,aAAa,EAAE;YACtB,KAAK,GAAG,IAAI,CAAC,aAAa,CAAC;SAC5B;aAAM,IAAI,IAAI,CAAC,SAAS,EAAE;YACzB,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC;SACxB;aAAM;YACL,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC;SAC7B;QACD,IAAI,KAAK,EAAE;YACT,IAAI,KAAK,IAAI,KAAK,CAAC,UAAU,EAAE;gBAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,kBAAkB,CAAC,KAAK,CAAC,UAAU,CAAC,aAAa,CAAC,aAAa,CAAC,CAAC;gBAC3F,IAAI,YAAY,EAAE;oBAChB,OAAO,YAAY,CAAC;iBACrB;aACF;SACF;IACH,CAAC;IAEO,cAAc;QACpB,IAAI,CAAC,eAAe,CAAC,aAAa,EAAE,CAAC;IACvC,CAAC;;;YApKF,SAAS,SAAC;gBACT,QAAQ,EAAE,qBAAqB;gBAC/B,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;GA0BT;gBACD,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;YA5CC,iBAAiB;;;kCAgDhB,SAAS,SAAC,cAAc,EAAE,EAAC,IAAI,EAAE,kBAAkB,EAAC;oCAOpD,SAAS,SAAC,gBAAgB;gCAO1B,SAAS,SAAC,YAAY;qBAOtB,KAAK;kBAGL,KAAK;uBAGL,KAAK;4BAGL,KAAK;wBAUL,MAAM;wBAGN,WAAW,SAAC,2BAA2B;0BAKvC,YAAY,SAAC,OAAO,EAAE,CAAC,QAAQ,CAAC","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  Input, OnChanges,\r\n  Output, SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { ColumnAlign, SimpleGridColumnDirective } from \"./simple-grid-column.directive\";\r\nimport { BaseInputComponent } from \"../base/base-input.component\";\r\n\r\n@Component({\r\n  selector: \"co-simple-grid-cell\",\r\n  template: `\r\n    <div class=\"simple-grid-column-cell-value\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\">\r\n      <ng-container *ngIf=\"editMode; else noInlineEdit\">\r\n        <ng-container #editTemplate *ngIf=\"column.editTemplate; else noEditTemplate\"\r\n                      [ngTemplateOutlet]=\"column.editTemplate\"\r\n                      [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n        <ng-template #noEditTemplate>\r\n          <ng-container *ngIf=\"column.template; else noTemplate\">\r\n            <ng-container [ngTemplateOutlet]=\"column.template\"\r\n                          [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n          </ng-container>\r\n          <ng-template #noTemplate>\r\n            <co-input-text [(model)]=\"row[column.field]\" [required]=\"column.required\"></co-input-text>\r\n          </ng-template>\r\n        </ng-template>\r\n      </ng-container>\r\n      <ng-template #noInlineEdit>\r\n        <ng-container *ngIf=\"column.template; else noTemplate\">\r\n          <ng-container [ngTemplateOutlet]=\"column.template\"\r\n                        [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n        </ng-container>\r\n        <ng-template #noTemplate>\r\n          <span [textContent]=\"column.getFieldValue(row[column.field])\"></span>\r\n        </ng-template>\r\n      </ng-template>\r\n    </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class SimpleGridCellComponent {\r\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\r\n\r\n  @ViewChild(\"editTemplate\", {read: BaseInputComponent}) set editTemplateContent(template) {\r\n    if (template) {\r\n      this._editTemplate = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @ViewChild(\"noEditTemplate\") set noEditTemplateContent(template) {\r\n    if (template) {\r\n      this._template = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @ViewChild(\"noTemplate\") set noTemplateContent(template) {\r\n    if (template) {\r\n      this._inputTemplate = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public column: SimpleGridColumnDirective;\r\n\r\n  @Input()\r\n  public row: {};\r\n\r\n  @Input()\r\n  public editMode: boolean = false;\r\n\r\n  @Input()\r\n  public set fieldEditMode(value: boolean) {\r\n    this._fieldEditMode = value;\r\n    this._setFocusComponent();\r\n  }\r\n\r\n  public get fieldEditMode(): boolean {\r\n    return this._fieldEditMode;\r\n  }\r\n\r\n  @Output()\r\n  public cellClick: EventEmitter<void> = new EventEmitter<void>();\r\n\r\n  @HostBinding(\"class.co-simple-grid-cell\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  public handleClick(event: MouseEvent): void {\r\n    if (this.column && !this.column.readonly) {\r\n      this.cellClick.next();\r\n    }\r\n  }\r\n\r\n  private _fieldEditMode: boolean = false;\r\n  private _focused: boolean = false;\r\n  private _editTemplate: TemplateRef<any>;\r\n  private _template: TemplateRef<any>;\r\n  private _inputTemplate: TemplateRef<any>;\r\n\r\n  constructor(private _changeDetector: ChangeDetectorRef) {\r\n  }\r\n\r\n  private _setFocusComponent(): void {\r\n    if (this.editMode && this.fieldEditMode) {\r\n      const element = this._getElement();\r\n      if (element) {\r\n        const focusEvent = this._createNewEvent(element, 'focus');\r\n        element.focus();\r\n        element.dispatchEvent(focusEvent);\r\n        this._focused = true;\r\n      }\r\n    } else {\r\n      if (this._focused) {\r\n        const element = this._getElement();\r\n        if (element) {\r\n          const blurEvent = this._createNewEvent(element, 'blur');\r\n          element.blur();\r\n          element.dispatchEvent(blurEvent);\r\n        }\r\n        this._focused = false;\r\n      }\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _getFirstFormInput(parent: any): any {\r\n    if (parent) {\r\n      const collection = Array.from(parent.getElementsByTagName('input'));\r\n      const otherCollection = Array.from(parent.getElementsByTagName('textarea'));\r\n      otherCollection.map(o => collection.push(o));\r\n      if (collection.length > 0) {\r\n        return collection[0];\r\n      }\r\n    }\r\n  }\r\n\r\n  private _createNewEvent(element: any, eventType: string): Event {\r\n    let event;\r\n    if (\"createEvent\" in document) {\r\n      event = document.createEvent(\"Event\");\r\n      event.initEvent(eventType, true, true);\r\n    } else if (\"Event\" in window) {\r\n      event = new Event(eventType, { bubbles: true, cancelable: true });\r\n    }\r\n    return event;\r\n  }\r\n\r\n  private _getElement(): HTMLElement {\r\n    let templ: TemplateRef<any>;\r\n    if (this._editTemplate) {\r\n      templ = this._editTemplate;\r\n    } else if (this._template) {\r\n      templ = this._template;\r\n    } else {\r\n      templ = this._inputTemplate;\r\n    }\r\n    if (templ) {\r\n      if (templ && templ.elementRef) {\r\n        const inputElement = this._getFirstFormInput(templ.elementRef.nativeElement.parentElement);\r\n        if (inputElement) {\r\n          return inputElement;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _detectChanges(): void {\r\n    this._changeDetector.detectChanges();\r\n  }\r\n}\r\n"]}
|
|
172
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid-cell.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid-cell.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostBinding,\r\n  HostListener,\r\n  Input, OnChanges,\r\n  Output, SimpleChanges,\r\n  TemplateRef,\r\n  ViewChild,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { ColumnAlign, SimpleGridColumnDirective } from \"./simple-grid-column.directive\";\r\nimport { BaseInputComponent } from \"../base/base-input.component\";\r\n\r\n@Component({\r\n  selector: \"co-simple-grid-cell\",\r\n  template: `\r\n      <div class=\"simple-grid-column-cell-value\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\">\r\n          <ng-container *ngIf=\"editMode; else noInlineEdit\">\r\n              <div class=\"simple-grid-column-cell-field\">\r\n                <ng-container #editTemplate *ngIf=\"column.editTemplate; else noEditTemplate\"\r\n                              [ngTemplateOutlet]=\"column.editTemplate\"\r\n                              [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n                <ng-template #noEditTemplate>\r\n                    <ng-container *ngIf=\"column.template; else noTemplate\">\r\n                        <ng-container [ngTemplateOutlet]=\"column.template\"\r\n                                      [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n                    </ng-container>\r\n                    <ng-template #noTemplate>\r\n                        <co-input-text [(model)]=\"row[column.field]\" [required]=\"column.required\"></co-input-text>\r\n                    </ng-template>\r\n                </ng-template>\r\n              </div>\r\n          </ng-container>\r\n          <ng-template #noInlineEdit>\r\n              <div class=\"simple-grid-column-cell-field\">\r\n                <ng-container *ngIf=\"column.template; else noTemplate\">\r\n                    <ng-container [ngTemplateOutlet]=\"column.template\"\r\n                                  [ngTemplateOutletContext]=\"{value: row[column.field], row: row}\"></ng-container>\r\n                </ng-container>\r\n                <ng-template #noTemplate>\r\n                    <span [textContent]=\"column.getFieldValue(row[column.field])\"></span>\r\n                </ng-template>\r\n              </div>\r\n          </ng-template>\r\n      </div>\r\n  `,\r\n  encapsulation: ViewEncapsulation.None\r\n})\r\nexport class SimpleGridCellComponent {\r\n  get editMode(): boolean {\r\n    return this._editMode;\r\n  }\r\n  @Input()\r\n  set editMode(value: boolean) {\r\n    this._editMode = value;\r\n  }\r\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\r\n\r\n  @ViewChild(\"editTemplate\", {read: BaseInputComponent}) set editTemplateContent(template) {\r\n    if (template) {\r\n      this._editTemplate = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @ViewChild(\"noEditTemplate\") set noEditTemplateContent(template) {\r\n    if (template) {\r\n      this._template = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @ViewChild(\"noTemplate\") set noTemplateContent(template) {\r\n    if (template) {\r\n      this._inputTemplate = template;\r\n      this._setFocusComponent();\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public column: SimpleGridColumnDirective;\r\n\r\n  @Input()\r\n  public row: {};\r\n\r\n  private _editMode: boolean = false;\r\n\r\n  @Input()\r\n  public set fieldEditMode(value: boolean) {\r\n    this._fieldEditMode = value;\r\n    this._setFocusComponent();\r\n  }\r\n\r\n  public get fieldEditMode(): boolean {\r\n    return this._fieldEditMode;\r\n  }\r\n\r\n  @Output()\r\n  public cellClick: EventEmitter<MouseEvent> = new EventEmitter<MouseEvent>();\r\n\r\n  @HostBinding(\"class.co-simple-grid-cell\")\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('click', ['$event'])\r\n  public handleClick(event: MouseEvent): void {\r\n    if (this.column && !this.column.readonly) {\r\n      this.cellClick.next();\r\n    }\r\n  }\r\n\r\n  private _fieldEditMode: boolean = false;\r\n  private _focused: boolean = false;\r\n  private _editTemplate: TemplateRef<any>;\r\n  private _template: TemplateRef<any>;\r\n  private _inputTemplate: TemplateRef<any>;\r\n\r\n  constructor(private _changeDetector: ChangeDetectorRef) {\r\n  }\r\n\r\n  private _setFocusComponent(): void {\r\n    if (this._editMode && this.fieldEditMode) {\r\n      const element = this._getElement();\r\n      if (element) {\r\n        const focusEvent = this._createNewEvent(element, 'focus');\r\n        element.focus();\r\n        element.dispatchEvent(focusEvent);\r\n        this._focused = true;\r\n      }\r\n    } else {\r\n      if (this._focused) {\r\n        const element = this._getElement();\r\n        if (element) {\r\n          const blurEvent = this._createNewEvent(element, 'blur');\r\n          element.blur();\r\n          element.dispatchEvent(blurEvent);\r\n        }\r\n        this._focused = false;\r\n      }\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _getFirstFormInput(parent: any): any {\r\n    if (parent) {\r\n      const collection = Array.from(parent.getElementsByTagName('input'));\r\n      const otherCollection = Array.from(parent.getElementsByTagName('textarea'));\r\n      otherCollection.map(o => collection.push(o));\r\n      if (collection.length > 0) {\r\n        return collection[0];\r\n      }\r\n    }\r\n  }\r\n\r\n  private _createNewEvent(element: any, eventType: string): Event {\r\n    let event;\r\n    if (\"createEvent\" in document) {\r\n      event = document.createEvent(\"Event\");\r\n      event.initEvent(eventType, true, true);\r\n    } else if (\"Event\" in window) {\r\n      event = new Event(eventType, { bubbles: true, cancelable: true });\r\n    }\r\n    return event;\r\n  }\r\n\r\n  private _getElement(): HTMLElement {\r\n    let templ: TemplateRef<any>;\r\n    if (this._editTemplate) {\r\n      templ = this._editTemplate;\r\n    } else if (this._template) {\r\n      templ = this._template;\r\n    } else {\r\n      templ = this._inputTemplate;\r\n    }\r\n    if (templ) {\r\n      if (templ && templ.elementRef) {\r\n        const inputElement = this._getFirstFormInput(templ.elementRef.nativeElement.parentElement);\r\n        if (inputElement) {\r\n          return inputElement;\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private _detectChanges(): void {\r\n    this._changeDetector.detectChanges();\r\n  }\r\n}\r\n"]}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import { __awaiter } from "tslib";
|
|
1
2
|
import { ChangeDetectionStrategy, ChangeDetectorRef, Component, HostBinding, HostListener, Input, ViewChildren, ViewEncapsulation } from '@angular/core';
|
|
2
3
|
import { FormMasterService } from '../../core/service/form-master.service';
|
|
3
4
|
import { BaseSimpleGridComponent } from './base-simple-grid.component';
|
|
@@ -52,6 +53,9 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
|
|
|
52
53
|
this.validateAndSave();
|
|
53
54
|
}
|
|
54
55
|
}
|
|
56
|
+
handleClickOutsideRow() {
|
|
57
|
+
this.validateAndSave();
|
|
58
|
+
}
|
|
55
59
|
isRowDisabled(row) {
|
|
56
60
|
if (this.rowDisabledFn && (typeof this.rowDisabledFn === 'function')) {
|
|
57
61
|
return this.rowDisabledFn.call(this, row);
|
|
@@ -68,25 +72,25 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
|
|
|
68
72
|
return !!singleColumn;
|
|
69
73
|
}
|
|
70
74
|
addNewRow() {
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
this.editRowIndex = this.data.length - 1;
|
|
78
|
-
this._nextAvailableCellToEdit(true).then((index) => {
|
|
79
|
-
this.editCellIndex = index;
|
|
75
|
+
return __awaiter(this, void 0, void 0, function* () {
|
|
76
|
+
if (this.inlineEdit) {
|
|
77
|
+
const valid = this.validateAndSave();
|
|
78
|
+
// this._detectChanges();
|
|
79
|
+
if (valid) {
|
|
80
|
+
this.data.push({});
|
|
80
81
|
this._detectChanges();
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
82
|
+
this._newRow = true;
|
|
83
|
+
this.editing = true;
|
|
84
|
+
this.editRowIndex = this.data.length - 1;
|
|
85
|
+
this.rowToEdit = this.data[this.editRowIndex];
|
|
86
|
+
this.editCellIndex = yield this._nextAvailableCellToEdit(true);
|
|
87
|
+
this._detectChanges();
|
|
88
|
+
}
|
|
85
89
|
}
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
}
|
|
90
|
+
else {
|
|
91
|
+
this.addRow.next();
|
|
92
|
+
}
|
|
93
|
+
});
|
|
90
94
|
}
|
|
91
95
|
validateAndSave(stopediting = true) {
|
|
92
96
|
if (!this.editing) {
|
|
@@ -110,8 +114,7 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
|
|
|
110
114
|
else {
|
|
111
115
|
this.data[this.editRowIndex] = this.rowToEdit;
|
|
112
116
|
}
|
|
113
|
-
this.
|
|
114
|
-
this.editing = false;
|
|
117
|
+
this._resetEdit();
|
|
115
118
|
this._detectChanges();
|
|
116
119
|
}
|
|
117
120
|
removeRow() {
|
|
@@ -130,7 +133,7 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
|
|
|
130
133
|
}, 200);
|
|
131
134
|
}
|
|
132
135
|
selectTheRow(index, emit = true) {
|
|
133
|
-
if (this.selectedRowIndex !== index && ((this.editing && this.validateAndSave()) || !this.editing)) {
|
|
136
|
+
if (this.selectedRowIndex === -1 || (this.selectedRowIndex !== index && ((this.editing && this.validateAndSave()) || !this.editing))) {
|
|
134
137
|
this.selectedRowIndex = index;
|
|
135
138
|
}
|
|
136
139
|
if (emit) {
|
|
@@ -151,17 +154,29 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
|
|
|
151
154
|
}
|
|
152
155
|
this._resetDblClick();
|
|
153
156
|
}
|
|
154
|
-
editRow(event) {
|
|
157
|
+
editRow(event, selectCell = true) {
|
|
155
158
|
this.editRowIndex = this.selectedRowIndex;
|
|
156
159
|
this.rowToEdit = this.data[this.editRowIndex];
|
|
157
160
|
this.editing = true;
|
|
158
|
-
|
|
159
|
-
this.
|
|
160
|
-
|
|
161
|
+
if (selectCell) {
|
|
162
|
+
this._nextAvailableCellToEdit(true).then((index) => {
|
|
163
|
+
this.editCellIndex = index;
|
|
164
|
+
});
|
|
165
|
+
}
|
|
161
166
|
this._detectChanges();
|
|
162
167
|
}
|
|
163
|
-
handleCellClick(
|
|
164
|
-
this.
|
|
168
|
+
handleCellClick(event, row, rowIndex, cellIndex) {
|
|
169
|
+
if (this.isRowDisabled(row)) {
|
|
170
|
+
this.selectedRowIndex = -1;
|
|
171
|
+
return;
|
|
172
|
+
}
|
|
173
|
+
this.selectTheRow(rowIndex, false);
|
|
174
|
+
if (this.inlineEdit) {
|
|
175
|
+
this.editRowIndex = rowIndex;
|
|
176
|
+
this.editCellIndex = cellIndex;
|
|
177
|
+
this.editing = true;
|
|
178
|
+
this.editRow(event, false);
|
|
179
|
+
}
|
|
165
180
|
this._detectChanges();
|
|
166
181
|
}
|
|
167
182
|
_resetDblClick() {
|
|
@@ -277,10 +292,7 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
|
|
|
277
292
|
}
|
|
278
293
|
this._newRow = false;
|
|
279
294
|
if (stopediting) {
|
|
280
|
-
this.
|
|
281
|
-
this.editCellIndex = -1;
|
|
282
|
-
this.editing = false;
|
|
283
|
-
this.rowToEdit = undefined;
|
|
295
|
+
this._resetEdit();
|
|
284
296
|
}
|
|
285
297
|
this._detectChanges();
|
|
286
298
|
}
|
|
@@ -296,6 +308,14 @@ export class SimpleGridComponent extends BaseSimpleGridComponent {
|
|
|
296
308
|
_detectChanges() {
|
|
297
309
|
this._changeDetection.detectChanges();
|
|
298
310
|
}
|
|
311
|
+
_resetEdit() {
|
|
312
|
+
this._newRow = false;
|
|
313
|
+
this.selectedRowIndex = -1;
|
|
314
|
+
this.editRowIndex = -1;
|
|
315
|
+
this.editCellIndex = -1;
|
|
316
|
+
this.editing = false;
|
|
317
|
+
this.rowToEdit = undefined;
|
|
318
|
+
}
|
|
299
319
|
}
|
|
300
320
|
SimpleGridComponent.decorators = [
|
|
301
321
|
{ type: Component, args: [{
|
|
@@ -312,7 +332,7 @@ SimpleGridComponent.decorators = [
|
|
|
312
332
|
(cancelClick)="cancelEditRow()"
|
|
313
333
|
(deleteClick)="removeRow()"
|
|
314
334
|
></co-grid-toolbar>
|
|
315
|
-
<table class="simple-grid-table">
|
|
335
|
+
<table class="simple-grid-table" [clickOutside]="editing" (clickOutside)="handleClickOutsideRow()">
|
|
316
336
|
<colgroup>
|
|
317
337
|
<col *ngFor="let column of headerColumns; let index = index"
|
|
318
338
|
[class.simple-grid-column-auto-fit]="column.autoFit"
|
|
@@ -341,7 +361,7 @@ SimpleGridComponent.decorators = [
|
|
|
341
361
|
</thead>
|
|
342
362
|
<tbody #dropList cdkDropList cdkDropListOrientation="vertical"
|
|
343
363
|
class="simple-grid-drag-drop-list"
|
|
344
|
-
[cdkDropListDisabled]="!dragDropEnabled"
|
|
364
|
+
[cdkDropListDisabled]="!dragDropEnabled || editing"
|
|
345
365
|
[cdkDropListData]="data"
|
|
346
366
|
[cdkDropListEnterPredicate]="handleCanDragDrop"
|
|
347
367
|
(cdkDropListDropped)="handleDrop($event)">
|
|
@@ -366,8 +386,8 @@ SimpleGridComponent.decorators = [
|
|
|
366
386
|
[column]="column"
|
|
367
387
|
[row]="row"
|
|
368
388
|
[editMode]="inlineEdit && editing && rowIndex === editRowIndex"
|
|
369
|
-
[fieldEditMode]="editCellIndex === columnIndex"
|
|
370
|
-
(cellClick)="handleCellClick(columnIndex)"
|
|
389
|
+
[fieldEditMode]="editCellIndex === columnIndex && rowIndex === editRowIndex"
|
|
390
|
+
(cellClick)="handleCellClick($event, row, rowIndex, columnIndex)"
|
|
371
391
|
></co-simple-grid-cell>
|
|
372
392
|
<div *ngIf="column.resizable" class="simple-grid-column-sizer-placeholder"></div>
|
|
373
393
|
</td>
|
|
@@ -408,4 +428,4 @@ SimpleGridComponent.propDecorators = {
|
|
|
408
428
|
showClass: [{ type: HostBinding, args: ['class.co-simple-grid',] }],
|
|
409
429
|
handleKeyDown: [{ type: HostListener, args: ['keydown', ['$event'],] }]
|
|
410
430
|
};
|
|
411
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  ViewChildren,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { FormMasterService } from '../../core/service/form-master.service';\r\nimport { BaseSimpleGridComponent } from './base-simple-grid.component';\r\nimport { ColumnAlign } from './simple-grid-column.directive';\r\n\r\n@Component({\r\n  selector: 'co-simple-grid',\r\n  template: `\r\n    <co-grid-toolbar *ngIf=\"showToolbar\" [class.right]=\"rightToolbar\"\r\n                     [showEdit]=\"showEdit\"\r\n                     [showAdd]=\"showAdd\"\r\n                     [showDelete]=\"showDelete\"\r\n                     [deleteEnabled]=\"selectedRowIndex > -1\"\r\n                     (addClick)=\"addNewRow()\"\r\n                     (editClick)=\"editRow($event)\"\r\n                     (saveClick)=\"validateAndSave()\"\r\n                     (cancelClick)=\"cancelEditRow()\"\r\n                     (deleteClick)=\"removeRow()\"\r\n    ></co-grid-toolbar>\r\n    <table class=\"simple-grid-table\">\r\n      <colgroup>\r\n        <col *ngFor=\"let column of headerColumns; let index = index\"\r\n             [class.simple-grid-column-auto-fit]=\"column.autoFit\"\r\n             [style.width.px]=\"column.width\"\r\n             [style.min-width.px]=\"MIN_COLUMN_WIDTH\">\r\n      </colgroup>\r\n      <thead>\r\n      <tr>\r\n        <th scope=\"col\" #headerCell class=\"simple-grid-column-header\" *ngFor=\"let column of headerColumns; let index = index\">\r\n          <div class=\"simple-grid-column-header-wrapper\" [class.resizable]=\"resizable\"\r\n               [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\">\r\n            <ng-container *ngIf=\"column.headerTemplate; else noHeaderTemplate\">\r\n              <ng-container [ngTemplateOutlet]=\"column.headerTemplate\"></ng-container>\r\n            </ng-container>\r\n            <ng-template #noHeaderTemplate>\r\n              <div class=\"simple-grid-column-header-label\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\"\r\n                   [textContent]=\"column.headerText || '&nbsp;'\"\r\n              ></div>\r\n            </ng-template>\r\n            <div *ngIf=\"resizable && column.resizable\" class=\"simple-grid-column-sizer\"\r\n                 (mousedown)=\"handleSizerMouseDown($event, column)\"\r\n            ></div>\r\n          </div>\r\n        </th>\r\n      </tr>\r\n      </thead>\r\n      <tbody #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n             class=\"simple-grid-drag-drop-list\"\r\n             [cdkDropListDisabled]=\"!dragDropEnabled\"\r\n             [cdkDropListData]=\"data\"\r\n             [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n             (cdkDropListDropped)=\"handleDrop($event)\">\r\n        <tr class=\"simple-grid-row\" [class.selected]=\"rowIndex === selectedRowIndex && !editing\" observeVisibility\r\n            [class.disabled]=\"isRowDisabled(row)\"\r\n          [class.editing]=\"rowIndex === editRowIndex\" *ngFor=\"let row of (!!rowsPerPage ? (data | paginate: {itemsPerPage: rowsPerPage, currentPage: currentPage}) : data); last as last; let rowIndex = index\" cdkDrag\r\n          (click)=\"handleClickRow($event, rowIndex, row)\" (dblclick)=\"handleDblClickRow($event, rowIndex, row)\" (visibilityChange)=\"rowVisible.next(row)\">\r\n          <co-form-test class=\"simple-grid-row-form\">\r\n            <ng-container *ngIf=\"isSingleColumnRow(row)\">\r\n              <td class=\"simple-grid-single-column-cell\" [attr.colspan]=\"headerColumns.length\">\r\n                <co-simple-grid-cell\r\n                  [column]=\"columns[singleColumnIndex(row)]\"\r\n                  [row]=\"row\"\r\n                  [editMode]=\"false\"\r\n                ></co-simple-grid-cell>\r\n              </td>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!isSingleColumnRow(row)\">\r\n              <ng-container *ngFor=\"let column of headerColumns; let columnIndex = index\">\r\n                <td class=\"simple-grid-column-cell\" *ngIf=\"columnIndex !== singleColumnIndex(row)\">\r\n                  <co-simple-grid-cell\r\n                    [column]=\"column\"\r\n                    [row]=\"row\"\r\n                    [editMode]=\"inlineEdit && editing && rowIndex === editRowIndex\"\r\n                    [fieldEditMode]=\"editCellIndex === columnIndex\"\r\n                    (cellClick)=\"handleCellClick(columnIndex)\"\r\n                  ></co-simple-grid-cell>\r\n                  <div *ngIf=\"column.resizable\" class=\"simple-grid-column-sizer-placeholder\"></div>\r\n                </td>\r\n              </ng-container>\r\n            </ng-container>\r\n          </co-form-test>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n    <co-pagination-bar *ngIf=\"data?.length > rowsPerPage\" class=\"pagination-bar\"\r\n                       [itemsPerPage]=\"rowsPerPage\"\r\n                       [currentPage]=\"currentPage\"\r\n                       [totalItems]=\"data.length\"\r\n                       [autoHide]=\"true\"\r\n                       (previousClick)=\"goToPreviousPage()\"\r\n                       (nextClick)=\"goToNextPage()\"\r\n                       (pageClick)=\"setCurrentPage($event)\"\r\n                        ></co-pagination-bar>\r\n  `,\r\n  providers: [\r\n    FormMasterService\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class SimpleGridComponent extends BaseSimpleGridComponent {\r\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\r\n\r\n  @ViewChildren('headerCell') set headerCells(cells) {\r\n    const headerElements = cells.toArray();\r\n    for (let i = 0; i < headerElements.length; i++) {\r\n      this.columns[i].elementRef = headerElements[i];\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public showAdd: boolean = false;\r\n\r\n  @Input()\r\n  public showDelete: boolean = false;\r\n\r\n  @Input()\r\n  public rightToolbar: boolean = false;\r\n\r\n  @Input()\r\n  public rowsPerPage: number = 1000;\r\n\r\n  @Input()\r\n  public rowDisabledFn: Function;\r\n\r\n  @HostBinding('class.co-simple-grid')\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  public handleKeyDown(event: KeyboardEvent): void {\r\n    if (!this.inlineEdit) {\r\n      return;\r\n    }\r\n    if (event.code === 'Tab') {\r\n      event.preventDefault();\r\n      this._nextAvailableCellToEdit(!event.shiftKey, this.editCellIndex)\r\n        .then((index: number) => {\r\n          this.editCellIndex = index;\r\n          this._changeDetection.markForCheck();\r\n        })\r\n      this._detectChanges();\r\n    }\r\n    if (event.code === 'Escape') {\r\n      this.cancelEditRow();\r\n    }\r\n    if (event.code === 'Enter') {\r\n      this.validateAndSave();\r\n    }\r\n  }\r\n\r\n  public editing: boolean = false;\r\n  public editRowIndex: number = -1;\r\n  public editCellIndex: number = -1;\r\n  public selectedRowIndex: number = -1;\r\n  public rowToEdit: any;\r\n  public currentPage: number = 1;\r\n\r\n  private _doubleClicked: boolean = false;\r\n  private _newRow: boolean = false;\r\n\r\n  constructor(\r\n    private _changeDetection: ChangeDetectorRef,\r\n    private _formMaster: FormMasterService\r\n  ) {\r\n    super();\r\n\r\n    this.dataChanged.subscribe(() => {\r\n      this.currentPage = 1;\r\n    })\r\n  }\r\n\r\n  public isRowDisabled(row: any): boolean {\r\n    if (this.rowDisabledFn && (typeof this.rowDisabledFn === 'function')) {\r\n      return this.rowDisabledFn.call(this, row);\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public isSingleColumn(column): boolean {\r\n    return column.singleColumn;\r\n  }\r\n\r\n  public rowContainsSingleColumn(row, columns): boolean {\r\n    const singleColumn = columns.find(column => this.isSingleColumn(column) && !!row[column.field]);\r\n    return !!singleColumn;\r\n  }\r\n\r\n  public addNewRow(): void {\r\n    if (this.inlineEdit) {\r\n      const valid: boolean = this.validateAndSave();\r\n      this._detectChanges();\r\n      if (valid) {\r\n        this.data.push({});\r\n        this._newRow = true;\r\n        this.editRowIndex = this.data.length - 1;\r\n        this._nextAvailableCellToEdit(true).then((index: number) => {\r\n          this.editCellIndex = index;\r\n          this._detectChanges();\r\n        });\r\n        this.editing = true;\r\n        this.rowToEdit = this.data[this.data.length - 1];\r\n        this._detectChanges();\r\n      }\r\n    } else {\r\n      this.addRow.next();\r\n    }\r\n  }\r\n\r\n  public validateAndSave(stopediting: boolean = true): boolean {\r\n    if (!this.editing) {\r\n      return true;\r\n    }\r\n    const valid: boolean = this._formMaster.submitSlaves();\r\n    this._detectChanges();\r\n    if (valid) {\r\n      this._saveRow(stopediting);\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public cancelEditRow(): void {\r\n    if (!this.editing) {\r\n      return;\r\n    }\r\n    if (this._newRow) {\r\n      this.data.splice(this.data.length - 1, 1);\r\n    } else {\r\n      this.data[this.editRowIndex] = this.rowToEdit;\r\n    }\r\n    this._newRow = false;\r\n    this.editing = false;\r\n    this._detectChanges();\r\n  }\r\n\r\n  public removeRow(): void {\r\n    this.deleteRow.next(this.data[this.selectedRowIndex]);\r\n  }\r\n\r\n  public handleClickRow(event: MouseEvent, index: number, row: any): void {\r\n    if (this.isRowDisabled(row)) {\r\n      this.selectedRowIndex = -1;\r\n      return;\r\n    }\r\n    setTimeout(() => {\r\n      if (this._doubleClicked) {\r\n        return;\r\n      }\r\n      this.selectTheRow(index);\r\n    }, 200);\r\n  }\r\n\r\n  public selectTheRow(index: number, emit: boolean = true): void {\r\n    if (this.selectedRowIndex !== index && ((this.editing && this.validateAndSave()) || !this.editing)) {\r\n      this.selectedRowIndex = index;\r\n    }\r\n    if (emit) {\r\n      this.selectRow.next(this.data[this.selectedRowIndex]);\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleDblClickRow(event: MouseEvent, index: number, row: any): void {\r\n    if (this.isRowDisabled(row)) {\r\n      this.selectedRowIndex = -1;\r\n      return;\r\n    }\r\n    this._doubleClicked = true;\r\n    this.dblClickRow.next(this.data[index]);\r\n    this.selectTheRow(index, false);\r\n    if (this.inlineEdit) {\r\n      this.editRow(event);\r\n    }\r\n    this._resetDblClick();\r\n  }\r\n\r\n  public editRow(event: MouseEvent): void {\r\n    this.editRowIndex = this.selectedRowIndex;\r\n    this.rowToEdit = this.data[this.editRowIndex];\r\n    this.editing = true;\r\n    this._nextAvailableCellToEdit(true).then((index: number) => {\r\n      this.editCellIndex = index;\r\n    });\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleCellClick(index: number): void {\r\n    this.editCellIndex = index;\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _resetDblClick(): void {\r\n    setTimeout(() => {\r\n      this._doubleClicked = false;\r\n    }, 500);\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param next; Move to next or previous cell\r\n   * @param start; Start from cellindex\r\n   * @private\r\n   */\r\n  private _nextAvailableCellToEdit(next: boolean, start: number = -1): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      const numEditableColumns: number = this.columns.filter(c => !c.readonly).length;\r\n      const wantedIndex = start + (next ? 1 : -1);\r\n      if (wantedIndex >= numEditableColumns) {\r\n        this._getNextEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getNextEditCellIndex(0));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else if (wantedIndex < 0) {\r\n        this._getPreviousEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getPreviousEditCellIndex(this.columns.length - 1));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else {\r\n        resolve(next ? this._getNextEditCellIndex(start + 1) : this._getPreviousEditCellIndex(start - 1));\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getNextEditCellIndex(start: number): number {\r\n    for (let i: number = start; i < this.columns.length; i++) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getPreviousEditCellIndex(start: number): number {\r\n    for (let i: number = start; i >= 0; i--) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getNextEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex + 1 >= this.data.length) {\r\n        if (this.autoAddRow) {\r\n          this.addNewRow();\r\n          newRowIndex = this.editRowIndex;\r\n        } else {\r\n          newRowIndex = 0;\r\n        }\r\n      } else {\r\n        newRowIndex = this.editRowIndex + 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getPreviousEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex - 1 < 0) {\r\n        newRowIndex = this.data.length - 1;\r\n      } else {\r\n        newRowIndex = this.editRowIndex - 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _saveRow(stopediting: boolean = true): void {\r\n    // emit saveEvent\r\n    if (this.rowToEdit) {\r\n      this.saveRow.next(this.rowToEdit);\r\n    }\r\n    this._newRow = false;\r\n    if (stopediting) {\r\n      this.editRowIndex = -1;\r\n      this.editCellIndex = -1;\r\n      this.editing = false;\r\n      this.rowToEdit = undefined;\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  public goToPreviousPage(): void {\r\n      this.currentPage -= 1;\r\n  }\r\n\r\n  public goToNextPage(): void {\r\n      this.currentPage += 1;\r\n  }\r\n\r\n  public setCurrentPage(page: number): void {\r\n    this.currentPage = page;\r\n  }\r\n\r\n  private _detectChanges(): void {\r\n    this._changeDetection.detectChanges();\r\n  }\r\n}\r\n"]}
|
|
431
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"simple-grid.component.js","sourceRoot":"","sources":["../../../../../../projects/corecomponents/src/lib/components/simple-grid/simple-grid.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  ChangeDetectionStrategy,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  HostBinding,\r\n  HostListener,\r\n  Input,\r\n  ViewChildren,\r\n  ViewEncapsulation\r\n} from '@angular/core';\r\nimport { FormMasterService } from '../../core/service/form-master.service';\r\nimport { BaseSimpleGridComponent } from './base-simple-grid.component';\r\nimport { ColumnAlign } from './simple-grid-column.directive';\r\n\r\n@Component({\r\n  selector: 'co-simple-grid',\r\n  template: `\r\n    <co-grid-toolbar *ngIf=\"showToolbar\" [class.right]=\"rightToolbar\"\r\n                     [showEdit]=\"showEdit\"\r\n                     [showAdd]=\"showAdd\"\r\n                     [showDelete]=\"showDelete\"\r\n                     [deleteEnabled]=\"selectedRowIndex > -1\"\r\n                     (addClick)=\"addNewRow()\"\r\n                     (editClick)=\"editRow($event)\"\r\n                     (saveClick)=\"validateAndSave()\"\r\n                     (cancelClick)=\"cancelEditRow()\"\r\n                     (deleteClick)=\"removeRow()\"\r\n    ></co-grid-toolbar>\r\n    <table class=\"simple-grid-table\" [clickOutside]=\"editing\" (clickOutside)=\"handleClickOutsideRow()\">\r\n      <colgroup>\r\n        <col *ngFor=\"let column of headerColumns; let index = index\"\r\n             [class.simple-grid-column-auto-fit]=\"column.autoFit\"\r\n             [style.width.px]=\"column.width\"\r\n             [style.min-width.px]=\"MIN_COLUMN_WIDTH\">\r\n      </colgroup>\r\n      <thead>\r\n      <tr>\r\n        <th scope=\"col\" #headerCell class=\"simple-grid-column-header\" *ngFor=\"let column of headerColumns; let index = index\">\r\n          <div class=\"simple-grid-column-header-wrapper\" [class.resizable]=\"resizable\"\r\n               [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\">\r\n            <ng-container *ngIf=\"column.headerTemplate; else noHeaderTemplate\">\r\n              <ng-container [ngTemplateOutlet]=\"column.headerTemplate\"></ng-container>\r\n            </ng-container>\r\n            <ng-template #noHeaderTemplate>\r\n              <div class=\"simple-grid-column-header-label\" [ngClass]=\"column.textAlign ? column.textAlign : defaultTextAlign\"\r\n                   [textContent]=\"column.headerText || '&nbsp;'\"\r\n              ></div>\r\n            </ng-template>\r\n            <div *ngIf=\"resizable && column.resizable\" class=\"simple-grid-column-sizer\"\r\n                 (mousedown)=\"handleSizerMouseDown($event, column)\"\r\n            ></div>\r\n          </div>\r\n        </th>\r\n      </tr>\r\n      </thead>\r\n      <tbody #dropList cdkDropList cdkDropListOrientation=\"vertical\"\r\n             class=\"simple-grid-drag-drop-list\"\r\n             [cdkDropListDisabled]=\"!dragDropEnabled || editing\"\r\n             [cdkDropListData]=\"data\"\r\n             [cdkDropListEnterPredicate]=\"handleCanDragDrop\"\r\n             (cdkDropListDropped)=\"handleDrop($event)\">\r\n        <tr class=\"simple-grid-row\" [class.selected]=\"rowIndex === selectedRowIndex && !editing\" observeVisibility\r\n            [class.disabled]=\"isRowDisabled(row)\"\r\n          [class.editing]=\"rowIndex === editRowIndex\" *ngFor=\"let row of (!!rowsPerPage ? (data | paginate: {itemsPerPage: rowsPerPage, currentPage: currentPage}) : data); last as last; let rowIndex = index\" cdkDrag\r\n          (click)=\"handleClickRow($event, rowIndex, row)\" (dblclick)=\"handleDblClickRow($event, rowIndex, row)\" (visibilityChange)=\"rowVisible.next(row)\">\r\n          <co-form-test class=\"simple-grid-row-form\">\r\n            <ng-container *ngIf=\"isSingleColumnRow(row)\">\r\n              <td class=\"simple-grid-single-column-cell\" [attr.colspan]=\"headerColumns.length\">\r\n                <co-simple-grid-cell\r\n                  [column]=\"columns[singleColumnIndex(row)]\"\r\n                  [row]=\"row\"\r\n                  [editMode]=\"false\"\r\n                ></co-simple-grid-cell>\r\n              </td>\r\n            </ng-container>\r\n            <ng-container *ngIf=\"!isSingleColumnRow(row)\">\r\n              <ng-container *ngFor=\"let column of headerColumns; let columnIndex = index\">\r\n                <td class=\"simple-grid-column-cell\" *ngIf=\"columnIndex !== singleColumnIndex(row)\">\r\n                  <co-simple-grid-cell\r\n                    [column]=\"column\"\r\n                    [row]=\"row\"\r\n                    [editMode]=\"inlineEdit && editing && rowIndex === editRowIndex\"\r\n                    [fieldEditMode]=\"editCellIndex === columnIndex && rowIndex === editRowIndex\"\r\n                    (cellClick)=\"handleCellClick($event, row, rowIndex, columnIndex)\"\r\n                  ></co-simple-grid-cell>\r\n                  <div *ngIf=\"column.resizable\" class=\"simple-grid-column-sizer-placeholder\"></div>\r\n                </td>\r\n              </ng-container>\r\n            </ng-container>\r\n          </co-form-test>\r\n        </tr>\r\n      </tbody>\r\n    </table>\r\n    <co-pagination-bar *ngIf=\"data?.length > rowsPerPage\" class=\"pagination-bar\"\r\n                       [itemsPerPage]=\"rowsPerPage\"\r\n                       [currentPage]=\"currentPage\"\r\n                       [totalItems]=\"data.length\"\r\n                       [autoHide]=\"true\"\r\n                       (previousClick)=\"goToPreviousPage()\"\r\n                       (nextClick)=\"goToNextPage()\"\r\n                       (pageClick)=\"setCurrentPage($event)\"\r\n                        ></co-pagination-bar>\r\n  `,\r\n  providers: [\r\n    FormMasterService\r\n  ],\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  encapsulation: ViewEncapsulation.None,\r\n})\r\nexport class SimpleGridComponent extends BaseSimpleGridComponent {\r\n  public readonly defaultTextAlign: ColumnAlign = ColumnAlign.Left;\r\n\r\n  @ViewChildren('headerCell') set headerCells(cells) {\r\n    const headerElements = cells.toArray();\r\n    for (let i = 0; i < headerElements.length; i++) {\r\n      this.columns[i].elementRef = headerElements[i];\r\n    }\r\n  }\r\n\r\n  @Input()\r\n  public showAdd: boolean = false;\r\n\r\n  @Input()\r\n  public showDelete: boolean = false;\r\n\r\n  @Input()\r\n  public rightToolbar: boolean = false;\r\n\r\n  @Input()\r\n  public rowsPerPage: number = 1000;\r\n\r\n  @Input()\r\n  public rowDisabledFn: Function;\r\n\r\n  @HostBinding('class.co-simple-grid')\r\n  public showClass(): boolean {\r\n    return true;\r\n  }\r\n\r\n  @HostListener('keydown', ['$event'])\r\n  public handleKeyDown(event: KeyboardEvent): void {\r\n    if (!this.inlineEdit) {\r\n      return;\r\n    }\r\n    if (event.code === 'Tab') {\r\n      event.preventDefault();\r\n      this._nextAvailableCellToEdit(!event.shiftKey, this.editCellIndex)\r\n        .then((index: number) => {\r\n          this.editCellIndex = index;\r\n          this._changeDetection.markForCheck();\r\n        })\r\n      this._detectChanges();\r\n    }\r\n    if (event.code === 'Escape') {\r\n      this.cancelEditRow();\r\n    }\r\n    if (event.code === 'Enter') {\r\n      this.validateAndSave();\r\n    }\r\n  }\r\n\r\n  public editing: boolean = false;\r\n  public editRowIndex: number = -1;\r\n  public editCellIndex: number = -1;\r\n  public selectedRowIndex: number = -1;\r\n  public rowToEdit: any;\r\n  public currentPage: number = 1;\r\n\r\n  private _doubleClicked: boolean = false;\r\n  private _newRow: boolean = false;\r\n\r\n  constructor(\r\n    private _changeDetection: ChangeDetectorRef,\r\n    private _formMaster: FormMasterService\r\n  ) {\r\n    super();\r\n\r\n    this.dataChanged.subscribe(() => {\r\n      this.currentPage = 1;\r\n    })\r\n  }\r\n\r\n  public handleClickOutsideRow(): void {\r\n    this.validateAndSave();\r\n  }\r\n\r\n  public isRowDisabled(row: any): boolean {\r\n    if (this.rowDisabledFn && (typeof this.rowDisabledFn === 'function')) {\r\n      return this.rowDisabledFn.call(this, row);\r\n    } else {\r\n      return false;\r\n    }\r\n  }\r\n\r\n  public isSingleColumn(column): boolean {\r\n    return column.singleColumn;\r\n  }\r\n\r\n  public rowContainsSingleColumn(row, columns): boolean {\r\n    const singleColumn = columns.find(column => this.isSingleColumn(column) && !!row[column.field]);\r\n    return !!singleColumn;\r\n  }\r\n\r\n  public async addNewRow(): Promise<void> {\r\n    if (this.inlineEdit) {\r\n      const valid: boolean = this.validateAndSave();\r\n      // this._detectChanges();\r\n      if (valid) {\r\n        this.data.push({});\r\n        this._detectChanges();\r\n        this._newRow = true;\r\n        this.editing = true;\r\n        this.editRowIndex = this.data.length - 1;\r\n        this.rowToEdit = this.data[this.editRowIndex];\r\n        this.editCellIndex = await this._nextAvailableCellToEdit(true);\r\n        this._detectChanges();\r\n      }\r\n    } else {\r\n      this.addRow.next();\r\n    }\r\n  }\r\n\r\n  public validateAndSave(stopediting: boolean = true): boolean {\r\n    if (!this.editing) {\r\n      return true;\r\n    }\r\n    const valid: boolean = this._formMaster.submitSlaves();\r\n    this._detectChanges();\r\n    if (valid) {\r\n      this._saveRow(stopediting);\r\n      return true;\r\n    }\r\n    return false;\r\n  }\r\n\r\n  public cancelEditRow(): void {\r\n    if (!this.editing) {\r\n      return;\r\n    }\r\n    if (this._newRow) {\r\n      this.data.splice(this.data.length - 1, 1);\r\n    } else {\r\n      this.data[this.editRowIndex] = this.rowToEdit;\r\n    }\r\n    this._resetEdit();\r\n    this._detectChanges();\r\n  }\r\n\r\n  public removeRow(): void {\r\n    this.deleteRow.next(this.data[this.selectedRowIndex]);\r\n  }\r\n\r\n  public handleClickRow(event: MouseEvent, index: number, row: any): void {\r\n    if (this.isRowDisabled(row)) {\r\n      this.selectedRowIndex = -1;\r\n      return;\r\n    }\r\n    setTimeout(() => {\r\n      if (this._doubleClicked) {\r\n        return;\r\n      }\r\n      this.selectTheRow(index);\r\n    }, 200);\r\n  }\r\n\r\n  public selectTheRow(index: number, emit: boolean = true): void {\r\n    if (this.selectedRowIndex === -1 || (this.selectedRowIndex !== index && ((this.editing && this.validateAndSave()) || !this.editing))) {\r\n      this.selectedRowIndex = index;\r\n    }\r\n    if (emit) {\r\n      this.selectRow.next(this.data[this.selectedRowIndex]);\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleDblClickRow(event: MouseEvent, index: number, row: any): void {\r\n    if (this.isRowDisabled(row)) {\r\n      this.selectedRowIndex = -1;\r\n      return;\r\n    }\r\n    this._doubleClicked = true;\r\n    this.dblClickRow.next(this.data[index]);\r\n    this.selectTheRow(index, false);\r\n    if (this.inlineEdit) {\r\n      this.editRow(event);\r\n    }\r\n    this._resetDblClick();\r\n  }\r\n\r\n  public editRow(event: MouseEvent, selectCell: boolean = true): void {\r\n    this.editRowIndex = this.selectedRowIndex;\r\n    this.rowToEdit = this.data[this.editRowIndex];\r\n    this.editing = true;\r\n    if (selectCell) {\r\n      this._nextAvailableCellToEdit(true).then((index: number) => {\r\n        this.editCellIndex = index;\r\n      });\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  public handleCellClick(event: MouseEvent, row: any, rowIndex: number, cellIndex: number): void {\r\n    if (this.isRowDisabled(row)) {\r\n      this.selectedRowIndex = -1;\r\n      return;\r\n    }\r\n    this.selectTheRow(rowIndex, false);\r\n    if (this.inlineEdit) {\r\n      this.editRowIndex = rowIndex;\r\n      this.editCellIndex = cellIndex;\r\n      this.editing = true;\r\n      this.editRow(event, false);\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  private _resetDblClick(): void {\r\n    setTimeout(() => {\r\n      this._doubleClicked = false;\r\n    }, 500);\r\n  }\r\n\r\n  /**\r\n   *\r\n   * @param next; Move to next or previous cell\r\n   * @param start; Start from cellindex\r\n   * @private\r\n   */\r\n  private _nextAvailableCellToEdit(next: boolean, start: number = -1): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      const numEditableColumns: number = this.columns.filter(c => !c.readonly).length;\r\n      const wantedIndex = start + (next ? 1 : -1);\r\n      if (wantedIndex >= numEditableColumns) {\r\n        this._getNextEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getNextEditCellIndex(0));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else if (wantedIndex < 0) {\r\n        this._getPreviousEditRowIndex()\r\n          .then((index: number) => {\r\n            this.editRowIndex = index;\r\n            resolve(this._getPreviousEditCellIndex(this.columns.length - 1));\r\n          })\r\n          .catch((e) => {\r\n            reject();\r\n          });\r\n      } else {\r\n        resolve(next ? this._getNextEditCellIndex(start + 1) : this._getPreviousEditCellIndex(start - 1));\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getNextEditCellIndex(start: number): number {\r\n    for (let i: number = start; i < this.columns.length; i++) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getPreviousEditCellIndex(start: number): number {\r\n    for (let i: number = start; i >= 0; i--) {\r\n      if (!this.columns[i].readonly) {\r\n        return i;\r\n      }\r\n    }\r\n  }\r\n\r\n  private _getNextEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex + 1 >= this.data.length) {\r\n        if (this.autoAddRow) {\r\n          this.addNewRow();\r\n          newRowIndex = this.editRowIndex;\r\n        } else {\r\n          newRowIndex = 0;\r\n        }\r\n      } else {\r\n        newRowIndex = this.editRowIndex + 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _getPreviousEditRowIndex(): Promise<number> {\r\n    return new Promise((resolve: Function, reject: Function) => {\r\n      let newRowIndex: number = 0;\r\n      if (this.editRowIndex - 1 < 0) {\r\n        newRowIndex = this.data.length - 1;\r\n      } else {\r\n        newRowIndex = this.editRowIndex - 1;\r\n      }\r\n      if (newRowIndex !== this.editRowIndex) { // go to different row validate current one first\r\n        if (this.validateAndSave(false)) {\r\n          this.rowToEdit = this.data[newRowIndex];\r\n          resolve(newRowIndex);\r\n        } else {\r\n          reject();\r\n        }\r\n      } else {\r\n        resolve(newRowIndex);\r\n      }\r\n    });\r\n  }\r\n\r\n  private _saveRow(stopediting: boolean = true): void {\r\n    // emit saveEvent\r\n    if (this.rowToEdit) {\r\n      this.saveRow.next(this.rowToEdit);\r\n    }\r\n    this._newRow = false;\r\n    if (stopediting) {\r\n      this._resetEdit();\r\n    }\r\n    this._detectChanges();\r\n  }\r\n\r\n  public goToPreviousPage(): void {\r\n      this.currentPage -= 1;\r\n  }\r\n\r\n  public goToNextPage(): void {\r\n      this.currentPage += 1;\r\n  }\r\n\r\n  public setCurrentPage(page: number): void {\r\n    this.currentPage = page;\r\n  }\r\n\r\n  private _detectChanges(): void {\r\n    this._changeDetection.detectChanges();\r\n  }\r\n\r\n  private _resetEdit(): void {\r\n    this._newRow = false;\r\n    this.selectedRowIndex = -1;\r\n    this.editRowIndex = -1;\r\n    this.editCellIndex = -1;\r\n    this.editing = false;\r\n    this.rowToEdit = undefined;\r\n  }\r\n}\r\n"]}
|