ftable
Version:
Angular 6/7 Tables
152 lines • 24.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component } from '@angular/core';
import { EventEmitter } from '@angular/core';
import { Output } from '@angular/core';
import { Input } from '@angular/core';
import { ViewChild, ElementRef } from '@angular/core';
var DateFFilterComponent = /** @class */ (function () {
function DateFFilterComponent() {
this.filter = new EventEmitter();
this.minDay = '';
this.minMonth = '';
this.minYear = '';
this.maxDay = '';
this.maxMonth = '';
this.maxYear = '';
}
/**
* @param {?} mode
* @param {?} max
* @param {?} event
* @return {?}
*/
DateFFilterComponent.prototype.onKeyUp = /**
* @param {?} mode
* @param {?} max
* @param {?} event
* @return {?}
*/
function (mode, max, event) {
// Ignore if Delete or Backspace
if (event.keyCode !== 8 && event.keyCode !== 46) {
// filter letters and Trim
this[mode] = this[mode].match(/[0-9]*/).join('').substring(0, max);
// Move focus for UX
if (mode === 'minDay' && (this[mode].length === 2 || event.keyCode === 39)) {
this._elMinMonthRef.nativeElement.focus();
}
else if (mode === 'minMonth' && (this[mode].length === 2 || event.keyCode === 39)) {
this._elMinYearRef.nativeElement.focus();
}
else if (mode === 'minYear' && (this[mode].length === 4 || event.keyCode === 39)) {
this._elMaxDayRef.nativeElement.focus();
}
else if (mode === 'maxDay' && (this[mode].length === 2 || event.keyCode === 39)) {
this._elMaxMonthRef.nativeElement.focus();
}
else if (mode === 'maxMonth' && (this[mode].length === 2 || event.keyCode === 39)) {
this._elMaxYearRef.nativeElement.focus();
}
else if (mode === 'maxYear' && (this[mode].length === 4 || event.keyCode === 39)) {
this._elMinDayRef.nativeElement.focus();
}
}
if (this.source === 'frontend') {
/** @type {?} */
var fn = function (name, minDay, minMonth, minYear, maxDay, maxMonth, maxYear) {
return function (d) {
return ((/** @type {?} */ (d))).filter(function (x) {
console.log(name, minDay, minMonth, minYear, maxDay, maxMonth, maxYear);
/** @type {?} */
var date = new Date(x[name]);
return (minDay.length > 0 ? Number(minDay) <= date.getDate() : true) &&
(minMonth.length > 0 ? Number(minMonth) <= date.getMonth() + 1 : true) &&
(minYear.length > 0 ? Number(minYear) <= date.getFullYear() : true) &&
(maxDay.length > 0 ? Number(maxDay) >= date.getDate() : true) &&
(maxMonth.length > 0 ? Number(maxMonth) >= date.getMonth() + 1 : true) &&
(maxYear.length > 0 ? Number(maxYear) >= date.getFullYear() : true);
});
};
};
this.filter.emit({ columnName: this.columnName, type: 'date', apply: fn(this.columnName, this.minDay, this.minMonth, this.minYear, this.maxDay, this.maxMonth, this.maxYear) });
}
else {
/** @type {?} */
var result = { minDay: this.minDay, minMonth: this.minMonth, minYear: this.minYear, maxDay: this.maxDay, maxMonth: this.maxMonth, maxYear: this.maxYear };
this.filter.emit({ columnName: this.columnName, type: 'date', apply: result });
}
};
/**
* @return {?}
*/
DateFFilterComponent.prototype.reset = /**
* @return {?}
*/
function () {
this.minDay = '';
this.minMonth = '';
this.minYear = '';
this.maxDay = '';
this.maxMonth = '';
this.maxYear = '';
this.filter.emit({ columnName: this.columnName, apply: null });
};
DateFFilterComponent.decorators = [
{ type: Component, args: [{
template: "\n\n <table class='ft-ffilter-table ft-ffilter-date-table'>\n <tr class='ft-ffilter-column'>\n <td class='ft-ffilter-row ft-ffilter-dd-row'>\n <input class=\"ft-i ft-i-ffilter ft-i-ffilter-day\" type='text' placeholder='dd' [(ngModel)]='minDay' (keyup)='onKeyUp(\"minDay\", 2, $event)' #minDayRef />\n </td>\n <td class='ft-ffilter-row ft-ffilter-mm-row'>\n <input class=\"ft-i ft-i-ffilter ft-i-ffilter-month\" type='text' placeholder='mm' [(ngModel)]='minMonth' (keyup)='onKeyUp(\"minMonth\", 2, $event)' #minMonthRef />\n </td>\n <td class='ft-ffilter-row ft-ffilter-yyyy-row'>\n <input class=\"ft-i ft-i-ffilter ft-i-ffilter-year\" type='text' placeholder='yyyy' [(ngModel)]='minYear' (keyup)='onKeyUp(\"minYear\", 4, $event)' #minYearRef />\n </td>\n </tr>\n <tr class='ft-ffilter-column'>\n <td class='ft-ffilter-row ft-ffilter-dd-row'>\n <input class=\"ft-i ft-i-ffilter ft-i-ffilter-day\" type='text' placeholder='dd' [(ngModel)]='maxDay' (keyup)='onKeyUp(\"maxDay\" , 2, $event)' #maxDayRef />\n </td>\n <td class='ft-ffilter-row ft-ffilter-mm-row'>\n <input class=\"ft-i ft-i-ffilter ft-i-ffilter-month\" type='text' placeholder='mm' [(ngModel)]='maxMonth' (keyup)='onKeyUp(\"maxMonth\", 2, $event)' #maxMonthRef />\n </td>\n <td class='ft-ffilter-row ft-ffilter-yyyy-row'>\n <input class=\"ft-i ft-i-ffilter ft-i-ffilter-year\" type='text' placeholder='yyyy' [(ngModel)]='maxYear' (keyup)='onKeyUp(\"maxYear\", 4, $event)' #maxYearRef />\n </td>\n </tr>\n</table>\n <!--\n <div class='ft-ffilter'>\n <div class=\"ft-filter-date ft-div1-ffilter\">\n <input class=\"ft-i ft-i-filter ft-i-filter-day\" type='text' placeholder='dd' [(ngModel)]='minDay' (keyup)='onKeyUp(\"minDay\", 2, $event)' #minDayRef />\n <input class=\"ft-i ft-i-filter ft-i-filter-month\" type='text' placeholder='mm' [(ngModel)]='minMonth' (keyup)='onKeyUp(\"minMonth\", 2, $event)' #minMonthRef />\n <input class=\"ft-i ft-i-filter ft-i-filter-year\" type='text' placeholder='yyyy' [(ngModel)]='minYear' (keyup)='onKeyUp(\"minYear\", 4, $event)' #minYearRef />\n </div>\n <div class=\"ft-filter-date ft-div2-ffilter\">\n <input class=\"ft-i ft-i-filter ft-i-filter-day\" type='text' placeholder='dd' [(ngModel)]='maxDay' (keyup)='onKeyUp(\"maxDay\" , 2, $event)' #maxDayRef />\n <input class=\"ft-i ft-i-filter ft-i-filter-month\" type='text' placeholder='mm' [(ngModel)]='maxMonth' (keyup)='onKeyUp(\"maxMonth\", 2, $event)' #maxMonthRef />\n <input class=\"ft-i ft-i-filter ft-i-filter-year\" type='text' placeholder='yyyy' [(ngModel)]='maxYear' (keyup)='onKeyUp(\"maxYear\", 4, $event)' #maxYearRef />\n </div>\n </div>\n\n -->\n ",
styles: ["\n :host { flex:1;\n }"]
}] }
];
DateFFilterComponent.propDecorators = {
_elMinDayRef: [{ type: ViewChild, args: ["minDayRef",] }],
_elMinMonthRef: [{ type: ViewChild, args: ["minMonthRef",] }],
_elMinYearRef: [{ type: ViewChild, args: ["minYearRef",] }],
_elMaxDayRef: [{ type: ViewChild, args: ["maxDayRef",] }],
_elMaxMonthRef: [{ type: ViewChild, args: ["maxMonthRef",] }],
_elMaxYearRef: [{ type: ViewChild, args: ["maxYearRef",] }],
source: [{ type: Input }],
otherData: [{ type: Input }],
columnName: [{ type: Input }],
filter: [{ type: Output }]
};
return DateFFilterComponent;
}());
export { DateFFilterComponent };
if (false) {
/** @type {?} */
DateFFilterComponent.prototype._elMinDayRef;
/** @type {?} */
DateFFilterComponent.prototype._elMinMonthRef;
/** @type {?} */
DateFFilterComponent.prototype._elMinYearRef;
/** @type {?} */
DateFFilterComponent.prototype._elMaxDayRef;
/** @type {?} */
DateFFilterComponent.prototype._elMaxMonthRef;
/** @type {?} */
DateFFilterComponent.prototype._elMaxYearRef;
/** @type {?} */
DateFFilterComponent.prototype.source;
/** @type {?} */
DateFFilterComponent.prototype.otherData;
/** @type {?} */
DateFFilterComponent.prototype.columnName;
/** @type {?} */
DateFFilterComponent.prototype.filter;
/** @type {?} */
DateFFilterComponent.prototype.minDay;
/** @type {?} */
DateFFilterComponent.prototype.minMonth;
/** @type {?} */
DateFFilterComponent.prototype.minYear;
/** @type {?} */
DateFFilterComponent.prototype.maxDay;
/** @type {?} */
DateFFilterComponent.prototype.maxMonth;
/** @type {?} */
DateFFilterComponent.prototype.maxYear;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"dateffilter.component.js","sourceRoot":"ng://ftable/","sources":["lib/ffilter/filters/dateffilter.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EAAE,SAAS,EAAE,MAAM,eAAe,CAAC;AAC1C,OAAO,EAAE,YAAY,EAAE,MAAM,eAAe,CAAC;AAC7C,OAAO,EAAE,MAAM,EAAE,MAAM,eAAe,CAAC;AACvC,OAAO,EAAE,KAAK,EAAE,MAAM,eAAe,CAAC;AACtC,OAAO,EAAE,SAAS,EAAE,UAAU,EAAE,MAAM,eAAe,CAAC;AAItD;IAAA;QA8DY,WAAM,GAAsB,IAAI,YAAY,EAAO,CAAC;QAGvD,WAAM,GAAG,EAAE,CAAC;QACZ,aAAQ,GAAG,EAAE,CAAC;QACd,YAAO,GAAG,EAAE,CAAC;QACb,WAAM,GAAG,EAAE,CAAC;QACZ,aAAQ,GAAG,EAAE,CAAC;QACd,YAAO,GAAG,EAAE,CAAC;IA8DtB,CAAC;;;;;;;IA5DC,sCAAO;;;;;;IAAP,UAAQ,IAAY,EAAE,GAAW,EAAE,KAAK;QACtC,gCAAgC;QAChC,IAAI,KAAK,CAAC,OAAO,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,EAAE;YAC/C,0BAA0B;YAC1B,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,SAAS,CAAC,CAAC,EAAE,GAAG,CAAC,CAAC;YAEnE,oBAAoB;YACpB,IAAI,IAAI,KAAK,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,CAAC,EAAE;gBAC1E,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aAC3C;iBACI,IAAI,IAAI,KAAK,UAAU,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,CAAC,EAAE;gBACjF,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aAC1C;iBACI,IAAI,IAAI,KAAK,SAAS,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,CAAC,EAAE;gBAChF,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aACzC;iBACI,IAAI,IAAI,KAAK,QAAQ,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,CAAC,EAAE;gBAC/E,IAAI,CAAC,cAAc,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aAC3C;iBACI,IAAI,IAAI,KAAK,UAAU,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,CAAC,EAAE;gBACjF,IAAI,CAAC,aAAa,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aAC1C;iBACI,IAAI,IAAI,KAAK,SAAS,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,CAAC,OAAO,KAAK,EAAE,CAAC,EAAE;gBAChF,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;aACzC;SACF;QAED,IAAI,IAAI,CAAC,MAAM,KAAK,UAAU,EAAE;;gBACxB,EAAE,GAAG,UAAU,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO;gBAC7E,OAAO,UAAA,CAAC;oBACN,OAAO,CAAC,mBAAO,CAAC,EAAA,CAAC,CAAC,MAAM,CAAC,UAAA,CAAC;wBACxB,OAAO,CAAC,GAAG,CAAC,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAE,OAAO,CAAC,CAAC;;4BAClE,IAAI,GAAG,IAAI,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC;wBAC9B,OAAO,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;4BAClE,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;4BACtE,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;4BACnE,CAAC,MAAM,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,OAAO,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC;4BAC7D,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,QAAQ,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;4BACtE,CAAC,OAAO,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,IAAI,IAAI,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAA;oBACvE,CAAC,CAAC,CAAC;gBACL,CAAC,CAAC;YACJ,CAAC;YAED,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,EAAE,CAAC,IAAI,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,MAAM,EAAE,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,OAAO,CAAC,EAAE,CAAC,CAAC;SACjL;aAAM;;gBACD,MAAM,GAAG,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,CAAC,MAAM,EAAE,QAAQ,EAAE,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE;YACzJ,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,IAAI,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,EAAE,CAAC,CAAC;SAChF;IAEH,CAAC;;;;IAED,oCAAK;;;IAAL;QACE,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,MAAM,GAAG,EAAE,CAAC;QACjB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;QACnB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE,UAAU,EAAE,IAAI,CAAC,UAAU,EAAE,KAAK,EAAE,IAAI,EAAE,CAAC,CAAC;IACjE,CAAC;;gBAnIF,SAAS,SAAC;oBACT,QAAQ,EAAE,myFAyCT;6BACQ,0BAEP;iBACH;;;+BAGE,SAAS,SAAC,WAAW;iCACrB,SAAS,SAAC,aAAa;gCACvB,SAAS,SAAC,YAAY;+BAEtB,SAAS,SAAC,WAAW;iCACrB,SAAS,SAAC,aAAa;gCACvB,SAAS,SAAC,YAAY;yBAGtB,KAAK;4BACL,KAAK;6BACL,KAAK;yBAEL,MAAM;;IAsET,2BAAC;CAAA,AApID,IAoIC;SApFY,oBAAoB;;;IAC/B,4CAAiD;;IACjD,8CAAqD;;IACrD,6CAAmD;;IAEnD,4CAAiD;;IACjD,8CAAqD;;IACrD,6CAAmD;;IAGnD,sCAA+B;;IAC/B,yCAA+B;;IAC/B,0CAAmC;;IAEnC,sCAA8D;;IAG9D,sCAAmB;;IACnB,wCAAqB;;IACrB,uCAAoB;;IACpB,sCAAmB;;IACnB,wCAAqB;;IACrB,uCAAoB","sourcesContent":["import { Component } from '@angular/core';\r\nimport { EventEmitter } from '@angular/core';\r\nimport { Output } from '@angular/core';\r\nimport { Input } from '@angular/core';\r\nimport { ViewChild, ElementRef } from '@angular/core';\r\n\r\nimport { FFilterBase } from './ffilter.base';\r\n\r\n@Component({\r\n  template: `\r\n\r\n  <table class='ft-ffilter-table ft-ffilter-date-table'>\r\n  <tr class='ft-ffilter-column'>\r\n      <td class='ft-ffilter-row  ft-ffilter-dd-row'>\r\n          <input class=\"ft-i ft-i-ffilter ft-i-ffilter-day\" type='text'  placeholder='dd'    [(ngModel)]='minDay'   (keyup)='onKeyUp(\"minDay\",   2, $event)'  #minDayRef />\r\n      </td>\r\n      <td class='ft-ffilter-row  ft-ffilter-mm-row'>\r\n          <input class=\"ft-i ft-i-ffilter ft-i-ffilter-month\" type='text'  placeholder='mm'    [(ngModel)]='minMonth' (keyup)='onKeyUp(\"minMonth\", 2, $event)' #minMonthRef />\r\n      </td>\r\n      <td class='ft-ffilter-row  ft-ffilter-yyyy-row'>\r\n          <input class=\"ft-i ft-i-ffilter ft-i-ffilter-year\" type='text'  placeholder='yyyy'  [(ngModel)]='minYear'  (keyup)='onKeyUp(\"minYear\",  4, $event)'   #minYearRef />\r\n      </td>\r\n  </tr>\r\n  <tr class='ft-ffilter-column'>\r\n      <td class='ft-ffilter-row  ft-ffilter-dd-row'>\r\n          <input class=\"ft-i ft-i-ffilter ft-i-ffilter-day\" type='text'  placeholder='dd'    [(ngModel)]='maxDay'   (keyup)='onKeyUp(\"maxDay\" ,  2, $event)'  #maxDayRef />\r\n      </td>\r\n      <td class='ft-ffilter-row  ft-ffilter-mm-row'>\r\n          <input class=\"ft-i ft-i-ffilter ft-i-ffilter-month\" type='text'  placeholder='mm'    [(ngModel)]='maxMonth' (keyup)='onKeyUp(\"maxMonth\", 2, $event)'  #maxMonthRef />\r\n      </td>\r\n      <td class='ft-ffilter-row  ft-ffilter-yyyy-row'>\r\n          <input class=\"ft-i ft-i-ffilter ft-i-ffilter-year\" type='text'  placeholder='yyyy'  [(ngModel)]='maxYear'  (keyup)='onKeyUp(\"maxYear\",  4, $event)'  #maxYearRef />\r\n      </td>\r\n  </tr>\r\n</table>\r\n  <!--\r\n  <div class='ft-ffilter'>\r\n    <div class=\"ft-filter-date ft-div1-ffilter\">\r\n    <input class=\"ft-i ft-i-filter ft-i-filter-day\" type='text'  placeholder='dd'    [(ngModel)]='minDay'   (keyup)='onKeyUp(\"minDay\",   2, $event)'  #minDayRef />\r\n    <input class=\"ft-i ft-i-filter ft-i-filter-month\" type='text'  placeholder='mm'    [(ngModel)]='minMonth' (keyup)='onKeyUp(\"minMonth\", 2, $event)' #minMonthRef />\r\n    <input class=\"ft-i ft-i-filter ft-i-filter-year\" type='text'  placeholder='yyyy'  [(ngModel)]='minYear'  (keyup)='onKeyUp(\"minYear\",  4, $event)'   #minYearRef />\r\n    </div>\r\n    <div class=\"ft-filter-date ft-div2-ffilter\">\r\n    <input class=\"ft-i ft-i-filter ft-i-filter-day\" type='text'  placeholder='dd'    [(ngModel)]='maxDay'   (keyup)='onKeyUp(\"maxDay\" ,  2, $event)'  #maxDayRef />\r\n    <input class=\"ft-i ft-i-filter ft-i-filter-month\" type='text'  placeholder='mm'    [(ngModel)]='maxMonth' (keyup)='onKeyUp(\"maxMonth\", 2, $event)'  #maxMonthRef />\r\n    <input class=\"ft-i ft-i-filter ft-i-filter-year\" type='text'  placeholder='yyyy'  [(ngModel)]='maxYear'  (keyup)='onKeyUp(\"maxYear\",  4, $event)'  #maxYearRef />\r\n    </div>\r\n  </div>\r\n\r\n  -->\r\n  `,\r\n  styles: [`\r\n  :host { flex:1;\r\n  }`]\r\n})\r\n\r\nexport class DateFFilterComponent implements FFilterBase {\r\n  @ViewChild(\"minDayRef\") _elMinDayRef: ElementRef;\r\n  @ViewChild(\"minMonthRef\") _elMinMonthRef: ElementRef;\r\n  @ViewChild(\"minYearRef\") _elMinYearRef: ElementRef;\r\n\r\n  @ViewChild(\"maxDayRef\") _elMaxDayRef: ElementRef;\r\n  @ViewChild(\"maxMonthRef\") _elMaxMonthRef: ElementRef;\r\n  @ViewChild(\"maxYearRef\") _elMaxYearRef: ElementRef;\r\n\r\n\r\n  @Input() public source: string;\r\n  @Input() public otherData: any;\r\n  @Input() public columnName: string;\r\n\r\n  @Output() filter: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n\r\n  public minDay = '';\r\n  public minMonth = '';\r\n  public minYear = '';\r\n  public maxDay = '';\r\n  public maxMonth = '';\r\n  public maxYear = '';\r\n\r\n  onKeyUp(mode: string, max: number, event) {\r\n    // Ignore if Delete or Backspace\r\n    if (event.keyCode !== 8 && event.keyCode !== 46) {\r\n      // filter letters and Trim\r\n      this[mode] = this[mode].match(/[0-9]*/).join('').substring(0, max);\r\n\r\n      // Move focus for UX\r\n      if (mode === 'minDay' && (this[mode].length === 2 || event.keyCode === 39)) {\r\n        this._elMinMonthRef.nativeElement.focus();\r\n      }\r\n      else if (mode === 'minMonth' && (this[mode].length === 2 || event.keyCode === 39)) {\r\n        this._elMinYearRef.nativeElement.focus();\r\n      }\r\n      else if (mode === 'minYear' && (this[mode].length === 4 || event.keyCode === 39)) {\r\n        this._elMaxDayRef.nativeElement.focus();\r\n      }\r\n      else if (mode === 'maxDay' && (this[mode].length === 2 || event.keyCode === 39)) {\r\n        this._elMaxMonthRef.nativeElement.focus();\r\n      }\r\n      else if (mode === 'maxMonth' && (this[mode].length === 2 || event.keyCode === 39)) {\r\n        this._elMaxYearRef.nativeElement.focus();\r\n      }\r\n      else if (mode === 'maxYear' && (this[mode].length === 4 || event.keyCode === 39)) {\r\n        this._elMinDayRef.nativeElement.focus();\r\n      }\r\n    }\r\n\r\n    if (this.source === 'frontend') {\r\n      const fn = function (name, minDay, minMonth, minYear, maxDay, maxMonth, maxYear) {\r\n        return d => {\r\n          return (<any[]>d).filter(x => {\r\n            console.log(name, minDay, minMonth, minYear, maxDay, maxMonth, maxYear);\r\n            const date = new Date(x[name]);\r\n            return (minDay.length > 0 ? Number(minDay) <= date.getDate() : true) &&\r\n              (minMonth.length > 0 ? Number(minMonth) <= date.getMonth() + 1 : true) &&\r\n              (minYear.length > 0 ? Number(minYear) <= date.getFullYear() : true) &&\r\n              (maxDay.length > 0 ? Number(maxDay) >= date.getDate() : true) &&\r\n              (maxMonth.length > 0 ? Number(maxMonth) >= date.getMonth() + 1 : true) &&\r\n              (maxYear.length > 0 ? Number(maxYear) >= date.getFullYear() : true)\r\n          });\r\n        };\r\n      };\r\n\r\n      this.filter.emit({ columnName: this.columnName, type: 'date', apply: fn(this.columnName, this.minDay, this.minMonth, this.minYear, this.maxDay, this.maxMonth, this.maxYear) });\r\n    } else {\r\n      var result = { minDay: this.minDay, minMonth: this.minMonth, minYear: this.minYear, maxDay: this.maxDay, maxMonth: this.maxMonth, maxYear: this.maxYear };\r\n      this.filter.emit({ columnName: this.columnName, type: 'date', apply: result });\r\n    }\r\n\r\n  }\r\n\r\n  reset() {\r\n    this.minDay = '';\r\n    this.minMonth = '';\r\n    this.minYear = '';\r\n    this.maxDay = '';\r\n    this.maxMonth = '';\r\n    this.maxYear = '';\r\n    this.filter.emit({ columnName: this.columnName, apply: null });\r\n  }\r\n}\r\n"]}