UNPKG

@firestitch/filter

Version:
214 lines 18.9 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { isString } from 'lodash-es'; import { ItemType } from '../models/filter-item'; export class QueryParams { /** * @param {?} _router * @param {?} _route * @param {?} _filterItems */ constructor(_router, _route, _filterItems) { this._router = _router; this._route = _route; this._filterItems = _filterItems; this._queryKeys = []; this._queryParamsToFilter(this._route.snapshot.queryParams, this._filterItems); } /** * Update query with filter values * @param {?} filterParams * @return {?} */ updateQueryParams(filterParams) { // transform selected filter values to query string /** @type {?} */ const newParams = this._filterToQueryParams(filterParams, this._filterItems); // Remove empty keys this._clearKeys(newParams); // Store query keys this._queryKeys = Object.keys(newParams); // Update query this._router.navigate([], { replaceUrl: true, relativeTo: this._route, queryParams: newParams, queryParamsHandling: 'merge' }).then((/** * @return {?} */ () => { })); } /** * Transformation for selected filter values to query string * @private * @param {?} params * @param {?} items * @return {?} */ _filterToQueryParams(params, items) { // selected filter keys /** @type {?} */ const filterKeys = Object.keys(params); return filterKeys.reduce((/** * @param {?} acc * @param {?} filterKey * @return {?} */ (acc, filterKey) => { // looking filter item /** @type {?} */ const filterItem = items.find((/** * @param {?} item * @return {?} */ (item) => item.name === filterKey)); if (filterItem) { if (filterItem.type === ItemType.Range) { acc[filterKey] = [params[filterKey].min, params[filterKey].max].join(','); } else if (filterItem.isTypeSelect() && filterItem.multiple && filterItem.model && filterItem.model.length > 0) { acc[filterKey] = filterItem.model.join(','); } else if (filterItem.isTypeAutocomplete()) { acc[filterKey] = [filterItem.model.value, filterItem.model.name].join(','); } else if (filterItem.type === ItemType.AutoCompleteChips) { acc[filterKey] = filterItem.model.map((/** * @param {?} item * @return {?} */ (item) => [item.value, item.name].join(','))).join(';'); } else { acc[filterKey] = params[filterKey]; } } return acc; }), {}); } /** * Parse query and update filter values * @private * @param {?} params * @param {?} items * @return {?} */ _queryParamsToFilter(params, items) { this._queryKeys = Object.keys(params); return this._queryKeys.forEach((/** * @param {?} queryKey * @return {?} */ (queryKey) => { /** @type {?} */ const filterItem = items.find((/** * @param {?} item * @return {?} */ (item) => item.name === queryKey)); if (filterItem) { if (filterItem.type === ItemType.Select && filterItem.multiple) { /** @type {?} */ const values = params[queryKey] .split(','); filterItem.parseAndSetValue(values); } else if (filterItem.type === ItemType.Range) { if (params[queryKey] && isString(params[queryKey])) { /** @type {?} */ const filterParts = params[queryKey].split(','); filterItem.model = { min: filterParts[0], max: filterParts[1] }; } } else if (filterItem.type === ItemType.Chips) { /** @type {?} */ const chipIds = params[queryKey] .split(',') .map((/** * @param {?} value * @return {?} */ (value) => +value)); filterItem.parseAndSetValue(chipIds); } else if (filterItem.type === ItemType.Checkbox) { filterItem.parseAndSetValue(params[queryKey] === 'true'); } else if (filterItem.type === ItemType.AutoComplete) { /** @type {?} */ const filterParts = params[queryKey].split(','); filterItem.model = { name: filterParts[1], value: +filterParts[0] }; } else if (filterItem.type === ItemType.AutoCompleteChips) { /** @type {?} */ const filterParts = params[queryKey].split(';'); filterItem.model = filterParts.reduce((/** * @param {?} acc * @param {?} value * @return {?} */ (acc, value) => { /** @type {?} */ const chipParts = value.split(','); acc.push({ name: chipParts[1], value: +chipParts[0], }); return acc; }), []); } else { filterItem.parseAndSetValue(params[queryKey]); } } })); } /** * @private * @param {?} params * @return {?} */ _clearKeys(params) { this._queryKeys.forEach((/** * @param {?} key * @return {?} */ (key) => { if (!params[key]) { params[key] = null; } })); } } if (false) { /** * @type {?} * @private */ QueryParams.prototype._queryKeys; /** * @type {?} * @private */ QueryParams.prototype._router; /** * @type {?} * @private */ QueryParams.prototype._route; /** * @type {?} * @private */ QueryParams.prototype._filterItems; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"query-params.js","sourceRoot":"ng://@firestitch/filter/","sources":["app/models/query-params.ts"],"names":[],"mappings":"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","sourcesContent":["import { ActivatedRoute, Router } from '@angular/router';\nimport { cloneDeep, isString } from 'lodash-es';\nimport { FsFilterConfigItem, ItemType } from '../models/filter-item';\n\n\nexport class QueryParams {\n  private _queryKeys = [];\n\n  constructor(\n    private _router: Router,\n    private _route: ActivatedRoute,\n    private _filterItems: FsFilterConfigItem[],\n  ) {\n    this._queryParamsToFilter(this._route.snapshot.queryParams, this._filterItems);\n  }\n\n  /**\n   * Update query with filter values\n   * @param filterParams\n   */\n  public updateQueryParams(filterParams) {\n    // transform selected filter values to query string\n    const newParams = this._filterToQueryParams(filterParams, this._filterItems);\n\n    // Remove empty keys\n    this._clearKeys(newParams);\n\n    // Store query keys\n    this._queryKeys = Object.keys(newParams);\n\n    // Update query\n    this._router.navigate([], {\n      replaceUrl: true,\n      relativeTo: this._route,\n      queryParams: newParams,\n      queryParamsHandling: 'merge'\n    }).then(() => {});\n  }\n\n  /**\n   * Transformation for selected filter values to query string\n   * @param params\n   * @param items\n   */\n  private _filterToQueryParams(params, items: FsFilterConfigItem[]) {\n    // selected filter keys\n    const filterKeys = Object.keys(params);\n\n    return filterKeys.reduce((acc, filterKey) => {\n\n      // looking filter item\n      const filterItem = items.find((item) => item.name === filterKey);\n\n      if (filterItem) {\n        if (filterItem.type === ItemType.Range) {\n          acc[filterKey] = [params[filterKey].min, params[filterKey].max].join(',')\n        } else if (filterItem.isTypeSelect() && filterItem.multiple && filterItem.model && filterItem.model.length > 0) {\n          acc[filterKey] = filterItem.model.join(',');\n        } else if (filterItem.isTypeAutocomplete()) {\n          acc[filterKey] = [filterItem.model.value, filterItem.model.name].join(',');\n        } else if (filterItem.type === ItemType.AutoCompleteChips) {\n          acc[filterKey] = filterItem.model.map((item) => [item.value, item.name].join(',')).join(';');\n        } else {\n          acc[filterKey] = params[filterKey];\n        }\n      }\n\n      return acc;\n    }, {});\n  }\n\n  /**\n   * Parse query and update filter values\n   * @param params\n   * @param items\n   */\n  private _queryParamsToFilter(params, items: FsFilterConfigItem[]) {\n    this._queryKeys = Object.keys(params);\n\n    return this._queryKeys.forEach((queryKey) => {\n\n      const filterItem = items.find((item) => item.name === queryKey);\n\n      if (filterItem) {\n        if (filterItem.type === ItemType.Select && filterItem.multiple) {\n          const values = params[queryKey]\n            .split(',');\n\n          filterItem.parseAndSetValue(values);\n        } else if (filterItem.type === ItemType.Range) {\n          if (params[queryKey] && isString(params[queryKey])) {\n            const filterParts = params[queryKey].split(',');\n            filterItem.model = {\n              min: filterParts[0],\n              max: filterParts[1]\n            };\n          }\n        } else if (filterItem.type === ItemType.Chips) {\n          const chipIds = params[queryKey]\n            .split(',')\n            .map((value) => +value);\n\n          filterItem.parseAndSetValue(chipIds);\n        } else if (filterItem.type === ItemType.Checkbox) {\n          filterItem.parseAndSetValue(params[queryKey] === 'true');\n        } else if (filterItem.type === ItemType.AutoComplete) {\n          const filterParts = params[queryKey].split(',');\n\n          filterItem.model = {\n            name: filterParts[1],\n            value: +filterParts[0]\n          }\n        } else if (filterItem.type === ItemType.AutoCompleteChips) {\n          const filterParts = params[queryKey].split(';');\n\n          filterItem.model = filterParts.reduce((acc, value) => {\n\n            const chipParts = value.split(',');\n\n            acc.push({\n              name: chipParts[1],\n              value: +chipParts[0],\n            });\n\n            return acc;\n          }, [])\n\n        } else {\n          filterItem.parseAndSetValue(params[queryKey]);\n        }\n      }\n    });\n  }\n\n  private _clearKeys(params) {\n    this._queryKeys.forEach((key) => {\n      if (!params[key]) {\n        params[key] = null;\n      }\n    })\n  }\n}\n"]}