chrv-components 1.2.17 → 1.2.19

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.
@@ -63,10 +63,10 @@ export class ChrPaginatorComponent {
63
63
  ngOnInit() { }
64
64
  }
65
65
  ChrPaginatorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ChrPaginatorComponent, deps: [{ token: i1.PaginationService }], target: i0.ɵɵFactoryTarget.Component });
66
- ChrPaginatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ChrPaginatorComponent, selector: "app-chr-paginator", inputs: { page: "page", pageSize: "pageSize" }, outputs: { pageChange: "pageChange", pageSizeChange: "pageSizeChange" }, ngImport: i0, template: "<div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row justify-start py-2 items-center content-center\">\n \u00C9l\u00E9ments par page:\n <div class=\"!w-10 !ml-1\">\n <app-chr-form class=\"!w-10 !ml-1\" (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'pageSize',\n value: pageSize,\n width: 'row'\n }]\n }]\">\n </app-chr-form>\n </div>\n </div>\n <div class=\"flex flex-row justify-end py-2 items-center content-center\">\n <button type=\"button\" *ngIf=\"!isFirstPage()\" (click)=\"previous()\"\n class=\"w-fit cursor-pointer\">Pr\u00E9c\u00E9dent</button>\n <div class=\"flex flex-row items-center content-center mx-2 w-fit\">\n <div class=\"!w-10 !mr-1\">\n <app-chr-form class=\"!w-10 !mr-1\" (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'currentPage',\n value: currentPage,\n width: 'row'\n }]\n }]\">\n </app-chr-form>\n </div> / {{lastPage()}}\n </div>\n <button type=\"button\" [ngClass]=\"!isLastPage() ? 'cursor-pointer' : '' \" (click)=\"!isLastPage() && next()\"\n class=\"w-fit\">Suivant</button>\n </div>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ChrFormComponent, selector: "app-chr-form", inputs: ["sections", "valid", "model", "disabled"], outputs: ["validChange", "modelChange", "valuesChange"] }] });
66
+ ChrPaginatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ChrPaginatorComponent, selector: "app-chr-paginator", inputs: { page: "page", pageSize: "pageSize" }, outputs: { pageChange: "pageChange", pageSizeChange: "pageSizeChange" }, ngImport: i0, template: "<div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row justify-start py-2 items-center content-center\">\n \u00C9l\u00E9ments par page:\n <div class=\"w-20 ml-1\">\n <app-chr-form (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'pageSize',\n value: pageSize,\n width: 'row',\n icon: 'check',\n iconCallback: setPageSize,\n }]\n }]\">\n </app-chr-form>\n </div>\n </div>\n <div class=\"flex flex-row justify-end py-2 items-center content-center\">\n <button type=\"button\" *ngIf=\"!isFirstPage()\" (click)=\"previous()\"\n class=\"w-fit cursor-pointer\">Pr\u00E9c\u00E9dent</button>\n <div class=\"flex flex-row items-center content-center mx-2 w-fit\">\n <div class=\"w-20 mr-1\">\n <app-chr-form (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'currentPage',\n value: currentPage,\n width: 'row',\n icon: 'check',\n iconCallback: setPage,\n }]\n }]\">\n </app-chr-form>\n </div> / {{lastPage()}}\n </div>\n <button type=\"button\" [ngClass]=\"!isLastPage() ? 'cursor-pointer' : '' \" (click)=\"!isLastPage() && next()\"\n class=\"w-fit\">Suivant</button>\n </div>\n</div>", styles: [""], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i3.ChrFormComponent, selector: "app-chr-form", inputs: ["sections", "valid", "model", "disabled"], outputs: ["validChange", "modelChange", "valuesChange"] }] });
67
67
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ChrPaginatorComponent, decorators: [{
68
68
  type: Component,
69
- args: [{ selector: 'app-chr-paginator', template: "<div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row justify-start py-2 items-center content-center\">\n \u00C9l\u00E9ments par page:\n <div class=\"!w-10 !ml-1\">\n <app-chr-form class=\"!w-10 !ml-1\" (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'pageSize',\n value: pageSize,\n width: 'row'\n }]\n }]\">\n </app-chr-form>\n </div>\n </div>\n <div class=\"flex flex-row justify-end py-2 items-center content-center\">\n <button type=\"button\" *ngIf=\"!isFirstPage()\" (click)=\"previous()\"\n class=\"w-fit cursor-pointer\">Pr\u00E9c\u00E9dent</button>\n <div class=\"flex flex-row items-center content-center mx-2 w-fit\">\n <div class=\"!w-10 !mr-1\">\n <app-chr-form class=\"!w-10 !mr-1\" (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'currentPage',\n value: currentPage,\n width: 'row'\n }]\n }]\">\n </app-chr-form>\n </div> / {{lastPage()}}\n </div>\n <button type=\"button\" [ngClass]=\"!isLastPage() ? 'cursor-pointer' : '' \" (click)=\"!isLastPage() && next()\"\n class=\"w-fit\">Suivant</button>\n </div>\n</div>" }]
69
+ args: [{ selector: 'app-chr-paginator', template: "<div class=\"flex flex-row justify-between\">\n <div class=\"flex flex-row justify-start py-2 items-center content-center\">\n \u00C9l\u00E9ments par page:\n <div class=\"w-20 ml-1\">\n <app-chr-form (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'pageSize',\n value: pageSize,\n width: 'row',\n icon: 'check',\n iconCallback: setPageSize,\n }]\n }]\">\n </app-chr-form>\n </div>\n </div>\n <div class=\"flex flex-row justify-end py-2 items-center content-center\">\n <button type=\"button\" *ngIf=\"!isFirstPage()\" (click)=\"previous()\"\n class=\"w-fit cursor-pointer\">Pr\u00E9c\u00E9dent</button>\n <div class=\"flex flex-row items-center content-center mx-2 w-fit\">\n <div class=\"w-20 mr-1\">\n <app-chr-form (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n { \n controls: [\n {\n type: 'number',\n name: 'currentPage',\n value: currentPage,\n width: 'row',\n icon: 'check',\n iconCallback: setPage,\n }]\n }]\">\n </app-chr-form>\n </div> / {{lastPage()}}\n </div>\n <button type=\"button\" [ngClass]=\"!isLastPage() ? 'cursor-pointer' : '' \" (click)=\"!isLastPage() && next()\"\n class=\"w-fit\">Suivant</button>\n </div>\n</div>" }]
70
70
  }], ctorParameters: function () { return [{ type: i1.PaginationService }]; }, propDecorators: { page: [{
71
71
  type: Input
72
72
  }], pageChange: [{
@@ -76,4 +76,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImpo
76
76
  }], pageSizeChange: [{
77
77
  type: Output
78
78
  }] } });
79
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chr-paginator.component.js","sourceRoot":"","sources":["../../../../../projects/chrv-components/src/lib/chr-paginator/chr-paginator.component.ts","../../../../../projects/chrv-components/src/lib/chr-paginator/chr-paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport { PaginationInstance, PaginationService } from 'ngx-pagination';\n\n@Component({\n  selector: 'app-chr-paginator',\n  templateUrl: './chr-paginator.component.html',\n  styleUrls: ['./chr-paginator.component.scss'],\n})\nexport class ChrPaginatorComponent implements OnInit, AfterContentChecked {\n  public currentPage: number = 1;\n\n  @Input() page: number = 1;\n  @Output() pageChange: EventEmitter<number> = new EventEmitter();\n\n  @Input() pageSize: number = 50;\n  @Output() pageSizeChange: EventEmitter<number> = new EventEmitter();\n  instance: PaginationInstance;\n\n  constructor(public service: PaginationService) {}\n\n  ngAfterContentChecked(): void {\n    //console.log(this.service, this.service.getInstance('chr_data-table'));\n    this.instance = this.service.getInstance(\n      'chr_data-table'\n    ) as PaginationInstance;\n  }\n\n  ngOnInit(): void {}\n\n  public previous = () => {\n    this.currentPage--;\n    this.emit();\n  };\n\n  public next = () => {\n    this.currentPage++;\n    this.emit();\n  };\n\n  public setPage = (page: number) => {\n    if (page < 1 || page > this.lastPage()) return;\n    this.currentPage = page;\n    this.emit();\n  };\n\n  public setPageEventHandler = (event: any) => {\n    return this.setPage(event.target.value);\n  };\n\n  public isFirstPage = () => {\n    return this.currentPage == 1;\n  };\n\n  public setPageSize = (pageSize: number) => {\n    this.setPage(1);\n    this.instance.itemsPerPage = pageSize;\n    this.pageSizeChange.emit(pageSize);\n  };\n\n  public setPageSizeEventHandler = (event: any) => {\n    return this.setPageSize(event.target.value);\n  };\n\n  public isLastPage = () => {\n    if (!this.instance.totalItems) return false;\n    return (\n      this.currentPage ==\n      Math.ceil(this.instance.totalItems / this.instance.itemsPerPage)\n    );\n  };\n\n  // public pageSize = () => this.instance.itemsPerPage;\n\n  public lastPage = () =>\n    this.instance.totalItems\n      ? Math.ceil(this.instance.totalItems / this.instance.itemsPerPage)\n      : 1;\n\n  private emit = (page: number | undefined = undefined) => {\n    if (!page) this.pageChange.emit(this.currentPage);\n    else this.pageChange.emit(page);\n  };\n}\n","<div class=\"flex flex-row justify-between\">\n    <div class=\"flex flex-row justify-start py-2 items-center content-center\">\n        Éléments par page:\n        <div class=\"!w-10 !ml-1\">\n            <app-chr-form class=\"!w-10 !ml-1\" (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n                { \n                    controls: [\n                    {\n                        type: 'number',\n                        name: 'pageSize',\n                        value: pageSize,\n                        width: 'row'\n                    }]\n                }]\">\n            </app-chr-form>\n        </div>\n    </div>\n    <div class=\"flex flex-row justify-end py-2 items-center content-center\">\n        <button type=\"button\" *ngIf=\"!isFirstPage()\" (click)=\"previous()\"\n            class=\"w-fit cursor-pointer\">Précédent</button>\n        <div class=\"flex flex-row items-center content-center mx-2 w-fit\">\n            <div class=\"!w-10 !mr-1\">\n                <app-chr-form class=\"!w-10 !mr-1\" (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n                    { \n                        controls: [\n                        {\n                            type: 'number',\n                            name: 'currentPage',\n                            value: currentPage,\n                            width: 'row'\n                        }]\n                    }]\">\n                </app-chr-form>\n            </div> / {{lastPage()}}\n        </div>\n        <button type=\"button\" [ngClass]=\"!isLastPage() ? 'cursor-pointer' : '' \" (click)=\"!isLastPage() && next()\"\n            class=\"w-fit\">Suivant</button>\n    </div>\n</div>"]}
79
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chr-paginator.component.js","sourceRoot":"","sources":["../../../../../projects/chrv-components/src/lib/chr-paginator/chr-paginator.component.ts","../../../../../projects/chrv-components/src/lib/chr-paginator/chr-paginator.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentChecked,\n  Component,\n  EventEmitter,\n  Input,\n  OnInit,\n  Output,\n} from '@angular/core';\nimport { PaginationInstance, PaginationService } from 'ngx-pagination';\n\n@Component({\n  selector: 'app-chr-paginator',\n  templateUrl: './chr-paginator.component.html',\n  styleUrls: ['./chr-paginator.component.scss'],\n})\nexport class ChrPaginatorComponent implements OnInit, AfterContentChecked {\n  public currentPage: number = 1;\n\n  @Input() page: number = 1;\n  @Output() pageChange: EventEmitter<number> = new EventEmitter();\n\n  @Input() pageSize: number = 50;\n  @Output() pageSizeChange: EventEmitter<number> = new EventEmitter();\n  instance: PaginationInstance;\n\n  constructor(public service: PaginationService) {}\n\n  ngAfterContentChecked(): void {\n    //console.log(this.service, this.service.getInstance('chr_data-table'));\n    this.instance = this.service.getInstance(\n      'chr_data-table'\n    ) as PaginationInstance;\n  }\n\n  ngOnInit(): void {}\n\n  public previous = () => {\n    this.currentPage--;\n    this.emit();\n  };\n\n  public next = () => {\n    this.currentPage++;\n    this.emit();\n  };\n\n  public setPage = (page: number) => {\n    if (page < 1 || page > this.lastPage()) return;\n    this.currentPage = page;\n    this.emit();\n  };\n\n  public setPageEventHandler = (event: any) => {\n    return this.setPage(event.target.value);\n  };\n\n  public isFirstPage = () => {\n    return this.currentPage == 1;\n  };\n\n  public setPageSize = (pageSize: number) => {\n    this.setPage(1);\n    this.instance.itemsPerPage = pageSize;\n    this.pageSizeChange.emit(pageSize);\n  };\n\n  public setPageSizeEventHandler = (event: any) => {\n    return this.setPageSize(event.target.value);\n  };\n\n  public isLastPage = () => {\n    if (!this.instance.totalItems) return false;\n    return (\n      this.currentPage ==\n      Math.ceil(this.instance.totalItems / this.instance.itemsPerPage)\n    );\n  };\n\n  // public pageSize = () => this.instance.itemsPerPage;\n\n  public lastPage = () =>\n    this.instance.totalItems\n      ? Math.ceil(this.instance.totalItems / this.instance.itemsPerPage)\n      : 1;\n\n  private emit = (page: number | undefined = undefined) => {\n    if (!page) this.pageChange.emit(this.currentPage);\n    else this.pageChange.emit(page);\n  };\n}\n","<div class=\"flex flex-row justify-between\">\n    <div class=\"flex flex-row justify-start py-2 items-center content-center\">\n        Éléments par page:\n        <div class=\"w-20 ml-1\">\n            <app-chr-form (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n                { \n                    controls: [\n                    {\n                        type: 'number',\n                        name: 'pageSize',\n                        value: pageSize,\n                        width: 'row',\n                        icon: 'check',\n                        iconCallback: setPageSize,\n                    }]\n                }]\">\n            </app-chr-form>\n        </div>\n    </div>\n    <div class=\"flex flex-row justify-end py-2 items-center content-center\">\n        <button type=\"button\" *ngIf=\"!isFirstPage()\" (click)=\"previous()\"\n            class=\"w-fit cursor-pointer\">Précédent</button>\n        <div class=\"flex flex-row items-center content-center mx-2 w-fit\">\n            <div class=\"w-20 mr-1\">\n                <app-chr-form (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n                    { \n                        controls: [\n                        {\n                            type: 'number',\n                            name: 'currentPage',\n                            value: currentPage,\n                            width: 'row',\n                            icon: 'check',\n                            iconCallback: setPage,\n                        }]\n                    }]\">\n                </app-chr-form>\n            </div> / {{lastPage()}}\n        </div>\n        <button type=\"button\" [ngClass]=\"!isLastPage() ? 'cursor-pointer' : '' \" (click)=\"!isLastPage() && next()\"\n            class=\"w-fit\">Suivant</button>\n    </div>\n</div>"]}