UNPKG

ornamentum

Version:
279 lines 22.2 kB
/** * @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"]}