@true-directive/grid
Version:
Angular Data Grid from Yopsilon.
737 lines • 112 kB
JavaScript
import * as tslib_1 from "tslib";
/**
* Copyright (c) 2018-2019 Aleksey Melnikov, True Directive Company.
* @link https://truedirective.com/
* @license MIT
*/
import { Component, Output, ViewChild, ElementRef, ChangeDetectorRef, KeyValueDiffers, EventEmitter, Inject } from '@angular/core';
import { takeUntil } from 'rxjs/operators';
import { ColumnBand, GridPart, UIActionType, UIAction, Keys, RowLayout } from '@true-directive/base';
import { RowDragEvent, RowClickEvent, ContextMenuEvent, CellClickEvent } from '@true-directive/base';
import { GridViewComponent } from './grid-view.component';
import { GridStateService } from './grid-state.service';
import { InternationalizationService } from './internationalization/internationalization.service';
var GridComponent = /** @class */ (function (_super) {
tslib_1.__extends(GridComponent, _super);
function GridComponent(state, intl, elementRef, changeDetector, keyValueDiffers) {
var _this = _super.call(this, state, intl, elementRef, changeDetector, keyValueDiffers) || this;
_this.state = state;
_this.intl = intl;
_this.elementRef = elementRef;
_this.changeDetector = changeDetector;
_this.keyValueDiffers = keyValueDiffers;
_this.rowMouseDown = new EventEmitter();
_this.rowMouseUp = new EventEmitter();
_this.rowClick = new EventEmitter();
_this.cellClick = new EventEmitter();
_this.rowDblClick = new EventEmitter();
_this.rowKeyDown = new EventEmitter();
_this.contextMenu = new EventEmitter();
_this.selectionChanged = new EventEmitter();
_this.checkedChanged = new EventEmitter();
/**
* Пользователь перетащил строки. Событие возникает до того, как строки будут перенесены
* гридом. Это действие можно отменить и обработать вне грида.
*/
_this.rowDrag = new EventEmitter(false);
/**
* Пользователь перетащил строки и грид обработал это действие.
*/
_this.rowDragged = new EventEmitter(false);
_this._cellTouched = null; // Ячейка с тачем
_this._cellTouchedScrollPos = { X: 0, Y: 0 };
_this._dragColumn = false; // Перетаскивание заголовка колонки в процессе
_this._drag_x0 = -1; // Предыдущая позиция перетаскиваемого заголовка
_this._drag_y0 = -1;
_this._lastSel = 0; // Время последнего изменения выделения
_this._paging = false; // Грид в процессе исполнения PgDn/PgUp
// Строчка ушла после редактирования...
_this.state.events.onRowUnfiltered.pipe(takeUntil(_this.destroy$)).subscribe(function (r) {
setTimeout(function () {
if (_this.state.dataSource.removeResultRow(r)) {
_this.state.layoutsHandler.updateSelectionIndices();
_this.need_recalc_page = true;
_this.updatePage('rowUnfiltered');
}
}, 100);
});
// Изменены колонки
_this.state.events.onColumnsChanged.pipe(takeUntil(_this.destroy$)).subscribe(function (v) {
_this.RC.clear();
_this.checkSize(true);
});
// Перетаскивание заголовка колонки
_this.state.events.onDrag.pipe(takeUntil(_this.destroy$)).subscribe(function (v) { return _this.dragColumn(v); });
// Drop заголовка колонки
_this.state.events.onDrop.pipe(takeUntil(_this.destroy$)).subscribe(function (v) { return _this.dropColumn(v); });
// Изменение выделения
_this.state.events.onSelect.pipe(takeUntil(_this.destroy$)).subscribe(function (cellPos) {
_this.refreshSelection(cellPos);
_this.selectionChanged.emit(_this.state.selection);
});
// Изменение значения
_this.state.events.onValueChanged.pipe(takeUntil(_this.destroy$)).subscribe(function (v) { return _this.detectChanges('valueChanged'); });
// Изменение значения чекбокса
_this.state.events.onCheckedChanged.pipe(takeUntil(_this.destroy$)).subscribe(function (e) { return _this.checkedChanged.emit(e); });
// Включение редактирования
_this.state.events.onStartEditing.pipe(takeUntil(_this.destroy$)).subscribe(function (v) { return _this.detectChanges('startEditing'); });
// Выключение редактирования
_this.state.events.onStopEditing.pipe(takeUntil(_this.destroy$)).subscribe(function (returnFocus) {
_this.detectChanges();
if (returnFocus && _this.state.settings.autoFocusAfterEditor) {
_this.focus();
}
});
return _this;
}
Object.defineProperty(GridComponent.prototype, "isDragging", {
get: function () {
return this._dragColumn;
},
enumerable: true,
configurable: true
});
/**
* Начало действия пользователя (перемещение строки или выделение ячеек)
* @param eX Начальная координата X
* @param eY Начальная координата Y
* @param place Часть грида, в которой инициировано действие
* @param ctrlKey Нажата ли клавиша Ctrl
* @param byTouch Инициировано ли тач-событием
*/
GridComponent.prototype.startAction = function (cp, eX, eY, place, ctrlKey, byTouch, button) {
if (ctrlKey === void 0) { ctrlKey = false; }
if (byTouch === void 0) { byTouch = false; }
if (button === void 0) { button = 0; }
if (cp && cp.row) {
this.scroller.prepareAutoScroll();
var uiType = this.state.ui.startAction(cp, ctrlKey, byTouch, button);
if (uiType) {
this.uiAction = new UIAction(uiType, null, eX, eY);
this.addDocumentMouseListeners();
}
}
};
/**
* Касание пальцем
* @param e Параметры события
*/
GridComponent.prototype.touchStart = function (e) {
// В течение 50мс не выделяем по тачстарту, потому что этот тач останавливает
// прокрутку
if (this._lastScroll.time > 0) {
var ms = Date.now() - this._lastScroll.time;
if (ms < 50) {
// Не выделяем ничего, если мы остановили прокрутку
return;
}
}
e.stopPropagation();
var touches = e.changedTouches;
if (touches.length === 1) {
// Если касание одно, то запоминаем ячейку, которой касаемся
this._cellTouched = this.cellByXY(touches[0].clientX, touches[0].clientY);
// Запоминаем положение прокрутки
this._cellTouchedScrollPos = {
X: this.scroller.scrollLeft,
Y: this.scroller.scrollTop
};
}
};
Object.defineProperty(GridComponent.prototype, "touchScroll", {
// Проверим, не было ли скролла во время касания
get: function () {
return this._cellTouchedScrollPos.X !== this.scroller.scrollLeft ||
this._cellTouchedScrollPos.Y !== this.scroller.scrollTop;
},
enumerable: true,
configurable: true
});
/**
* Окончание касания
* @param e Параметры события
*/
GridComponent.prototype.touchEnd = function (e) {
var touches = e.changedTouches;
if (touches.length >= 1) {
var rr = this.cellByXY(touches[0].clientX, touches[0].clientY);
if (rr !== null &&
rr.equals(this._cellTouched) && !this.touchScroll) {
// Should we toggle a checkbox in this cell?
if (this.state.settings.checkByCellClick && this.state.check.canToggleCheck(rr)) {
// Yes, we should.
this.state.ui.toggleCheck(rr.row, rr.fieldName);
}
else {
// Something will be selected.
if (!rr.equals(this.state.selection.focusedCell)) {
// Если клик не на выделенной ячейке, то начинаем выделение.
// Начало и окончание выделения вынесено сюда, т.к. мы не можем
// сразу понять, действие пользователя - это прокрутка или
// выделение строки.
// Поэтому, если положение прокрутки не изменилось - выделяем
this.startAction(rr, touches[0].clientX, touches[0].clientY, GridPart.CENTER, false, true);
}
else {
// Редактирование и фокус на редакторе
this.state.ui.startAction(this._cellTouched, false, true);
e.stopPropagation();
return;
}
}
// End selecting anyway
this.state.ui.endSelect(rr, true);
}
}
e.stopPropagation();
};
/**
* Нажатие кнопки мыши.
* @param e Параметры события
*/
GridComponent.prototype.dataMouseDown = function (e) {
if (this._cellTouched) {
// Touchstart has been handled. Skip this mousedown.
return;
}
this.rowMouseDown.emit(e);
if (!e.defaultPrevented) {
var cp = this.cellByXY(e.clientX, e.clientY);
if (this.state.ui.mouseDown(cp, false, e.button)) {
// This event has been handled.
return;
}
this.startAction(cp, e.clientX, e.clientY, GridPart.CENTER, e.ctrlKey, false, e.button);
}
};
GridComponent.prototype.doRowClick = function (e) {
if (this.state.ui.click(this.cellByXY(e.clientX, e.clientY))) {
e.stopPropagation();
e.preventDefault();
}
};
GridComponent.prototype.dataContextMenu = function (e) {
if (this.settings.enableDataContextMenu && this.settings.dataContextMenuActions.length > 0) {
this.menuStarter.start(e, this.state.settings.dataContextMenuActions, 'selection');
this.detectChanges();
e.preventDefault();
return;
}
this.contextMenu.emit(new ContextMenuEvent(this.cellByXY(e.clientX, e.clientY), e));
};
GridComponent.prototype.dataRowClick = function (e, r) {
this.rowClick.emit(new RowClickEvent(r, e));
this.cellClick.emit(new CellClickEvent(this.cellByXY(e.clientX, e.clientY), e));
if (this._cellTouched) {
// Skip this click.
this._cellTouched = null;
return;
}
this.doRowClick(e);
};
GridComponent.prototype.dataRowDblClick = function (e, r) {
this.rowDblClick.emit(new RowClickEvent(r, e));
this.state.ui.dblClick(e, r);
};
/**
* Key event handler
* @param keyEvent Key event parameters
*/
GridComponent.prototype.processKey = function (e) {
var _this = this;
this.rowKeyDown.emit(e);
if (e.defaultPrevented) {
return;
}
var keyCode = e.keyCode;
if (keyCode === Keys.SPACE && this.state.selection.focusedRow) {
var f = this.state.check.firstCheckableField();
if (f !== '') {
this.toggleCheckbox({ row: this.state.selection.focusedRow, fieldName: f });
return true;
}
}
var ri = this.state.dataSource.resultRows.indexOf(this.state.selection.focusedRow);
if (!this.state.st.fixedRowHeight && (keyCode === Keys.PAGE_DOWN || keyCode === Keys.PAGE_UP)) {
// При переменной высоте строк прокрутить на одну страницу вниз или вверх - большая печаль.
// Потому что мы не знаем, какая высота у строк выше или ниже текущей страницы.
// Поэтому принимаем тяжелое решение и...
// 1. Игнорируем нажатие, если еще не обработали предыдущее:
if (this._paging) {
return true;
}
// 2. Рендерим с запасом
var overWork = { fwd: 4, back: 4 };
// 3. Запас как раз равен максимальному количеству строк, умещающемуся на экране
if (keyCode === Keys.PAGE_DOWN) {
overWork.fwd = this.scroller.viewPortHeight / this.RC.currentRH + 1;
}
else {
if (keyCode === Keys.PAGE_UP) {
overWork.back = this.scroller.viewPortHeight / this.RC.currentRH + 1;
}
}
// 4. Рендерим страницу с заданной переработкой
this.updatePage('keydown', true, overWork);
// 5. Указываем на приостановку обработки клавиш
this._paging = true;
setTimeout(function () {
// 6. Теперь мы можем точно рассчитать емкость предыдущей страницы
var newPageCapacity = _this.RC.pageCapacity(ri, _this.scroller.viewPortHeight, _this.state.dataSource.resultRows.length);
// 7. Handle key
if (_this.state.ui.processKey(newPageCapacity, e)) {
e.stopPropagation();
}
// 8. Done
_this._paging = false;
}, 50);
return true;
}
// Остальное намного проще
var pageCapacity = this.RC.pageCapacity(ri, this.scroller.viewPortHeight, this.state.dataSource.resultRows.length);
return this.state.ui.processKey(pageCapacity, e);
};
GridComponent.prototype.dataKeyDown = function (e) {
if (this.processKey(e)) {
e.preventDefault();
e.stopPropagation();
}
};
GridComponent.prototype.checkAll = function (fieldName) {
this.state.check.setColumnCheck(this.state.columnCollection.columnByFieldName(fieldName), true);
};
GridComponent.prototype.uncheckAll = function (fieldName) {
this.state.check.setColumnCheck(this.state.columnCollection.columnByFieldName(fieldName), false);
};
/**
* Continue selecting
* @param e Event parameters
*/
GridComponent.prototype.doSelect = function (e) {
var rr = this.cellByXY(e.clientX, e.clientY);
if (rr && rr.fieldName !== '') {
this.state.ui.proceedToSelect(rr);
}
this.scroller.checkAutoScrollX(e.clientX);
this.scroller.checkAutoScrollY(e.clientY);
};
Object.defineProperty(GridComponent.prototype, "selection", {
/**
* Selection of the grid
* @return GridSelection instance with selected ranges list.
*/
get: function () {
return this.state.selection;
},
enumerable: true,
configurable: true
});
Object.defineProperty(GridComponent.prototype, "selectedData", {
/**
* Returns data which contained in selected ranges
* @return Array with the data
*/
get: function () {
return this.state.getSelectedData(this.selection).result;
},
enumerable: true,
configurable: true
});
Object.defineProperty(GridComponent.prototype, "draggedRows", {
get: function () {
if (this.uiAction && this.uiAction.target) {
if (this.uiAction.renderTarget === null) {
// Первые три записи в обратном порядке
this.uiAction.renderTarget = [];
for (var i = 0; i < 3 && i < this.uiAction.target.length; i++) {
this.uiAction.renderTarget.unshift(this.uiAction.target[i]);
}
}
return this.uiAction.renderTarget;
}
return [];
},
enumerable: true,
configurable: true
});
GridComponent.prototype.getDragTransform = function (i) {
var l = this.draggedRows.length;
var scale = Math.pow(0.97, l - i - 1);
var dx = -40;
var dy = -i * this.state.settings.rowHeight + (l - i - 1) * 7 - 40;
var res = 'matrix(' + scale + ', 0, 0, 1, ' + dx + ', ' + dy + ')';
return res;
};
GridComponent.prototype.getDragWidth = function () {
var res = 0;
this.state.layoutDrag.columns.forEach(function (c) { return res += c.width; });
return res + this.state.settings.widthUnit;
};
GridComponent.prototype.checkRowDrag = function (e) {
if (!this.state.settings.rowDrag) {
return false;
}
if (this.uiAction.action === UIActionType.ROW_DRAG) {
// Уже включено
return false;
}
var xx = e.clientX;
var yy = e.clientY;
if (Math.abs(xx - this.uiAction.x) > 9 || Math.abs(yy - this.uiAction.y) > 9) {
this.startDragRows();
return true;
}
return false;
};
GridComponent.prototype.startDragRows = function () {
this.uiAction.action = UIActionType.ROW_DRAG;
this.state.dragDrop.setDragItem(this.uiAction);
this.setDragPosition(this.uiAction);
this.detectChanges();
this.dragInProcess(true);
this.dragItem.nativeElement.style.visibility = 'visible';
};
GridComponent.prototype.specifyDropPosition = function (pos, rLeft, e) {
return pos;
};
GridComponent.prototype.dropInfo = function (e) {
var r = RowLayout.rowPosByXY(this.rowLayouts(this.displayedRows), e.clientX, e.clientY, this.state.isTree);
var rl = r.rl;
if (!rl) {
return null;
}
var centerRect = this.scroller.centerRect;
var rd = rl.rowComponent;
var rr = rd.firstCellRect();
r = this.specifyDropPosition(r, rr.left, e);
var canDrop = this.state.canDrop(this.uiAction.target, rl.rowComponent.row, r.pos);
var dropTarget = null;
if (canDrop !== '') {
dropTarget = rl.rowComponent.row;
r.pos = canDrop;
}
var top = (r.pos !== 'before' ? rl.clientRect.bottom : rl.clientRect.top) - 1;
var left = rr.left;
var height = 2;
var width = rl.clientRect.width - (left - centerRect.left);
if (r.pos === 'last') {
left -= this.state.settings.levelIndent;
width += this.state.settings.levelIndent;
}
if (r.pos === 'in') {
top -= rl.clientRect.height - 3;
height = rl.clientRect.height - 6;
}
if (left < centerRect.left) {
left = centerRect.left;
}
if ((left + width) > rl.clientRect.right) {
width = rl.clientRect.right - left;
}
var rect = new DOMRect(left, top, width, height);
if (rect.top < centerRect.top - 1 || rect.top >= centerRect.bottom) {
return null;
}
return {
dropTarget: dropTarget,
rowPosition: r,
pos: r.pos,
markerRect: rect
};
};
GridComponent.prototype.dragRows = function (e) {
if (!this.uiAction.move(e.clientX, e.clientY)) {
//return null;
}
this.setDragPosition(this.uiAction);
var di = this.dropInfo(e);
if (di === null || di.dropTarget === null) {
this.toggleClass(true, 'true-drag-not-allowed');
this.toggleClass(false, 'true-drag-allowed');
this.hideMarker();
}
else {
this.showMarker(di.markerRect.left, di.markerRect.top, di.markerRect.width, di.markerRect.height, true);
this.toggleClass(false, 'true-drag-not-allowed');
this.toggleClass(true, 'true-drag-allowed');
}
this.scroller.checkAutoScrollY(e.clientY);
return di ? di.rowPosition : null;
};
GridComponent.prototype.endDragRows = function (e) {
this.hideMarker();
this.scroller.stopAutoScroll();
this.toggleClass(false, 'true-drag-not-allowed');
this.toggleClass(false, 'true-drag-allowed');
this.dragItem.nativeElement.style.visibility = 'hidden';
this.dragInProcess(false);
var di = this.dropInfo(e);
if (di && di.dropTarget) {
var ce = new RowDragEvent(this.uiAction.target, di.dropTarget, di.pos);
this.rowDrag.emit(ce);
if (!ce.isCanceled) {
this.state.moveRows(this.uiAction.target, di.dropTarget, di.pos);
this.rowDragged.emit(ce);
}
}
};
GridComponent.prototype.documentMouseMove = function (e) {
_super.prototype.documentMouseMove.call(this, e);
if (this.uiAction) // если что-то началось..
{
if (e.clientX === this.uiAction.x && e.clientY === this.uiAction.y) {
return;
}
if (this.checkRowDrag(e)) {
return;
}
if (this.uiAction.action === UIActionType.ROW_DRAG) {
this.dragRows(e);
}
// Продолжаем выделение данных
if (this.uiAction.action === UIActionType.SELECT) {
var dt = Date.now();
var ms = dt - this._lastSel;
var delay = this.state.IE ? 70 : 0;
if (ms < delay) {
// Не так давно обновляли..
return;
}
this._lastSel = Date.now();
this.doSelect(e);
e.preventDefault();
e.stopPropagation();
}
}
};
// Завершение выделения области
GridComponent.prototype.documentMouseUp = function (e) {
if (this.uiAction.action === UIActionType.ROW_DRAG) {
// Переставляем.
this.endDragRows(e);
}
if (this.uiAction.action === UIActionType.SELECT) {
var rr = this.cellByXY(e.clientX, e.clientY);
if (rr && rr.fieldName !== '') {
this.state.ui.endSelect(rr, false, e.button);
this.focus();
}
}
_super.prototype.documentMouseUp.call(this, e);
this.rowMouseUp.emit(e);
// Останавливаем автопрокрутку
this.scroller.stopAutoScroll();
this.uiAction = null;
};
GridComponent.prototype.resizeInProcess = function (value) {
this.toggleClass(value, 'true-resize-in-process');
};
GridComponent.prototype.dragInProcess = function (value) {
this.toggleClass(value, 'true-drag-in-process');
};
GridComponent.prototype.showMarker = function (mrX, mrY, mrW, mrH, rowDrag) {
if (rowDrag === void 0) { rowDrag = false; }
this.dropMarker.nativeElement.style.top = mrY + 'px';
this.dropMarker.nativeElement.style.left = mrX + 'px';
this.dropMarker.nativeElement.style.width = mrW + 'px';
this.dropMarker.nativeElement.style.height = mrH + 'px';
this.dropMarker.nativeElement.style.visibility = 'visible';
};
// Hide marker of REORDERING/RESIZING
GridComponent.prototype.hideMarker = function () {
this.dropMarker.nativeElement.style.visibility = 'hidden';
};
GridComponent.prototype.proceedToResizeColumn = function (ui) {
var r0 = this.scroller.clientRect;
var mrX = ui.x;
if ((mrX > r0.left) && mrX < r0.right) {
this.showMarker(mrX, r0.top + 1, 1, r0.height - 2);
}
else {
this.hideMarker();
}
if (ui.x < r0.left) { // листаем влево
this.scroller.scrollSpeedX = -this.state.st.autoScrollStep;
}
else {
if (ui.x > r0.right) {
this.scroller.scrollSpeedX = this.state.st.autoScrollStep;
}
else {
this.scroller.scrollSpeedX = 0;
}
}
};
GridComponent.prototype.resizeColumn = function (e) {
if (e.action === 'start') {
this.resizeInProcess(true);
return;
}
if (e.action === 'end') {
this.hideMarker();
this.resizeInProcess(false);
return;
}
this.proceedToResizeColumn(e.ui);
};
GridComponent.prototype.setDragPosition = function (e) {
var dy = this.state.iOS ? window.pageYOffset : 0;
this.dragItem.nativeElement.style.left = e.x + e.targetOffsetX + 'px';
this.dragItem.nativeElement.style.top = dy + e.y + e.targetOffsetY + 'px';
};
GridComponent.prototype.isDragColumn = function () {
return this._dragColumn;
};
GridComponent.prototype.startDragColumn = function (e) {
if (this.filterPopup && this.filterPopup.visible) {
this.filterPopup.closePopup();
}
this._dragColumn = true;
this.scroller.prepareAutoScroll();
this.state.dragDrop.setDragItem(e);
this.detectChanges('dragColumn');
this.setDragPosition(e);
this.dragItem.nativeElement.style.visibility = 'visible';
this.dragInProcess(true);
};
GridComponent.prototype.commitDrag = function () {
this.checkSize();
this.need_recalc_page = true;
};
GridComponent.prototype.dragColumn = function (e) {
if (!this._dragColumn) {
this.startDragColumn(e);
return;
}
this.setDragPosition(e);
if (Math.abs(e.x - this._drag_x0) < 5 && Math.abs(e.y - this._drag_y0) < 5) {
return;
}
this._drag_x0 = e.x;
this._drag_y0 = e.y;
var dropInfo = null;
this.headerParts.forEach(function (p) {
if (p && !dropInfo) {
dropInfo = p.canDrop(e, false); //showMarker);
}
});
if (dropInfo) {
if (e.target instanceof ColumnBand) {
this.state.reorderBand(e.target, dropInfo);
}
else {
this.state.reorderColumn(e.target, dropInfo, false);
}
this.commitDrag();
}
var r0 = this.scroller.checkAutoScrollX(e.x);
// Передаем rectangle
this.checkParts(e.x, r0, e.target);
};
GridComponent.prototype.dropColumn = function (e) {
var _this = this;
this._dragColumn = false;
this.scroller.stopAutoScroll();
this.dragItem.nativeElement.style.visibility = 'hidden';
var dropInfo = null;
this.headerParts.forEach(function (p) {
if (!dropInfo && p) {
dropInfo = p.canDrop(e, false);
}
});
if (dropInfo) {
this.state.reorderColumn(e.target, dropInfo);
}
else {
this.state.fixDrag(e.target); // Если тащили из панели группировки, то!
}
this.state.dragDrop.clearDragItem();
this.dragInProcess(false);
// Почему через 100 миллисекунд? Для того,чтобы плавно затухло
setTimeout(function () {
_this.state.layoutsHandler.setLayoutsVisibility();
_this.updatePage('dropColumn', true);
// Может поменяться ширина центральной части
_this.checkSize();
}, 100);
};
/**
* Обработка события строки - переключение чекбокса.
* @param e Параметры события
*/
GridComponent.prototype.toggleCheckbox = function (e) {
this.state.ui.toggleCheck(e.row, e.fieldName, e.value);
};
GridComponent.prototype.toggleCheckColumn = function (col) {
this.state.ui.toggleCheckColumn(col);
};
GridComponent.prototype.setAppearance = function () {
_super.prototype.setAppearance.call(this);
this.dragItem.nativeElement.classList.add(this.state.sta.dragItemClass);
};
tslib_1.__decorate([
Output('rowMouseDown'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "rowMouseDown", void 0);
tslib_1.__decorate([
Output('rowMouseUp'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "rowMouseUp", void 0);
tslib_1.__decorate([
Output('rowClick'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "rowClick", void 0);
tslib_1.__decorate([
Output('cellClick'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "cellClick", void 0);
tslib_1.__decorate([
Output('rowDblClick'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "rowDblClick", void 0);
tslib_1.__decorate([
Output('rowKeyDown'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "rowKeyDown", void 0);
tslib_1.__decorate([
Output('contextMenu'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "contextMenu", void 0);
tslib_1.__decorate([
Output('selectionChanged'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "selectionChanged", void 0);
tslib_1.__decorate([
Output('checkedChanged'),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "checkedChanged", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "rowDrag", void 0);
tslib_1.__decorate([
Output(),
tslib_1.__metadata("design:type", EventEmitter)
], GridComponent.prototype, "rowDragged", void 0);
tslib_1.__decorate([
ViewChild('dropMarker', { static: true }),
tslib_1.__metadata("design:type", Object)
], GridComponent.prototype, "dropMarker", void 0);
GridComponent = tslib_1.__decorate([
Component({
selector: 'true-grid',
template: "<div #dropMarker class=\"true-grid-drop-marker\"></div>\r\n\r\n<true-menu-starter #menuStarter (itemClick)=\"menuItemClick($event)\"></true-menu-starter>\r\n<!-- \u0432\u0441\u043F\u043B\u044B\u0432\u0430\u044E\u0449\u0435\u0435 \u043E\u043A\u043D\u043E \u0434\u043B\u044F \u0444\u0438\u043B\u044C\u0442\u0440\u043E\u0432 -->\r\n<true-filter-popup #filterPopup *ngIf=\"state.settings.allowFilter\"\r\n (setFilter)=\"setFilter($event)\"\r\n (resetFilter)=\"resetFilter($event)\"\r\n (closed)=\"filterClosed($event)\">\r\n</true-filter-popup>\r\n<!-- \u042D\u043B\u0435\u043C\u0435\u043D\u0442, \u043A\u043E\u0442\u043E\u0440\u044B\u0439 \u043F\u0435\u0440\u0435\u0442\u0430\u0441\u043A\u0438\u0432\u0430\u0435\u0442\u0441\u044F \u043C\u044B\u0448\u044C\u044E, \u043F\u0440\u0438 reordering columns -->\r\n<div #dragItem true-drag-item class=\"true-grid-drag-item\">\r\n <true-grid-header *ngIf=\"isDragColumn()\"\r\n [ngClass]=\"state.settings.appearance.headerAreaClass\"\r\n [layout]=\"state.layoutDrag\"></true-grid-header>\r\n <div *ngIf=\"!isDragColumn()\" class=\"true-drag-data\" [ngClass]=\"settings.appearance.getDataClass()\">\r\n <table *ngFor=\"let r of draggedRows; let i=index\"\r\n [style.transform]=\"getDragTransform(i)\"\r\n [style.width]=\"getDragWidth()\"\r\n class=\"true-grid-data true-grid-data_fixed-height\">\r\n <colgroup>\r\n <col *ngFor=\"let c of state.layoutDrag.columns\" [style.width]=\"c.displayedWidthU\" />\r\n </colgroup>\r\n <tbody>\r\n <tr true-row\r\n [row]=\"r\"\r\n [true-layout]=\"state.layoutDrag\"\r\n [true-state]=\"state\"\r\n [true-i]=\"i\"\r\n [style.height.px]=\"state.settings.rowHeight\">\r\n </tr>\r\n </tbody>\r\n </table>\r\n </div>\r\n</div>\r\n<!-- \u041A\u043E\u043C\u043F\u043E\u043D\u0435\u043D\u0442, \u043E\u0441\u0443\u0449\u0435\u0441\u0442\u0432\u043B\u044F\u044E\u0449\u0438\u0439 \u0441\u0438\u043D\u0445\u0440\u043E\u043D\u043D\u044B\u0439 \u0441\u043A\u0440\u043E\u043B\u043B\u0438\u043D\u0433 \u0434\u0430\u043D\u043D\u044B\u0445 \u0438 \u0432\u0441\u0435\u0445 \u0441\u043E\u043F\u0443\u0442\u0441\u0442\u0432\u0443\u044E\u0449\u0438\u0445 \u044D\u043B\u0435\u043C\u0435\u043D\u0442\u043E\u0432 -->\r\n<true-scroller #scroller\r\n tabindex=\"-1\"\r\n [maxHeight]=\"maxHeight\"\r\n (keydown)=\"dataKeyDown($event)\"\r\n (autoscrollx)=\"gridAutoScrollX($event)\"\r\n (scroll)=\"gridScroll($event)\">\r\n <!-- \u0417\u0430\u0433\u043E\u043B\u043E\u0432\u043A\u0438 -->\r\n <true-grid-header #gridHeader true-header\r\n [layout]=\"state.layout\"\r\n [scroller]=\"scroller\"\r\n (toggleCheckColumn)=\"toggleCheckColumn($event)\"\r\n (resizeColumn)=\"resizeColumn($event)\">\r\n </true-grid-header>\r\n <!-- \u041E\u0441\u043D\u043E\u0432\u043D\u0430\u044F \u0447\u0430\u0441\u0442\u044C \u0434\u0430\u043D\u043D\u044B\u0445 -->\r\n <div true-data [ngClass]=\"settings.appearance.getDataClass()\">\r\n <table #gridData class=\"true-grid-data\"\r\n [class.true-grid-data_fixed-height]=\"state.settings.fixedRowHeight\"\r\n [style.width]=\"state.layout.dataWidth\"\r\n (mousedown)=\"dataMouseDown($event)\">\r\n <colgroup>\r\n <!-- \u0433\u0440\u0443\u043F\u043F\u0438\u0440\u043E\u0432\u043A\u0430 \u0438 \u0434\u0435\u0440\u0435\u0432\u044C\u044F -->\r\n <col *ngFor=\"let c of state.layout.levelColumns\" [style.width]=\"state.st.levelWidth\" />\r\n <!-- \u0434\u0430\u043D\u043D\u044B\u0435 -->\r\n <col *ngFor=\"let c of state.layout.columns\" [style.width]=\"c.displayedWidthU\" />\r\n </colgroup>\r\n\r\n <tbody *ngIf=\"!state.st.customTemplate\">\r\n <tr *ngFor=\"let r of RC.ghostRows('start'); trackBy: RC.trackGhostRowStart\" [style.height.px]=\"r.H\" style=\"border:0\">\r\n <td [style.height.px]=\"r.H\" style=\"padding:0; border-right: 0;\"> </td>\r\n </tr>\r\n <tr *ngFor=\"let r of visibleRows; let i=index; trackBy: trackRow;\"\r\n true-row\r\n [view-port-left]=\"viewPortLeft\"\r\n [view-port-width]=\"viewPortWidth\"\r\n [row]=\"r\"\r\n [true-locale]=\"locale\"\r\n [true-layout]=\"state.layout\"\r\n [true-state]=\"state\"\r\n [true-i]=\"i\"\r\n [style.height.px]=\"state.settings.rowHeight\"\r\n (toggleCheckbox)=\"toggleCheckbox($event)\"\r\n (click)=\"dataRowClick($event, r)\"\r\n (contextmenu)=\"dataContextMenu($event)\"\r\n (dblclick)=\"dataRowDblClick($event, r)\"\r\n #displayedRows>\r\n </tr>\r\n <tr *ngFor=\"let r of RC.ghostRows('end')\" [style.height.px]=\"r.H\">\r\n <td [style.height.px]=\"r.H\" style=\"padding:0; border-right: 0;\"> </td>\r\n </tr>\r\n <!--<tr *ngIf=\"visibleRows.length === 0\"><td style=\"border: 0;\"></td></tr>--> <!-- \u0412\u044B\u043D\u0435\u0441\u0442\u0438 \u0432 \u0441\u0442\u0438\u043B\u0438 -->\r\n </tbody>\r\n <!-- User's template -->\r\n <ng-content *ngIf=\"state.st.customTemplate\" select=\"[true-body]\"></ng-content>\r\n </table>\r\n </div>\r\n <!-- Footer -->\r\n <true-grid-footer #gridFooter true-footer [layout]=\"state.layout\"></true-grid-footer>\r\n</true-scroller>\r\n",
providers: [{ provide: 'gridState', useClass: GridStateService }],
styles: [":host{display:block;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.true-grid{box-sizing:border-box;height:100%;width:100%}.true-grid-data{box-sizing:border-box;table-layout:fixed;border-spacing:0;border-collapse:collapse;outline:0}.true-grid-data td{overflow-x:hidden;overflow-y:hidden}.true-grid-drop-marker{box-sizing:border-box;visibility:hidden;position:fixed;width:3px;border:1px solid #757779;background-color:rgba(255,255,255,.05);pointer-events:none;z-index:7}.true-grid-data_fixed-height td:not(.true-cell-indent){white-space:nowrap}.true-grid-data_fixed-height td:not(.true-cell-indent):not(.true-cell-checkbox){text-overflow:ellipsis}.true-cell-checkbox.true-check-by-click{cursor:pointer}.true-grid-drag-item{visibility:hidden;position:fixed;overflow-x:hidden;text-overflow:ellipsis;pointer-events:none;z-index:8}::ng-deep .true-grid-btn{cursor:pointer;align-self:stretch;visibility:hidden;display:-webkit-box;display:flex;-webkit-box-orient:vertical;-webkit-box-direction:normal;flex-direction:column;-webkit-box-pack:center;justify-content:center;flex-shrink:0}::ng-deep .true-grid-btn span{display:inline-block}::ng-deep .true-align-right{text-align:right}::ng-deep .true-align-center{text-align:center}::ng-deep .true-align-left{text-align:left!important}"]
}),
tslib_1.__param(0, Inject('gridState')),
tslib_1.__metadata("design:paramtypes", [GridStateService,
InternationalizationService,
ElementRef,
ChangeDetectorRef,
KeyValueDiffers])
], GridComponent);
return GridComponent;
}(GridViewComponent));
export { GridComponent };
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"grid.component.js","sourceRoot":"ng://@true-directive/grid/","sources":["src/grid.component.ts"],"names":[],"mappings":"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