thingsboard/ui-ngx/src/app/modules/home/models/entity/entities-table-config.models.ts

170 lines
7.3 KiB
TypeScript
Raw Normal View History

2019-08-12 19:34:23 +03:00
///
/// Copyright © 2016-2019 The Thingsboard Authors
///
/// Licensed under the Apache License, Version 2.0 (the "License");
/// you may not use this file except in compliance with the License.
/// You may obtain a copy of the License at
///
/// http://www.apache.org/licenses/LICENSE-2.0
///
/// Unless required by applicable law or agreed to in writing, software
/// distributed under the License is distributed on an "AS IS" BASIS,
/// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
/// See the License for the specific language governing permissions and
/// limitations under the License.
///
2019-08-21 18:18:46 +03:00
import {BaseData, HasId} from '@shared/models/base-data';
import {EntitiesFetchFunction} from '@home/models/datasource/entity-datasource';
import {Observable, of} from 'rxjs';
import {emptyPageData} from '@shared/models/page/page-data';
import {DatePipe} from '@angular/common';
import {Direction, SortOrder} from '@shared/models/page/sort-order';
import {EntityType, EntityTypeResource, EntityTypeTranslation} from '@shared/models/entity-type.models';
import {EntityComponent} from '@home/components/entity/entity.component';
import {Type} from '@angular/core';
import {EntityAction} from './entity-component.models';
import {HasUUID} from '@shared/models/id/has-uuid';
import {PageLink} from '@shared/models/page/page-link';
import {EntitiesTableComponent} from '@home/components/entity/entities-table.component';
import {EntityTableHeaderComponent} from '@home/components/entity/entity-table-header.component';
import {ActivatedRoute} from '@angular/router';
import { EntityTabsComponent } from '../../components/entity/entity-tabs.component';
2019-08-12 19:34:23 +03:00
export type EntityBooleanFunction<T extends BaseData<HasId>> = (entity: T) => boolean;
export type EntityStringFunction<T extends BaseData<HasId>> = (entity: T) => string;
export type EntityCountStringFunction = (count: number) => string;
export type EntityTwoWayOperation<T extends BaseData<HasId>> = (entity: T) => Observable<T>;
export type EntityByIdOperation<T extends BaseData<HasId>> = (id: HasUUID) => Observable<T>;
export type EntityIdOneWayOperation = (id: HasUUID) => Observable<any>;
export type EntityActionFunction<T extends BaseData<HasId>> = (action: EntityAction<T>) => boolean;
export type CreateEntityOperation<T extends BaseData<HasId>> = () => Observable<T>;
export type CellContentFunction<T extends BaseData<HasId>> = (entity: T, key: string) => string;
export type CellTooltipFunction<T extends BaseData<HasId>> = (entity: T, key: string) => string | undefined;
2019-08-22 18:44:48 +03:00
export type HeaderCellStyleFunction<T extends BaseData<HasId>> = (key: string) => object;
2019-08-12 19:34:23 +03:00
export type CellStyleFunction<T extends BaseData<HasId>> = (entity: T, key: string) => object;
export interface CellActionDescriptor<T extends BaseData<HasId>> {
name: string;
nameFunction?: (entity: T) => string;
icon?: string;
mdiIcon?: string;
style?: any;
2019-08-12 19:34:23 +03:00
isEnabled: (entity: T) => boolean;
onAction: ($event: MouseEvent, entity: T) => void;
}
export interface GroupActionDescriptor<T extends BaseData<HasId>> {
name: string;
icon: string;
isEnabled: boolean;
onAction: ($event: MouseEvent, entities: T[]) => void;
}
export interface HeaderActionDescriptor {
name: string;
icon: string;
isEnabled: () => boolean;
onAction: ($event: MouseEvent) => void;
}
2019-08-22 18:44:48 +03:00
export type EntityTableColumnType = 'content' | 'action';
export class BaseEntityTableColumn<T extends BaseData<HasId>> {
constructor(public type: EntityTableColumnType,
public key: string,
public title: string,
public maxWidth: string = '100%',
public sortable: boolean = true) {
}
}
export class EntityTableColumn<T extends BaseData<HasId>> extends BaseEntityTableColumn<T> {
2019-08-12 19:34:23 +03:00
constructor(public key: string,
public title: string,
public maxWidth: string = '100%',
public cellContentFunction: CellContentFunction<T> = (entity, property) => entity[property],
2019-08-13 19:58:35 +03:00
public cellStyleFunction: CellStyleFunction<T> = () => ({}),
2019-08-22 18:44:48 +03:00
public sortable: boolean = true,
public headerCellStyleFunction: HeaderCellStyleFunction<T> = () => ({}),
public cellTooltipFunction: CellTooltipFunction<T> = () => undefined) {
2019-08-22 18:44:48 +03:00
super('content', key, title, maxWidth, sortable);
}
}
export class EntityActionTableColumn<T extends BaseData<HasId>> extends BaseEntityTableColumn<T> {
constructor(public key: string,
public title: string,
public actionDescriptor: CellActionDescriptor<T>,
public maxWidth: string = '100%') {
super('action', key, title, maxWidth, false);
2019-08-12 19:34:23 +03:00
}
}
export class DateEntityTableColumn<T extends BaseData<HasId>> extends EntityTableColumn<T> {
constructor(key: string,
title: string,
datePipe: DatePipe,
maxWidth: string = '100%',
dateFormat: string = 'yyyy-MM-dd HH:mm:ss',
cellStyleFunction: CellStyleFunction<T> = () => ({})) {
super(key,
title,
maxWidth,
(entity, property) => datePipe.transform(entity[property], dateFormat),
cellStyleFunction);
}
}
2019-08-22 18:44:48 +03:00
export type EntityColumn<T extends BaseData<HasId>> = EntityTableColumn<T> | EntityActionTableColumn<T>;
2019-08-12 19:34:23 +03:00
export class EntityTableConfig<T extends BaseData<HasId>, P extends PageLink = PageLink> {
constructor() {}
componentsData: any = null;
loadDataOnInit = true;
onLoadAction: (route: ActivatedRoute) => void = null;
table: EntitiesTableComponent = null;
useTimePageLink = false;
entityType: EntityType = null;
tableTitle = '';
selectionEnabled = true;
searchEnabled = true;
addEnabled = true;
entitiesDeleteEnabled = true;
detailsPanelEnabled = true;
actionsColumnTitle = null;
entityTranslations: EntityTypeTranslation;
entityResources: EntityTypeResource;
entityComponent: Type<EntityComponent<T>>;
2019-08-21 18:18:46 +03:00
entityTabsComponent: Type<EntityTabsComponent<T>>;
2019-08-19 20:09:41 +03:00
addDialogStyle = {};
2019-08-12 19:34:23 +03:00
defaultSortOrder: SortOrder = {property: 'createdTime', direction: Direction.ASC};
2019-08-22 18:44:48 +03:00
columns: Array<EntityColumn<T>> = [];
2019-08-12 19:34:23 +03:00
cellActionDescriptors: Array<CellActionDescriptor<T>> = [];
groupActionDescriptors: Array<GroupActionDescriptor<T>> = [];
headerActionDescriptors: Array<HeaderActionDescriptor> = [];
2019-08-14 19:55:24 +03:00
addActionDescriptors: Array<HeaderActionDescriptor> = [];
2019-08-12 19:34:23 +03:00
headerComponent: Type<EntityTableHeaderComponent<T>>;
addEntity: CreateEntityOperation<T> = null;
detailsReadonly: EntityBooleanFunction<T> = () => false;
2019-08-15 20:39:56 +03:00
entitySelectionEnabled: EntityBooleanFunction<T> = () => true;
2019-08-12 19:34:23 +03:00
deleteEnabled: EntityBooleanFunction<T> = () => true;
deleteEntityTitle: EntityStringFunction<T> = () => '';
deleteEntityContent: EntityStringFunction<T> = () => '';
deleteEntitiesTitle: EntityCountStringFunction = () => '';
deleteEntitiesContent: EntityCountStringFunction = () => '';
loadEntity: EntityByIdOperation<T> = () => of();
saveEntity: EntityTwoWayOperation<T> = (entity) => of(entity);
deleteEntity: EntityIdOneWayOperation = () => of();
entitiesFetchFunction: EntitiesFetchFunction<T, P> = () => of(emptyPageData<T>());
onEntityAction: EntityActionFunction<T> = () => false;
}
2019-08-13 19:58:35 +03:00
export function checkBoxCell(value: boolean): string {
return `<mat-icon class="material-icons mat-icon">${value ? 'check_box' : 'check_box_outline_blank'}</mat-icon>`;
}