X-Git-Url: https://gerrit.onap.org/r/gitweb?a=blobdiff_plain;f=src%2Futils%2FRoutes.js;h=81306712d24bf6ad7489438bd014bbb4e768ff86;hb=HEAD;hp=9d1517792cd09fee957036a801887f5d8d0f0a38;hpb=c1917730a648ddbb6cd51307cea9464a697700d8;p=aai%2Fsparky-fe.git diff --git a/src/utils/Routes.js b/src/utils/Routes.js index 9d15177..8130671 100644 --- a/src/utils/Routes.js +++ b/src/utils/Routes.js @@ -2,8 +2,8 @@ * ============LICENSE_START======================================================= * org.onap.aai * ================================================================================ - * Copyright © 2017 AT&T Intellectual Property. All rights reserved. - * Copyright © 2017 Amdocs + * Copyright © 2017-2018 AT&T Intellectual Property. All rights reserved. + * Copyright © 2017-2018 Amdocs * ================================================================================ * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. @@ -17,20 +17,97 @@ * See the License for the specific language governing permissions and * limitations under the License. * ============LICENSE_END========================================================= - * - * ECOMP is a trademark and service mark of AT&T Intellectual Property. */ +import {encrypt, decrypt } from './Crypto.js'; + + export function changeUrlAddress(pathObj, historyObj) { - let toGo = '/' + - pathObj.route + - '/' + - pathObj.hashId; + let toGo = '/' + pathObj.route; + // left global search to act the same as before for our 2 static views for now + // until we decide to change those 2 views too to act like extensible views. + if (pathObj.route === 'schema' || pathObj.route === 'vnfSearch') { + if (pathObj.filterValues && pathObj.filterValues.length > 0) { + let filterList = []; + for (let index in pathObj.filterValues) { + if (pathObj.filterValues[index].filterValue !== undefined) { + filterList.push(pathObj.filterValues[index].filterId + + '=' + + pathObj.filterValues[index].filterValue); + } else { + filterList.push(pathObj.filterValues[index].filterId + '='); + } + } + toGo = toGo + '/' + filterList.toString(); + } else { + toGo = toGo + '/' + pathObj.hashId; + } + } else { + toGo += '/' + encrypt(JSON.stringify(pathObj)); + } historyObj.push(toGo, {lastRoute: pathObj.route}); } -export function buildRouteObj(routePath, routeHash) { +export function buildRouteObjWithHash(routePath, routeHash) { return { route: routePath, hashId: routeHash }; } + + +export function decryptParamsForView(params) { + let jsonParam = {}; + + function isJson(str) { + try { + JSON.parse(str); + } catch (e) { + return false; + } + return true; + }; + + let stringParams; + + try { + stringParams = decrypt(params); + } catch(e) { + //add inline message in next story + //happens when user changes the url. + } + + if(!isJson(stringParams)) { + return jsonParam; + } + + jsonParam = JSON.parse(stringParams); + return jsonParam; +} + +export function buildRouteObjWithFilters(routePath, routeFiltersObj) { + let filterValues = []; + if (routeFiltersObj !== undefined) { + for (let id in routeFiltersObj) { + if (routeFiltersObj[id] !== undefined) { + filterValues.push( + { + 'filterId': id, + 'filterValue': routeFiltersObj[id] + } + ); + } else { + filterValues.push( + { + 'filterId': id, + 'filterValue': '' + } + ); + } + } + } + + return { + route: routePath, + filterValues: filterValues + }; +}