@firestitch/filter
Version: 
248 lines • 20.1 kB
JavaScript
/**
 * @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';
var QueryParams = /** @class */ (function () {
    function QueryParams(_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
     */
    /**
     * Update query with filter values
     * @param {?} filterParams
     * @return {?}
     */
    QueryParams.prototype.updateQueryParams = /**
     * Update query with filter values
     * @param {?} filterParams
     * @return {?}
     */
    function (filterParams) {
        // transform selected filter values to query string
        /** @type {?} */
        var 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([], {
            relativeTo: this._route,
            queryParams: newParams,
            queryParamsHandling: 'merge'
        }).then((/**
         * @return {?}
         */
        function () { }));
    };
    /**
     * Transformation for selected filter values to query string
     * @param params
     * @param items
     */
    /**
     * Transformation for selected filter values to query string
     * @private
     * @param {?} params
     * @param {?} items
     * @return {?}
     */
    QueryParams.prototype._filterToQueryParams = /**
     * Transformation for selected filter values to query string
     * @private
     * @param {?} params
     * @param {?} items
     * @return {?}
     */
    function (params, items) {
        // selected filter keys
        /** @type {?} */
        var filterKeys = Object.keys(params);
        return filterKeys.reduce((/**
         * @param {?} acc
         * @param {?} filterKey
         * @return {?}
         */
        function (acc, filterKey) {
            // looking filter item
            /** @type {?} */
            var filterItem = items.find((/**
             * @param {?} item
             * @return {?}
             */
            function (item) { return item.name === filterKey; }));
            if (filterItem) {
                if (filterItem.type === ItemType.Range) {
                    acc[filterKey] = [params[filterKey].min, params[filterKey].max].join(',');
                }
                else if (filterItem.type === ItemType.Select && filterItem.multiple && filterItem.model.length > 0) {
                    acc[filterKey] = filterItem.model.join(',');
                }
                else if (filterItem.type === ItemType.AutoComplete) {
                    acc[filterKey] = [filterItem.model.value, filterItem.model.name].join(',');
                }
                else if (filterItem.type === ItemType.AutoCompleteChips) {
                    acc[filterKey] = filterItem.model.map((/**
                     * @param {?} item
                     * @return {?}
                     */
                    function (item) { return [item.value, item.name].join(','); })).join(';');
                }
                else {
                    acc[filterKey] = params[filterKey];
                }
            }
            return acc;
        }), {});
    };
    /**
     * Parse query and update filter values
     * @param params
     * @param items
     */
    /**
     * Parse query and update filter values
     * @private
     * @param {?} params
     * @param {?} items
     * @return {?}
     */
    QueryParams.prototype._queryParamsToFilter = /**
     * Parse query and update filter values
     * @private
     * @param {?} params
     * @param {?} items
     * @return {?}
     */
    function (params, items) {
        this._queryKeys = Object.keys(params);
        return this._queryKeys.forEach((/**
         * @param {?} queryKey
         * @return {?}
         */
        function (queryKey) {
            /** @type {?} */
            var filterItem = items.find((/**
             * @param {?} item
             * @return {?}
             */
            function (item) { return item.name === queryKey; }));
            if (filterItem) {
                if (filterItem.type === ItemType.Select && filterItem.multiple) {
                    /** @type {?} */
                    var values = params[queryKey]
                        .split(',');
                    filterItem.parseAndSetValue(values);
                }
                else if (filterItem.type === ItemType.Range) {
                    if (params[queryKey] && isString(params[queryKey])) {
                        /** @type {?} */
                        var filterParts = params[queryKey].split(',');
                        filterItem.model = {
                            min: filterParts[0],
                            max: filterParts[1]
                        };
                    }
                }
                else if (filterItem.type === ItemType.Chips) {
                    /** @type {?} */
                    var chipIds = params[queryKey]
                        .split(',')
                        .map((/**
                     * @param {?} value
                     * @return {?}
                     */
                    function (value) { return +value; }));
                    filterItem.parseAndSetValue(chipIds);
                }
                else if (filterItem.type === ItemType.Checkbox) {
                    filterItem.parseAndSetValue(params[queryKey] === 'true');
                }
                else if (filterItem.type === ItemType.AutoComplete) {
                    /** @type {?} */
                    var filterParts = params[queryKey].split(',');
                    filterItem.model = {
                        name: filterParts[1],
                        value: +filterParts[0]
                    };
                }
                else if (filterItem.type === ItemType.AutoCompleteChips) {
                    /** @type {?} */
                    var filterParts = params[queryKey].split(';');
                    filterItem.model = filterParts.reduce((/**
                     * @param {?} acc
                     * @param {?} value
                     * @return {?}
                     */
                    function (acc, value) {
                        /** @type {?} */
                        var chipParts = value.split(',');
                        acc.push({
                            name: chipParts[1],
                            value: +chipParts[0],
                        });
                        return acc;
                    }), []);
                }
                else {
                    filterItem.parseAndSetValue(params[queryKey]);
                }
            }
        }));
    };
    /**
     * @private
     * @param {?} params
     * @return {?}
     */
    QueryParams.prototype._clearKeys = /**
     * @private
     * @param {?} params
     * @return {?}
     */
    function (params) {
        this._queryKeys.forEach((/**
         * @param {?} key
         * @return {?}
         */
        function (key) {
            if (!params[key]) {
                params[key] = null;
            }
        }));
    };
    return QueryParams;
}());
export { QueryParams };
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      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.type === ItemType.Select && filterItem.multiple && filterItem.model.length > 0) {\n          acc[filterKey] = filterItem.model.join(',');\n        } else if (filterItem.type === ItemType.AutoComplete) {\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"]}