UNPKG

@firestitch/filter

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