chrv-components 1.8.53 → 1.8.54
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.
|
Binary file
|
|
@@ -117,16 +117,16 @@ export class ChrTableComponent {
|
|
|
117
117
|
return this.sortBy;
|
|
118
118
|
};
|
|
119
119
|
this.getTextColor = (color = 'none') => {
|
|
120
|
-
return TextColors[color];
|
|
120
|
+
return TextColors[color] || TextColors['black'];
|
|
121
121
|
};
|
|
122
122
|
this.getBackgroundColor = (color = 'none') => {
|
|
123
|
-
return BackgroundColors[color];
|
|
123
|
+
return BackgroundColors[color] || BackgroundColors['accent'];
|
|
124
124
|
};
|
|
125
125
|
this.getBorderColor = (color = 'none') => {
|
|
126
|
-
return BorderColors[color];
|
|
126
|
+
return BorderColors[color] || BorderColors['accent'];
|
|
127
127
|
};
|
|
128
128
|
this.getAlignment = (alignment = 'center') => {
|
|
129
|
-
return Aligments[alignment];
|
|
129
|
+
return Aligments[alignment] || Aligments['left'];
|
|
130
130
|
};
|
|
131
131
|
}
|
|
132
132
|
ngOnInit() {
|
|
@@ -220,4 +220,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.6", ngImpor
|
|
|
220
220
|
}], textColor: [{
|
|
221
221
|
type: Input
|
|
222
222
|
}] } });
|
|
223
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chr-table.component.js","sourceRoot":"","sources":["../../../../../projects/chrv-components/src/lib/chr-table/chr-table.component.ts","../../../../../projects/chrv-components/src/lib/chr-table/chr-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  AfterViewInit,\n  EventEmitter,\n  Output,\n  ChangeDetectorRef,\n  OnInit,\n} from '@angular/core';\nimport { ChrPaginatorComponent } from '../chr-paginator/chr-paginator.component';\nimport { ChrButtonComponent } from '../chr-button/chr-button.component';\nimport { ChrTableHeaderCellComponent } from '../chr-table-header-cell/chr-table-header-cell.component';\nimport { NgxPaginationModule } from 'ngx-pagination';\nimport {\n  CommonModule,\n  DATE_PIPE_DEFAULT_OPTIONS,\n  DatePipe,\n  NgFor,\n} from '@angular/common';\nimport { DataService } from '../services/data.service';\nimport { SortPipe } from 'chrv-pipes';\nexport type Color =\n  | 'primary'\n  | 'accent'\n  | 'warn'\n  | 'alert'\n  | 'darkeraccent'\n  | 'white'\n  | 'black'\n  | 'none';\n\nexport type Alignment = 'left' | 'center' | 'right';\n\nexport const BackgroundColors: { [key: string]: string } = {\n  accent: 'bg-chrlblue',\n  primary: 'bg-chrdblue',\n  darkeraccent: 'bg-chrmblue',\n  alert: 'bg-chrorange',\n  warn: 'bg-chrwarning',\n};\nexport const TextColors: { [key: string]: string } = {\n  accent: 'text-chrlblue',\n  primary: 'text-chrdblue',\n  darkeraccent: 'text-chrmblue',\n  alert: 'text-chrorange',\n  warn: 'text-chrwarning',\n  white: 'text-white',\n  black: 'text-black',\n};\n\nexport const BorderColors: { [key: string]: string } = {\n  accent: 'border-chrlblue',\n  primary: 'border-chrdblue',\n  darkeraccent: 'border-chrmblue',\n  alert: 'border-chrorange',\n  warn: 'border-chrwarning',\n};\n\nexport const Aligments: { [key: string]: string } = {\n  left: 'text-left justify-start',\n  center: 'text-center justify-center',\n  right: 'text-right justify-end',\n};\n\nexport interface IChips {\n  display: string;\n  name: string;\n  callback: (entry: any) => string | boolean;\n  textColor?: 'primary' | 'accent' | 'warn' | 'alert' | 'darkeraccent' | 'none';\n  backgroundColor?:\n    | 'primary'\n    | 'accent'\n    | 'warn'\n    | 'alert'\n    | 'darkeraccent'\n    | 'none';\n}\n\nexport interface IColumn {\n  display: string;\n  alignment?: 'left' | 'center' | 'right';\n  chips?: IChips[];\n  properties?: string[];\n  callback?: Function;\n  date?: string;\n  isLink?: boolean;\n  linkStaticUrl?: string;\n}\n\nexport interface IComputedRow {\n  columns: IComputedColumn[];\n}\n\nexport interface IComputedColumn {\n  label?: string;\n  value?: any;\n  callback?: Function;\n  alignment?: 'left' | 'center' | 'right';\n  after?: string;\n}\n\nexport interface IAction {\n  display?: string;\n  icon?: string;\n  callback: Function;\n  disabled?: boolean;\n  disabledCallback?: Function;\n  color: 'primary' | 'accent' | 'warn' | 'alert' | 'darkeraccent' | 'none';\n}\n\n@Component({\n  selector: 'app-chr-table, [app-chr-table]',\n  templateUrl: './chr-table.component.html',\n  styleUrls: ['./chr-table.component.scss', '../../../../../tailwindbuild.css'],\n  standalone: true,\n  imports: [\n    ChrTableHeaderCellComponent,\n    ChrButtonComponent,\n    ChrPaginatorComponent,\n    SortPipe,\n    NgxPaginationModule,\n    CommonModule,\n    NgFor,\n    DatePipe,\n  ],\n  providers: [\n    DatePipe,\n    {\n      provide: DATE_PIPE_DEFAULT_OPTIONS,\n      useValue: { dateFormat: 'shortDate' },\n    },\n  ],\n})\nexport class ChrTableComponent implements OnInit, AfterViewInit {\n  @Input() computedRows?: IComputedRow[];\n  @Input() columns?: IColumn[];\n  @Input() data: any[] | null = [];\n  @Input() actions?: IAction[];\n\n  @Input() isAsc: boolean = true;\n  @Output() isAscChange: EventEmitter<boolean> = new EventEmitter();\n  @Input() sortBy?: string;\n  @Output() sortByChange: EventEmitter<string> = new EventEmitter();\n\n  @Input() pageSize: number = 50;\n  @Output() pageSizeChange: EventEmitter<number> = new EventEmitter();\n\n  @Input() currentPage: number = 1;\n  @Output() currentPageChange: EventEmitter<number> = new EventEmitter();\n\n  @Input() selectable: boolean = false;\n\n  @Input() selection: any[] = [];\n  @Output() selectionChange: EventEmitter<any[]> = new EventEmitter();\n\n  @Input() id?: string = 'chr_base-data-table';\n\n  @Input() color: 'primary' | 'accent' | 'warn' | 'alert' | 'darkeraccent' =\n    'accent';\n\n  @Input() textColor:\n    | 'primary'\n    | 'accent'\n    | 'warn'\n    | 'alert'\n    | 'darkeraccent'\n    | 'white'\n    | 'black' = 'black';\n\n  private _page: number = 1;\n\n  currentProperty: any | null = null;\n  currentText: string | null = null;\n\n  constructor(\n    private _date: DatePipe,\n    private dataService: DataService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    this.dataService.get(`${this.id}_sortBy`).subscribe((res) => {\n      if (res) this.sortBy = res;\n    });\n    this.dataService.get(`${this.id}_isAsc`).subscribe((res) => {\n      if (res) this.isAsc = res;\n    });\n  }\n  ngAfterViewInit(): void {}\n\n  protected emitIsAsc(isAsc: any) {\n    this.dataService.set(`${this.id}_isAsc`, isAsc);\n    this.isAscChange.emit(isAsc);\n  }\n\n  protected emitSortBy(sortBy: any) {\n    this.dataService.set(`${this.id}_sortBy`, sortBy);\n    this.sortByChange.emit(sortBy);\n  }\n\n  protected emitPageSize(pageSize: any) {\n    this.pageSize = pageSize;\n    this.pageSizeChange.emit(pageSize);\n  }\n\n  protected emitCurrentPage(currentPage: any) {\n    this.currentPage = currentPage;\n    this.currentPageChange.emit(currentPage);\n  }\n\n  protected getProperty = (entry: any, properties?: any[]) => {\n    this.currentProperty = null;\n    this.currentText = null;\n\n    if (!properties) {\n      this.currentProperty = entry;\n      return entry;\n    }\n    let value = entry;\n    for (const i of properties) {\n      value = (value as any)?.[i];\n    }\n    this.currentProperty = value;\n    return value;\n  };\n\n  protected getText = (property: any, column: IColumn) => {\n    let text = null;\n\n    if (column.callback) text = column.callback(property);\n\n    if (text == null && column.date)\n      text = this._date.transform(property, column.date);\n\n    this.currentText = text || property;\n\n    return text || property;\n    // column.date\n    //   ? column.callback\n    // \t? column.callback(property)\n    // \t: (property | date : column.date)\n    //   : column.callback\n    // \t? column.callback(property)\n    // \t: property\n  };\n\n  protected select = (entry: any, event: MouseEvent) => {\n    const pointer = <PointerEvent>event;\n    const target = <HTMLInputElement>pointer.target;\n    if (target.checked) {\n      this.selection.push(entry);\n    } else {\n      this.selection = this.selection.filter((x) => x !== entry);\n    }\n\n    this.selectionChange.emit(this.selection);\n  };\n\n  public getSelection = () => {\n    return this.selection;\n  };\n\n  public setSelection = (data: any[]) => {\n    this.selection = data;\n    this.selectionChange.emit(this.selection);\n  };\n\n  protected contains = (entry: any) => {\n    return this.selection.includes(entry);\n  };\n\n  protected getIsAsc = () => {\n    return this.isAsc;\n  };\n\n  protected getSortBy = () => {\n    return this.sortBy;\n  };\n\n  protected getTextColor = (color: Color = 'none') => {\n    return TextColors[color];\n  };\n\n  protected getBackgroundColor = (color: Color = 'none') => {\n    return BackgroundColors[color];\n  };\n\n  protected getBorderColor = (color: Color = 'none') => {\n    return BorderColors[color];\n  };\n\n  protected getAlignment = (alignment: Alignment = 'center') => {\n    return Aligments[alignment];\n  };\n}\n","<div class=\"h-full no-scrollbar\">\n  <ng-content class=\"mt-5\"></ng-content>\n  <div class=\"flex flex-col flex-1 overflow-auto no-scrollbar\">\n    @if (data) {\n    <!-- max-w-[75%] -->\n    <table\n      class=\"table-auto max-w-full border dark:border-none relative flex flex-row flex-no-wrap w-full rounded-lg sm:shadow-lg bg-transparent no-scrollbar\">\n      <thead class=\"text-black\">\n        @if (data.length <= 0) { <tr class=\"flex flex-col flex-no wrap sm:table-row rounded-lg mb-2 sm:mb-0\"\n          [ngClass]=\"[getBackgroundColor(color), getTextColor(textColor)]\">\n          @for (column of columns; track column) {\n          <th app-chr-table-header-cell class=\"p-3 h-14\" display=\"{{ column.display }}\" column=\"{{ column.properties }}\"\n            [(isAsc)]=\"isAsc\" (isAscChange)=\"emitIsAsc($event)\" [(sortBy)]=\"sortBy\" (sortByChange)=\"emitSortBy($event)\">\n          </th>\n          }\n          @if (actions) {\n          <th\n            class=\"h-14 p-3 text-left sm:text-center place-content-center place-items-center items-center align-middle sm:w-0\">\n            Actions\n          </th>\n          }\n          </tr>\n          }\n          @for (entry of data |\n          sort:isAsc:sortBy | paginate: {itemsPerPage: pageSize, currentPage: currentPage, id: this.id}; track entry)\n          {\n          <tr class=\"flex flex-col flex-no wrap sm:table-row rounded-lg mb-2 sm:mb-0 \"\n            [ngClass]=\"[getBackgroundColor(color), getTextColor(textColor)]\">\n            <th *ngIf=\"selectable\" class=\"p-3 h-14\"></th>\n            @for (column of columns; track column) {\n            <th app-chr-table-header-cell class=\"p-3 h-14\" display=\"{{ column.display }}\"\n              column=\"{{ column.properties }}\" [(isAsc)]=\"isAsc\" alignment=\"{{column.alignment}}\"\n              (isAscChange)=\"emitIsAsc($event)\" [(sortBy)]=\"sortBy\" (sortByChange)=\"emitSortBy($event)\"></th>\n            }\n            @if (actions) {\n            <th\n              class=\"h-14 p-3 text-left sm:text-center place-content-center place-items-center items-center align-middle self-center sm:w-0\">\n              Actions\n            </th>\n            }\n          </tr>\n          }\n      </thead>\n      <tbody class=\"w-full\">\n        @if (data.length <= 0) { <tr\n          class=\"flex flex-col flex-no-wrap sm:table-row rounded-lg mb-0 sm:mb-2 dark:bg-slate-600\">\n          <td class=\"p-3 h-14\">Pas de donnée(s)</td>\n          @for (column of columns | slice: 1; track column) {\n          <td class=\"p-3 h-14\"></td>\n          }\n          @if (actions) {\n          <td class=\"p-3 h-14 grid gap-3 justify-center align-middle items-center\"\n            [ngClass]=\"actions.length > 1 ? 'grid-cols-2' : 'grid-cols-1'\"></td>\n          }\n          </tr>\n          }\n          @for (entry of data |\n          sort:isAsc:sortBy | paginate: {itemsPerPage: pageSize, currentPage: currentPage, id: this.id}; track\n          entry; let i = $index) {\n          <tr [attr.data-index]=\"i\"\n            class=\"flex flex-col flex-no-wrap sm:table-row mb-2 sm:mb-0 dark:text-gray-400 dark:bg-slate-600 sm:odd:bg-gray-200 sm:dark:odd:bg-slate-700 sm:border-t-2 sm:first:border-0\"\n            [ngClass]=\"[getBorderColor(color)]\">\n            <td *ngIf=\"selectable\"\n              class=\"p-3 h-14 text-ellipsis max-w-full border-t-2 first:border-0 sm:first:border-t-2\"\n              [ngClass]=\"getBorderColor(color)\"><input type=\"checkbox\" (click)=\"select(entry, $event)\"\n                [checked]=\"contains(entry)\" /></td>\n            @for (column of columns; track column;) {\n            <td [ngClass]=\"\n                column.chips\n                  ? ''\n                  : ''\n              \" class=\"p-3 h-14 text-ellipsis max-w-full border-t-2 first:border-0 sm:first:border-t-2\"\n              [ngClass]=\"getBorderColor(color)\">\n              <ng-container [ngTemplateOutlet]=\"default\"\n                [ngTemplateOutletContext]=\"{prop: getProperty(entry, column.properties), column: column}\">\n              </ng-container>\n            </td>\n            }\n\n            <ng-template #default let-column='column' let-property=\"prop\">\n              @if (column.isLink) {\n              <a target=\"_blank\" class=\"text-{{column.alignment}}\" href=\"{{column.linkStaticUrl}}{{\n              getText(property, column)\n              }}\">\n                {{\n                currentText\n                }}\n              </a>\n              }\n              @if (!column.isLink) {\n              <div class=\"flex flex-row\" [ngClass]=\"{\n                'justify-start': column.alignment == 'left',\n                'justify-center': column.alignment == 'center',\n                'justify-end': column.alignment == 'right',\n                'gap-2': column.chipsDisplay && getText(property, column)\n              }\">\n                @if (column.chips && column.chips.length > 0) {\n                <div>\n                  @for(chip of column.chips; track chip; let i = $index){\n                  <span *ngIf=\"chip.callback(entry) === true || chip.callback(entry) === chip.name\"\n                    class=\"w-24 flex text-center content-center align-middle items-center justify-center text-xs font-medium py-0.5 rounded-full\"\n                    [ngClass]=\"[getBackgroundColor(chip.backgroundColor), getTextColor(chip.textColor)]\">\n                    {{ chip.display }}\n                  </span>\n                  }\n                </div>\n                }@else {\n                <p class=\"inline-block overflow-hidden text-nowrap text-ellipsis max-w-full\">\n                  {{\n                  currentText || getText(property, column)\n                  }}\n                </p>\n                }\n              </div>\n              }\n            </ng-template>\n\n            @if (actions) {\n            <td class=\"p-3 h-14 flex gap-2 w-full sm:w-min justify-center\">\n              @for (action of actions; track action) {\n              <app-chr-button class=\"w-full\" [disabled]=\"\n                  action.disabledCallback\n                    ? action.disabledCallback(entry)\n                    : action.disabled || false\n                \" [display]=\"action.display\" [icon]=\"action.icon\" [click]=\"action.callback.bind(null, entry, i)\"\n                [color]=\"action.color\" type=\"responsive\">\n              </app-chr-button>\n              }\n            </td>\n            }\n          </tr>\n          }\n          @for (r of computedRows; track r) {\n          <tr\n            class=\"flex flex-col flex-no-wrap sm:table-row mb-2 sm:mb-0 dark:text-gray-400 dark:bg-slate-600 sm:odd:bg-gray-200 sm:dark:odd:bg-slate-700\">\n            @for (c of r.columns; track c) {\n            <td [ngClass]=\"c.alignment && 'text-'+(c.alignment||'left')\" class=\"p-3 h-14\">\n              {{c.label && c.label + ':'}} {{c.value || (c.callback && c.callback(data))}} {{c.after}}\n            </td>\n            }\n          </tr>\n          }\n      </tbody>\n    </table>\n    <app-chr-paginator [id]=\"this.id\" [(pageSize)]=\"pageSize\" [(page)]=\"currentPage\"\n      (pageSizeChange)=\"emitPageSize($event)\" (pageChange)=\"emitCurrentPage($event)\"></app-chr-paginator>\n    }\n  </div>\n</div>"]}
|
|
223
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"chr-table.component.js","sourceRoot":"","sources":["../../../../../projects/chrv-components/src/lib/chr-table/chr-table.component.ts","../../../../../projects/chrv-components/src/lib/chr-table/chr-table.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  Input,\n  AfterViewInit,\n  EventEmitter,\n  Output,\n  ChangeDetectorRef,\n  OnInit,\n} from '@angular/core';\nimport { ChrPaginatorComponent } from '../chr-paginator/chr-paginator.component';\nimport { ChrButtonComponent } from '../chr-button/chr-button.component';\nimport { ChrTableHeaderCellComponent } from '../chr-table-header-cell/chr-table-header-cell.component';\nimport { NgxPaginationModule } from 'ngx-pagination';\nimport {\n  CommonModule,\n  DATE_PIPE_DEFAULT_OPTIONS,\n  DatePipe,\n  NgFor,\n} from '@angular/common';\nimport { DataService } from '../services/data.service';\nimport { SortPipe } from 'chrv-pipes';\nexport type Color =\n  | 'primary'\n  | 'accent'\n  | 'warn'\n  | 'alert'\n  | 'darkeraccent'\n  | 'white'\n  | 'black'\n  | 'none';\n\nexport type Alignment = 'left' | 'center' | 'right';\n\nexport const BackgroundColors: { [key: string]: string } = {\n  accent: 'bg-chrlblue',\n  primary: 'bg-chrdblue',\n  darkeraccent: 'bg-chrmblue',\n  alert: 'bg-chrorange',\n  warn: 'bg-chrwarning',\n};\nexport const TextColors: { [key: string]: string } = {\n  accent: 'text-chrlblue',\n  primary: 'text-chrdblue',\n  darkeraccent: 'text-chrmblue',\n  alert: 'text-chrorange',\n  warn: 'text-chrwarning',\n  white: 'text-white',\n  black: 'text-black',\n};\n\nexport const BorderColors: { [key: string]: string } = {\n  accent: 'border-chrlblue',\n  primary: 'border-chrdblue',\n  darkeraccent: 'border-chrmblue',\n  alert: 'border-chrorange',\n  warn: 'border-chrwarning',\n};\n\nexport const Aligments: { [key: string]: string } = {\n  left: 'text-left justify-start',\n  center: 'text-center justify-center',\n  right: 'text-right justify-end',\n};\n\nexport interface IChips {\n  display: string;\n  name: string;\n  callback: (entry: any) => string | boolean;\n  textColor?: 'primary' | 'accent' | 'warn' | 'alert' | 'darkeraccent' | 'none';\n  backgroundColor?:\n    | 'primary'\n    | 'accent'\n    | 'warn'\n    | 'alert'\n    | 'darkeraccent'\n    | 'none';\n}\n\nexport interface IColumn {\n  display: string;\n  alignment?: 'left' | 'center' | 'right';\n  chips?: IChips[];\n  properties?: string[];\n  callback?: Function;\n  date?: string;\n  isLink?: boolean;\n  linkStaticUrl?: string;\n}\n\nexport interface IComputedRow {\n  columns: IComputedColumn[];\n}\n\nexport interface IComputedColumn {\n  label?: string;\n  value?: any;\n  callback?: Function;\n  alignment?: 'left' | 'center' | 'right';\n  after?: string;\n}\n\nexport interface IAction {\n  display?: string;\n  icon?: string;\n  callback: Function;\n  disabled?: boolean;\n  disabledCallback?: Function;\n  color: 'primary' | 'accent' | 'warn' | 'alert' | 'darkeraccent' | 'none';\n}\n\n@Component({\n  selector: 'app-chr-table, [app-chr-table]',\n  templateUrl: './chr-table.component.html',\n  styleUrls: ['./chr-table.component.scss', '../../../../../tailwindbuild.css'],\n  standalone: true,\n  imports: [\n    ChrTableHeaderCellComponent,\n    ChrButtonComponent,\n    ChrPaginatorComponent,\n    SortPipe,\n    NgxPaginationModule,\n    CommonModule,\n    NgFor,\n    DatePipe,\n  ],\n  providers: [\n    DatePipe,\n    {\n      provide: DATE_PIPE_DEFAULT_OPTIONS,\n      useValue: { dateFormat: 'shortDate' },\n    },\n  ],\n})\nexport class ChrTableComponent implements OnInit, AfterViewInit {\n  @Input() computedRows?: IComputedRow[];\n  @Input() columns?: IColumn[];\n  @Input() data: any[] | null = [];\n  @Input() actions?: IAction[];\n\n  @Input() isAsc: boolean = true;\n  @Output() isAscChange: EventEmitter<boolean> = new EventEmitter();\n  @Input() sortBy?: string;\n  @Output() sortByChange: EventEmitter<string> = new EventEmitter();\n\n  @Input() pageSize: number = 50;\n  @Output() pageSizeChange: EventEmitter<number> = new EventEmitter();\n\n  @Input() currentPage: number = 1;\n  @Output() currentPageChange: EventEmitter<number> = new EventEmitter();\n\n  @Input() selectable: boolean = false;\n\n  @Input() selection: any[] = [];\n  @Output() selectionChange: EventEmitter<any[]> = new EventEmitter();\n\n  @Input() id?: string = 'chr_base-data-table';\n\n  @Input() color: 'primary' | 'accent' | 'warn' | 'alert' | 'darkeraccent' =\n    'accent';\n\n  @Input() textColor:\n    | 'primary'\n    | 'accent'\n    | 'warn'\n    | 'alert'\n    | 'darkeraccent'\n    | 'white'\n    | 'black' = 'black';\n\n  private _page: number = 1;\n\n  currentProperty: any | null = null;\n  currentText: string | null = null;\n\n  constructor(\n    private _date: DatePipe,\n    private dataService: DataService,\n    private changeDetector: ChangeDetectorRef\n  ) {}\n\n  ngOnInit(): void {\n    this.dataService.get(`${this.id}_sortBy`).subscribe((res) => {\n      if (res) this.sortBy = res;\n    });\n    this.dataService.get(`${this.id}_isAsc`).subscribe((res) => {\n      if (res) this.isAsc = res;\n    });\n  }\n  ngAfterViewInit(): void {}\n\n  protected emitIsAsc(isAsc: any) {\n    this.dataService.set(`${this.id}_isAsc`, isAsc);\n    this.isAscChange.emit(isAsc);\n  }\n\n  protected emitSortBy(sortBy: any) {\n    this.dataService.set(`${this.id}_sortBy`, sortBy);\n    this.sortByChange.emit(sortBy);\n  }\n\n  protected emitPageSize(pageSize: any) {\n    this.pageSize = pageSize;\n    this.pageSizeChange.emit(pageSize);\n  }\n\n  protected emitCurrentPage(currentPage: any) {\n    this.currentPage = currentPage;\n    this.currentPageChange.emit(currentPage);\n  }\n\n  protected getProperty = (entry: any, properties?: any[]) => {\n    this.currentProperty = null;\n    this.currentText = null;\n\n    if (!properties) {\n      this.currentProperty = entry;\n      return entry;\n    }\n    let value = entry;\n    for (const i of properties) {\n      value = (value as any)?.[i];\n    }\n    this.currentProperty = value;\n    return value;\n  };\n\n  protected getText = (property: any, column: IColumn) => {\n    let text = null;\n\n    if (column.callback) text = column.callback(property);\n\n    if (text == null && column.date)\n      text = this._date.transform(property, column.date);\n\n    this.currentText = text || property;\n\n    return text || property;\n    // column.date\n    //   ? column.callback\n    // \t? column.callback(property)\n    // \t: (property | date : column.date)\n    //   : column.callback\n    // \t? column.callback(property)\n    // \t: property\n  };\n\n  protected select = (entry: any, event: MouseEvent) => {\n    const pointer = <PointerEvent>event;\n    const target = <HTMLInputElement>pointer.target;\n    if (target.checked) {\n      this.selection.push(entry);\n    } else {\n      this.selection = this.selection.filter((x) => x !== entry);\n    }\n\n    this.selectionChange.emit(this.selection);\n  };\n\n  public getSelection = () => {\n    return this.selection;\n  };\n\n  public setSelection = (data: any[]) => {\n    this.selection = data;\n    this.selectionChange.emit(this.selection);\n  };\n\n  protected contains = (entry: any) => {\n    return this.selection.includes(entry);\n  };\n\n  protected getIsAsc = () => {\n    return this.isAsc;\n  };\n\n  protected getSortBy = () => {\n    return this.sortBy;\n  };\n\n  protected getTextColor = (color: Color = 'none') => {\n    return TextColors[color] || TextColors['black'];\n  };\n\n  protected getBackgroundColor = (color: Color = 'none') => {\n    return BackgroundColors[color] || BackgroundColors['accent'];\n  };\n\n  protected getBorderColor = (color: Color = 'none') => {\n    return BorderColors[color] || BorderColors['accent'];\n  };\n\n  protected getAlignment = (alignment: Alignment = 'center') => {\n    return Aligments[alignment] || Aligments['left'];\n  };\n}\n","<div class=\"h-full no-scrollbar\">\n  <ng-content class=\"mt-5\"></ng-content>\n  <div class=\"flex flex-col flex-1 overflow-auto no-scrollbar\">\n    @if (data) {\n    <!-- max-w-[75%] -->\n    <table\n      class=\"table-auto max-w-full border dark:border-none relative flex flex-row flex-no-wrap w-full rounded-lg sm:shadow-lg bg-transparent no-scrollbar\">\n      <thead class=\"text-black\">\n        @if (data.length <= 0) { <tr class=\"flex flex-col flex-no wrap sm:table-row rounded-lg mb-2 sm:mb-0\"\n          [ngClass]=\"[getBackgroundColor(color), getTextColor(textColor)]\">\n          @for (column of columns; track column) {\n          <th app-chr-table-header-cell class=\"p-3 h-14\" display=\"{{ column.display }}\" column=\"{{ column.properties }}\"\n            [(isAsc)]=\"isAsc\" (isAscChange)=\"emitIsAsc($event)\" [(sortBy)]=\"sortBy\" (sortByChange)=\"emitSortBy($event)\">\n          </th>\n          }\n          @if (actions) {\n          <th\n            class=\"h-14 p-3 text-left sm:text-center place-content-center place-items-center items-center align-middle sm:w-0\">\n            Actions\n          </th>\n          }\n          </tr>\n          }\n          @for (entry of data |\n          sort:isAsc:sortBy | paginate: {itemsPerPage: pageSize, currentPage: currentPage, id: this.id}; track entry)\n          {\n          <tr class=\"flex flex-col flex-no wrap sm:table-row rounded-lg mb-2 sm:mb-0 \"\n            [ngClass]=\"[getBackgroundColor(color), getTextColor(textColor)]\">\n            <th *ngIf=\"selectable\" class=\"p-3 h-14\"></th>\n            @for (column of columns; track column) {\n            <th app-chr-table-header-cell class=\"p-3 h-14\" display=\"{{ column.display }}\"\n              column=\"{{ column.properties }}\" [(isAsc)]=\"isAsc\" alignment=\"{{column.alignment}}\"\n              (isAscChange)=\"emitIsAsc($event)\" [(sortBy)]=\"sortBy\" (sortByChange)=\"emitSortBy($event)\"></th>\n            }\n            @if (actions) {\n            <th\n              class=\"h-14 p-3 text-left sm:text-center place-content-center place-items-center items-center align-middle self-center sm:w-0\">\n              Actions\n            </th>\n            }\n          </tr>\n          }\n      </thead>\n      <tbody class=\"w-full\">\n        @if (data.length <= 0) { <tr\n          class=\"flex flex-col flex-no-wrap sm:table-row rounded-lg mb-0 sm:mb-2 dark:bg-slate-600\">\n          <td class=\"p-3 h-14\">Pas de donnée(s)</td>\n          @for (column of columns | slice: 1; track column) {\n          <td class=\"p-3 h-14\"></td>\n          }\n          @if (actions) {\n          <td class=\"p-3 h-14 grid gap-3 justify-center align-middle items-center\"\n            [ngClass]=\"actions.length > 1 ? 'grid-cols-2' : 'grid-cols-1'\"></td>\n          }\n          </tr>\n          }\n          @for (entry of data |\n          sort:isAsc:sortBy | paginate: {itemsPerPage: pageSize, currentPage: currentPage, id: this.id}; track\n          entry; let i = $index) {\n          <tr [attr.data-index]=\"i\"\n            class=\"flex flex-col flex-no-wrap sm:table-row mb-2 sm:mb-0 dark:text-gray-400 dark:bg-slate-600 sm:odd:bg-gray-200 sm:dark:odd:bg-slate-700 sm:border-t-2 sm:first:border-0\"\n            [ngClass]=\"[getBorderColor(color)]\">\n            <td *ngIf=\"selectable\"\n              class=\"p-3 h-14 text-ellipsis max-w-full border-t-2 first:border-0 sm:first:border-t-2\"\n              [ngClass]=\"getBorderColor(color)\"><input type=\"checkbox\" (click)=\"select(entry, $event)\"\n                [checked]=\"contains(entry)\" /></td>\n            @for (column of columns; track column;) {\n            <td [ngClass]=\"\n                column.chips\n                  ? ''\n                  : ''\n              \" class=\"p-3 h-14 text-ellipsis max-w-full border-t-2 first:border-0 sm:first:border-t-2\"\n              [ngClass]=\"getBorderColor(color)\">\n              <ng-container [ngTemplateOutlet]=\"default\"\n                [ngTemplateOutletContext]=\"{prop: getProperty(entry, column.properties), column: column}\">\n              </ng-container>\n            </td>\n            }\n\n            <ng-template #default let-column='column' let-property=\"prop\">\n              @if (column.isLink) {\n              <a target=\"_blank\" class=\"text-{{column.alignment}}\" href=\"{{column.linkStaticUrl}}{{\n              getText(property, column)\n              }}\">\n                {{\n                currentText\n                }}\n              </a>\n              }\n              @if (!column.isLink) {\n              <div class=\"flex flex-row\" [ngClass]=\"{\n                'justify-start': column.alignment == 'left',\n                'justify-center': column.alignment == 'center',\n                'justify-end': column.alignment == 'right',\n                'gap-2': column.chipsDisplay && getText(property, column)\n              }\">\n                @if (column.chips && column.chips.length > 0) {\n                <div>\n                  @for(chip of column.chips; track chip; let i = $index){\n                  <span *ngIf=\"chip.callback(entry) === true || chip.callback(entry) === chip.name\"\n                    class=\"w-24 flex text-center content-center align-middle items-center justify-center text-xs font-medium py-0.5 rounded-full\"\n                    [ngClass]=\"[getBackgroundColor(chip.backgroundColor), getTextColor(chip.textColor)]\">\n                    {{ chip.display }}\n                  </span>\n                  }\n                </div>\n                }@else {\n                <p class=\"inline-block overflow-hidden text-nowrap text-ellipsis max-w-full\">\n                  {{\n                  currentText || getText(property, column)\n                  }}\n                </p>\n                }\n              </div>\n              }\n            </ng-template>\n\n            @if (actions) {\n            <td class=\"p-3 h-14 flex gap-2 w-full sm:w-min justify-center\">\n              @for (action of actions; track action) {\n              <app-chr-button class=\"w-full\" [disabled]=\"\n                  action.disabledCallback\n                    ? action.disabledCallback(entry)\n                    : action.disabled || false\n                \" [display]=\"action.display\" [icon]=\"action.icon\" [click]=\"action.callback.bind(null, entry, i)\"\n                [color]=\"action.color\" type=\"responsive\">\n              </app-chr-button>\n              }\n            </td>\n            }\n          </tr>\n          }\n          @for (r of computedRows; track r) {\n          <tr\n            class=\"flex flex-col flex-no-wrap sm:table-row mb-2 sm:mb-0 dark:text-gray-400 dark:bg-slate-600 sm:odd:bg-gray-200 sm:dark:odd:bg-slate-700\">\n            @for (c of r.columns; track c) {\n            <td [ngClass]=\"c.alignment && 'text-'+(c.alignment||'left')\" class=\"p-3 h-14\">\n              {{c.label && c.label + ':'}} {{c.value || (c.callback && c.callback(data))}} {{c.after}}\n            </td>\n            }\n          </tr>\n          }\n      </tbody>\n    </table>\n    <app-chr-paginator [id]=\"this.id\" [(pageSize)]=\"pageSize\" [(page)]=\"currentPage\"\n      (pageSizeChange)=\"emitPageSize($event)\" (pageChange)=\"emitCurrentPage($event)\"></app-chr-paginator>\n    }\n  </div>\n</div>"]}
|
|
@@ -1846,16 +1846,16 @@ class ChrTableComponent {
|
|
|
1846
1846
|
return this.sortBy;
|
|
1847
1847
|
};
|
|
1848
1848
|
this.getTextColor = (color = 'none') => {
|
|
1849
|
-
return TextColors[color];
|
|
1849
|
+
return TextColors[color] || TextColors['black'];
|
|
1850
1850
|
};
|
|
1851
1851
|
this.getBackgroundColor = (color = 'none') => {
|
|
1852
|
-
return BackgroundColors[color];
|
|
1852
|
+
return BackgroundColors[color] || BackgroundColors['accent'];
|
|
1853
1853
|
};
|
|
1854
1854
|
this.getBorderColor = (color = 'none') => {
|
|
1855
|
-
return BorderColors[color];
|
|
1855
|
+
return BorderColors[color] || BorderColors['accent'];
|
|
1856
1856
|
};
|
|
1857
1857
|
this.getAlignment = (alignment = 'center') => {
|
|
1858
|
-
return Aligments[alignment];
|
|
1858
|
+
return Aligments[alignment] || Aligments['left'];
|
|
1859
1859
|
};
|
|
1860
1860
|
}
|
|
1861
1861
|
ngOnInit() {
|