UNPKG

@catull/igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

1,037 lines 108 kB
import { __decorate, __metadata } from "tslib"; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, HostBinding, HostListener, Input, TemplateRef, ViewChild, NgZone, OnInit, OnDestroy, OnChanges, SimpleChanges } from '@angular/core'; import { IgxTextHighlightDirective } from '../directives/text-highlight/text-highlight.directive'; import { GridBaseAPIService } from './api.service'; import { getNodeSizeViaRange, ROW_COLLAPSE_KEYS, ROW_EXPAND_KEYS, SUPPORTED_KEYS, NAVIGATION_KEYS, isIE, isLeftClick, PlatformUtil } from '../core/utils'; import { IgxGridSelectionService, ISelectionNode, IgxGridCRUDService } from './selection/selection.service'; import { DeprecateProperty, DeprecateMethod } from '../core/deprecateDecorators'; import { HammerGesturesManager } from '../core/touch'; import { GridSelectionMode } from './common/enums'; /** * Providing reference to `IgxGridCellComponent`: * ```typescript * @ViewChild('grid', { read: IgxGridComponent }) * public grid: IgxGridComponent; * ``` * ```typescript * let column = this.grid.columnList.first; * ``` * ```typescript * let cell = column.cells[0]; * ``` */ let IgxGridCellComponent = class IgxGridCellComponent { constructor(selectionService, crudService, gridAPI, cdr, element, zone, touchManager, platformUtil) { this.selectionService = selectionService; this.crudService = crudService; this.gridAPI = gridAPI; this.cdr = cdr; this.element = element; this.zone = zone; this.touchManager = touchManager; this.platformUtil = platformUtil; this._vIndex = -1; /** * Sets/gets the highlight class of the cell. * Default value is `"igx-highlight"`. * ```typescript * let highlightClass = this.cell.highlightClass; * ``` * ```typescript * this.cell.highlightClass = 'igx-cell-highlight'; * ``` * @memberof IgxGridCellComponent */ this.highlightClass = 'igx-highlight'; /** * Sets/gets the active highlight class class of the cell. * Default value is `"igx-highlight__active"`. * ```typescript * let activeHighlightClass = this.cell.activeHighlightClass; * ``` * ```typescript * this.cell.activeHighlightClass = 'igx-cell-highlight_active'; * ``` * @memberof IgxGridCellComponent */ this.activeHighlightClass = 'igx-highlight__active'; /** * @hidden * @internal */ this.lastPinned = false; /** * Returns whether the cell is in edit mode. */ this.editMode = false; /** * Sets/get the `tabindex` property of the cell. * Default value is `0`. * ```typescript * this.cell.tabindex = 1; * ``` * ```typescript * let cellTabIndex = this.cell.tabindex; * ``` * @memberof IgxGridCellComponent */ this.tabindex = 0; /** * Sets/get the `role` property of the cell. * Default value is `"gridcell"`. * ```typescript * this.cell.role = 'grid-cell'; * ``` * ```typescript * let cellRole = this.cell.role; * ``` * @memberof IgxGridCellComponent */ this.role = 'gridcell'; /** * Gets the width of the cell. * ```typescript * let cellWidth = this.cell.width; * ``` * @memberof IgxGridCellComponent */ this.width = ''; /** * @hidden * @internal */ this.focused = false; this.isInCompositionMode = false; this._cellSelection = GridSelectionMode.multiple; /** * * @hidden * @internal */ this.pointerdown = (event) => { if (!isLeftClick(event)) { this.selectionService.addKeyboardRange(); this.selectionService.initKeyboardState(); this.selectionService.primaryButton = false; return; } this.selectionService.pointerDown(this.selectionNode, event.shiftKey, event.ctrlKey); }; /** * * @hidden * @internal */ this.pointerenter = (event) => { const dragMode = this.selectionService.pointerEnter(this.selectionNode, event); if (dragMode) { this.grid.cdr.detectChanges(); } }; /** * @hidden * @internal */ this.pointerup = (event) => { if (this.grid.hasColumnLayouts) { this.grid.navigation.setStartNavigationCell(this.colStart, this.rowStart, null); } if (!isLeftClick(event)) { return; } if (this.selectionService.pointerUp(this.selectionNode, this.grid.onRangeSelection)) { this.grid.cdr.detectChanges(); } this._updateCRUDStatus(); }; /** * @hidden * @internal */ this.onDoubleClick = (event) => { if (event.type === 'doubletap') { // prevent double-tap to zoom on iOS event.preventDefault(); } if (this.editable && !this.editMode && !this.row.deleted) { this.crudService.begin(this); } this.grid.onDoubleClick.emit({ cell: this, event }); }; } /** * Gets the cell template context object. * ```typescript * let context = this.cell.context(); * ``` * @memberof IgxGridCellComponent */ get context() { return { $implicit: this.value, cell: this }; } /** * Gets the cell template. * ```typescript * let template = this.cell.template; * ``` * @memberof IgxGridCellComponent */ get template() { if (this.editMode) { const inlineEditorTemplate = this.column.inlineEditorTemplate; return inlineEditorTemplate ? inlineEditorTemplate : this.inlineEditorTemplate; } if (this.cellTemplate) { return this.cellTemplate; } return this.defaultCellTemplate; } /** * Gets the `id` of the grid in which the cell is stored. * ```typescript * let gridId = this.cell.gridID; * ``` * @memberof IgxGridCellComponent */ get gridID() { return this.row.gridID; } /** * Gets the grid of the cell. * ```typescript * let grid = this.cell.grid; * ``` * @memberof IgxGridCellComponent */ get grid() { return this.gridAPI.grid; } /** * Gets the `index` of the row where the cell is stored. * ```typescript * let rowIndex = this.cell.rowIndex; * ``` * @memberof IgxGridCellComponent */ get rowIndex() { return this.row.index; } /** * Gets the `index` of the cell column. * ```typescript * let columnIndex = this.cell.columnIndex; * ``` * @memberof IgxGridCellComponent */ get columnIndex() { return this.column.index; } /** * Gets the visible `index` of the in which the cell is stored. * ```typescript * let visibleColumnIndex = this.cell.visibleColumnIndex; * ``` * @memberof IgxGridCellComponent */ get visibleColumnIndex() { return this.column.columnLayoutChild ? this.column.visibleIndex : this._vIndex; } set visibleColumnIndex(val) { this._vIndex = val; } /** * Gets the ID of the cell. * ```typescript * let cellID = this.cell.cellID; * ``` * @memberof IgxGridCellComponent */ get cellID() { const primaryKey = this.grid.primaryKey; const rowID = primaryKey ? this.rowData[primaryKey] : this.rowData; return { rowID, columnID: this.columnIndex, rowIndex: this.rowIndex }; } /** * Returns a reference to the nativeElement of the cell. * ```typescript * let cellNativeElement = this.cell.nativeElement; * ``` * @memberof IgxGridCellComponent */ get nativeElement() { return this.element.nativeElement; } /** * @deprecated * Use `cell.editMode` as a getter and * `cell.setEditMode(true | false)` to start/exit edit mode. * * Gets/sets whether the cell is in edit mode. * ```typescript * let isCellInEditMode = this.cell.inEditMode; * ``` * @memberof IgxGridCellComponent */ get inEditMode() { return this.editMode; } set inEditMode(value) { this.setEditMode(value); } /** * @hidden * @internal */ get cellSelectionMode() { return this._cellSelection; } set cellSelectionMode(value) { if (this._cellSelection === value) { return; } this.zone.runOutsideAngular(() => { value === GridSelectionMode.multiple ? this.addPointerListeners(value) : this.removePointerListeners(this._cellSelection); }); this._cellSelection = value; } /** * Gets whether the cell is editable. * ```typescript * let isCellReadonly = this.cell.readonly; * ``` * @memberof IgxGridCellComponent */ get readonly() { return !this.column.editable; } get gridRowSpan() { return this.column.gridRowSpan; } get gridColumnSpan() { return this.column.gridColumnSpan; } get rowEnd() { return this.column.rowEnd; } get colEnd() { return this.column.colEnd; } get rowStart() { return this.column.rowStart; } get colStart() { return this.column.colStart; } /** * Returns a string containing the grid `id` and the column `field` concatenated by "_". * ```typescript * let describedBy = this.cell.describedBy; * ``` * @memberof IgxGridCellComponent */ get describedby() { return `${this.row.gridID}_${this.column.field}`; } /** * Gets whether the cell is selected. * ```typescript * let isSelected = this.cell.selected; * ``` * @memberof IgxGridCellComponent */ get selected() { return this.selectionService.selected(this.selectionNode); } /** * Selects/deselects the cell. * ```typescript * this.cell.selected = true. * ``` * @memberof IgxGridCellComponent */ set selected(val) { const node = this.selectionNode; val ? this.selectionService.add(node) : this.selectionService.remove(node); this.grid.notifyChanges(); } get dirty() { if (this.grid.rowEditable) { const rowCurrentState = this.grid.transactions.getAggregatedValue(this.row.rowID, false); if (rowCurrentState) { return rowCurrentState[this.column.field] !== undefined && rowCurrentState[this.column.field] !== null; } } else { const rowTransaction = this.grid.transactions.getState(this.row.rowID); return rowTransaction && rowTransaction.value && (rowTransaction.value[this.column.field] || rowTransaction.value[this.column.field] === 0 || rowTransaction.value[this.column.field] === false); } return false; } /** * Sets the current edit value while a cell is in edit mode. * Only for cell editing mode. * ```typescript * this.cell.editValue = value; * ``` * @memberof IgxGridCellComponent */ set editValue(value) { if (this.crudService.inEditMode) { this.crudService.cell.editValue = value; } } /** * Gets the current edit value while a cell is in edit mode. * Only for cell editing mode. * ```typescript * let editValue = this.cell.editValue; * ``` * @memberof IgxGridCellComponent */ get editValue() { if (this.crudService.inEditMode) { return this.crudService.cell.editValue; } } /** * Returns whether the cell is editable. */ get editable() { return this.column.editable; } set highlight(value) { this._highlight = value; if (this._highlight && this.grid.lastSearchInfo.searchText) { this._highlight.highlight(this.grid.lastSearchInfo.searchText, this.grid.lastSearchInfo.caseSensitive, this.grid.lastSearchInfo.exactMatch); this._highlight.activateIfNecessary(); } } get highlight() { return this._highlight; } get selectionNode() { return { row: this.rowIndex, column: this.column.columnLayoutChild ? this.column.parent.visibleIndex : this.visibleColumnIndex, layout: this.column.columnLayoutChild ? { rowStart: this.column.rowStart, colStart: this.column.colStart, rowEnd: this.column.rowEnd, colEnd: this.column.colEnd, columnVisibleIndex: this.visibleColumnIndex } : null }; } addPointerListeners(selection) { if (selection !== GridSelectionMode.multiple) { return; } this.nativeElement.addEventListener('pointerdown', this.pointerdown); this.nativeElement.addEventListener('pointerenter', this.pointerenter); this.nativeElement.addEventListener('pointerup', this.pointerup); } removePointerListeners(selection) { if (selection !== GridSelectionMode.multiple) { return; } this.nativeElement.removeEventListener('pointerdown', this.pointerdown); this.nativeElement.removeEventListener('pointerenter', this.pointerenter); this.nativeElement.removeEventListener('pointerup', this.pointerup); } /** * @hidden * @internal */ ngOnInit() { this.zone.runOutsideAngular(() => { this.addPointerListeners(this.cellSelectionMode); // IE 11 workarounds if (isIE()) { this.compositionStartHandler = () => this.isInCompositionMode = true; this.compositionEndHandler = () => this.isInCompositionMode = false; // Hitting Enter with IME submits and exits from edit mode instead of first closing the IME dialog this.nativeElement.addEventListener('compositionstart', this.compositionStartHandler); this.nativeElement.addEventListener('compositionend', this.compositionEndHandler); } }); if (this.platformUtil.isIOS) { this.touchManager.addEventListener(this.nativeElement, 'doubletap', this.onDoubleClick, { cssProps: {} /* don't disable user-select, etc */ }); } } /** * @hidden * @internal */ ngOnDestroy() { this.zone.runOutsideAngular(() => { this.removePointerListeners(this.cellSelectionMode); if (isIE()) { this.nativeElement.removeEventListener('compositionstart', this.compositionStartHandler); this.nativeElement.removeEventListener('compositionend', this.compositionEndHandler); } }); this.touchManager.destroy(); } /** * @hidden * @internal */ _updateCRUDStatus() { if (this.editMode) { return; } const crud = this.crudService; const editableCell = this.crudService.cell; const editMode = !!(crud.row || crud.cell); if (this.editable && editMode && !this.row.deleted) { if (editableCell) { this.gridAPI.update_cell(editableCell, editableCell.editValue); } crud.end(); this.grid.notifyChanges(); crud.begin(this); return; } if (editableCell && crud.sameRow(this.cellID.rowID)) { this.gridAPI.submit_value(); } else if (editMode && !crud.sameRow(this.cellID.rowID)) { this.grid.endEdit(true); } } /** * @deprecated * Gets whether the cell is selected. * ```typescript * let isCellSelected = thid.cell.isCellSelected(); * ``` * @memberof IgxGridCellComponent */ isCellSelected() { return this.selectionService.selected(this.selectionNode); } /** * @hidden * @internal */ ngOnChanges(changes) { if (changes.value && !changes.value.firstChange) { if (this.highlight) { this.highlight.lastSearchInfo.searchedText = this.grid.lastSearchInfo.searchText; this.highlight.lastSearchInfo.caseSensitive = this.grid.lastSearchInfo.caseSensitive; this.highlight.lastSearchInfo.exactMatch = this.grid.lastSearchInfo.exactMatch; } } } /** * Starts/ends edit mode for the cell. * * ```typescript * cell.setEditMode(true); * ``` */ setEditMode(value) { if (this.row.deleted) { return; } if (this.editable && value) { this.gridAPI.submit_value(); this.crudService.begin(this); } else { this.gridAPI.escape_editMode(); } this.grid.notifyChanges(); } /** * Sets new value to the cell. * ```typescript * this.cell.update('New Value'); * ``` * @memberof IgxGridCellComponent */ // TODO: Refactor update(val) { if (this.row.deleted) { return; } const cell = this.crudService.createCell(this); const args = this.gridAPI.update_cell(cell, val); if (this.crudService.cell && this.crudService.sameCell(cell)) { if (args.cancel) { return; } this.gridAPI.escape_editMode(); } this.cdr.markForCheck(); } /** * @hidden * @internal */ onClick(event) { this.grid.onCellClick.emit({ cell: this, event }); } /** * @hidden * @internal */ onContextMenu(event) { this.grid.onContextMenu.emit({ cell: this, event }); } /** * @hidden * @internal */ onFocus(event) { if (this.focused) { return; } this.focused = true; this.row.focused = true; const node = this.selectionNode; const shouldEmitSelection = !this.selectionService.isActiveNode(node); if (this.selectionService.primaryButton) { this._updateCRUDStatus(); this.selectionService.activeElement = node; } else { this.selectionService.activeElement = null; if (this.crudService.inEditMode && !this.editMode) { this.gridAPI.submit_value(); } } this.selectionService.primaryButton = true; if (this.cellSelectionMode === GridSelectionMode.multiple && this.selectionService.activeElement) { this.selectionService.add(this.selectionService.activeElement, false); // pointer events handle range generation this.selectionService.keyboardStateOnFocus(node, this.grid.onRangeSelection, this.nativeElement); } if (this.grid.isCellSelectable && shouldEmitSelection) { this.grid.onSelection.emit({ cell: this, event }); } } /** * @hidden * @internal */ onBlur() { this.focused = false; this.row.focused = false; } handleAlt(key, event) { if (this.row.nativeElement.tagName.toLowerCase() === 'igx-tree-grid-row' && this.isToggleKey(key)) { const collapse = this.row.expanded && ROW_COLLAPSE_KEYS.has(key); const expand = !this.row.expanded && ROW_EXPAND_KEYS.has(key); if (collapse) { this.gridAPI.trigger_row_expansion_toggle(this.row.treeRow, !this.row.expanded, event, this.visibleColumnIndex); } else if (expand) { this.gridAPI.trigger_row_expansion_toggle(this.row.treeRow, !this.row.expanded, event, this.visibleColumnIndex); } } else if (this.grid.hasDetails && this.isToggleKey(key)) { const collapse = this.row.expanded && ROW_COLLAPSE_KEYS.has(key); const expand = !this.row.expanded && ROW_EXPAND_KEYS.has(key); const expandedStates = this.grid.expansionStates; if (expand) { expandedStates.set(this.row.rowID, true); } else if (collapse) { expandedStates.set(this.row.rowID, false); } this.grid.expansionStates = expandedStates; this.grid.notifyChanges(); } } handleTab(shift) { if (shift) { this.grid.navigation.performShiftTabKey(this.row.nativeElement, this.selectionNode); } else { this.grid.navigation.performTab(this.row.nativeElement, this.selectionNode); } } handleEnd(ctrl) { if (ctrl) { this.grid.navigation.goToLastCell(); } else { this.grid.navigation.onKeydownEnd(this.rowIndex, false, this.rowStart); } } handleHome(ctrl) { if (ctrl) { this.grid.navigation.goToFirstCell(); } else { this.grid.navigation.onKeydownHome(this.rowIndex, false, this.rowStart); } } // TODO: Refactor /** * * @hidden * @internal */ dispatchEvent(event) { const key = event.key.toLowerCase(); const shift = event.shiftKey; const ctrl = event.ctrlKey; const node = this.selectionNode; if (!SUPPORTED_KEYS.has(key)) { return; } event.stopPropagation(); const keydownArgs = { targetType: 'dataCell', target: this, event: event, cancel: false }; this.grid.onGridKeydown.emit(keydownArgs); if (keydownArgs.cancel) { this.selectionService.clear(); this.selectionService.keyboardState.active = true; return; } if (event.altKey) { event.preventDefault(); this.handleAlt(key, event); return; } this.selectionService.keyboardStateOnKeydown(node, shift, shift && key === 'tab'); if (key === 'tab') { event.preventDefault(); } if (this.editMode) { if (NAVIGATION_KEYS.has(key)) { if (this.column.inlineEditorTemplate) { return; } if (['date', 'boolean'].indexOf(this.column.dataType) > -1) { return; } return; } } if (NAVIGATION_KEYS.has(key)) { event.preventDefault(); } switch (key) { case 'tab': this.handleTab(shift); break; case 'end': this.handleEnd(ctrl); break; case 'home': this.handleHome(ctrl); break; case 'arrowleft': case 'left': if (ctrl) { this.grid.navigation.onKeydownHome(node.row, false, this.rowStart); break; } this.grid.navigation.onKeydownArrowLeft(this.nativeElement, this.selectionNode); break; case 'arrowright': case 'right': if (ctrl) { this.grid.navigation.onKeydownEnd(node.row, false, this.rowStart); break; } this.grid.navigation.onKeydownArrowRight(this.nativeElement, this.selectionNode); break; case 'arrowup': case 'up': if (ctrl) { this.grid.navigation.navigateTop(this.visibleColumnIndex); break; } this.grid.navigation.navigateUp(this.row.nativeElement, this.selectionNode); break; case 'arrowdown': case 'down': if (ctrl) { this.grid.navigation.navigateBottom(this.visibleColumnIndex); break; } this.grid.navigation.navigateDown(this.row.nativeElement, this.selectionNode); break; case 'enter': case 'f2': this.onKeydownEnterEditMode(); break; case 'escape': case 'esc': this.onKeydownExitEditMode(); break; case ' ': case 'spacebar': case 'space': if (this.grid.isRowSelectable) { this.row.selected ? this.selectionService.deselectRow(this.row.rowID, event) : this.selectionService.selectRowById(this.row.rowID, false, event); } break; default: return; } } /** * @hidden * @internal */ onKeydownEnterEditMode() { if (this.isInCompositionMode) { return; } if (this.column.editable && !this.row.deleted) { if (this.editMode) { this.grid.endEdit(true); this.nativeElement.focus(); } else { this.crudService.begin(this); } } } /** * @hidden * @internal */ onKeydownExitEditMode() { if (this.isInCompositionMode) { return; } if (this.editMode) { const args = this.crudService.cell.createEditEventArgs(); this.grid.onCellEditCancel.emit(args); if (args.cancel) { return; } this.grid.endEdit(false); this.nativeElement.focus(); } } /** * If the provided string matches the text in the cell, the text gets highlighted. * ```typescript * this.cell.highlightText('Cell Value', true); * ``` * @memberof IgxGridCellComponent */ highlightText(text, caseSensitive, exactMatch) { return this.highlight && this.column.searchable ? this.highlight.highlight(text, caseSensitive, exactMatch) : 0; } /** * Clears the highlight of the text in the cell. * ```typescript * this.cell.clearHighLight(); * ``` * @memberof IgxGridCellComponent */ clearHighlight() { if (this.highlight && this.column.searchable) { this.highlight.clearHighlight(); } } /** * @hidden * @internal */ calculateSizeToFit(range) { return Math.max(...Array.from(this.nativeElement.children) .map((child) => getNodeSizeViaRange(range, child))); } isToggleKey(key) { return ROW_COLLAPSE_KEYS.has(key) || ROW_EXPAND_KEYS.has(key); } }; IgxGridCellComponent.ctorParameters = () => [ { type: IgxGridSelectionService }, { type: IgxGridCRUDService }, { type: GridBaseAPIService }, { type: ChangeDetectorRef }, { type: ElementRef }, { type: NgZone }, { type: HammerGesturesManager }, { type: PlatformUtil } ]; __decorate([ Input(), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "column", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "row", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "rowData", void 0); __decorate([ Input(), __metadata("design:type", TemplateRef) ], IgxGridCellComponent.prototype, "cellTemplate", void 0); __decorate([ Input(), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "value", void 0); __decorate([ Input(), __metadata("design:type", Function) ], IgxGridCellComponent.prototype, "formatter", void 0); __decorate([ HostBinding('attr.data-rowIndex'), __metadata("design:type", Number), __metadata("design:paramtypes", []) ], IgxGridCellComponent.prototype, "rowIndex", null); __decorate([ HostBinding('attr.data-visibleIndex'), Input(), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], IgxGridCellComponent.prototype, "visibleColumnIndex", null); __decorate([ DeprecateProperty(`'inEditMode' is deprecated\nUse 'editMode' to get the current state and 'setEditMode(boolean)' as a setter`), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxGridCellComponent.prototype, "inEditMode", null); __decorate([ Input(), __metadata("design:type", Object), __metadata("design:paramtypes", [Object]) ], IgxGridCellComponent.prototype, "cellSelectionMode", null); __decorate([ Input(), HostBinding('class.igx-grid__td--pinned-last'), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "lastPinned", void 0); __decorate([ Input(), HostBinding('class.igx-grid__td--editing'), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "editMode", void 0); __decorate([ HostBinding('attr.tabindex'), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "tabindex", void 0); __decorate([ HostBinding('attr.role'), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "role", void 0); __decorate([ HostBinding('attr.aria-readonly'), __metadata("design:type", Boolean), __metadata("design:paramtypes", []) ], IgxGridCellComponent.prototype, "readonly", null); __decorate([ HostBinding('attr.aria-describedby'), __metadata("design:type", String), __metadata("design:paramtypes", []) ], IgxGridCellComponent.prototype, "describedby", null); __decorate([ Input(), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "width", void 0); __decorate([ HostBinding('attr.aria-selected'), HostBinding('class.igx-grid__td--selected'), __metadata("design:type", Boolean), __metadata("design:paramtypes", [Boolean]) ], IgxGridCellComponent.prototype, "selected", null); __decorate([ HostBinding('class.igx-grid__td--edited'), __metadata("design:type", Object), __metadata("design:paramtypes", []) ], IgxGridCellComponent.prototype, "dirty", null); __decorate([ HostBinding('class.igx-grid__td--active'), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "focused", void 0); __decorate([ ViewChild('defaultCell', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxGridCellComponent.prototype, "defaultCellTemplate", void 0); __decorate([ ViewChild('inlineEditor', { read: TemplateRef, static: true }), __metadata("design:type", TemplateRef) ], IgxGridCellComponent.prototype, "inlineEditorTemplate", void 0); __decorate([ ViewChild(IgxTextHighlightDirective, { read: IgxTextHighlightDirective }), __metadata("design:type", IgxTextHighlightDirective), __metadata("design:paramtypes", [IgxTextHighlightDirective]) ], IgxGridCellComponent.prototype, "highlight", null); __decorate([ DeprecateMethod(`'isCellSelected' is deprecated. Use 'selected' property instead.`), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], IgxGridCellComponent.prototype, "isCellSelected", null); __decorate([ HostListener('dblclick', ['$event']), __metadata("design:type", Object) ], IgxGridCellComponent.prototype, "onDoubleClick", void 0); __decorate([ HostListener('click', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [MouseEvent]), __metadata("design:returntype", void 0) ], IgxGridCellComponent.prototype, "onClick", null); __decorate([ HostListener('contextmenu', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [MouseEvent]), __metadata("design:returntype", void 0) ], IgxGridCellComponent.prototype, "onContextMenu", null); __decorate([ HostListener('focus', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [FocusEvent]), __metadata("design:returntype", void 0) ], IgxGridCellComponent.prototype, "onFocus", null); __decorate([ HostListener('blur'), __metadata("design:type", Function), __metadata("design:paramtypes", []), __metadata("design:returntype", void 0) ], IgxGridCellComponent.prototype, "onBlur", null); __decorate([ HostListener('keydown', ['$event']), __metadata("design:type", Function), __metadata("design:paramtypes", [KeyboardEvent]), __metadata("design:returntype", void 0) ], IgxGridCellComponent.prototype, "dispatchEvent", null); IgxGridCellComponent = __decorate([ Component({ changeDetection: ChangeDetectionStrategy.OnPush, selector: 'igx-grid-cell', template: "<ng-template #defaultCell>\n <div igxTextHighlight style=\"pointer-events: none\" [cssClass]=\"highlightClass\" [activeCssClass]=\"activeHighlightClass\" [groupName]=\"gridID\"\n [value]=\"formatter ? formatter(value) : column.dataType === 'number' ? (value | igxdecimal: grid.locale) : column.dataType === 'date' ? (value | igxdate: grid.locale) : value\"\n [row]=\"rowData\" [column]=\"this.column.field\" [containerClass]=\"'igx-grid__td-text'\"\n class=\"igx-grid__td-text\">{{ formatter ? formatter(value) : column.dataType === 'number' ? (value | igxdecimal:\n grid.locale) : column.dataType === 'date' ? (value | igxdate: grid.locale) : value }}</div>\n</ng-template>\n<ng-template #inlineEditor let-cell=\"cell\">\n <ng-container *ngIf=\"column.dataType === 'string'\">\n <igx-input-group displayDensity=\"compact\">\n <input igxInput [value]=\"editValue\" (input)=\"editValue = $event.target.value\" [igxFocus]=\"focused\" />\n </igx-input-group>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'number'\">\n <igx-input-group displayDensity=\"compact\">\n <input igxInput [value]=\"editValue\" (input)=\"editValue = $event.target.value\" [igxFocus]=\"focused\" type=\"number\">\n </igx-input-group>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'boolean'\">\n <igx-checkbox (change)=\"editValue = $event.checked\" [value]=\"editValue\" [checked]=\"editValue\"\n [igxFocus]=\"focused\" [disableRipple]=\"true\"></igx-checkbox>\n </ng-container>\n <ng-container *ngIf=\"column.dataType === 'date'\">\n <igx-date-picker [style.width.%]=\"100\" [outlet]=\"grid.outletDirective\" mode=\"dropdown\"\n [locale]=\"grid.locale\" [(value)]=\"editValue\" [igxFocus]=\"focused\" [labelVisibility]=\"false\">\n </igx-date-picker>\n </ng-container>\n</ng-template>\n<ng-container *ngTemplateOutlet=\"template; context: context\">\n</ng-container>\n", providers: [HammerGesturesManager] }), __metadata("design:paramtypes", [IgxGridSelectionService, IgxGridCRUDService, GridBaseAPIService, ChangeDetectorRef, ElementRef, NgZone, HammerGesturesManager, PlatformUtil]) ], IgxGridCellComponent); export { IgxGridCellComponent }; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/grids/cell.component.ts"],"names":[],"mappings":"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