@firestitch/filter
Version:
243 lines • 20.7 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { pickBy, isEqual, isObject, isArray } from 'lodash-es';
import { list as arrayList } from '@firestitch/common';
var FilterParams = /** @class */ (function () {
function FilterParams(_router, _route, _filterItems) {
this._router = _router;
this._route = _route;
this._filterItems = _filterItems;
this._preserveParams = {};
}
/**
* @return {?}
*/
FilterParams.prototype.getValues = /**
* @return {?}
*/
function () {
/** @type {?} */
var values = {};
this._filterItems.forEach((/**
* @param {?} filter
* @return {?}
*/
function (filter) {
values[filter.name] = filter.value;
}));
return values;
};
/**
* @return {?}
*/
FilterParams.prototype.getFlattenedParams = /**
* @return {?}
*/
function () {
/** @type {?} */
var params = {};
this._filterItems.forEach((/**
* @param {?} filterItem
* @return {?}
*/
function (filterItem) {
Object.assign(params, filterItem.flattenedParams);
}));
return pickBy(params);
};
/**
* @return {?}
*/
FilterParams.prototype.updateQueryParams = /**
* @return {?}
*/
function () {
/** @type {?} */
var flattenedParams = this.getFlattenedParams();
this._filterItems.forEach((/**
* @param {?} filterItem
* @return {?}
*/
function (filterItem) {
if (filterItem.isTypeSelect && filterItem.isolate) {
/** @type {?} */
var isolated = arrayList(filterItem.values, 'value').sort();
/** @type {?} */
var value = filterItem.value.sort();
if (isEqual(value, isolated)) {
flattenedParams[filterItem.name] = null;
}
}
if (filterItem.isTypeAutocomplete) {
if (isObject(filterItem.model)) {
flattenedParams[filterItem.name] = filterItem.model.value + ':' + filterItem.model.name;
}
}
else if (filterItem.isTypeAutocompleteChips) {
if (isArray(filterItem.model) && filterItem.model.length) {
flattenedParams[filterItem.name] = filterItem.model.map((/**
* @param {?} item
* @return {?}
*/
function (item) {
return item.value + ':' + item.name;
})).join(',');
}
}
}));
/** @type {?} */
var params = Object.assign({}, this._preserveParams, flattenedParams);
// Update query
this._router.navigate([], {
replaceUrl: true,
relativeTo: this._route,
queryParams: params
}).then((/**
* @return {?}
*/
function () { }));
};
/**
* Parse query and update filter values
* @param params
*/
/**
* Parse query and update filter values
* @param {?} params
* @return {?}
*/
FilterParams.prototype.updateFromQueryParams = /**
* Parse query and update filter values
* @param {?} params
* @return {?}
*/
function (params) {
var _this = this;
Object.keys(params).forEach((/**
* @param {?} name
* @return {?}
*/
function (name) {
/** @type {?} */
var found = _this._filterItems.some((/**
* @param {?} filterItem
* @return {?}
*/
function (filterItem) {
if (filterItem.isTypeRange) {
return name === filterItem.name.concat('_min') ||
name === filterItem.name.concat('_max') ||
name === filterItem.name;
}
else if (filterItem.isTypeDateRange || filterItem.isTypeDateTimeRange) {
return name === filterItem.name.concat('_from') || name === filterItem.name.concat('_to');
}
return filterItem.name === name;
}));
if (!found) {
_this._preserveParams[name] = params[name];
}
}));
this._filterItems.forEach((/**
* @param {?} filterItem
* @return {?}
*/
function (filterItem) {
/** @type {?} */
var param = params[filterItem.name];
if (filterItem.isTypeRange) {
/** @type {?} */
var min = params[filterItem.name + '_min'];
/** @type {?} */
var max = params[filterItem.name + '_max'];
filterItem.model = { min: min, max: max };
}
else if (filterItem.isTypeDateRange || filterItem.isTypeDateTimeRange) {
/** @type {?} */
var from = params[filterItem.name + '_from'];
/** @type {?} */
var to = params[filterItem.name + '_to'];
filterItem.model = { from: from, to: to };
}
else if (param) {
if (filterItem.isTypeSelect && filterItem.multiple) {
if (filterItem.isolate && param === filterItem.isolate.value) {
filterItem.model = [param];
filterItem.isolate.enabled = true;
}
else {
filterItem.model = param.split(',');
}
}
else if (filterItem.isTypeChips) {
filterItem.model = param
.split(',')
.map((/**
* @param {?} value
* @return {?}
*/
function (value) { return +value; }));
}
else if (filterItem.isTypeCheckbox) {
filterItem.model = param;
}
else if (filterItem.isTypeAutocomplete) {
/** @type {?} */
var filterParts = param.split(':');
filterItem.model = {
name: filterParts[1],
value: +filterParts[0]
};
}
else if (filterItem.isTypeAutocompleteChips) {
/** @type {?} */
var filterParts = param.split(',');
filterItem.model = filterParts.reduce((/**
* @param {?} arry
* @param {?} value
* @return {?}
*/
function (arry, value) {
/** @type {?} */
var chipParts = value.split(':');
arry.push({
name: chipParts[1],
value: +chipParts[0],
});
return arry;
}), []);
}
else {
filterItem.model = param;
}
}
}));
};
return FilterParams;
}());
export { FilterParams };
if (false) {
/**
* @type {?}
* @private
*/
FilterParams.prototype._preserveParams;
/**
* @type {?}
* @private
*/
FilterParams.prototype._router;
/**
* @type {?}
* @private
*/
FilterParams.prototype._route;
/**
* @type {?}
* @private
*/
FilterParams.prototype._filterItems;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"filter-params.js","sourceRoot":"ng://@firestitch/filter/","sources":["app/models/filter-params.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router, Params } from '@angular/router';\nimport { pickBy, isEqual, isObject, isArray } from 'lodash-es';\nimport { list as arrayList } from '@firestitch/common';\nimport { FsFilterConfigItem } from '../models/filter-item';\n\n\nexport class FilterParams {\n\n  private _preserveParams = {};\n\n  constructor(\n    private _router: Router,\n    private _route: ActivatedRoute,\n    private _filterItems: FsFilterConfigItem[],\n  ) {}\n\n  public getValues() {\n\n    const values = {};\n    this._filterItems.forEach(filter => {\n      values[filter.name] = filter.value;\n    });\n\n    return values;\n  }\n\n  public getFlattenedParams() {\n\n    const params = {};\n    this._filterItems.forEach((filterItem: FsFilterConfigItem) => {\n      Object.assign(params, filterItem.flattenedParams);\n    });\n\n    return pickBy(params);\n  }\n\n  public updateQueryParams() {\n\n    const flattenedParams = this.getFlattenedParams();\n\n    this._filterItems.forEach(filterItem => {\n\n      if (filterItem.isTypeSelect && filterItem.isolate) {\n\n        const isolated = arrayList(filterItem.values, 'value').sort();\n        const value = filterItem.value.sort();\n\n        if (isEqual(value, isolated)) {\n          flattenedParams[filterItem.name] = null;\n        }\n      }\n\n      if (filterItem.isTypeAutocomplete) {\n        if (isObject(filterItem.model)) {\n          flattenedParams[filterItem.name] = filterItem.model.value + ':' + filterItem.model.name;\n        }\n      } else if (filterItem.isTypeAutocompleteChips) {\n        if (isArray(filterItem.model) && filterItem.model.length) {\n          flattenedParams[filterItem.name] = filterItem.model.map((item) => {\n            return item.value + ':' + item.name;\n          }).join(',');\n        }\n      }\n    });\n\n    const params = Object.assign(\n        {},\n        this._preserveParams,\n        flattenedParams);\n\n    // Update query\n    this._router.navigate([], {\n      replaceUrl: true,\n      relativeTo: this._route,\n      queryParams: params\n    }).then(() => {});\n  }\n\n  /**\n   * Parse query and update filter values\n   * @param params\n   */\n  public updateFromQueryParams(params: Params) {\n\n    Object.keys(params).forEach((name) => {\n\n      const found = this._filterItems.some(filterItem => {\n\n        if (filterItem.isTypeRange) {\n          return  name === filterItem.name.concat('_min') ||\n                  name === filterItem.name.concat('_max') ||\n                  name === filterItem.name;\n\n        } else if (filterItem.isTypeDateRange || filterItem.isTypeDateTimeRange) {\n          return name === filterItem.name.concat('_from') || name === filterItem.name.concat('_to');\n        }\n\n        return filterItem.name === name;\n      });\n\n      if (!found) {\n        this._preserveParams[name] = params[name];\n      }\n    });\n\n    this._filterItems.forEach(filterItem => {\n\n      const param = params[filterItem.name];\n\n      if (filterItem.isTypeRange) {\n\n        const min = params[filterItem.name + '_min'];\n        const max = params[filterItem.name + '_max'];\n\n        filterItem.model = { min: min, max: max };\n\n      } else if (filterItem.isTypeDateRange || filterItem.isTypeDateTimeRange) {\n\n        const from = params[filterItem.name + '_from'];\n        const to = params[filterItem.name + '_to'];\n\n        filterItem.model = { from: from, to: to };\n\n      } else if (param) {\n\n        if (filterItem.isTypeSelect && filterItem.multiple) {\n\n          if (filterItem.isolate && param === filterItem.isolate.value) {\n            filterItem.model = [param];\n            filterItem.isolate.enabled = true;\n          } else {\n            filterItem.model = param.split(',');\n          }\n\n        } else if (filterItem.isTypeChips) {\n\n            filterItem.model = param\n                                .split(',')\n                                .map((value) => +value);\n\n        } else if (filterItem.isTypeCheckbox) {\n          filterItem.model = param;\n\n        } else if (filterItem.isTypeAutocomplete) {\n          const filterParts = param.split(':');\n\n          filterItem.model = {\n            name: filterParts[1],\n            value: +filterParts[0]\n          }\n        } else if (filterItem.isTypeAutocompleteChips) {\n          const filterParts = param.split(',');\n\n          filterItem.model = filterParts.reduce((arry, value) => {\n\n            const chipParts = value.split(':');\n\n            arry.push({\n              name: chipParts[1],\n              value: +chipParts[0],\n            });\n\n            return arry;\n          }, [])\n\n        } else {\n          filterItem.model = param;\n        }\n      }\n    });\n  }\n}\n"]}