@ng-nest/ui 13.1.2 → 13.1.5
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/core/config/config.d.ts +9 -0
- package/date-picker/picker-date.component.d.ts +1 -1
- package/dialog/dialog-portal.component.d.ts +33 -5
- package/dialog/dialog-portal.directives.d.ts +17 -0
- package/dialog/dialog-ref.d.ts +11 -1
- package/dialog/dialog.component.d.ts +3 -5
- package/dialog/dialog.module.d.ts +1 -1
- package/dialog/dialog.property.d.ts +37 -4
- package/dialog/dialog.service.d.ts +1 -0
- package/empty/empty.component.d.ts +1 -1
- package/esm2020/core/config/config.mjs +1 -1
- package/esm2020/date-picker/picker-date.component.mjs +2 -2
- package/esm2020/dialog/dialog-portal.component.mjs +49 -12
- package/esm2020/dialog/dialog-portal.directives.mjs +47 -1
- package/esm2020/dialog/dialog-ref.mjs +83 -2
- package/esm2020/dialog/dialog.component.mjs +27 -28
- package/esm2020/dialog/dialog.module.mjs +10 -2
- package/esm2020/dialog/dialog.property.mjs +10 -3
- package/esm2020/dialog/dialog.service.mjs +56 -8
- package/esm2020/empty/empty.component.mjs +2 -2
- package/esm2020/i18n/i18n.property.mjs +1 -1
- package/esm2020/i18n/languages/ar_EG.mjs +7 -1
- package/esm2020/i18n/languages/bg_BG.mjs +7 -1
- package/esm2020/i18n/languages/ca_ES.mjs +7 -1
- package/esm2020/i18n/languages/cs_CZ.mjs +7 -1
- package/esm2020/i18n/languages/da_DK.mjs +7 -1
- package/esm2020/i18n/languages/de_DE.mjs +7 -1
- package/esm2020/i18n/languages/el_GR.mjs +7 -1
- package/esm2020/i18n/languages/en_GB.mjs +7 -1
- package/esm2020/i18n/languages/en_US.mjs +7 -1
- package/esm2020/i18n/languages/es_ES.mjs +7 -1
- package/esm2020/i18n/languages/et_EE.mjs +7 -1
- package/esm2020/i18n/languages/fa_IR.mjs +7 -1
- package/esm2020/i18n/languages/fi_FI.mjs +7 -1
- package/esm2020/i18n/languages/fr_BE.mjs +7 -1
- package/esm2020/i18n/languages/fr_FR.mjs +7 -1
- package/esm2020/i18n/languages/he_IL.mjs +7 -1
- package/esm2020/i18n/languages/hi_IN.mjs +7 -1
- package/esm2020/i18n/languages/hr_HR.mjs +7 -1
- package/esm2020/i18n/languages/hu_HU.mjs +7 -1
- package/esm2020/i18n/languages/hy_AM.mjs +7 -1
- package/esm2020/i18n/languages/id_ID.mjs +7 -1
- package/esm2020/i18n/languages/is_IS.mjs +7 -1
- package/esm2020/i18n/languages/it_IT.mjs +7 -1
- package/esm2020/i18n/languages/ja_JP.mjs +7 -1
- package/esm2020/i18n/languages/ka_GE.mjs +7 -1
- package/esm2020/i18n/languages/kn_IN.mjs +7 -1
- package/esm2020/i18n/languages/ko_KR.mjs +7 -1
- package/esm2020/i18n/languages/ku_IQ.mjs +7 -1
- package/esm2020/i18n/languages/lv_LV.mjs +7 -1
- package/esm2020/i18n/languages/mn_MN.mjs +7 -1
- package/esm2020/i18n/languages/ms_MY.mjs +7 -1
- package/esm2020/i18n/languages/nb_NO.mjs +7 -1
- package/esm2020/i18n/languages/ne_NP.mjs +7 -1
- package/esm2020/i18n/languages/nl_BE.mjs +7 -1
- package/esm2020/i18n/languages/nl_NL.mjs +7 -1
- package/esm2020/i18n/languages/pl_PL.mjs +7 -1
- package/esm2020/i18n/languages/pt_BR.mjs +7 -1
- package/esm2020/i18n/languages/pt_PT.mjs +7 -1
- package/esm2020/i18n/languages/ro_RO.mjs +7 -1
- package/esm2020/i18n/languages/ru_RU.mjs +7 -1
- package/esm2020/i18n/languages/sk_SK.mjs +7 -1
- package/esm2020/i18n/languages/sl_SI.mjs +7 -1
- package/esm2020/i18n/languages/sr_RS.mjs +7 -1
- package/esm2020/i18n/languages/sv_SE.mjs +7 -1
- package/esm2020/i18n/languages/ta_IN.mjs +7 -1
- package/esm2020/i18n/languages/th_TH.mjs +7 -1
- package/esm2020/i18n/languages/tr_TR.mjs +7 -1
- package/esm2020/i18n/languages/uk_UA.mjs +7 -1
- package/esm2020/i18n/languages/vi_VN.mjs +7 -1
- package/esm2020/i18n/languages/zh_CN.mjs +7 -1
- package/esm2020/i18n/languages/zh_TW.mjs +7 -1
- package/esm2020/list/list-option.component.mjs +21 -8
- package/esm2020/list/list.component.mjs +55 -13
- package/esm2020/list/list.module.mjs +5 -1
- package/esm2020/list/list.property.mjs +33 -5
- package/esm2020/page-header/page-header.component.mjs +2 -2
- package/esm2020/pagination/pagination.component.mjs +2 -2
- package/esm2020/rate/rate.component.mjs +21 -4
- package/esm2020/rate/rate.property.mjs +9 -3
- package/esm2020/resizable/resizable.directive.mjs +81 -37
- package/esm2020/resizable/resizable.property.mjs +1 -1
- package/esm2020/select/select-portal.component.mjs +26 -9
- package/esm2020/select/select.component.mjs +15 -3
- package/esm2020/select/select.module.mjs +5 -4
- package/esm2020/select/select.property.mjs +12 -2
- package/esm2020/text-retract/text-retract.component.mjs +2 -2
- package/esm2020/upload/upload.component.mjs +13 -9
- package/esm2020/upload/upload.property.mjs +30 -2
- package/fesm2015/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-date-picker.mjs +1 -1
- package/fesm2015/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-dialog.mjs +285 -55
- package/fesm2015/ng-nest-ui-dialog.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-empty.mjs +1 -1
- package/fesm2015/ng-nest-ui-empty.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-i18n.mjs +306 -0
- package/fesm2015/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-list.mjs +107 -22
- package/fesm2015/ng-nest-ui-list.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-page-header.mjs +1 -1
- package/fesm2015/ng-nest-ui-page-header.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-pagination.mjs +1 -1
- package/fesm2015/ng-nest-ui-pagination.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-rate.mjs +27 -4
- package/fesm2015/ng-nest-ui-rate.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-resizable.mjs +80 -36
- package/fesm2015/ng-nest-ui-resizable.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-select.mjs +56 -16
- package/fesm2015/ng-nest-ui-select.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-text-retract.mjs +1 -1
- package/fesm2015/ng-nest-ui-text-retract.mjs.map +1 -1
- package/fesm2015/ng-nest-ui-upload.mjs +41 -9
- package/fesm2015/ng-nest-ui-upload.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-core.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-date-picker.mjs +1 -1
- package/fesm2020/ng-nest-ui-date-picker.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-dialog.mjs +277 -54
- package/fesm2020/ng-nest-ui-dialog.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-empty.mjs +1 -1
- package/fesm2020/ng-nest-ui-empty.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-i18n.mjs +306 -0
- package/fesm2020/ng-nest-ui-i18n.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-list.mjs +107 -22
- package/fesm2020/ng-nest-ui-list.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-page-header.mjs +1 -1
- package/fesm2020/ng-nest-ui-page-header.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-pagination.mjs +1 -1
- package/fesm2020/ng-nest-ui-pagination.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-rate.mjs +27 -4
- package/fesm2020/ng-nest-ui-rate.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-resizable.mjs +80 -36
- package/fesm2020/ng-nest-ui-resizable.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-select.mjs +56 -16
- package/fesm2020/ng-nest-ui-select.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-text-retract.mjs +1 -1
- package/fesm2020/ng-nest-ui-text-retract.mjs.map +1 -1
- package/fesm2020/ng-nest-ui-upload.mjs +41 -9
- package/fesm2020/ng-nest-ui-upload.mjs.map +1 -1
- package/i18n/i18n.property.d.ts +8 -0
- package/i18n/languages/ar_EG.d.ts +6 -0
- package/i18n/languages/bg_BG.d.ts +6 -0
- package/i18n/languages/ca_ES.d.ts +6 -0
- package/i18n/languages/cs_CZ.d.ts +6 -0
- package/i18n/languages/da_DK.d.ts +6 -0
- package/i18n/languages/de_DE.d.ts +6 -0
- package/i18n/languages/el_GR.d.ts +6 -0
- package/i18n/languages/en_GB.d.ts +6 -0
- package/i18n/languages/en_US.d.ts +6 -0
- package/i18n/languages/es_ES.d.ts +6 -0
- package/i18n/languages/et_EE.d.ts +6 -0
- package/i18n/languages/fa_IR.d.ts +6 -0
- package/i18n/languages/fi_FI.d.ts +6 -0
- package/i18n/languages/fr_BE.d.ts +6 -0
- package/i18n/languages/fr_FR.d.ts +6 -0
- package/i18n/languages/he_IL.d.ts +6 -0
- package/i18n/languages/hi_IN.d.ts +6 -0
- package/i18n/languages/hr_HR.d.ts +6 -0
- package/i18n/languages/hu_HU.d.ts +6 -0
- package/i18n/languages/hy_AM.d.ts +6 -0
- package/i18n/languages/id_ID.d.ts +6 -0
- package/i18n/languages/is_IS.d.ts +6 -0
- package/i18n/languages/it_IT.d.ts +6 -0
- package/i18n/languages/ja_JP.d.ts +6 -0
- package/i18n/languages/ka_GE.d.ts +6 -0
- package/i18n/languages/kn_IN.d.ts +6 -0
- package/i18n/languages/ko_KR.d.ts +6 -0
- package/i18n/languages/ku_IQ.d.ts +6 -0
- package/i18n/languages/lv_LV.d.ts +6 -0
- package/i18n/languages/mn_MN.d.ts +6 -0
- package/i18n/languages/ms_MY.d.ts +6 -0
- package/i18n/languages/nb_NO.d.ts +6 -0
- package/i18n/languages/ne_NP.d.ts +6 -0
- package/i18n/languages/nl_BE.d.ts +6 -0
- package/i18n/languages/nl_NL.d.ts +6 -0
- package/i18n/languages/pl_PL.d.ts +6 -0
- package/i18n/languages/pt_BR.d.ts +6 -0
- package/i18n/languages/pt_PT.d.ts +6 -0
- package/i18n/languages/ro_RO.d.ts +6 -0
- package/i18n/languages/ru_RU.d.ts +6 -0
- package/i18n/languages/sk_SK.d.ts +6 -0
- package/i18n/languages/sl_SI.d.ts +6 -0
- package/i18n/languages/sr_RS.d.ts +6 -0
- package/i18n/languages/sv_SE.d.ts +6 -0
- package/i18n/languages/ta_IN.d.ts +6 -0
- package/i18n/languages/th_TH.d.ts +6 -0
- package/i18n/languages/tr_TR.d.ts +6 -0
- package/i18n/languages/uk_UA.d.ts +6 -0
- package/i18n/languages/vi_VN.d.ts +6 -0
- package/i18n/languages/zh_CN.d.ts +6 -0
- package/i18n/languages/zh_TW.d.ts +6 -0
- package/list/examples/en_US/default/size/README.md +6 -0
- package/list/examples/zh_CN/default/size/README.md +6 -0
- package/list/list-option.component.d.ts +8 -2
- package/list/list.component.d.ts +7 -1
- package/list/list.module.d.ts +3 -2
- package/list/list.property.d.ts +29 -4
- package/package.json +1 -1
- package/page-header/page-header.component.d.ts +1 -1
- package/pagination/pagination.component.d.ts +1 -1
- package/rate/examples/en_US/default/color/README.md +6 -0
- package/rate/examples/zh_CN/default/color/README.md +6 -0
- package/rate/rate.component.d.ts +1 -0
- package/rate/rate.property.d.ts +13 -1
- package/resizable/resizable.directive.d.ts +5 -8
- package/resizable/resizable.property.d.ts +5 -0
- package/select/select-portal.component.d.ts +10 -1
- package/select/select.component.d.ts +1 -0
- package/select/select.module.d.ts +2 -1
- package/select/select.property.d.ts +11 -1
- package/style/core/index.css +3 -0
- package/style/core/index.css.map +1 -1
- package/style/directives/resizable/mixin.scss +5 -0
- package/tag/examples/zh_CN/default/bordered/README.md +1 -1
- package/text-retract/text-retract.component.d.ts +1 -1
- package/upload/upload.component.d.ts +4 -4
- package/upload/upload.property.d.ts +21 -1
|
@@ -47,7 +47,7 @@ export class XPaginationComponent extends XPaginationProperty {
|
|
|
47
47
|
const { total, size, index } = changes;
|
|
48
48
|
XIsChange(total, size, index) && this.setIndexes();
|
|
49
49
|
}
|
|
50
|
-
|
|
50
|
+
ngOnDestroy() {
|
|
51
51
|
this._unSubject.next();
|
|
52
52
|
this._unSubject.unsubscribe();
|
|
53
53
|
}
|
|
@@ -129,4 +129,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
129
129
|
type: Component,
|
|
130
130
|
args: [{ selector: `${XPaginationPrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, template: "<x-buttons *ngIf=\"!simple; else simpleTpl\" [space]=\"space\" [hiddenBorder]=\"hiddenBorder\">\r\n <x-button\r\n *ngIf=\"showEllipsis\"\r\n [icon]=\"'fto-chevrons-left'\"\r\n [title]=\"'pagination.first' | xI18n\"\r\n [disabled]=\"disabled || firstActivated\"\r\n (click)=\"jump(1)\"\r\n ></x-button>\r\n <ng-container *xOutlet=\"previousTpl\"></ng-container>\r\n <x-button\r\n *ngFor=\"let item of indexes; trackBy: trackByItem\"\r\n [disabled]=\"disabled\"\r\n [activated]=\"getActivated(item)\"\r\n (click)=\"jump(item)\"\r\n >{{ item }}</x-button\r\n >\r\n <ng-container *xOutlet=\"nextTpl\"></ng-container>\r\n <x-button\r\n *ngIf=\"showEllipsis && !simple\"\r\n [icon]=\"'fto-chevrons-right'\"\r\n [title]=\"'pagination.last' | xI18n\"\r\n [disabled]=\"disabled || lastActivated\"\r\n (click)=\"jump(lastIndex)\"\r\n ></x-button>\r\n</x-buttons>\r\n<ng-template #simpleTpl>\r\n <div class=\"x-pagination-simple\">\r\n <x-input\r\n [bordered]=\"!hiddenBorder\"\r\n [before]=\"previousTpl\"\r\n [after]=\"nextTpl\"\r\n [style.width.px]=\"simpleIndexWidth\"\r\n [(ngModel)]=\"index\"\r\n (xKeydown)=\"onSimpleKeydown($event)\"\r\n ></x-input>\r\n <span>/</span>\r\n <span>{{ lastIndex }}</span>\r\n </div>\r\n</ng-template>\r\n<x-select\r\n *ngIf=\"showSize\"\r\n [style.width.px]=\"sizeWidth\"\r\n class=\"x-pagination-size\"\r\n [data]=\"sizeData\"\r\n clearable=\"false\"\r\n [disabled]=\"disabled\"\r\n [bordered]=\"!hiddenBorder\"\r\n [nodeTpl]=\"nodeTpl\"\r\n [(ngModel)]=\"size\"\r\n (ngModelChange)=\"sizeChanged()\"\r\n></x-select>\r\n<div *ngIf=\"showJump && !simple\" class=\"x-pagination-jump\">\r\n <span>{{ 'pagination.jump' | xI18n }}</span>\r\n <x-input [bordered]=\"!hiddenBorder\" [style.width.px]=\"jumpWidth\" [(ngModel)]=\"jumpPage\" (xKeydown)=\"onKeydown($event)\"></x-input>\r\n</div>\r\n<x-button *ngIf=\"showTotal\" [disabled]=\"disabled\" class=\"x-pagination-total\" [type]=\"hiddenBorder === true ? 'text' : 'initial'\"\r\n ><ng-container *xOutlet=\"totalTpl; context: { $total: total }\"\r\n >{{ 'pagination.total' | xI18n }} {{ total }} {{ 'pagination.item' | xI18n }}</ng-container\r\n ></x-button\r\n>\r\n\r\n<ng-template #previousTpl>\r\n <x-button\r\n [icon]=\"'fto-chevron-left'\"\r\n [title]=\"'pagination.previous' | xI18n\"\r\n [disabled]=\"disabled || leftDisabled\"\r\n (click)=\"jump(-1, true)\"\r\n ></x-button>\r\n</ng-template>\r\n\r\n<ng-template #nextTpl>\r\n <x-button\r\n [icon]=\"'fto-chevron-right'\"\r\n [title]=\"'pagination.next' | xI18n\"\r\n [disabled]=\"disabled || rightDisabled\"\r\n (click)=\"jump(1, true)\"\r\n ></x-button>\r\n</ng-template>\r\n\r\n<ng-template #nodeTpl let-node=\"$node\">\r\n <ng-container *ngIf=\"node\"> {{ node?.label }} {{ 'pagination.sizePage' | xI18n }} </ng-container>\r\n</ng-template>\r\n", styles: [".x-pagination{margin:0;padding:0;display:inline-flex}.x-pagination>.x-buttons.x-buttons-hiddenBorder>x-button>.x-button{min-width:1.75rem}.x-pagination>.x-buttons.x-buttons-hiddenBorder>x-button>.x-button-activated{background-color:#0000000d}.x-pagination-size,.x-pagination-total{margin-left:.5rem}.x-pagination-jump{margin-left:.5rem;display:inline-flex;align-items:center}.x-pagination-jump x-input{margin-left:.5rem}.x-pagination-simple{margin:0 .5rem;display:inline-flex;align-items:center}.x-pagination-simple>x-input input{text-align:center}.x-pagination-simple>span{margin-left:.5rem}\n"] }]
|
|
131
131
|
}], ctorParameters: function () { return [{ type: i1.XConfigService }, { type: i0.ElementRef }, { type: i0.Renderer2 }, { type: i0.ChangeDetectorRef }, { type: i2.XI18nService }]; } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/pagination/pagination.component.ts","../../../../../lib/ng-nest/ui/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  ElementRef,\r\n  Renderer2,\r\n  ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { XPaginationPrefix, XPaginationProperty } from './pagination.property';\r\nimport { XIsChange, XConfigService } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { XI18nService } from '@ng-nest/ui/i18n';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { ENTER } from '@angular/cdk/keycodes';\r\n\r\n@Component({\r\n  selector: `${XPaginationPrefix}`,\r\n  templateUrl: './pagination.component.html',\r\n  styleUrls: ['./style/index.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XPaginationComponent extends XPaginationProperty implements OnChanges {\r\n  lastIndex!: number;\r\n  indexes: number[] = [];\r\n  indexFirst: number = 1;\r\n  indexLast: number = 1;\r\n  jumpPage: number | null = null;\r\n\r\n  private _unSubject = new Subject<void>();\r\n\r\n  get leftDisabled() {\r\n    return Number(this.index) === 1 || Number(this.total) === 0;\r\n  }\r\n\r\n  get rightDisabled() {\r\n    return Number(this.index) === this.lastIndex || Number(this.total) === 0;\r\n  }\r\n\r\n  get firstActivated() {\r\n    return Number(this.index) === 1;\r\n  }\r\n\r\n  get lastActivated() {\r\n    return Number(this.index) === this.lastIndex;\r\n  }\r\n\r\n  constructor(\r\n    public configService: XConfigService,\r\n    public elementRef: ElementRef,\r\n    public renderer: Renderer2,\r\n    public cdr: ChangeDetectorRef,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n    this.renderer.addClass(this.elementRef.nativeElement, XPaginationPrefix);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.i18n.localeChange.pipe(takeUntil(this._unSubject)).subscribe(() => this.cdr.markForCheck());\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { total, size, index } = changes;\r\n    XIsChange(total, size, index) && this.setIndexes();\r\n  }\r\n\r\n  ngOnDestory() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  sizeChanged() {\r\n    this.setIndexes();\r\n    this.sizeChange.emit(this.size as number);\r\n  }\r\n\r\n  setIndexes() {\r\n    this.lastIndex = Math.ceil(Number(this.total) / Number(this.size)) || 1;\r\n    const indexes: number[] = [];\r\n    const current = Number(this.index) - 1;\r\n    const maxSize = Number(this.pageLinkSize);\r\n    const pages = Math.min(maxSize, this.lastIndex);\r\n    let start = Math.max(0, Math.ceil(current - pages / 2)),\r\n      end = Math.min(this.lastIndex - 1, start + pages - 1);\r\n    var delta = maxSize - (end - start + 1);\r\n    start = Math.max(0, start - delta);\r\n\r\n    for (let i = start; i <= end; i++) {\r\n      indexes.push(i + 1);\r\n    }\r\n    this.indexes = indexes;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  jump(index: number, isDiff = false) {\r\n    const ix = this.validateIndex(isDiff ? Number(this.index) + index : index);\r\n    if (ix !== this.index) {\r\n      this.index = ix;\r\n      this.setIndexes();\r\n      this.indexChange.emit(this.index);\r\n    }\r\n  }\r\n\r\n  onKeydown(event: KeyboardEvent) {\r\n    if (this.jumpPage !== null && event.keyCode === ENTER) {\r\n      if (this.jumpPage <= this.indexFirst) {\r\n        this.jump(this.indexFirst);\r\n      } else if (this.jumpPage >= this.lastIndex) {\r\n        this.jump(this.lastIndex);\r\n      } else {\r\n        this.jump(this.jumpPage);\r\n      }\r\n      this.jumpPage = null;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  onSimpleKeydown(event: KeyboardEvent) {\r\n    if (this.index !== null && event.keyCode === ENTER) {\r\n      if (this.index <= this.indexFirst) {\r\n        this.index = this.indexFirst;\r\n      } else if (this.index >= this.lastIndex) {\r\n        this.index = this.lastIndex;\r\n      }\r\n      this.jump(this.index as number);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  validateIndex(value: number): number {\r\n    if (value > this.lastIndex) {\r\n      return this.lastIndex;\r\n    } else if (value < 1) {\r\n      return 1;\r\n    } else {\r\n      return value;\r\n    }\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.index) === index;\r\n  }\r\n\r\n  trackByItem(_index: number, item: number) {\r\n    return item;\r\n  }\r\n}\r\n","<x-buttons *ngIf=\"!simple; else simpleTpl\" [space]=\"space\" [hiddenBorder]=\"hiddenBorder\">\r\n  <x-button\r\n    *ngIf=\"showEllipsis\"\r\n    [icon]=\"'fto-chevrons-left'\"\r\n    [title]=\"'pagination.first' | xI18n\"\r\n    [disabled]=\"disabled || firstActivated\"\r\n    (click)=\"jump(1)\"\r\n  ></x-button>\r\n  <ng-container *xOutlet=\"previousTpl\"></ng-container>\r\n  <x-button\r\n    *ngFor=\"let item of indexes; trackBy: trackByItem\"\r\n    [disabled]=\"disabled\"\r\n    [activated]=\"getActivated(item)\"\r\n    (click)=\"jump(item)\"\r\n    >{{ item }}</x-button\r\n  >\r\n  <ng-container *xOutlet=\"nextTpl\"></ng-container>\r\n  <x-button\r\n    *ngIf=\"showEllipsis && !simple\"\r\n    [icon]=\"'fto-chevrons-right'\"\r\n    [title]=\"'pagination.last' | xI18n\"\r\n    [disabled]=\"disabled || lastActivated\"\r\n    (click)=\"jump(lastIndex)\"\r\n  ></x-button>\r\n</x-buttons>\r\n<ng-template #simpleTpl>\r\n  <div class=\"x-pagination-simple\">\r\n    <x-input\r\n      [bordered]=\"!hiddenBorder\"\r\n      [before]=\"previousTpl\"\r\n      [after]=\"nextTpl\"\r\n      [style.width.px]=\"simpleIndexWidth\"\r\n      [(ngModel)]=\"index\"\r\n      (xKeydown)=\"onSimpleKeydown($event)\"\r\n    ></x-input>\r\n    <span>/</span>\r\n    <span>{{ lastIndex }}</span>\r\n  </div>\r\n</ng-template>\r\n<x-select\r\n  *ngIf=\"showSize\"\r\n  [style.width.px]=\"sizeWidth\"\r\n  class=\"x-pagination-size\"\r\n  [data]=\"sizeData\"\r\n  clearable=\"false\"\r\n  [disabled]=\"disabled\"\r\n  [bordered]=\"!hiddenBorder\"\r\n  [nodeTpl]=\"nodeTpl\"\r\n  [(ngModel)]=\"size\"\r\n  (ngModelChange)=\"sizeChanged()\"\r\n></x-select>\r\n<div *ngIf=\"showJump && !simple\" class=\"x-pagination-jump\">\r\n  <span>{{ 'pagination.jump' | xI18n }}</span>\r\n  <x-input [bordered]=\"!hiddenBorder\" [style.width.px]=\"jumpWidth\" [(ngModel)]=\"jumpPage\" (xKeydown)=\"onKeydown($event)\"></x-input>\r\n</div>\r\n<x-button *ngIf=\"showTotal\" [disabled]=\"disabled\" class=\"x-pagination-total\" [type]=\"hiddenBorder === true ? 'text' : 'initial'\"\r\n  ><ng-container *xOutlet=\"totalTpl; context: { $total: total }\"\r\n    >{{ 'pagination.total' | xI18n }} {{ total }} {{ 'pagination.item' | xI18n }}</ng-container\r\n  ></x-button\r\n>\r\n\r\n<ng-template #previousTpl>\r\n  <x-button\r\n    [icon]=\"'fto-chevron-left'\"\r\n    [title]=\"'pagination.previous' | xI18n\"\r\n    [disabled]=\"disabled || leftDisabled\"\r\n    (click)=\"jump(-1, true)\"\r\n  ></x-button>\r\n</ng-template>\r\n\r\n<ng-template #nextTpl>\r\n  <x-button\r\n    [icon]=\"'fto-chevron-right'\"\r\n    [title]=\"'pagination.next' | xI18n\"\r\n    [disabled]=\"disabled || rightDisabled\"\r\n    (click)=\"jump(1, true)\"\r\n  ></x-button>\r\n</ng-template>\r\n\r\n<ng-template #nodeTpl let-node=\"$node\">\r\n  <ng-container *ngIf=\"node\"> {{ node?.label }} {{ 'pagination.sizePage' | xI18n }} </ng-container>\r\n</ng-template>\r\n"]}
|
|
132
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"pagination.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/pagination/pagination.component.ts","../../../../../lib/ng-nest/ui/pagination/pagination.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  Component,\r\n  ViewEncapsulation,\r\n  ChangeDetectionStrategy,\r\n  OnChanges,\r\n  SimpleChanges,\r\n  ElementRef,\r\n  Renderer2,\r\n  ChangeDetectorRef\r\n} from '@angular/core';\r\nimport { XPaginationPrefix, XPaginationProperty } from './pagination.property';\r\nimport { XIsChange, XConfigService } from '@ng-nest/ui/core';\r\nimport { Subject } from 'rxjs';\r\nimport { XI18nService } from '@ng-nest/ui/i18n';\r\nimport { takeUntil } from 'rxjs/operators';\r\nimport { ENTER } from '@angular/cdk/keycodes';\r\n\r\n@Component({\r\n  selector: `${XPaginationPrefix}`,\r\n  templateUrl: './pagination.component.html',\r\n  styleUrls: ['./style/index.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush\r\n})\r\nexport class XPaginationComponent extends XPaginationProperty implements OnChanges {\r\n  lastIndex!: number;\r\n  indexes: number[] = [];\r\n  indexFirst: number = 1;\r\n  indexLast: number = 1;\r\n  jumpPage: number | null = null;\r\n\r\n  private _unSubject = new Subject<void>();\r\n\r\n  get leftDisabled() {\r\n    return Number(this.index) === 1 || Number(this.total) === 0;\r\n  }\r\n\r\n  get rightDisabled() {\r\n    return Number(this.index) === this.lastIndex || Number(this.total) === 0;\r\n  }\r\n\r\n  get firstActivated() {\r\n    return Number(this.index) === 1;\r\n  }\r\n\r\n  get lastActivated() {\r\n    return Number(this.index) === this.lastIndex;\r\n  }\r\n\r\n  constructor(\r\n    public configService: XConfigService,\r\n    public elementRef: ElementRef,\r\n    public renderer: Renderer2,\r\n    public cdr: ChangeDetectorRef,\r\n    public i18n: XI18nService\r\n  ) {\r\n    super();\r\n    this.renderer.addClass(this.elementRef.nativeElement, XPaginationPrefix);\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.i18n.localeChange.pipe(takeUntil(this._unSubject)).subscribe(() => this.cdr.markForCheck());\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    const { total, size, index } = changes;\r\n    XIsChange(total, size, index) && this.setIndexes();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this._unSubject.next();\r\n    this._unSubject.unsubscribe();\r\n  }\r\n\r\n  sizeChanged() {\r\n    this.setIndexes();\r\n    this.sizeChange.emit(this.size as number);\r\n  }\r\n\r\n  setIndexes() {\r\n    this.lastIndex = Math.ceil(Number(this.total) / Number(this.size)) || 1;\r\n    const indexes: number[] = [];\r\n    const current = Number(this.index) - 1;\r\n    const maxSize = Number(this.pageLinkSize);\r\n    const pages = Math.min(maxSize, this.lastIndex);\r\n    let start = Math.max(0, Math.ceil(current - pages / 2)),\r\n      end = Math.min(this.lastIndex - 1, start + pages - 1);\r\n    var delta = maxSize - (end - start + 1);\r\n    start = Math.max(0, start - delta);\r\n\r\n    for (let i = start; i <= end; i++) {\r\n      indexes.push(i + 1);\r\n    }\r\n    this.indexes = indexes;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  jump(index: number, isDiff = false) {\r\n    const ix = this.validateIndex(isDiff ? Number(this.index) + index : index);\r\n    if (ix !== this.index) {\r\n      this.index = ix;\r\n      this.setIndexes();\r\n      this.indexChange.emit(this.index);\r\n    }\r\n  }\r\n\r\n  onKeydown(event: KeyboardEvent) {\r\n    if (this.jumpPage !== null && event.keyCode === ENTER) {\r\n      if (this.jumpPage <= this.indexFirst) {\r\n        this.jump(this.indexFirst);\r\n      } else if (this.jumpPage >= this.lastIndex) {\r\n        this.jump(this.lastIndex);\r\n      } else {\r\n        this.jump(this.jumpPage);\r\n      }\r\n      this.jumpPage = null;\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  onSimpleKeydown(event: KeyboardEvent) {\r\n    if (this.index !== null && event.keyCode === ENTER) {\r\n      if (this.index <= this.indexFirst) {\r\n        this.index = this.indexFirst;\r\n      } else if (this.index >= this.lastIndex) {\r\n        this.index = this.lastIndex;\r\n      }\r\n      this.jump(this.index as number);\r\n      this.cdr.detectChanges();\r\n    }\r\n  }\r\n\r\n  validateIndex(value: number): number {\r\n    if (value > this.lastIndex) {\r\n      return this.lastIndex;\r\n    } else if (value < 1) {\r\n      return 1;\r\n    } else {\r\n      return value;\r\n    }\r\n  }\r\n\r\n  getActivated(index: number) {\r\n    return Number(this.index) === index;\r\n  }\r\n\r\n  trackByItem(_index: number, item: number) {\r\n    return item;\r\n  }\r\n}\r\n","<x-buttons *ngIf=\"!simple; else simpleTpl\" [space]=\"space\" [hiddenBorder]=\"hiddenBorder\">\r\n  <x-button\r\n    *ngIf=\"showEllipsis\"\r\n    [icon]=\"'fto-chevrons-left'\"\r\n    [title]=\"'pagination.first' | xI18n\"\r\n    [disabled]=\"disabled || firstActivated\"\r\n    (click)=\"jump(1)\"\r\n  ></x-button>\r\n  <ng-container *xOutlet=\"previousTpl\"></ng-container>\r\n  <x-button\r\n    *ngFor=\"let item of indexes; trackBy: trackByItem\"\r\n    [disabled]=\"disabled\"\r\n    [activated]=\"getActivated(item)\"\r\n    (click)=\"jump(item)\"\r\n    >{{ item }}</x-button\r\n  >\r\n  <ng-container *xOutlet=\"nextTpl\"></ng-container>\r\n  <x-button\r\n    *ngIf=\"showEllipsis && !simple\"\r\n    [icon]=\"'fto-chevrons-right'\"\r\n    [title]=\"'pagination.last' | xI18n\"\r\n    [disabled]=\"disabled || lastActivated\"\r\n    (click)=\"jump(lastIndex)\"\r\n  ></x-button>\r\n</x-buttons>\r\n<ng-template #simpleTpl>\r\n  <div class=\"x-pagination-simple\">\r\n    <x-input\r\n      [bordered]=\"!hiddenBorder\"\r\n      [before]=\"previousTpl\"\r\n      [after]=\"nextTpl\"\r\n      [style.width.px]=\"simpleIndexWidth\"\r\n      [(ngModel)]=\"index\"\r\n      (xKeydown)=\"onSimpleKeydown($event)\"\r\n    ></x-input>\r\n    <span>/</span>\r\n    <span>{{ lastIndex }}</span>\r\n  </div>\r\n</ng-template>\r\n<x-select\r\n  *ngIf=\"showSize\"\r\n  [style.width.px]=\"sizeWidth\"\r\n  class=\"x-pagination-size\"\r\n  [data]=\"sizeData\"\r\n  clearable=\"false\"\r\n  [disabled]=\"disabled\"\r\n  [bordered]=\"!hiddenBorder\"\r\n  [nodeTpl]=\"nodeTpl\"\r\n  [(ngModel)]=\"size\"\r\n  (ngModelChange)=\"sizeChanged()\"\r\n></x-select>\r\n<div *ngIf=\"showJump && !simple\" class=\"x-pagination-jump\">\r\n  <span>{{ 'pagination.jump' | xI18n }}</span>\r\n  <x-input [bordered]=\"!hiddenBorder\" [style.width.px]=\"jumpWidth\" [(ngModel)]=\"jumpPage\" (xKeydown)=\"onKeydown($event)\"></x-input>\r\n</div>\r\n<x-button *ngIf=\"showTotal\" [disabled]=\"disabled\" class=\"x-pagination-total\" [type]=\"hiddenBorder === true ? 'text' : 'initial'\"\r\n  ><ng-container *xOutlet=\"totalTpl; context: { $total: total }\"\r\n    >{{ 'pagination.total' | xI18n }} {{ total }} {{ 'pagination.item' | xI18n }}</ng-container\r\n  ></x-button\r\n>\r\n\r\n<ng-template #previousTpl>\r\n  <x-button\r\n    [icon]=\"'fto-chevron-left'\"\r\n    [title]=\"'pagination.previous' | xI18n\"\r\n    [disabled]=\"disabled || leftDisabled\"\r\n    (click)=\"jump(-1, true)\"\r\n  ></x-button>\r\n</ng-template>\r\n\r\n<ng-template #nextTpl>\r\n  <x-button\r\n    [icon]=\"'fto-chevron-right'\"\r\n    [title]=\"'pagination.next' | xI18n\"\r\n    [disabled]=\"disabled || rightDisabled\"\r\n    (click)=\"jump(1, true)\"\r\n  ></x-button>\r\n</ng-template>\r\n\r\n<ng-template #nodeTpl let-node=\"$node\">\r\n  <ng-container *ngIf=\"node\"> {{ node?.label }} {{ 'pagination.sizePage' | xI18n }} </ng-container>\r\n</ng-template>\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Component, ViewEncapsulation, ChangeDetectionStrategy, ViewChild } from '@angular/core';
|
|
2
|
-
import { XIsEmpty, XClearClass } from '@ng-nest/ui/core';
|
|
2
|
+
import { XIsEmpty, XClearClass, XIsString, XIsObject } from '@ng-nest/ui/core';
|
|
3
3
|
import { XRatePrefix, XRateProperty } from './rate.property';
|
|
4
4
|
import { XValueAccessor } from '@ng-nest/ui/base-form';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -18,6 +18,23 @@ export class XRateComponent extends XRateProperty {
|
|
|
18
18
|
this.hoverHalfActivated = 0;
|
|
19
19
|
this.rateNodes = [];
|
|
20
20
|
}
|
|
21
|
+
get getColor() {
|
|
22
|
+
let color = '';
|
|
23
|
+
if (XIsString(this.color)) {
|
|
24
|
+
color = this.color;
|
|
25
|
+
}
|
|
26
|
+
else if (XIsObject(this.color)) {
|
|
27
|
+
this.color = this.color;
|
|
28
|
+
let val = this.half ? (Math.floor(this.hoverActivated) + this.hoverHalfActivated) * 0.5 : this.hoverActivated;
|
|
29
|
+
for (let key in this.color) {
|
|
30
|
+
if (this.color[key](val)) {
|
|
31
|
+
color = key;
|
|
32
|
+
break;
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
return color;
|
|
37
|
+
}
|
|
21
38
|
writeValue(value) {
|
|
22
39
|
if (XIsEmpty(value))
|
|
23
40
|
value = 0;
|
|
@@ -84,12 +101,12 @@ export class XRateComponent extends XRateProperty {
|
|
|
84
101
|
}
|
|
85
102
|
}
|
|
86
103
|
/** @nocollapse */ /** @nocollapse */ XRateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XRateComponent, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: i0.ChangeDetectorRef }, { token: i1.XConfigService }], target: i0.ɵɵFactoryTarget.Component });
|
|
87
|
-
/** @nocollapse */ /** @nocollapse */ XRateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XRateComponent, selector: "x-rate", providers: [XValueAccessor(XRateComponent)], viewQueries: [{ propertyName: "rate", first: true, predicate: ["rate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n #rate\r\n class=\"x-rate\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-rate-icons\" (mouseleave)=\"leaveRates()\">\r\n <div\r\n class=\"x-rate-icon\"\r\n [class.activated]=\"rate <= hoverActivated\"\r\n [class.half-activated]=\"rate <= hoverHalfActivated\"\r\n *ngFor=\"let rate of rates; index as i; trackBy: trackByItem\"\r\n >\r\n <div
|
|
104
|
+
/** @nocollapse */ /** @nocollapse */ XRateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XRateComponent, selector: "x-rate", providers: [XValueAccessor(XRateComponent)], viewQueries: [{ propertyName: "rate", first: true, predicate: ["rate"], descendants: true, static: true }], usesInheritance: true, ngImport: i0, template: "<div\r\n #rate\r\n class=\"x-rate\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-rate-icons\" (mouseleave)=\"leaveRates()\">\r\n <div\r\n class=\"x-rate-icon\"\r\n [class.activated]=\"rate <= hoverActivated\"\r\n [class.half-activated]=\"rate <= hoverHalfActivated\"\r\n [style.color]=\"rate <= hoverActivated ? getColor : ''\"\r\n *ngFor=\"let rate of rates; index as i; trackBy: trackByItem\"\r\n >\r\n <div\r\n *ngIf=\"half\"\r\n class=\"x-rate-half\"\r\n [style.color]=\"rate <= hoverHalfActivated ? getColor : ''\"\r\n (mouseenter)=\"rateHalfHover(rate, $event)\"\r\n (click)=\"rateHalfClick(rate, $event)\"\r\n >\r\n <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n </ng-container>\r\n </div>\r\n <div class=\"x-rate-back\" (mouseenter)=\"rateHover(rate, $event)\" (click)=\"rateClick(rate, $event)\">\r\n <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #iconTpl>\r\n <x-icon type=\"adf-star\"></x-icon>\r\n</ng-template>\r\n", styles: [".x-rate{margin:0;padding:0;width:100%}.x-rate.x-flex{display:flex}.x-rate.x-justify-start{justify-content:flex-start}.x-rate.x-justify-center{justify-content:center}.x-rate.x-justify-end{justify-content:flex-end}.x-rate.x-justify-space-between{justify-content:space-between}.x-rate.x-justify-space-around{justify-content:space-around}.x-rate.x-align-start{align-items:flex-start}.x-rate.x-align-center{align-items:center}.x-rate.x-align-end{align-items:flex-end}.x-rate.x-direction-column{flex-direction:column}.x-rate.x-direction-column-reverse{flex-direction:column-reverse}.x-rate.x-direction-row{flex-direction:row}.x-rate.x-direction-row-reverse{flex-direction:row-reverse}.x-rate>label{display:inline-block;white-space:nowrap;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);position:relative;color:var(--x-text-300);font-weight:600}.x-rate>label.x-text-align-start{text-align:start}.x-rate>label.x-text-align-center{text-align:center}.x-rate>label.x-text-align-end{text-align:end}.x-rate-icons{display:inline-flex;align-items:center;height:calc(var(--x-font-size) + .875rem);cursor:pointer}.x-rate-icon{margin:0 .2rem;display:flex;align-items:center;position:relative;color:var(--x-info);transition:transform var(--x-animation-duration-base),color var(--x-animation-duration-base);font-size:calc(var(--x-font-size-big) + .125rem)}.x-rate-icon .x-icon{vertical-align:0}.x-rate-icon:hover{transform:scale(1.1)}.x-rate-icon.activated,.x-rate-icon.half-activated .x-rate-half{color:var(--x-warning)}.x-rate-half{position:absolute;top:0;left:0;width:50%;height:100%;overflow:hidden;display:flex;align-items:center}.x-rate-half:hover{opacity:1}.x-rate-back{display:flex;align-items:center}.x-rate.x-invalid>label,.x-rate.x-required>label{color:var(--x-danger)}.x-rate.x-disabled .x-rate-icons{cursor:not-allowed;opacity:.8}.x-rate.x-direction-row>label{padding:0 .5rem 0 0}.x-rate.x-direction-row-reverse>label{padding:0 0 0 .5rem}.x-rate.x-direction-column,.x-rate.x-direction-column-reverse{align-items:inherit}\n"], components: [{ type: i2.XIconComponent, selector: "x-icon" }], directives: [{ type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { type: i3.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { type: i3.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None });
|
|
88
105
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XRateComponent, decorators: [{
|
|
89
106
|
type: Component,
|
|
90
|
-
args: [{ selector: `${XRatePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XRateComponent)], template: "<div\r\n #rate\r\n class=\"x-rate\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-rate-icons\" (mouseleave)=\"leaveRates()\">\r\n <div\r\n class=\"x-rate-icon\"\r\n [class.activated]=\"rate <= hoverActivated\"\r\n [class.half-activated]=\"rate <= hoverHalfActivated\"\r\n *ngFor=\"let rate of rates; index as i; trackBy: trackByItem\"\r\n >\r\n <div
|
|
107
|
+
args: [{ selector: `${XRatePrefix}`, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, providers: [XValueAccessor(XRateComponent)], template: "<div\r\n #rate\r\n class=\"x-rate\"\r\n [class.x-flex]=\"justify || align || direction\"\r\n [class.x-disabled]=\"disabled\"\r\n [class.x-required]=\"requiredIsEmpty\"\r\n [class.x-invalid]=\"invalid\"\r\n>\r\n <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n <div class=\"x-rate-icons\" (mouseleave)=\"leaveRates()\">\r\n <div\r\n class=\"x-rate-icon\"\r\n [class.activated]=\"rate <= hoverActivated\"\r\n [class.half-activated]=\"rate <= hoverHalfActivated\"\r\n [style.color]=\"rate <= hoverActivated ? getColor : ''\"\r\n *ngFor=\"let rate of rates; index as i; trackBy: trackByItem\"\r\n >\r\n <div\r\n *ngIf=\"half\"\r\n class=\"x-rate-half\"\r\n [style.color]=\"rate <= hoverHalfActivated ? getColor : ''\"\r\n (mouseenter)=\"rateHalfHover(rate, $event)\"\r\n (click)=\"rateHalfClick(rate, $event)\"\r\n >\r\n <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n </ng-container>\r\n </div>\r\n <div class=\"x-rate-back\" (mouseenter)=\"rateHover(rate, $event)\" (click)=\"rateClick(rate, $event)\">\r\n <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n </ng-container>\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n\r\n<ng-template #iconTpl>\r\n <x-icon type=\"adf-star\"></x-icon>\r\n</ng-template>\r\n", styles: [".x-rate{margin:0;padding:0;width:100%}.x-rate.x-flex{display:flex}.x-rate.x-justify-start{justify-content:flex-start}.x-rate.x-justify-center{justify-content:center}.x-rate.x-justify-end{justify-content:flex-end}.x-rate.x-justify-space-between{justify-content:space-between}.x-rate.x-justify-space-around{justify-content:space-around}.x-rate.x-align-start{align-items:flex-start}.x-rate.x-align-center{align-items:center}.x-rate.x-align-end{align-items:flex-end}.x-rate.x-direction-column{flex-direction:column}.x-rate.x-direction-column-reverse{flex-direction:column-reverse}.x-rate.x-direction-row{flex-direction:row}.x-rate.x-direction-row-reverse{flex-direction:row-reverse}.x-rate>label{display:inline-block;white-space:nowrap;height:calc(var(--x-font-size) + .875rem);line-height:calc(var(--x-font-size) + .875rem);position:relative;color:var(--x-text-300);font-weight:600}.x-rate>label.x-text-align-start{text-align:start}.x-rate>label.x-text-align-center{text-align:center}.x-rate>label.x-text-align-end{text-align:end}.x-rate-icons{display:inline-flex;align-items:center;height:calc(var(--x-font-size) + .875rem);cursor:pointer}.x-rate-icon{margin:0 .2rem;display:flex;align-items:center;position:relative;color:var(--x-info);transition:transform var(--x-animation-duration-base),color var(--x-animation-duration-base);font-size:calc(var(--x-font-size-big) + .125rem)}.x-rate-icon .x-icon{vertical-align:0}.x-rate-icon:hover{transform:scale(1.1)}.x-rate-icon.activated,.x-rate-icon.half-activated .x-rate-half{color:var(--x-warning)}.x-rate-half{position:absolute;top:0;left:0;width:50%;height:100%;overflow:hidden;display:flex;align-items:center}.x-rate-half:hover{opacity:1}.x-rate-back{display:flex;align-items:center}.x-rate.x-invalid>label,.x-rate.x-required>label{color:var(--x-danger)}.x-rate.x-disabled .x-rate-icons{cursor:not-allowed;opacity:.8}.x-rate.x-direction-row>label{padding:0 .5rem 0 0}.x-rate.x-direction-row-reverse>label{padding:0 0 0 .5rem}.x-rate.x-direction-column,.x-rate.x-direction-column-reverse{align-items:inherit}\n"] }]
|
|
91
108
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: i0.ChangeDetectorRef }, { type: i1.XConfigService }]; }, propDecorators: { rate: [{
|
|
92
109
|
type: ViewChild,
|
|
93
110
|
args: ['rate', { static: true }]
|
|
94
111
|
}] } });
|
|
95
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rate.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/rate/rate.component.ts","../../../../../lib/ng-nest/ui/rate/rate.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, Renderer2, ElementRef, ChangeDetectorRef, ViewChild } from '@angular/core';\r\nimport { XIsEmpty, XClearClass, XConfigService } from '@ng-nest/ui/core';\r\nimport { XRatePrefix, XRateProperty } from './rate.property';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\n\r\n@Component({\r\n  selector: `${XRatePrefix}`,\r\n  templateUrl: './rate.component.html',\r\n  styleUrls: ['./rate.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XRateComponent)]\r\n})\r\nexport class XRateComponent extends XRateProperty {\r\n  @ViewChild('rate', { static: true }) rate!: ElementRef;\r\n  rates: number[] = [];\r\n\r\n  hoverActivated = 0;\r\n  hoverHalfActivated = 0;\r\n\r\n  override writeValue(value: any) {\r\n    if (XIsEmpty(value)) value = 0;\r\n    this.value = value;\r\n    this.hoverActivated = value;\r\n    this.hoverHalfActivated = Math.ceil(value);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  rateNodes: any = [];\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setRates();\r\n    this.setFlex(this.rate.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setClassMap();\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.labelMap);\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  setRates() {\r\n    this.rates = Array(this.count)\r\n      .fill(0)\r\n      .map((_, i) => i + 1);\r\n  }\r\n\r\n  rateHover(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.hoverActivated = rate;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  leaveRates() {\r\n    if (this.disabled) return;\r\n    const activited = this.value;\r\n    this.hoverActivated = activited;\r\n    this.hoverHalfActivated = Math.ceil(activited);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  rateClick(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.value = this.value === rate ? 0 : rate;\r\n    if (this.onChange) this.onChange(this.value);\r\n  }\r\n\r\n  rateHalfHover(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.hoverActivated = rate - 1;\r\n    this.hoverHalfActivated = rate;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  rateHalfClick(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.value = rate - 0.5;\r\n    if (this.onChange) this.onChange(this.value);\r\n  }\r\n\r\n  trackByItem(_index: number, item: number) {\r\n    return item;\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div\r\n  #rate\r\n  class=\"x-rate\"\r\n  [class.x-flex]=\"justify || align || direction\"\r\n  [class.x-disabled]=\"disabled\"\r\n  [class.x-required]=\"requiredIsEmpty\"\r\n  [class.x-invalid]=\"invalid\"\r\n>\r\n  <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n  <div class=\"x-rate-icons\" (mouseleave)=\"leaveRates()\">\r\n    <div\r\n      class=\"x-rate-icon\"\r\n      [class.activated]=\"rate <= hoverActivated\"\r\n      [class.half-activated]=\"rate <= hoverHalfActivated\"\r\n      *ngFor=\"let rate of rates; index as i; trackBy: trackByItem\"\r\n    >\r\n      <div *ngIf=\"half\" class=\"x-rate-half\" (mouseenter)=\"rateHalfHover(rate, $event)\" (click)=\"rateHalfClick(rate, $event)\">\r\n        <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n          <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"x-rate-back\" (mouseenter)=\"rateHover(rate, $event)\" (click)=\"rateClick(rate, $event)\">\r\n        <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n          <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #iconTpl>\r\n  <x-icon type=\"adf-star\"></x-icon>\r\n</ng-template>\r\n"]}
|
|
112
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"rate.component.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/rate/rate.component.ts","../../../../../lib/ng-nest/ui/rate/rate.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ViewEncapsulation, ChangeDetectionStrategy, Renderer2, ElementRef, ChangeDetectorRef, ViewChild } from '@angular/core';\r\nimport { XIsEmpty, XClearClass, XConfigService, XIsString, XIsObject } from '@ng-nest/ui/core';\r\nimport { XRatePrefix, XRateProperty } from './rate.property';\r\nimport { XValueAccessor } from '@ng-nest/ui/base-form';\r\n\r\n@Component({\r\n  selector: `${XRatePrefix}`,\r\n  templateUrl: './rate.component.html',\r\n  styleUrls: ['./rate.component.scss'],\r\n  encapsulation: ViewEncapsulation.None,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  providers: [XValueAccessor(XRateComponent)]\r\n})\r\nexport class XRateComponent extends XRateProperty {\r\n  @ViewChild('rate', { static: true }) rate!: ElementRef;\r\n  rates: number[] = [];\r\n\r\n  hoverActivated = 0;\r\n  hoverHalfActivated = 0;\r\n\r\n  get getColor() {\r\n    let color = '';\r\n    if (XIsString(this.color)) {\r\n      color = this.color as string;\r\n    } else if (XIsObject(this.color)) {\r\n      this.color = this.color as { [color: string]: (rate: number) => boolean };\r\n      let val = this.half ? (Math.floor(this.hoverActivated) + this.hoverHalfActivated) * 0.5 : this.hoverActivated;\r\n      for (let key in this.color) {\r\n        if (this.color[key](val)) {\r\n          color = key;\r\n          break;\r\n        }\r\n      }\r\n    }\r\n    return color;\r\n  }\r\n\r\n  override writeValue(value: any) {\r\n    if (XIsEmpty(value)) value = 0;\r\n    this.value = value;\r\n    this.hoverActivated = value;\r\n    this.hoverHalfActivated = Math.ceil(value);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  rateNodes: any = [];\r\n  constructor(\r\n    public renderer: Renderer2,\r\n    public elementRef: ElementRef,\r\n    public cdr: ChangeDetectorRef,\r\n    public configService: XConfigService\r\n  ) {\r\n    super();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setRates();\r\n    this.setFlex(this.rate.nativeElement, this.renderer, this.justify, this.align, this.direction);\r\n    this.setClassMap();\r\n  }\r\n\r\n  setClassMap() {\r\n    XClearClass(this.labelMap);\r\n    this.labelMap[`x-text-align-${this.labelAlign}`] = this.labelAlign ? true : false;\r\n  }\r\n\r\n  setRates() {\r\n    this.rates = Array(this.count)\r\n      .fill(0)\r\n      .map((_, i) => i + 1);\r\n  }\r\n\r\n  rateHover(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.hoverActivated = rate;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  leaveRates() {\r\n    if (this.disabled) return;\r\n    const activited = this.value;\r\n    this.hoverActivated = activited;\r\n    this.hoverHalfActivated = Math.ceil(activited);\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  rateClick(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.value = this.value === rate ? 0 : rate;\r\n    if (this.onChange) this.onChange(this.value);\r\n  }\r\n\r\n  rateHalfHover(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.hoverActivated = rate - 1;\r\n    this.hoverHalfActivated = rate;\r\n    this.cdr.detectChanges();\r\n  }\r\n\r\n  rateHalfClick(rate: number, _event: MouseEvent) {\r\n    if (this.disabled) return;\r\n    this.value = rate - 0.5;\r\n    if (this.onChange) this.onChange(this.value);\r\n  }\r\n\r\n  trackByItem(_index: number, item: number) {\r\n    return item;\r\n  }\r\n\r\n  formControlChanges() {\r\n    this.ngOnInit();\r\n    this.cdr.detectChanges();\r\n  }\r\n}\r\n","<div\r\n  #rate\r\n  class=\"x-rate\"\r\n  [class.x-flex]=\"justify || align || direction\"\r\n  [class.x-disabled]=\"disabled\"\r\n  [class.x-required]=\"requiredIsEmpty\"\r\n  [class.x-invalid]=\"invalid\"\r\n>\r\n  <label *ngIf=\"label\" [style.width]=\"labelWidth\" [ngClass]=\"labelMap\">{{ label }}</label>\r\n  <div class=\"x-rate-icons\" (mouseleave)=\"leaveRates()\">\r\n    <div\r\n      class=\"x-rate-icon\"\r\n      [class.activated]=\"rate <= hoverActivated\"\r\n      [class.half-activated]=\"rate <= hoverHalfActivated\"\r\n      [style.color]=\"rate <= hoverActivated ? getColor : ''\"\r\n      *ngFor=\"let rate of rates; index as i; trackBy: trackByItem\"\r\n    >\r\n      <div\r\n        *ngIf=\"half\"\r\n        class=\"x-rate-half\"\r\n        [style.color]=\"rate <= hoverHalfActivated ? getColor : ''\"\r\n        (mouseenter)=\"rateHalfHover(rate, $event)\"\r\n        (click)=\"rateHalfClick(rate, $event)\"\r\n      >\r\n        <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n          <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n        </ng-container>\r\n      </div>\r\n      <div class=\"x-rate-back\" (mouseenter)=\"rateHover(rate, $event)\" (click)=\"rateClick(rate, $event)\">\r\n        <ng-container *ngIf=\"customTemp; else iconTpl\">\r\n          <ng-container *ngTemplateOutlet=\"customTemp\"></ng-container>\r\n        </ng-container>\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n\r\n<ng-template #iconTpl>\r\n  <x-icon type=\"adf-star\"></x-icon>\r\n</ng-template>\r\n"]}
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { __decorate } from "tslib";
|
|
2
|
-
import { XInputNumber, XInputBoolean } from '@ng-nest/ui/core';
|
|
2
|
+
import { XInputNumber, XInputBoolean, XWithConfig } from '@ng-nest/ui/core';
|
|
3
3
|
import { Input, Component } from '@angular/core';
|
|
4
4
|
import { XControlValueAccessor } from '@ng-nest/ui/base-form';
|
|
5
5
|
import * as i0 from "@angular/core";
|
|
@@ -9,6 +9,7 @@ import * as i0 from "@angular/core";
|
|
|
9
9
|
* @decorator component
|
|
10
10
|
*/
|
|
11
11
|
export const XRatePrefix = 'x-rate';
|
|
12
|
+
const X_CONFIG_NAME = 'rate';
|
|
12
13
|
/**
|
|
13
14
|
* Rate Property
|
|
14
15
|
*/
|
|
@@ -23,13 +24,16 @@ export class XRateProperty extends XControlValueAccessor {
|
|
|
23
24
|
}
|
|
24
25
|
}
|
|
25
26
|
/** @nocollapse */ /** @nocollapse */ XRateProperty.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XRateProperty, deps: null, target: i0.ɵɵFactoryTarget.Component });
|
|
26
|
-
/** @nocollapse */ /** @nocollapse */ XRateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XRateProperty, selector: "ng-component", inputs: { count: "count", half: "half", customTemp: "customTemp" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
|
|
27
|
+
/** @nocollapse */ /** @nocollapse */ XRateProperty.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "12.0.0", version: "13.3.2", type: XRateProperty, selector: "ng-component", inputs: { count: "count", half: "half", color: "color", customTemp: "customTemp" }, usesInheritance: true, ngImport: i0, template: '', isInline: true });
|
|
27
28
|
__decorate([
|
|
28
29
|
XInputNumber()
|
|
29
30
|
], XRateProperty.prototype, "count", void 0);
|
|
30
31
|
__decorate([
|
|
31
32
|
XInputBoolean()
|
|
32
33
|
], XRateProperty.prototype, "half", void 0);
|
|
34
|
+
__decorate([
|
|
35
|
+
XWithConfig(X_CONFIG_NAME)
|
|
36
|
+
], XRateProperty.prototype, "color", void 0);
|
|
33
37
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XRateProperty, decorators: [{
|
|
34
38
|
type: Component,
|
|
35
39
|
args: [{ template: '' }]
|
|
@@ -37,7 +41,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImpor
|
|
|
37
41
|
type: Input
|
|
38
42
|
}], half: [{
|
|
39
43
|
type: Input
|
|
44
|
+
}], color: [{
|
|
45
|
+
type: Input
|
|
40
46
|
}], customTemp: [{
|
|
41
47
|
type: Input
|
|
42
48
|
}] } });
|
|
43
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
49
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmF0ZS5wcm9wZXJ0eS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uL2xpYi9uZy1uZXN0L3VpL3JhdGUvcmF0ZS5wcm9wZXJ0eS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiO0FBQUEsT0FBTyxFQUFFLFlBQVksRUFBVyxhQUFhLEVBQXVCLFdBQVcsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQzFHLE9BQU8sRUFBRSxLQUFLLEVBQUUsU0FBUyxFQUFlLE1BQU0sZUFBZSxDQUFDO0FBQzlELE9BQU8sRUFBRSxxQkFBcUIsRUFBZSxNQUFNLHVCQUF1QixDQUFDOztBQUUzRTs7OztHQUlHO0FBQ0gsTUFBTSxDQUFDLE1BQU0sV0FBVyxHQUFHLFFBQVEsQ0FBQztBQUNwQyxNQUFNLGFBQWEsR0FBRyxNQUFNLENBQUM7QUFFN0I7O0dBRUc7QUFFSCxNQUFNLE9BQU8sYUFBYyxTQUFRLHFCQUEwQjtJQUQ3RDs7UUFFRTs7O1dBR0c7UUFDc0IsVUFBSyxHQUFZLENBQUMsQ0FBQztLQWdCN0M7O2dKQXJCWSxhQUFhO29JQUFiLGFBQWEsK0pBREgsRUFBRTtBQU1FO0lBQWYsWUFBWSxFQUFFOzRDQUFvQjtBQUtsQjtJQUFoQixhQUFhLEVBQUU7MkNBQWlCO0FBS087SUFBdkMsV0FBVyxDQUFhLGFBQWEsQ0FBQzs0Q0FBb0I7MkZBZnpELGFBQWE7a0JBRHpCLFNBQVM7bUJBQUMsRUFBRSxRQUFRLEVBQUUsRUFBRSxFQUFFOzhCQU1BLEtBQUs7c0JBQTdCLEtBQUs7Z0JBS29CLElBQUk7c0JBQTdCLEtBQUs7Z0JBSzJDLEtBQUs7c0JBQXJELEtBQUs7Z0JBS0csVUFBVTtzQkFBbEIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IFhJbnB1dE51bWJlciwgWE51bWJlciwgWElucHV0Qm9vbGVhbiwgWEJvb2xlYW4sIFhUZW1wbGF0ZSwgWFdpdGhDb25maWcgfSBmcm9tICdAbmctbmVzdC91aS9jb3JlJztcclxuaW1wb3J0IHsgSW5wdXQsIENvbXBvbmVudCwgVGVtcGxhdGVSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcclxuaW1wb3J0IHsgWENvbnRyb2xWYWx1ZUFjY2Vzc29yLCBYRm9ybU9wdGlvbiB9IGZyb20gJ0BuZy1uZXN0L3VpL2Jhc2UtZm9ybSc7XHJcblxyXG4vKipcclxuICogUmF0ZVxyXG4gKiBAc2VsZWN0b3IgeC1yYXRlXHJcbiAqIEBkZWNvcmF0b3IgY29tcG9uZW50XHJcbiAqL1xyXG5leHBvcnQgY29uc3QgWFJhdGVQcmVmaXggPSAneC1yYXRlJztcclxuY29uc3QgWF9DT05GSUdfTkFNRSA9ICdyYXRlJztcclxuXHJcbi8qKlxyXG4gKiBSYXRlIFByb3BlcnR5XHJcbiAqL1xyXG5AQ29tcG9uZW50KHsgdGVtcGxhdGU6ICcnIH0pXHJcbmV4cG9ydCBjbGFzcyBYUmF0ZVByb3BlcnR5IGV4dGVuZHMgWENvbnRyb2xWYWx1ZUFjY2Vzc29yPGFueT4gaW1wbGVtZW50cyBYUmF0ZU9wdGlvbiB7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOivhOWIhuS4quaVsFxyXG4gICAqIEBlbl9VUyBOdW1iZXIgb2YgcmF0aW5nc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYSW5wdXROdW1iZXIoKSBjb3VudDogWE51bWJlciA9IDU7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWNiuaYn+aooeW8j1xyXG4gICAqIEBlbl9VUyBOdW1iZXIgb2YgcmF0aW5nc1xyXG4gICAqL1xyXG4gIEBJbnB1dCgpIEBYSW5wdXRCb29sZWFuKCkgaGFsZj86IFhCb29sZWFuO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDpopzoibJcclxuICAgKiBAZW5fVVMgQ29sb3JcclxuICAgKi9cclxuICBASW5wdXQoKSBAWFdpdGhDb25maWc8WFJhdGVDb2xvcj4oWF9DT05GSUdfTkFNRSkgY29sb3I/OiBYUmF0ZUNvbG9yO1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDoh6rlrprkuYnmqKHmnb9cclxuICAgKiBAZW5fVVMgQ3VzdG9tIHRlbXBsYXRlXHJcbiAgICovXHJcbiAgQElucHV0KCkgY3VzdG9tVGVtcCE6IFRlbXBsYXRlUmVmPGFueT47XHJcbn1cclxuXHJcbi8qKlxyXG4gKiBAemhfQ04g6aKc6Imy57G75Z6LXHJcbiAqIEBlbl9VUyBDb2xvciB0eXBlXHJcbiAqL1xyXG5leHBvcnQgdHlwZSBYUmF0ZUNvbG9yID0gc3RyaW5nIHwgeyBbY29sb3I6IHN0cmluZ106IChyYXRlOiBudW1iZXIpID0+IGJvb2xlYW4gfTtcclxuXHJcbi8qKlxyXG4gKiBSYXRlIE9wdGlvblxyXG4gKiBAdW5kb2N1bWVudCB0cnVlXHJcbiAqL1xyXG5leHBvcnQgaW50ZXJmYWNlIFhSYXRlT3B0aW9uIGV4dGVuZHMgWEZvcm1PcHRpb24ge1xyXG4gIC8qKlxyXG4gICAqIEB6aF9DTiDor4TliIbkuKrmlbBcclxuICAgKiBAZW5fVVMgTnVtYmVyIG9mIHJhdGluZ3NcclxuICAgKi9cclxuICBjb3VudD86IFhOdW1iZXI7XHJcbiAgLyoqXHJcbiAgICogQHpoX0NOIOWNiuaYn+aooeW8j1xyXG4gICAqIEBlbl9VUyBOdW1iZXIgb2YgcmF0aW5nc1xyXG4gICAqL1xyXG4gIGhhbGY/OiBYQm9vbGVhbjtcclxuICAvKipcclxuICAgKiBAemhfQ04g6Ieq5a6a5LmJ5qih5p2/XHJcbiAgICogQGVuX1VTIEN1c3RvbSB0ZW1wbGF0ZVxyXG4gICAqL1xyXG4gIGN1c3RvbVRlbXA/OiBYVGVtcGxhdGU7XHJcbn1cclxuIl19
|
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { DOCUMENT } from '@angular/common';
|
|
2
|
-
import { Directive, HostListener, Inject } from '@angular/core';
|
|
3
|
-
import { XIsArray, XIsString } from '@ng-nest/ui/core';
|
|
2
|
+
import { Directive, HostBinding, HostListener, Inject } from '@angular/core';
|
|
3
|
+
import { XIsArray, XIsChange, XIsString } from '@ng-nest/ui/core';
|
|
4
4
|
import { fromEvent, takeUntil } from 'rxjs';
|
|
5
5
|
import { XResizablePrefix, XResizableProperty } from './resizable.property';
|
|
6
6
|
import * as i0 from "@angular/core";
|
|
@@ -15,9 +15,13 @@ export class XResizableDirective extends XResizableProperty {
|
|
|
15
15
|
this.newBox = { clientWidth: 0, clientHeight: 0, offsetLeft: 0, offsetTop: 0 };
|
|
16
16
|
this.positionNodes = {};
|
|
17
17
|
this.activatingNodes = [];
|
|
18
|
+
this.firstLoaded = true;
|
|
18
19
|
this.document = doc;
|
|
19
20
|
this.ele = this.elementRef.nativeElement;
|
|
20
21
|
}
|
|
22
|
+
get getDisabled() {
|
|
23
|
+
return !this.xResizable;
|
|
24
|
+
}
|
|
21
25
|
ngOnInit() {
|
|
22
26
|
this.setMapClass();
|
|
23
27
|
}
|
|
@@ -27,6 +31,10 @@ export class XResizableDirective extends XResizableProperty {
|
|
|
27
31
|
ngOnDestroy() {
|
|
28
32
|
this.destroySubscription();
|
|
29
33
|
}
|
|
34
|
+
ngOnChanges(changes) {
|
|
35
|
+
const { xResizable } = changes;
|
|
36
|
+
XIsChange(xResizable) && this.setPosition();
|
|
37
|
+
}
|
|
30
38
|
mousedown(event) {
|
|
31
39
|
if (!this.xResizable)
|
|
32
40
|
return;
|
|
@@ -61,7 +69,7 @@ export class XResizableDirective extends XResizableProperty {
|
|
|
61
69
|
this.renderer.addClass(this.ele, XResizablePrefix);
|
|
62
70
|
}
|
|
63
71
|
setPosition() {
|
|
64
|
-
if (!this.xResizable)
|
|
72
|
+
if (!this.xResizable && !this.firstLoaded)
|
|
65
73
|
return;
|
|
66
74
|
let positions = [];
|
|
67
75
|
if (XIsString(this.position)) {
|
|
@@ -78,10 +86,13 @@ export class XResizableDirective extends XResizableProperty {
|
|
|
78
86
|
}
|
|
79
87
|
this.createNode(...this.positions);
|
|
80
88
|
const computedStyle = window.getComputedStyle(this.ele);
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
89
|
+
setTimeout(() => {
|
|
90
|
+
this.minWidth = parseFloat(computedStyle.minWidth);
|
|
91
|
+
this.maxWidth = parseFloat(computedStyle.maxWidth);
|
|
92
|
+
this.minHeight = parseFloat(computedStyle.minHeight);
|
|
93
|
+
this.maxHeight = parseFloat(computedStyle.maxHeight);
|
|
94
|
+
this.firstLoaded = false;
|
|
95
|
+
});
|
|
85
96
|
}
|
|
86
97
|
setActivatingNodes(direction) {
|
|
87
98
|
if (!this.positions.includes(direction))
|
|
@@ -159,46 +170,76 @@ export class XResizableDirective extends XResizableProperty {
|
|
|
159
170
|
offsetLeft: this.newBox.offsetLeft - Number(this.offsetLeft),
|
|
160
171
|
offsetTop: this.newBox.offsetTop - Number(this.offsetTop)
|
|
161
172
|
};
|
|
162
|
-
this.
|
|
163
|
-
this.
|
|
164
|
-
this.resizing.emit({ ...this.newBox, event: evt });
|
|
173
|
+
this.resizeBox(box);
|
|
174
|
+
this.resizing.emit({ ...this.newBox, event: evt, direction: this.direction });
|
|
165
175
|
}
|
|
166
|
-
|
|
176
|
+
resizeBox(box) {
|
|
177
|
+
if (this.ghost)
|
|
178
|
+
return;
|
|
167
179
|
const overMinWidth = !this.minWidth || box.clientWidth >= this.minWidth;
|
|
168
180
|
const underMaxWidth = !this.maxWidth || box.clientWidth <= this.maxWidth;
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
181
|
+
const overMinHeight = !this.minHeight || box.clientHeight >= this.minHeight;
|
|
182
|
+
const underMaxHeight = !this.maxHeight || box.clientHeight <= this.maxHeight;
|
|
183
|
+
switch (this.direction) {
|
|
184
|
+
case 'right':
|
|
185
|
+
if (overMinWidth && underMaxWidth) {
|
|
172
186
|
this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);
|
|
173
187
|
}
|
|
174
|
-
|
|
175
|
-
|
|
176
|
-
|
|
177
|
-
|
|
178
|
-
|
|
188
|
+
break;
|
|
189
|
+
case 'top-end':
|
|
190
|
+
if (overMinWidth && underMaxWidth) {
|
|
191
|
+
this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);
|
|
192
|
+
}
|
|
193
|
+
if (overMinHeight && underMaxHeight) {
|
|
194
|
+
this.renderer.setStyle(this.ele, 'top', `${box.offsetTop}px`);
|
|
195
|
+
this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);
|
|
196
|
+
}
|
|
197
|
+
break;
|
|
198
|
+
case 'bottom-end':
|
|
199
|
+
if (overMinWidth && underMaxWidth) {
|
|
200
|
+
this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);
|
|
201
|
+
}
|
|
202
|
+
if (overMinHeight && underMaxHeight) {
|
|
203
|
+
this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);
|
|
204
|
+
}
|
|
205
|
+
break;
|
|
206
|
+
case 'bottom-start':
|
|
207
|
+
if (overMinWidth && underMaxWidth) {
|
|
179
208
|
this.renderer.setStyle(this.ele, 'left', `${box.offsetLeft}px`);
|
|
180
209
|
this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);
|
|
181
210
|
}
|
|
182
|
-
|
|
183
|
-
}
|
|
184
|
-
}
|
|
185
|
-
resizeHeight(box) {
|
|
186
|
-
const overMinHeight = !this.minHeight || box.clientHeight >= this.minHeight;
|
|
187
|
-
const underMaxHeight = !this.maxHeight || box.clientHeight <= this.maxHeight;
|
|
188
|
-
if (['bottom-end', 'bottom', 'bottom-start'].includes(this.direction)) {
|
|
189
|
-
if (overMinHeight && underMaxHeight) {
|
|
190
|
-
if (!this.ghost) {
|
|
211
|
+
if (overMinHeight && underMaxHeight) {
|
|
191
212
|
this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);
|
|
192
213
|
}
|
|
193
|
-
|
|
194
|
-
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
214
|
+
break;
|
|
215
|
+
case 'left':
|
|
216
|
+
console.log(this.minWidth);
|
|
217
|
+
if (overMinWidth && underMaxWidth) {
|
|
218
|
+
this.renderer.setStyle(this.ele, 'left', `${box.offsetLeft}px`);
|
|
219
|
+
this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);
|
|
220
|
+
}
|
|
221
|
+
break;
|
|
222
|
+
case 'top-start':
|
|
223
|
+
if (overMinWidth && underMaxWidth) {
|
|
224
|
+
this.renderer.setStyle(this.ele, 'left', `${box.offsetLeft}px`);
|
|
225
|
+
this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);
|
|
226
|
+
}
|
|
227
|
+
if (overMinHeight && underMaxHeight) {
|
|
198
228
|
this.renderer.setStyle(this.ele, 'top', `${box.offsetTop}px`);
|
|
199
229
|
this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);
|
|
200
230
|
}
|
|
201
|
-
|
|
231
|
+
break;
|
|
232
|
+
case 'top':
|
|
233
|
+
if (overMinHeight && underMaxHeight) {
|
|
234
|
+
this.renderer.setStyle(this.ele, 'top', `${box.offsetTop}px`);
|
|
235
|
+
this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);
|
|
236
|
+
}
|
|
237
|
+
break;
|
|
238
|
+
case 'bottom':
|
|
239
|
+
if (overMinHeight && underMaxHeight) {
|
|
240
|
+
this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);
|
|
241
|
+
}
|
|
242
|
+
break;
|
|
202
243
|
}
|
|
203
244
|
}
|
|
204
245
|
destroySubscription() {
|
|
@@ -209,18 +250,21 @@ export class XResizableDirective extends XResizableProperty {
|
|
|
209
250
|
}
|
|
210
251
|
}
|
|
211
252
|
/** @nocollapse */ /** @nocollapse */ XResizableDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XResizableDirective, deps: [{ token: i0.Renderer2 }, { token: i0.ElementRef }, { token: DOCUMENT }], target: i0.ɵɵFactoryTarget.Directive });
|
|
212
|
-
/** @nocollapse */ /** @nocollapse */ XResizableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: XResizableDirective, selector: "[xResizable]", host: { listeners: { "mousedown": "mousedown($event)", "touchstart": "mousedown($event)" } }, usesInheritance: true, ngImport: i0 });
|
|
253
|
+
/** @nocollapse */ /** @nocollapse */ XResizableDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "12.0.0", version: "13.3.2", type: XResizableDirective, selector: "[xResizable]", host: { listeners: { "mousedown": "mousedown($event)", "touchstart": "mousedown($event)" }, properties: { "class.x-resizable-disabled": "this.getDisabled" } }, usesInheritance: true, usesOnChanges: true, ngImport: i0 });
|
|
213
254
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.3.2", ngImport: i0, type: XResizableDirective, decorators: [{
|
|
214
255
|
type: Directive,
|
|
215
256
|
args: [{ selector: '[xResizable]' }]
|
|
216
257
|
}], ctorParameters: function () { return [{ type: i0.Renderer2 }, { type: i0.ElementRef }, { type: undefined, decorators: [{
|
|
217
258
|
type: Inject,
|
|
218
259
|
args: [DOCUMENT]
|
|
219
|
-
}] }]; }, propDecorators: {
|
|
260
|
+
}] }]; }, propDecorators: { getDisabled: [{
|
|
261
|
+
type: HostBinding,
|
|
262
|
+
args: ['class.x-resizable-disabled']
|
|
263
|
+
}], mousedown: [{
|
|
220
264
|
type: HostListener,
|
|
221
265
|
args: ['mousedown', ['$event']]
|
|
222
266
|
}, {
|
|
223
267
|
type: HostListener,
|
|
224
268
|
args: ['touchstart', ['$event']]
|
|
225
269
|
}] } });
|
|
226
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/resizable/resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\r\nimport { Directive, ElementRef, HostListener, Inject, OnDestroy, OnInit, Renderer2 } from '@angular/core';\r\nimport { XIsArray, XIsString } from '@ng-nest/ui/core';\r\nimport { fromEvent, Subscription, takeUntil } from 'rxjs';\r\nimport { XResizablePosition, XResizablePrefix, XResizableProperty } from './resizable.property';\r\n\r\n@Directive({ selector: '[xResizable]' })\r\nexport class XResizableDirective extends XResizableProperty implements OnInit, OnDestroy {\r\n  document!: Document;\r\n  ele!: HTMLElement;\r\n  cornerPositions: XResizablePosition[] = ['top-start', 'top-end', 'bottom-start', 'bottom-end'];\r\n  allPositions: XResizablePosition[] = ['left', 'right', 'top', 'bottom', ...this.cornerPositions];\r\n  positions: XResizablePosition[] = [];\r\n  direction?: XResizablePosition | null;\r\n  newBox = { clientWidth: 0, clientHeight: 0, offsetLeft: 0, offsetTop: 0 };\r\n  mouseUpSub?: Subscription;\r\n\r\n  minWidth?: number;\r\n  maxWidth?: number;\r\n  minHeight?: number;\r\n  maxHeight?: number;\r\n\r\n  positionNodes: { [key: string]: HTMLElement } = {};\r\n  activatingNodes: HTMLElement[] = [];\r\n\r\n  constructor(private renderer: Renderer2, private elementRef: ElementRef, @Inject(DOCUMENT) doc: any) {\r\n    super();\r\n    this.document = doc;\r\n    this.ele = this.elementRef.nativeElement;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setMapClass();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setPosition();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroySubscription();\r\n  }\r\n\r\n  @HostListener('mousedown', ['$event'])\r\n  @HostListener('touchstart', ['$event'])\r\n  mousedown(event: MouseEvent | TouchEvent) {\r\n    if (!this.xResizable) return;\r\n    const classList = (event.target as HTMLElement).classList;\r\n    let direction: XResizablePosition | null = null;\r\n    for (let pos of this.allPositions) {\r\n      if (classList.contains(`x-resizable-${pos}`)) {\r\n        direction = pos;\r\n        break;\r\n      }\r\n    }\r\n    if (!direction) return;\r\n\r\n    const evt = event.type.startsWith('touch') ? (event as TouchEvent).targetTouches[0] : (event as MouseEvent);\r\n    const { clientWidth, clientHeight, offsetLeft, offsetTop } = this.ele;\r\n    const { screenX, screenY } = evt;\r\n    const isTouchEvent = event.type.startsWith('touch');\r\n    const moveEvent = isTouchEvent ? 'touchmove' : 'mousemove';\r\n    const upEvent = isTouchEvent ? 'touchend' : 'mouseup';\r\n\r\n    this.setActivatingNodes(direction);\r\n    this.initResize(event, direction);\r\n\r\n    const mouseup = fromEvent(this.document, upEvent);\r\n    this.mouseUpSub = mouseup.subscribe((ev) => {\r\n      this.mouseup(ev as MouseEvent | TouchEvent);\r\n    });\r\n    const mouseMoveSub = fromEvent(document, moveEvent)\r\n      .pipe(takeUntil(mouseup))\r\n      .subscribe((ev) => this.move(ev as MouseEvent | TouchEvent, clientWidth, clientHeight, offsetTop, offsetLeft, screenX, screenY));\r\n\r\n    this.mouseUpSub.add(mouseMoveSub);\r\n  }\r\n\r\n  setMapClass() {\r\n    this.renderer.addClass(this.ele, XResizablePrefix);\r\n  }\r\n\r\n  setPosition() {\r\n    if (!this.xResizable) return;\r\n    let positions: XResizablePosition[] = [];\r\n    if (XIsString(this.position)) {\r\n      positions.push(this.position as XResizablePosition);\r\n    } else if (XIsArray(this.position)) {\r\n      positions = this.position as XResizablePosition[];\r\n    }\r\n\r\n    if (positions.includes('all')) {\r\n      this.positions = this.allPositions;\r\n    } else {\r\n      this.positions = positions;\r\n    }\r\n    this.createNode(...this.positions);\r\n\r\n    const computedStyle = window.getComputedStyle(this.ele);\r\n    this.minWidth = parseFloat(computedStyle.minWidth);\r\n    this.maxWidth = parseFloat(computedStyle.maxWidth);\r\n    this.minHeight = parseFloat(computedStyle.minHeight);\r\n    this.maxHeight = parseFloat(computedStyle.maxHeight);\r\n  }\r\n\r\n  setActivatingNodes(direction: XResizablePosition) {\r\n    if (!this.positions.includes(direction)) return;\r\n    const addActivatingNode = (...direction: XResizablePosition[]) => {\r\n      for (let item of direction) {\r\n        const nd = this.positionNodes[item];\r\n        const isNd = this.activatingNodes.includes(nd);\r\n        if (!nd || isNd) continue;\r\n        this.renderer.addClass(nd, 'x-resizable-activating');\r\n        this.activatingNodes.push(nd);\r\n      }\r\n    };\r\n    if (this.cornerPositions.includes(direction)) {\r\n      switch (direction) {\r\n        case 'bottom-end':\r\n          addActivatingNode('bottom', 'right');\r\n          break;\r\n        case 'top-end':\r\n          addActivatingNode('top', 'right');\r\n          break;\r\n        case 'bottom-start':\r\n          addActivatingNode('bottom', 'left');\r\n          break;\r\n        case 'top-start':\r\n          addActivatingNode('top', 'left');\r\n          break;\r\n      }\r\n    }\r\n    addActivatingNode(direction);\r\n  }\r\n\r\n  createNode(...classes: XResizablePosition[]) {\r\n    for (let cla of classes) {\r\n      const pos = this.renderer.createElement('div');\r\n      this.renderer.addClass(pos, `x-resizable-${cla}`);\r\n      this.renderer.appendChild(this.ele, pos);\r\n      this.positionNodes[cla] = pos;\r\n    }\r\n  }\r\n\r\n  initResize(event: MouseEvent | TouchEvent, direction: XResizablePosition) {\r\n    this.direction = direction;\r\n    this.renderer.addClass(this.ele, `x-resizable-resizing`);\r\n    let { clientWidth, clientHeight, offsetLeft, offsetTop } = this.ele;\r\n    this.newBox = { clientWidth, clientHeight, offsetLeft, offsetTop };\r\n    event.stopPropagation();\r\n    this.resizeBegin.emit();\r\n  }\r\n\r\n  mouseup(event: MouseEvent | TouchEvent) {\r\n    this.endResize(event);\r\n    this.destroySubscription();\r\n  }\r\n\r\n  endResize(event: MouseEvent | TouchEvent) {\r\n    const evt = event.type.startsWith('touch') ? (event as TouchEvent).targetTouches[0] : (event as MouseEvent);\r\n    this.direction = null;\r\n    this.renderer.removeClass(this.ele, `x-resizable-resizing`);\r\n    for (const node of this.activatingNodes) {\r\n      this.renderer.removeClass(node, 'x-resizable-activating');\r\n    }\r\n    this.activatingNodes = [];\r\n    this.resizeEnd.emit({ event: evt, ...this.newBox });\r\n  }\r\n\r\n  move(event: MouseEvent | TouchEvent, width: number, height: number, top: number, left: number, screenX: number, screenY: number) {\r\n    const evt = event.type.startsWith('touch') ? (event as TouchEvent).targetTouches[0] : (event as MouseEvent);\r\n    const movementX = evt.screenX - screenX;\r\n    const movementY = evt.screenY - screenY;\r\n\r\n    this.newBox = {\r\n      clientWidth: width - (['bottom-start', 'left', 'top-start'].includes(this.direction as string) ? movementX : -movementX),\r\n      clientHeight: height - (['top-start', 'top', 'top-end'].includes(this.direction as string) ? movementY : -movementY),\r\n      offsetLeft: left + movementX,\r\n      offsetTop: top + movementY\r\n    };\r\n\r\n    const box = {\r\n      ...this.newBox,\r\n      offsetLeft: this.newBox.offsetLeft - Number(this.offsetLeft),\r\n      offsetTop: this.newBox.offsetTop - Number(this.offsetTop)\r\n    };\r\n\r\n    this.resizeWidth(box);\r\n    this.resizeHeight(box);\r\n\r\n    this.resizing.emit({ ...this.newBox, event: evt });\r\n  }\r\n\r\n  resizeWidth(box: { clientWidth: number; clientHeight: number; offsetLeft: number; offsetTop: number }): void {\r\n    const overMinWidth = !this.minWidth || box.clientWidth >= this.minWidth;\r\n    const underMaxWidth = !this.maxWidth || box.clientWidth <= this.maxWidth;\r\n\r\n    if (['bottom-end', 'right', 'top-end'].includes(this.direction as string)) {\r\n      if (overMinWidth && underMaxWidth) {\r\n        if (!this.ghost) {\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n      }\r\n    }\r\n    if (['bottom-start', 'left', 'top-start'].includes(this.direction as string)) {\r\n      if (overMinWidth && underMaxWidth) {\r\n        if (!this.ghost) {\r\n          this.renderer.setStyle(this.ele, 'left', `${box.offsetLeft}px`);\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  resizeHeight(box: { clientWidth: number; clientHeight: number; offsetLeft: number; offsetTop: number }): void {\r\n    const overMinHeight = !this.minHeight || box.clientHeight >= this.minHeight;\r\n    const underMaxHeight = !this.maxHeight || box.clientHeight <= this.maxHeight;\r\n    if (['bottom-end', 'bottom', 'bottom-start'].includes(this.direction as string)) {\r\n      if (overMinHeight && underMaxHeight) {\r\n        if (!this.ghost) {\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n      }\r\n    }\r\n\r\n    if (['top-start', 'top', 'top-end'].includes(this.direction as string)) {\r\n      if (overMinHeight && underMaxHeight) {\r\n        if (!this.ghost) {\r\n          this.renderer.setStyle(this.ele, 'top', `${box.offsetTop}px`);\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n      }\r\n    }\r\n  }\r\n\r\n  private destroySubscription() {\r\n    if (this.mouseUpSub) {\r\n      this.mouseUpSub.unsubscribe();\r\n      this.mouseUpSub = undefined;\r\n    }\r\n  }\r\n}\r\n"]}
|
|
270
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"resizable.directive.js","sourceRoot":"","sources":["../../../../../lib/ng-nest/ui/resizable/resizable.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import { DOCUMENT } from '@angular/common';\r\nimport { Directive, ElementRef, HostBinding, HostListener, Inject, OnDestroy, OnInit, Renderer2, SimpleChanges } from '@angular/core';\r\nimport { XIsArray, XIsChange, XIsString } from '@ng-nest/ui/core';\r\nimport { fromEvent, Subscription, takeUntil } from 'rxjs';\r\nimport { XResizablePosition, XResizablePrefix, XResizableProperty } from './resizable.property';\r\n\r\n@Directive({ selector: '[xResizable]' })\r\nexport class XResizableDirective extends XResizableProperty implements OnInit, OnDestroy {\r\n  @HostBinding('class.x-resizable-disabled') get getDisabled() {\r\n    return !this.xResizable;\r\n  }\r\n  document!: Document;\r\n  ele!: HTMLElement;\r\n  cornerPositions: XResizablePosition[] = ['top-start', 'top-end', 'bottom-start', 'bottom-end'];\r\n  allPositions: XResizablePosition[] = ['left', 'right', 'top', 'bottom', ...this.cornerPositions];\r\n  positions: XResizablePosition[] = [];\r\n  direction?: XResizablePosition | null;\r\n  newBox = { clientWidth: 0, clientHeight: 0, offsetLeft: 0, offsetTop: 0 };\r\n  mouseUpSub?: Subscription;\r\n\r\n  minWidth?: number;\r\n  maxWidth?: number;\r\n  minHeight?: number;\r\n  maxHeight?: number;\r\n\r\n  positionNodes: { [key: string]: HTMLElement } = {};\r\n  activatingNodes: HTMLElement[] = [];\r\n\r\n  firstLoaded = true;\r\n\r\n  constructor(private renderer: Renderer2, private elementRef: ElementRef, @Inject(DOCUMENT) doc: any) {\r\n    super();\r\n    this.document = doc;\r\n    this.ele = this.elementRef.nativeElement;\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.setMapClass();\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.setPosition();\r\n  }\r\n\r\n  ngOnDestroy() {\r\n    this.destroySubscription();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges) {\r\n    const { xResizable } = changes;\r\n    XIsChange(xResizable) && this.setPosition();\r\n  }\r\n\r\n  @HostListener('mousedown', ['$event'])\r\n  @HostListener('touchstart', ['$event'])\r\n  mousedown(event: MouseEvent | TouchEvent) {\r\n    if (!this.xResizable) return;\r\n    const classList = (event.target as HTMLElement).classList;\r\n    let direction: XResizablePosition | null = null;\r\n    for (let pos of this.allPositions) {\r\n      if (classList.contains(`x-resizable-${pos}`)) {\r\n        direction = pos;\r\n        break;\r\n      }\r\n    }\r\n    if (!direction) return;\r\n\r\n    const evt = event.type.startsWith('touch') ? (event as TouchEvent).targetTouches[0] : (event as MouseEvent);\r\n    const { clientWidth, clientHeight, offsetLeft, offsetTop } = this.ele;\r\n    const { screenX, screenY } = evt;\r\n    const isTouchEvent = event.type.startsWith('touch');\r\n    const moveEvent = isTouchEvent ? 'touchmove' : 'mousemove';\r\n    const upEvent = isTouchEvent ? 'touchend' : 'mouseup';\r\n\r\n    this.setActivatingNodes(direction);\r\n    this.initResize(event, direction);\r\n\r\n    const mouseup = fromEvent(this.document, upEvent);\r\n    this.mouseUpSub = mouseup.subscribe((ev) => {\r\n      this.mouseup(ev as MouseEvent | TouchEvent);\r\n    });\r\n    const mouseMoveSub = fromEvent(document, moveEvent)\r\n      .pipe(takeUntil(mouseup))\r\n      .subscribe((ev) => this.move(ev as MouseEvent | TouchEvent, clientWidth, clientHeight, offsetTop, offsetLeft, screenX, screenY));\r\n\r\n    this.mouseUpSub.add(mouseMoveSub);\r\n  }\r\n\r\n  setMapClass() {\r\n    this.renderer.addClass(this.ele, XResizablePrefix);\r\n  }\r\n\r\n  setPosition() {\r\n    if (!this.xResizable && !this.firstLoaded) return;\r\n    let positions: XResizablePosition[] = [];\r\n    if (XIsString(this.position)) {\r\n      positions.push(this.position as XResizablePosition);\r\n    } else if (XIsArray(this.position)) {\r\n      positions = this.position as XResizablePosition[];\r\n    }\r\n\r\n    if (positions.includes('all')) {\r\n      this.positions = this.allPositions;\r\n    } else {\r\n      this.positions = positions;\r\n    }\r\n    this.createNode(...this.positions);\r\n\r\n    const computedStyle = window.getComputedStyle(this.ele);\r\n    setTimeout(() => {\r\n      this.minWidth = parseFloat(computedStyle.minWidth);\r\n      this.maxWidth = parseFloat(computedStyle.maxWidth);\r\n      this.minHeight = parseFloat(computedStyle.minHeight);\r\n      this.maxHeight = parseFloat(computedStyle.maxHeight);\r\n      this.firstLoaded = false;\r\n    });\r\n  }\r\n\r\n  setActivatingNodes(direction: XResizablePosition) {\r\n    if (!this.positions.includes(direction)) return;\r\n    const addActivatingNode = (...direction: XResizablePosition[]) => {\r\n      for (let item of direction) {\r\n        const nd = this.positionNodes[item];\r\n        const isNd = this.activatingNodes.includes(nd);\r\n        if (!nd || isNd) continue;\r\n        this.renderer.addClass(nd, 'x-resizable-activating');\r\n        this.activatingNodes.push(nd);\r\n      }\r\n    };\r\n    if (this.cornerPositions.includes(direction)) {\r\n      switch (direction) {\r\n        case 'bottom-end':\r\n          addActivatingNode('bottom', 'right');\r\n          break;\r\n        case 'top-end':\r\n          addActivatingNode('top', 'right');\r\n          break;\r\n        case 'bottom-start':\r\n          addActivatingNode('bottom', 'left');\r\n          break;\r\n        case 'top-start':\r\n          addActivatingNode('top', 'left');\r\n          break;\r\n      }\r\n    }\r\n    addActivatingNode(direction);\r\n  }\r\n\r\n  createNode(...classes: XResizablePosition[]) {\r\n    for (let cla of classes) {\r\n      const pos = this.renderer.createElement('div');\r\n      this.renderer.addClass(pos, `x-resizable-${cla}`);\r\n      this.renderer.appendChild(this.ele, pos);\r\n      this.positionNodes[cla] = pos;\r\n    }\r\n  }\r\n\r\n  initResize(event: MouseEvent | TouchEvent, direction: XResizablePosition) {\r\n    this.direction = direction;\r\n    this.renderer.addClass(this.ele, `x-resizable-resizing`);\r\n    let { clientWidth, clientHeight, offsetLeft, offsetTop } = this.ele;\r\n    this.newBox = { clientWidth, clientHeight, offsetLeft, offsetTop };\r\n    event.stopPropagation();\r\n    this.resizeBegin.emit();\r\n  }\r\n\r\n  mouseup(event: MouseEvent | TouchEvent) {\r\n    this.endResize(event);\r\n    this.destroySubscription();\r\n  }\r\n\r\n  endResize(event: MouseEvent | TouchEvent) {\r\n    const evt = event.type.startsWith('touch') ? (event as TouchEvent).targetTouches[0] : (event as MouseEvent);\r\n    this.direction = null;\r\n    this.renderer.removeClass(this.ele, `x-resizable-resizing`);\r\n    for (const node of this.activatingNodes) {\r\n      this.renderer.removeClass(node, 'x-resizable-activating');\r\n    }\r\n    this.activatingNodes = [];\r\n    this.resizeEnd.emit({ event: evt, ...this.newBox });\r\n  }\r\n\r\n  move(event: MouseEvent | TouchEvent, width: number, height: number, top: number, left: number, screenX: number, screenY: number) {\r\n    const evt = event.type.startsWith('touch') ? (event as TouchEvent).targetTouches[0] : (event as MouseEvent);\r\n    const movementX = evt.screenX - screenX;\r\n    const movementY = evt.screenY - screenY;\r\n\r\n    this.newBox = {\r\n      clientWidth: width - (['bottom-start', 'left', 'top-start'].includes(this.direction as string) ? movementX : -movementX),\r\n      clientHeight: height - (['top-start', 'top', 'top-end'].includes(this.direction as string) ? movementY : -movementY),\r\n      offsetLeft: left + movementX,\r\n      offsetTop: top + movementY\r\n    };\r\n\r\n    const box = {\r\n      ...this.newBox,\r\n      offsetLeft: this.newBox.offsetLeft - Number(this.offsetLeft),\r\n      offsetTop: this.newBox.offsetTop - Number(this.offsetTop)\r\n    };\r\n\r\n    this.resizeBox(box);\r\n\r\n    this.resizing.emit({ ...this.newBox, event: evt, direction: this.direction });\r\n  }\r\n\r\n  resizeBox(box: { clientWidth: number; clientHeight: number; offsetLeft: number; offsetTop: number }) {\r\n    if (this.ghost) return;\r\n    const overMinWidth = !this.minWidth || box.clientWidth >= this.minWidth;\r\n    const underMaxWidth = !this.maxWidth || box.clientWidth <= this.maxWidth;\r\n    const overMinHeight = !this.minHeight || box.clientHeight >= this.minHeight;\r\n    const underMaxHeight = !this.maxHeight || box.clientHeight <= this.maxHeight;\r\n\r\n    switch (this.direction) {\r\n      case 'right':\r\n        if (overMinWidth && underMaxWidth) {\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n        break;\r\n      case 'top-end':\r\n        if (overMinWidth && underMaxWidth) {\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n        if (overMinHeight && underMaxHeight) {\r\n          this.renderer.setStyle(this.ele, 'top', `${box.offsetTop}px`);\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n        break;\r\n      case 'bottom-end':\r\n        if (overMinWidth && underMaxWidth) {\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n        if (overMinHeight && underMaxHeight) {\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n        break;\r\n      case 'bottom-start':\r\n        if (overMinWidth && underMaxWidth) {\r\n          this.renderer.setStyle(this.ele, 'left', `${box.offsetLeft}px`);\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n        if (overMinHeight && underMaxHeight) {\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n        break;\r\n      case 'left':\r\n        console.log(this.minWidth);\r\n        if (overMinWidth && underMaxWidth) {\r\n          this.renderer.setStyle(this.ele, 'left', `${box.offsetLeft}px`);\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n        break;\r\n      case 'top-start':\r\n        if (overMinWidth && underMaxWidth) {\r\n          this.renderer.setStyle(this.ele, 'left', `${box.offsetLeft}px`);\r\n          this.renderer.setStyle(this.ele, 'width', `${box.clientWidth}px`);\r\n        }\r\n        if (overMinHeight && underMaxHeight) {\r\n          this.renderer.setStyle(this.ele, 'top', `${box.offsetTop}px`);\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n        break;\r\n      case 'top':\r\n        if (overMinHeight && underMaxHeight) {\r\n          this.renderer.setStyle(this.ele, 'top', `${box.offsetTop}px`);\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n        break;\r\n      case 'bottom':\r\n        if (overMinHeight && underMaxHeight) {\r\n          this.renderer.setStyle(this.ele, 'height', `${box.clientHeight}px`);\r\n        }\r\n        break;\r\n    }\r\n  }\r\n\r\n  private destroySubscription() {\r\n    if (this.mouseUpSub) {\r\n      this.mouseUpSub.unsubscribe();\r\n      this.mouseUpSub = undefined;\r\n    }\r\n  }\r\n}\r\n"]}
|