ornamentum
Version:
Angular Toolkit
279 lines • 22.2 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Inject, Injectable, InjectionToken } from '@angular/core';
/** @type {?} */
export const DATA_TABLE_CONFIG = new InjectionToken('dataTableConfig');
/**
* Data table config service
* Manage all the global configurations of grid which can be overridden while importing the module.
*/
export class DataTableConfigService {
/**
* @param {?} dataTableConfig
*/
constructor(dataTableConfig) {
this.dataTableConfig = dataTableConfig;
// Table base config
this.persistTableState = false;
this.storageMode = 'session';
this.multiColumnSortable = false;
this.showHeader = false;
this.title = '';
this.width = undefined;
this.minContentHeight = 200;
this.minContentWidth = undefined;
this.contentHeight = undefined;
this.pageable = false;
this.loadOnScroll = false;
this.loadViewDistanceRatio = 1;
this.showIndexColumn = false;
this.indexColumnTitle = '#';
this.rowSelectable = false;
this.selectMode = 'single';
this.showRowSelectCheckbox = true;
this.showRowSelectAllCheckbox = false;
this.showSubstituteRows = false;
this.expandableRows = false;
this.selectOnRowClick = false;
this.expandOnRowClick = false;
this.autoFetch = true;
this.showLoadingSpinner = true;
this.selectTrackBy = 'id';
this.filterDebounceTime = 500;
this.filterDebounce = true;
this.showRefreshButton = false;
this.showColumnSelector = false;
this.columnSelectorWidth = 240;
this.expanderColumnWidth = 30;
this.indexColumnWidth = 30;
this.selectionColumnWidth = 30;
this.showRowExpandLoadingSpinner = false;
this.offset = 0;
this.limit = 10;
this.maxLimit = 100;
this.stateKeyPrefix = 'grid_state_';
this.baseTranslations = {
noDataMessage: {
header: 'Whoops!',
body: 'No data to display. Added data will appear here.',
},
pagination: {
limit: 'Limit:',
rangeKey: 'Results:',
rangeSeparator: 'of',
nextTooltip: 'Next',
previousTooltip: 'Previous',
lastTooltip: 'Last',
firstTooltip: 'First'
},
columnSelector: {
header: 'Show/Hide Column'
},
dropdownFilter: {
noDataMessage: 'No Results Available',
filterPlaceholder: 'Search',
selectedOptionWrapPlaceholder: 'Options',
selectPlaceholder: 'Select'
}
};
// Table column config
this.sortable = false;
this.sortOrder = '';
this.filterable = false;
this.filterPlaceholder = 'Search';
this.columnResizable = false;
this.columnVisible = true;
this.showDropdownFilter = false;
this.showFilterClearButton = true;
// Column dropdown filter options
this.dropdownFilterMenuPosition = 'bottom-left';
this.dropdownFilterSelectMode = 'multi';
this.dropdownFilterSearchable = true;
this.dropdownFilterSearchDebounceTime = 500;
this.dropdownFilterSearchDebounce = true;
this.dropdownFilterWrapDisplaySelectLimit = 1;
this.dropdownFilterGroupByField = undefined;
this.dropdownFilterShowSelectedOptionRemoveButton = false;
this.dropdownFilterShowClearSelectionButton = true;
this.dropdownFilterMenuWidth = 320;
this.dropdownFilterMenuHeight = 250;
this.dropdownFilterMultiSelectOptionMaxWidth = 135;
this.dropdownFilterCloseMenuOnSelect = true;
this.dropdownFilterDynamicDimensionCalculation = true;
this.dropdownFilterDynamicWidthRatio = 1.25;
this.dropdownFilterDynamicHeightRatio = 1.25;
if (dataTableConfig) {
Object.assign(this, dataTableConfig);
}
}
/**
* @param {?} value
* @return {?}
*/
set translations(value) {
if (!value) {
return;
}
// all keys are object type.
for (const [key, val] of Object.entries(value)) {
this.baseTranslations[key] = Object.assign({}, this.baseTranslations[key], val);
}
}
/**
* Returns translations.
* @return {?}
*/
get translations() {
return this.baseTranslations;
}
/**
* Get row select checkbox column.
* @return {?}
*/
get showRowSelectCheckboxColumn() {
return this.rowSelectable && this.showRowSelectCheckbox;
}
}
DataTableConfigService.decorators = [
{ type: Injectable }
];
/** @nocollapse */
DataTableConfigService.ctorParameters = () => [
{ type: undefined, decorators: [{ type: Inject, args: [DATA_TABLE_CONFIG,] }] }
];
if (false) {
/** @type {?} */
DataTableConfigService.prototype.persistTableState;
/** @type {?} */
DataTableConfigService.prototype.storageMode;
/** @type {?} */
DataTableConfigService.prototype.multiColumnSortable;
/** @type {?} */
DataTableConfigService.prototype.showHeader;
/** @type {?} */
DataTableConfigService.prototype.title;
/** @type {?} */
DataTableConfigService.prototype.width;
/** @type {?} */
DataTableConfigService.prototype.minContentHeight;
/** @type {?} */
DataTableConfigService.prototype.minContentWidth;
/** @type {?} */
DataTableConfigService.prototype.contentHeight;
/** @type {?} */
DataTableConfigService.prototype.pageable;
/** @type {?} */
DataTableConfigService.prototype.loadOnScroll;
/** @type {?} */
DataTableConfigService.prototype.loadViewDistanceRatio;
/** @type {?} */
DataTableConfigService.prototype.showIndexColumn;
/** @type {?} */
DataTableConfigService.prototype.indexColumnTitle;
/** @type {?} */
DataTableConfigService.prototype.rowSelectable;
/** @type {?} */
DataTableConfigService.prototype.selectMode;
/** @type {?} */
DataTableConfigService.prototype.showRowSelectCheckbox;
/** @type {?} */
DataTableConfigService.prototype.showRowSelectAllCheckbox;
/** @type {?} */
DataTableConfigService.prototype.showSubstituteRows;
/** @type {?} */
DataTableConfigService.prototype.expandableRows;
/** @type {?} */
DataTableConfigService.prototype.selectOnRowClick;
/** @type {?} */
DataTableConfigService.prototype.expandOnRowClick;
/** @type {?} */
DataTableConfigService.prototype.autoFetch;
/** @type {?} */
DataTableConfigService.prototype.showLoadingSpinner;
/** @type {?} */
DataTableConfigService.prototype.selectTrackBy;
/** @type {?} */
DataTableConfigService.prototype.filterDebounceTime;
/** @type {?} */
DataTableConfigService.prototype.filterDebounce;
/** @type {?} */
DataTableConfigService.prototype.showRefreshButton;
/** @type {?} */
DataTableConfigService.prototype.showColumnSelector;
/** @type {?} */
DataTableConfigService.prototype.columnSelectorWidth;
/** @type {?} */
DataTableConfigService.prototype.expanderColumnWidth;
/** @type {?} */
DataTableConfigService.prototype.indexColumnWidth;
/** @type {?} */
DataTableConfigService.prototype.selectionColumnWidth;
/** @type {?} */
DataTableConfigService.prototype.showRowExpandLoadingSpinner;
/** @type {?} */
DataTableConfigService.prototype.offset;
/** @type {?} */
DataTableConfigService.prototype.limit;
/** @type {?} */
DataTableConfigService.prototype.maxLimit;
/** @type {?} */
DataTableConfigService.prototype.stateKeyPrefix;
/** @type {?} */
DataTableConfigService.prototype.baseTranslations;
/** @type {?} */
DataTableConfigService.prototype.sortable;
/** @type {?} */
DataTableConfigService.prototype.sortOrder;
/** @type {?} */
DataTableConfigService.prototype.filterable;
/** @type {?} */
DataTableConfigService.prototype.filterPlaceholder;
/** @type {?} */
DataTableConfigService.prototype.columnResizable;
/** @type {?} */
DataTableConfigService.prototype.columnVisible;
/** @type {?} */
DataTableConfigService.prototype.showDropdownFilter;
/** @type {?} */
DataTableConfigService.prototype.showFilterClearButton;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterMenuPosition;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterSelectMode;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterSearchable;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterSearchDebounceTime;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterSearchDebounce;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterWrapDisplaySelectLimit;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterGroupByField;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterShowSelectedOptionRemoveButton;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterShowClearSelectionButton;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterMenuWidth;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterMenuHeight;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterMultiSelectOptionMaxWidth;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterCloseMenuOnSelect;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterDynamicDimensionCalculation;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterDynamicWidthRatio;
/** @type {?} */
DataTableConfigService.prototype.dropdownFilterDynamicHeightRatio;
/**
* @type {?}
* @private
*/
DataTableConfigService.prototype.dataTableConfig;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"data-table-config.service.js","sourceRoot":"ng://ornamentum/","sources":["data-table/services/data-table-config.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Inject, Injectable, InjectionToken } from '@angular/core';\n\nimport { DataTableTranslations } from '../models/data-table-translations.model';\nimport { DataTableConfig } from '../models/data-table-config.model';\n\nimport { DataTableStorageMode } from '../models/data-table-storage-mode.model';\nimport { DataTableSortOrder } from '../models/data-table-sort-order.model';\nimport { DataTableSelectMode } from '../models/data-table-select-mode.model';\nimport { DropdownSelectMode } from '../../dropdown/dropdown.module';\nimport { ViewPosition } from '../../utility/models/view-position.model';\n\nexport const DATA_TABLE_CONFIG = new InjectionToken<DataTableConfig>('dataTableConfig');\n\n/**\n * Data table config service\n * Manage all the global configurations of grid which can be overridden while importing the module.\n */\n@Injectable()\nexport class DataTableConfigService implements DataTableConfig {\n  // Table base config\n  public persistTableState = false;\n  public storageMode: DataTableStorageMode = 'session';\n  public multiColumnSortable = false;\n  public showHeader = false;\n  public title = '';\n  public width = undefined;\n  public minContentHeight: string | number = 200;\n  public minContentWidth = undefined;\n  public contentHeight = undefined;\n  public pageable = false;\n  public loadOnScroll = false;\n  public loadViewDistanceRatio = 1;\n  public showIndexColumn = false;\n  public indexColumnTitle = '#';\n  public rowSelectable = false;\n  public selectMode: DataTableSelectMode = 'single';\n  public showRowSelectCheckbox = true;\n  public showRowSelectAllCheckbox = false;\n  public showSubstituteRows = false;\n  public expandableRows = false;\n  public selectOnRowClick = false;\n  public expandOnRowClick = false;\n  public autoFetch = true;\n  public showLoadingSpinner = true;\n  public selectTrackBy = 'id';\n  public filterDebounceTime = 500;\n  public filterDebounce = true;\n  public showRefreshButton = false;\n  public showColumnSelector = false;\n  public columnSelectorWidth = 240;\n  public expanderColumnWidth: string | number = 30;\n  public indexColumnWidth: string | number = 30;\n  public selectionColumnWidth: string | number = 30;\n  public showRowExpandLoadingSpinner = false;\n  public offset = 0;\n  public limit = 10;\n  public maxLimit = 100;\n  public stateKeyPrefix = 'grid_state_';\n  public baseTranslations: DataTableTranslations = {\n    noDataMessage: {\n      header: 'Whoops!',\n      body: 'No data to display. Added data will appear here.',\n    },\n    pagination: {\n      limit: 'Limit:',\n      rangeKey: 'Results:',\n      rangeSeparator: 'of',\n      nextTooltip: 'Next',\n      previousTooltip: 'Previous',\n      lastTooltip: 'Last',\n      firstTooltip: 'First'\n    },\n    columnSelector: {\n      header: 'Show/Hide Column'\n    },\n    dropdownFilter: {\n      noDataMessage: 'No Results Available',\n      filterPlaceholder: 'Search',\n      selectedOptionWrapPlaceholder: 'Options',\n      selectPlaceholder: 'Select'\n    }\n  };\n\n  // Table column config\n  public sortable = false;\n  public sortOrder: DataTableSortOrder = '';\n  public filterable = false;\n  public filterPlaceholder = 'Search';\n  public columnResizable = false;\n  public columnVisible = true;\n  public showDropdownFilter = false;\n  public showFilterClearButton = true;\n\n  // Column dropdown filter options\n  public dropdownFilterMenuPosition: ViewPosition = 'bottom-left';\n  public dropdownFilterSelectMode: DropdownSelectMode = 'multi';\n  public dropdownFilterSearchable = true;\n  public dropdownFilterSearchDebounceTime = 500;\n  public dropdownFilterSearchDebounce = true;\n  public dropdownFilterWrapDisplaySelectLimit = 1;\n  public dropdownFilterGroupByField = undefined;\n  public dropdownFilterShowSelectedOptionRemoveButton = false;\n  public dropdownFilterShowClearSelectionButton = true;\n  public dropdownFilterMenuWidth = 320;\n  public dropdownFilterMenuHeight = 250;\n  public dropdownFilterMultiSelectOptionMaxWidth = 135;\n  public dropdownFilterCloseMenuOnSelect = true;\n  public dropdownFilterDynamicDimensionCalculation = true;\n  public dropdownFilterDynamicWidthRatio = 1.25;\n  public dropdownFilterDynamicHeightRatio = 1.25;\n\n  constructor(@Inject(DATA_TABLE_CONFIG) private dataTableConfig: DataTableConfig) {\n    if (dataTableConfig) {\n      Object.assign(this, dataTableConfig);\n    }\n  }\n\n  public set translations(value: DataTableTranslations) {\n    if (!value) {\n      return;\n    }\n\n    // all keys are object type.\n    for (const [key, val] of Object.entries(value)) {\n      this.baseTranslations[key] = { ...this.baseTranslations[key], ...val };\n    }\n  }\n\n  /**\n   * Returns translations.\n   */\n  public get translations(): DataTableTranslations {\n    return this.baseTranslations;\n  }\n\n  /**\n   * Get row select checkbox column.\n   */\n  public get showRowSelectCheckboxColumn(): boolean {\n    return this.rowSelectable && this.showRowSelectCheckbox;\n  }\n}\n\n"]}