chrv-components 1.1.7 → 1.2.0

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.
@@ -0,0 +1,73 @@
1
+ import { Component, EventEmitter, Output, } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ import * as i1 from "ngx-pagination";
4
+ import * as i2 from "@angular/common";
5
+ import * as i3 from "../chr-form/chr-form.component";
6
+ export class ChrPaginatorComponent {
7
+ constructor(service) {
8
+ this.service = service;
9
+ this.currentPage = 1;
10
+ this.pageChange = new EventEmitter();
11
+ this.pageSizeChange = new EventEmitter();
12
+ this.previous = () => {
13
+ this.currentPage--;
14
+ this.emit();
15
+ };
16
+ this.next = () => {
17
+ this.currentPage++;
18
+ this.emit();
19
+ };
20
+ this.setPage = (page) => {
21
+ if (page < 1 || page > this.lastPage())
22
+ return;
23
+ this.currentPage = page;
24
+ this.emit();
25
+ };
26
+ this.setPageEventHandler = (event) => {
27
+ return this.setPage(event.target.value);
28
+ };
29
+ this.isFirstPage = () => {
30
+ return this.currentPage == 1;
31
+ };
32
+ this.setPageSize = (pageSize) => {
33
+ this.setPage(1);
34
+ this.instance.itemsPerPage = pageSize;
35
+ this.pageSizeChange.emit(pageSize);
36
+ };
37
+ this.setPageSizeEventHandler = (event) => {
38
+ return this.setPageSize(event.target.value);
39
+ };
40
+ this.isLastPage = () => {
41
+ if (!this.instance.totalItems)
42
+ return false;
43
+ return (this.currentPage ==
44
+ Math.ceil(this.instance.totalItems / this.instance.itemsPerPage));
45
+ };
46
+ this.pageSize = () => this.instance.itemsPerPage;
47
+ this.lastPage = () => this.instance.totalItems
48
+ ? Math.ceil(this.instance.totalItems / this.instance.itemsPerPage)
49
+ : 1;
50
+ this.emit = (page = undefined) => {
51
+ if (!page)
52
+ this.pageChange.emit(this.currentPage);
53
+ else
54
+ this.pageChange.emit(page);
55
+ };
56
+ }
57
+ ngAfterContentChecked() {
58
+ //console.log(this.service, this.service.getInstance('chr_data-table'));
59
+ this.instance = this.service.getInstance('chr_data-table');
60
+ }
61
+ ngOnInit() { }
62
+ }
63
+ ChrPaginatorComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ChrPaginatorComponent, deps: [{ token: i1.PaginationService }], target: i0.ɵɵFactoryTarget.Component });
64
+ ChrPaginatorComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: ChrPaginatorComponent, selector: "app-chr-paginator", 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 \u00C9lements par page:\n <app-chr-form class=\"ml-1\" (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n { controls: [\n {\n type: 'text',\n name: 'pageSize',\n value: pageSize(),\n width: 'row'\n }]\n }]\">\n </app-chr-form>\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 (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n { controls: [\n {\n type: 'text',\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"] }] });
65
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: ChrPaginatorComponent, decorators: [{
66
+ type: Component,
67
+ 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 \u00C9lements par page:\n <app-chr-form class=\"ml-1\" (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n { controls: [\n {\n type: 'text',\n name: 'pageSize',\n value: pageSize(),\n width: 'row'\n }]\n }]\">\n </app-chr-form>\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 (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n { controls: [\n {\n type: 'text',\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>" }]
68
+ }], ctorParameters: function () { return [{ type: i1.PaginationService }]; }, propDecorators: { pageChange: [{
69
+ type: Output
70
+ }], pageSizeChange: [{
71
+ type: Output
72
+ }] } });
73
+ //# 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  AfterContentInit,\n  AfterViewInit,\n  Component,\n  EventEmitter,\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  @Output() pageChange: EventEmitter<number> = new EventEmitter();\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        Élements par page:\n        <app-chr-form class=\"ml-1\" (keyup.enter)=\"setPageSizeEventHandler($event)\" [sections]=\"[\n        { controls: [\n        {\n            type: 'text',\n            name: 'pageSize',\n            value: pageSize(),\n            width: 'row'\n        }]\n        }]\">\n        </app-chr-form>\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 (keyup.enter)=\"setPageEventHandler($event)\" [sections]=\"[\n            { controls: [\n            {\n              type: 'text',\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>"]}