@commercelayer/organization-config 1.4.0 → 1.4.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/README.md CHANGED
@@ -12,7 +12,7 @@ you can use the function `getConfig` to manipulate the configuration settings of
12
12
 
13
13
  ```javascript
14
14
  getConfig({
15
- jsonConfig: {},
15
+ jsonConfig: organizationConfig,
16
16
  market: 'market:id:hashid',
17
17
  params: { lang: 'en', orderId: 'your-order-id' }
18
18
  })
package/dist/index.cjs CHANGED
@@ -1,2 +1,2 @@
1
- "use strict";var u=Object.create;var o=Object.defineProperty;var C=Object.getOwnPropertyDescriptor;var p=Object.getOwnPropertyNames;var d=Object.getPrototypeOf,y=Object.prototype.hasOwnProperty;var k=(e,n)=>{for(var t in n)o(e,t,{get:n[t],enumerable:!0})},g=(e,n,t,r)=>{if(n&&typeof n=="object"||typeof n=="function")for(let i of p(n))!y.call(e,i)&&i!==t&&o(e,i,{get:()=>n[i],enumerable:!(r=C(n,i))||r.enumerable});return e};var m=(e,n,t)=>(t=e!=null?u(d(e)):{},g(n||!e||!e.__esModule?o(t,"default",{value:e,enumerable:!0}):t,e)),_=e=>g(o({},"__esModule",{value:!0}),e);var h={};k(h,{getConfig:()=>N});module.exports=_(h);var f=m(require("lodash/merge"),1);function N({jsonConfig:e,market:n,params:t}){if(e?.mfe==null)return console.warn("No configuration found."),null;let r=e?.mfe?.default,i=n!=null?e?.mfe[n]:{};function a(s){let c=JSON.stringify(s).replace(/:lang/g,t?.lang??":lang").replace(/:access_token/g,t?.accessToken??":access_token").replace(/:order_id/g,t?.orderId??":order_id");return JSON.parse(c)}let l=(0,f.default)(JSON.parse(JSON.stringify(r)),i);return a(l)}0&&(module.exports={getConfig});
1
+ "use strict";var l=Object.defineProperty;var p=Object.getOwnPropertyDescriptor;var _=Object.getOwnPropertyNames;var N=Object.prototype.hasOwnProperty;var h=(e,n)=>{for(var t in n)l(e,t,{get:n[t],enumerable:!0})},T=(e,n,t,r)=>{if(n&&typeof n=="object"||typeof n=="function")for(let i of _(n))!N.call(e,i)&&i!==t&&l(e,i,{get:()=>n[i],enumerable:!(r=p(n,i))||r.enumerable});return e};var b=e=>T(l({},"__esModule",{value:!0}),e);var S={};h(S,{getConfig:()=>D});module.exports=b(S);var s=require("merge-anything");function D({jsonConfig:e,market:n,params:t}){var g,f,o;if((e==null?void 0:e.mfe)==null)return console.warn("No configuration found."),null;let r=(f=(g=e==null?void 0:e.mfe)==null?void 0:g.default)!=null?f:{},i=n!=null?(o=e==null?void 0:e.mfe[n])!=null?o:{}:{};function d(y){var c,u,a;let k=JSON.stringify(y).replace(/:lang/g,(c=t==null?void 0:t.lang)!=null?c:":lang").replace(/:access_token/g,(u=t==null?void 0:t.accessToken)!=null?u:":access_token").replace(/:order_id/g,(a=t==null?void 0:t.orderId)!=null?a:":order_id");return JSON.parse(k)}let C=(0,s.merge)(JSON.parse(JSON.stringify(r)),i);return d(C)}0&&(module.exports={getConfig});
2
2
  //# sourceMappingURL=index.cjs.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import merge from 'lodash/merge'\n\nexport type NullableType<T> = T | null | undefined\n\ninterface ConfigParams {\n /**\n * language used to replace `:lang` placeholder\n */\n lang?: NullableType<string>\n /**\n * accessToken used to replace `:access_token` placeholder\n */\n accessToken?: NullableType<string>\n /**\n * order id used to replace `:order_id` placeholder\n */\n orderId?: NullableType<string>\n}\n\ninterface LinkConfig {\n cart?: string\n checkout?: string\n my_account?: string\n identity?: string\n}\n\ninterface Country {\n value: string\n label: string\n}\n\ntype StateConfig = Record<string, Country[]>\n\ninterface CheckoutConfig {\n thankyou_page?: string\n billing_countries?: Country[]\n shipping_countries?: Country[]\n billing_states?: StateConfig[]\n shipping_states?: StateConfig[]\n default_country?: string\n}\n\ninterface UrlsConfig {\n privacy: string\n terms: string\n}\n\nexport interface DefaultConfig {\n links?: LinkConfig\n checkout?: CheckoutConfig\n urls?: UrlsConfig\n}\n\nexport interface Configs {\n default: DefaultConfig\n [key: string]: Partial<DefaultConfig>\n}\n\ninterface GetConfigProps {\n /**\n * `config` attribute of the organization\n */\n jsonConfig?: { mfe?: Configs }\n /**\n * `market:id:hashid` used to override default configuration\n */\n market?: string\n /**\n * `params` used to replace url placeholders\n */\n params?: ConfigParams\n}\n\n/**\n * The function is going to manipulate the organization configuration,\n * extract the `mfe` key and merge `default` configuration with overrides\n * for the market used.\n */\nexport function getConfig({\n jsonConfig,\n market,\n params\n}: GetConfigProps): DefaultConfig | null {\n if (jsonConfig?.mfe == null) {\n console.warn('No configuration found.')\n return null\n }\n\n const defaultConfig = jsonConfig?.mfe?.default\n const overrideConfig = market != null ? jsonConfig?.mfe[market] : {}\n\n // Replace placeholders in all string values within the object\n function replacePlaceholders(config: DefaultConfig): DefaultConfig {\n const replacedConfig = JSON.stringify(config)\n .replace(/:lang/g, params?.lang ?? ':lang')\n .replace(/:access_token/g, params?.accessToken ?? ':access_token')\n .replace(/:order_id/g, params?.orderId ?? ':order_id')\n\n return JSON.parse(replacedConfig)\n }\n\n const mergedConfig: DefaultConfig = merge(\n JSON.parse(JSON.stringify(defaultConfig)),\n overrideConfig\n )\n return replacePlaceholders(mergedConfig)\n}\n"],"mappings":"0jBAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,eAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAAkB,6BA8EX,SAASF,EAAU,CACxB,WAAAG,EACA,OAAAC,EACA,OAAAC,CACF,EAAyC,CACvC,GAAIF,GAAY,KAAO,KACrB,eAAQ,KAAK,yBAAyB,EAC/B,KAGT,IAAMG,EAAgBH,GAAY,KAAK,QACjCI,EAAiBH,GAAU,KAAOD,GAAY,IAAIC,CAAM,EAAI,CAAC,EAGnE,SAASI,EAAoBC,EAAsC,CACjE,IAAMC,EAAiB,KAAK,UAAUD,CAAM,EACzC,QAAQ,SAAUJ,GAAQ,MAAQ,OAAO,EACzC,QAAQ,iBAAkBA,GAAQ,aAAe,eAAe,EAChE,QAAQ,aAAcA,GAAQ,SAAW,WAAW,EAEvD,OAAO,KAAK,MAAMK,CAAc,CAClC,CAEA,IAAMC,KAA8B,EAAAC,SAClC,KAAK,MAAM,KAAK,UAAUN,CAAa,CAAC,EACxCC,CACF,EACA,OAAOC,EAAoBG,CAAY,CACzC","names":["src_exports","__export","getConfig","__toCommonJS","import_merge","jsonConfig","market","params","defaultConfig","overrideConfig","replacePlaceholders","config","replacedConfig","mergedConfig","merge"]}
1
+ {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { merge } from 'merge-anything'\n\nexport type NullableType<T> = T | null | undefined\n\ninterface ConfigParams {\n /**\n * language used to replace `:lang` placeholder\n */\n lang?: NullableType<string>\n /**\n * accessToken used to replace `:access_token` placeholder\n */\n accessToken?: NullableType<string>\n /**\n * order id used to replace `:order_id` placeholder\n */\n orderId?: NullableType<string>\n}\n\ninterface LinkConfig {\n cart?: string\n checkout?: string\n my_account?: string\n identity?: string\n}\n\ninterface Country {\n value: string\n label: string\n}\n\ntype StateConfig = Record<string, Country[]>\n\ninterface CheckoutConfig {\n thankyou_page?: string\n billing_countries?: Country[]\n shipping_countries?: Country[]\n billing_states?: StateConfig[]\n shipping_states?: StateConfig[]\n default_country?: string\n}\n\ninterface UrlsConfig {\n privacy: string\n terms: string\n}\n\nexport interface DefaultConfig {\n links?: LinkConfig\n checkout?: CheckoutConfig\n urls?: UrlsConfig\n}\n\nexport interface Configs {\n default: DefaultConfig\n [key: string]: Partial<DefaultConfig>\n}\n\ninterface GetConfigProps {\n /**\n * `config` attribute of the organization\n */\n jsonConfig?: { mfe?: Configs }\n /**\n * `market:id:hashid` used to override default configuration\n */\n market?: string\n /**\n * `params` used to replace url placeholders\n */\n params?: ConfigParams\n}\n\n/**\n * The function is going to manipulate the organization configuration,\n * extract the `mfe` key and merge `default` configuration with overrides\n * for the market used.\n */\nexport function getConfig({\n jsonConfig,\n market,\n params\n}: GetConfigProps): DefaultConfig | null {\n if (jsonConfig?.mfe == null) {\n console.warn('No configuration found.')\n return null\n }\n\n const defaultConfig = jsonConfig?.mfe?.default ?? {}\n const overrideConfig = market != null ? jsonConfig?.mfe[market] ?? {} : {}\n\n // Replace placeholders in all string values within the object\n function replacePlaceholders(config: DefaultConfig): DefaultConfig {\n const replacedConfig = JSON.stringify(config)\n .replace(/:lang/g, params?.lang ?? ':lang')\n .replace(/:access_token/g, params?.accessToken ?? ':access_token')\n .replace(/:order_id/g, params?.orderId ?? ':order_id')\n\n return JSON.parse(replacedConfig)\n }\n\n const mergedConfig: DefaultConfig = merge(\n JSON.parse(JSON.stringify(defaultConfig)),\n overrideConfig\n )\n return replacePlaceholders(mergedConfig)\n}\n"],"mappings":"yaAAA,IAAAA,EAAA,GAAAC,EAAAD,EAAA,eAAAE,IAAA,eAAAC,EAAAH,GAAA,IAAAI,EAAsB,0BA8Ef,SAASF,EAAU,CACxB,WAAAG,EACA,OAAAC,EACA,OAAAC,CACF,EAAyC,CAlFzC,IAAAC,EAAAC,EAAAC,EAmFE,IAAIL,GAAA,YAAAA,EAAY,MAAO,KACrB,eAAQ,KAAK,yBAAyB,EAC/B,KAGT,IAAMM,GAAgBF,GAAAD,EAAAH,GAAA,YAAAA,EAAY,MAAZ,YAAAG,EAAiB,UAAjB,KAAAC,EAA4B,CAAC,EAC7CG,EAAiBN,GAAU,MAAOI,EAAAL,GAAA,YAAAA,EAAY,IAAIC,KAAhB,KAAAI,EAA2B,CAAC,EAAI,CAAC,EAGzE,SAASG,EAAoBC,EAAsC,CA5FrE,IAAAN,EAAAC,EAAAC,EA6FI,IAAMK,EAAiB,KAAK,UAAUD,CAAM,EACzC,QAAQ,UAAUN,EAAAD,GAAA,YAAAA,EAAQ,OAAR,KAAAC,EAAgB,OAAO,EACzC,QAAQ,kBAAkBC,EAAAF,GAAA,YAAAA,EAAQ,cAAR,KAAAE,EAAuB,eAAe,EAChE,QAAQ,cAAcC,EAAAH,GAAA,YAAAA,EAAQ,UAAR,KAAAG,EAAmB,WAAW,EAEvD,OAAO,KAAK,MAAMK,CAAc,CAClC,CAEA,IAAMC,KAA8B,SAClC,KAAK,MAAM,KAAK,UAAUL,CAAa,CAAC,EACxCC,CACF,EACA,OAAOC,EAAoBG,CAAY,CACzC","names":["src_exports","__export","getConfig","__toCommonJS","import_merge_anything","jsonConfig","market","params","_a","_b","_c","defaultConfig","overrideConfig","replacePlaceholders","config","replacedConfig","mergedConfig"]}
package/dist/index.js CHANGED
@@ -1,2 +1,2 @@
1
- import l from"lodash/merge";function c({jsonConfig:e,market:t,params:n}){if(e?.mfe==null)return console.warn("No configuration found."),null;let i=e?.mfe?.default,r=t!=null?e?.mfe[t]:{};function o(f){let a=JSON.stringify(f).replace(/:lang/g,n?.lang??":lang").replace(/:access_token/g,n?.accessToken??":access_token").replace(/:order_id/g,n?.orderId??":order_id");return JSON.parse(a)}let g=l(JSON.parse(JSON.stringify(i)),r);return o(g)}export{c as getConfig};
1
+ import{merge as y}from"merge-anything";function p({jsonConfig:e,market:n,params:t}){var i,r,l;if((e==null?void 0:e.mfe)==null)return console.warn("No configuration found."),null;let c=(r=(i=e==null?void 0:e.mfe)==null?void 0:i.default)!=null?r:{},u=n!=null?(l=e==null?void 0:e.mfe[n])!=null?l:{}:{};function a(d){var g,f,o;let C=JSON.stringify(d).replace(/:lang/g,(g=t==null?void 0:t.lang)!=null?g:":lang").replace(/:access_token/g,(f=t==null?void 0:t.accessToken)!=null?f:":access_token").replace(/:order_id/g,(o=t==null?void 0:t.orderId)!=null?o:":order_id");return JSON.parse(C)}let s=y(JSON.parse(JSON.stringify(c)),u);return a(s)}export{p as getConfig};
2
2
  //# sourceMappingURL=index.js.map
package/dist/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import merge from 'lodash/merge'\n\nexport type NullableType<T> = T | null | undefined\n\ninterface ConfigParams {\n /**\n * language used to replace `:lang` placeholder\n */\n lang?: NullableType<string>\n /**\n * accessToken used to replace `:access_token` placeholder\n */\n accessToken?: NullableType<string>\n /**\n * order id used to replace `:order_id` placeholder\n */\n orderId?: NullableType<string>\n}\n\ninterface LinkConfig {\n cart?: string\n checkout?: string\n my_account?: string\n identity?: string\n}\n\ninterface Country {\n value: string\n label: string\n}\n\ntype StateConfig = Record<string, Country[]>\n\ninterface CheckoutConfig {\n thankyou_page?: string\n billing_countries?: Country[]\n shipping_countries?: Country[]\n billing_states?: StateConfig[]\n shipping_states?: StateConfig[]\n default_country?: string\n}\n\ninterface UrlsConfig {\n privacy: string\n terms: string\n}\n\nexport interface DefaultConfig {\n links?: LinkConfig\n checkout?: CheckoutConfig\n urls?: UrlsConfig\n}\n\nexport interface Configs {\n default: DefaultConfig\n [key: string]: Partial<DefaultConfig>\n}\n\ninterface GetConfigProps {\n /**\n * `config` attribute of the organization\n */\n jsonConfig?: { mfe?: Configs }\n /**\n * `market:id:hashid` used to override default configuration\n */\n market?: string\n /**\n * `params` used to replace url placeholders\n */\n params?: ConfigParams\n}\n\n/**\n * The function is going to manipulate the organization configuration,\n * extract the `mfe` key and merge `default` configuration with overrides\n * for the market used.\n */\nexport function getConfig({\n jsonConfig,\n market,\n params\n}: GetConfigProps): DefaultConfig | null {\n if (jsonConfig?.mfe == null) {\n console.warn('No configuration found.')\n return null\n }\n\n const defaultConfig = jsonConfig?.mfe?.default\n const overrideConfig = market != null ? jsonConfig?.mfe[market] : {}\n\n // Replace placeholders in all string values within the object\n function replacePlaceholders(config: DefaultConfig): DefaultConfig {\n const replacedConfig = JSON.stringify(config)\n .replace(/:lang/g, params?.lang ?? ':lang')\n .replace(/:access_token/g, params?.accessToken ?? ':access_token')\n .replace(/:order_id/g, params?.orderId ?? ':order_id')\n\n return JSON.parse(replacedConfig)\n }\n\n const mergedConfig: DefaultConfig = merge(\n JSON.parse(JSON.stringify(defaultConfig)),\n overrideConfig\n )\n return replacePlaceholders(mergedConfig)\n}\n"],"mappings":"AAAA,OAAOA,MAAW,eA8EX,SAASC,EAAU,CACxB,WAAAC,EACA,OAAAC,EACA,OAAAC,CACF,EAAyC,CACvC,GAAIF,GAAY,KAAO,KACrB,eAAQ,KAAK,yBAAyB,EAC/B,KAGT,IAAMG,EAAgBH,GAAY,KAAK,QACjCI,EAAiBH,GAAU,KAAOD,GAAY,IAAIC,CAAM,EAAI,CAAC,EAGnE,SAASI,EAAoBC,EAAsC,CACjE,IAAMC,EAAiB,KAAK,UAAUD,CAAM,EACzC,QAAQ,SAAUJ,GAAQ,MAAQ,OAAO,EACzC,QAAQ,iBAAkBA,GAAQ,aAAe,eAAe,EAChE,QAAQ,aAAcA,GAAQ,SAAW,WAAW,EAEvD,OAAO,KAAK,MAAMK,CAAc,CAClC,CAEA,IAAMC,EAA8BV,EAClC,KAAK,MAAM,KAAK,UAAUK,CAAa,CAAC,EACxCC,CACF,EACA,OAAOC,EAAoBG,CAAY,CACzC","names":["merge","getConfig","jsonConfig","market","params","defaultConfig","overrideConfig","replacePlaceholders","config","replacedConfig","mergedConfig"]}
1
+ {"version":3,"sources":["../src/index.ts"],"sourcesContent":["import { merge } from 'merge-anything'\n\nexport type NullableType<T> = T | null | undefined\n\ninterface ConfigParams {\n /**\n * language used to replace `:lang` placeholder\n */\n lang?: NullableType<string>\n /**\n * accessToken used to replace `:access_token` placeholder\n */\n accessToken?: NullableType<string>\n /**\n * order id used to replace `:order_id` placeholder\n */\n orderId?: NullableType<string>\n}\n\ninterface LinkConfig {\n cart?: string\n checkout?: string\n my_account?: string\n identity?: string\n}\n\ninterface Country {\n value: string\n label: string\n}\n\ntype StateConfig = Record<string, Country[]>\n\ninterface CheckoutConfig {\n thankyou_page?: string\n billing_countries?: Country[]\n shipping_countries?: Country[]\n billing_states?: StateConfig[]\n shipping_states?: StateConfig[]\n default_country?: string\n}\n\ninterface UrlsConfig {\n privacy: string\n terms: string\n}\n\nexport interface DefaultConfig {\n links?: LinkConfig\n checkout?: CheckoutConfig\n urls?: UrlsConfig\n}\n\nexport interface Configs {\n default: DefaultConfig\n [key: string]: Partial<DefaultConfig>\n}\n\ninterface GetConfigProps {\n /**\n * `config` attribute of the organization\n */\n jsonConfig?: { mfe?: Configs }\n /**\n * `market:id:hashid` used to override default configuration\n */\n market?: string\n /**\n * `params` used to replace url placeholders\n */\n params?: ConfigParams\n}\n\n/**\n * The function is going to manipulate the organization configuration,\n * extract the `mfe` key and merge `default` configuration with overrides\n * for the market used.\n */\nexport function getConfig({\n jsonConfig,\n market,\n params\n}: GetConfigProps): DefaultConfig | null {\n if (jsonConfig?.mfe == null) {\n console.warn('No configuration found.')\n return null\n }\n\n const defaultConfig = jsonConfig?.mfe?.default ?? {}\n const overrideConfig = market != null ? jsonConfig?.mfe[market] ?? {} : {}\n\n // Replace placeholders in all string values within the object\n function replacePlaceholders(config: DefaultConfig): DefaultConfig {\n const replacedConfig = JSON.stringify(config)\n .replace(/:lang/g, params?.lang ?? ':lang')\n .replace(/:access_token/g, params?.accessToken ?? ':access_token')\n .replace(/:order_id/g, params?.orderId ?? ':order_id')\n\n return JSON.parse(replacedConfig)\n }\n\n const mergedConfig: DefaultConfig = merge(\n JSON.parse(JSON.stringify(defaultConfig)),\n overrideConfig\n )\n return replacePlaceholders(mergedConfig)\n}\n"],"mappings":"AAAA,OAAS,SAAAA,MAAa,iBA8Ef,SAASC,EAAU,CACxB,WAAAC,EACA,OAAAC,EACA,OAAAC,CACF,EAAyC,CAlFzC,IAAAC,EAAAC,EAAAC,EAmFE,IAAIL,GAAA,YAAAA,EAAY,MAAO,KACrB,eAAQ,KAAK,yBAAyB,EAC/B,KAGT,IAAMM,GAAgBF,GAAAD,EAAAH,GAAA,YAAAA,EAAY,MAAZ,YAAAG,EAAiB,UAAjB,KAAAC,EAA4B,CAAC,EAC7CG,EAAiBN,GAAU,MAAOI,EAAAL,GAAA,YAAAA,EAAY,IAAIC,KAAhB,KAAAI,EAA2B,CAAC,EAAI,CAAC,EAGzE,SAASG,EAAoBC,EAAsC,CA5FrE,IAAAN,EAAAC,EAAAC,EA6FI,IAAMK,EAAiB,KAAK,UAAUD,CAAM,EACzC,QAAQ,UAAUN,EAAAD,GAAA,YAAAA,EAAQ,OAAR,KAAAC,EAAgB,OAAO,EACzC,QAAQ,kBAAkBC,EAAAF,GAAA,YAAAA,EAAQ,cAAR,KAAAE,EAAuB,eAAe,EAChE,QAAQ,cAAcC,EAAAH,GAAA,YAAAA,EAAQ,UAAR,KAAAG,EAAmB,WAAW,EAEvD,OAAO,KAAK,MAAMK,CAAc,CAClC,CAEA,IAAMC,EAA8Bb,EAClC,KAAK,MAAM,KAAK,UAAUQ,CAAa,CAAC,EACxCC,CACF,EACA,OAAOC,EAAoBG,CAAY,CACzC","names":["merge","getConfig","jsonConfig","market","params","_a","_b","_c","defaultConfig","overrideConfig","replacePlaceholders","config","replacedConfig","mergedConfig"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@commercelayer/organization-config",
3
- "version": "1.4.0",
3
+ "version": "1.4.2",
4
4
  "description": "Organization config utils for extracting config by market",
5
5
  "author": {
6
6
  "name": "Matteo Alessani",
@@ -37,7 +37,10 @@
37
37
  "devDependencies": {
38
38
  "@commercelayer/eslint-config-ts": "^1.4.0",
39
39
  "@types/lodash": "^4.17.0",
40
+ "deepmerge": "^4.3.1",
41
+ "deepmerge-ts": "^5.1.0",
40
42
  "eslint": "^8.57.0",
43
+ "lodash": "^4.17.21",
41
44
  "tsup": "^8.0.2",
42
45
  "typescript": "^5.4.2",
43
46
  "vitest": "^1.4.0"
@@ -47,12 +50,13 @@
47
50
  "typescript": ">=5.0"
48
51
  },
49
52
  "dependencies": {
50
- "lodash": "^4.17.21"
53
+ "merge-anything": "^5.1.7"
51
54
  },
52
55
  "scripts": {
53
56
  "lint": "eslint src --ext .ts,.tsx",
54
57
  "lint:fix": "eslint src --ext .ts,.tsx --fix",
55
58
  "test": "pnpm run lint && vitest run --silent",
59
+ "bench": "vitest bench",
56
60
  "build": "tsup"
57
61
  }
58
62
  }