@dropins/storefront-company-management 1.0.0-beta2 → 1.0.0-beta3

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.
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Fetches user permissions and returns both the allowed permission IDs and the role response
3
+ * This is a general-purpose API function that can be used across the application
4
+ */
5
+ export declare const fetchUserPermissions: () => Promise<{
6
+ allowedIds: Set<string>;
7
+ roleResponse: any;
8
+ }>;
9
+ //# sourceMappingURL=fetchUserPermissions.d.ts.map
@@ -0,0 +1,18 @@
1
+ /********************************************************************
2
+ * ADOBE CONFIDENTIAL
3
+ * __________________
4
+ *
5
+ * Copyright 2025 Adobe
6
+ * All Rights Reserved.
7
+ *
8
+ * NOTICE: All information contained herein is, and remains
9
+ * the property of Adobe and its suppliers, if any. The intellectual
10
+ * and technical concepts contained herein are proprietary to Adobe
11
+ * and its suppliers and are protected by all applicable intellectual
12
+ * property laws, including trade secret and copyright laws.
13
+ * Dissemination of this information or reproduction of this material
14
+ * is strictly forbidden unless prior written permission is obtained
15
+ * from Adobe.
16
+ *******************************************************************/
17
+ export { fetchUserPermissions } from './fetchUserPermissions';
18
+ //# sourceMappingURL=index.d.ts.map
@@ -1,5 +1,4 @@
1
1
  import { CompanyModel } from '../../data/models/company';
2
2
 
3
- export declare const resetCompanyCache: () => void;
4
- export declare const getCompany: (useCache?: boolean) => Promise<CompanyModel | null>;
3
+ export declare const getCompany: () => Promise<CompanyModel | null>;
5
4
  //# sourceMappingURL=getCompany.d.ts.map
@@ -17,6 +17,6 @@
17
17
  export declare const COMPANY_LEGAL_ADDRESS_FRAGMENT = "\n fragment COMPANY_LEGAL_ADDRESS_FRAGMENT on CompanyLegalAddress {\n street\n city\n region {\n region\n region_code\n region_id\n }\n country_code\n postcode\n telephone\n }\n";
18
18
  export declare const COMPANY_BASIC_INFO_FRAGMENT = "\n fragment COMPANY_BASIC_INFO_FRAGMENT on Company {\n id\n name\n email\n legal_name\n vat_tax_id\n reseller_id\n }\n";
19
19
  export declare const COMPANY_SALES_REPRESENTATIVE_FRAGMENT = "\n fragment COMPANY_SALES_REPRESENTATIVE_FRAGMENT on CompanySalesRepresentative {\n firstname\n lastname\n email\n }\n";
20
- export declare const COMPANY_ADMIN_FRAGMENT = "\n fragment COMPANY_ADMIN_FRAGMENT on Customer {\n id\n firstname\n lastname\n email\n job_title\n }\n";
20
+ export declare const COMPANY_ADMIN_FRAGMENT = "\n fragment COMPANY_ADMIN_FRAGMENT on Customer {\n firstname\n lastname\n email\n job_title\n }\n";
21
21
  export declare const COMPANY_FULL_FRAGMENT: string;
22
22
  //# sourceMappingURL=CompanyFragment.graphql.d.ts.map
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Builds a dynamic company query based on user permissions
3
+ */
4
+ export declare const buildCompanyQuery: (allowed: Set<string>) => string;
5
+ /**
6
+ * Builds a dynamic company update mutation based on user permissions
7
+ */
8
+ export declare const buildUpdateCompanyMutation: (allowed: Set<string>) => string;
9
+ //# sourceMappingURL=buildCompanyQueries.d.ts.map
package/api/index.d.ts CHANGED
@@ -16,6 +16,7 @@
16
16
  *******************************************************************/
17
17
  export * from './initialize';
18
18
  export * from './fetch-graphql';
19
+ export * from './fetchUserPermissions';
19
20
  export * from './checkIsCompanyEnabled';
20
21
  export * from './getCompany';
21
22
  export * from './updateCompany';
package/api.js CHANGED
@@ -1,4 +1,4 @@
1
1
  /*! Copyright 2025 Adobe
2
2
  All Rights Reserved. */
3
- import{v as e}from"./chunks/getCountries.js";import{f as i,a as m,e as l,g as y,c as h,r as d,s as u,b as C,d as f,u as b}from"./chunks/getCountries.js";import"@dropins/tools/event-bus.js";import"@dropins/tools/fetch-graphql.js";const n=async(a={})=>({success:!0,config:a}),o=async()=>{try{return await e("test@test.com"),{companyEnabled:!0}}catch{return{companyEnabled:!1,error:"Company functionality not available"}}};export{o as checkIsCompanyEnabled,i as fetchGraphQl,m as getCompany,l as getConfig,y as getCountries,n as initialize,h as removeFetchGraphQlHeader,d as resetCompanyCache,u as setEndpoint,C as setFetchGraphQlHeader,f as setFetchGraphQlHeaders,b as updateCompany,e as validateCompanyEmail};
3
+ import{v as e}from"./chunks/getCountries.js";import{f as p,e as m,a as l,d as h,g as y,r as d,s as u,b as f,c as C,u as b}from"./chunks/getCountries.js";import"@dropins/tools/event-bus.js";import"@dropins/tools/fetch-graphql.js";const n=async(a={})=>({success:!0,config:a}),o=async()=>{try{return await e("test@test.com"),{companyEnabled:!0}}catch{return{companyEnabled:!1,error:"Company functionality not available"}}};export{o as checkIsCompanyEnabled,p as fetchGraphQl,m as fetchUserPermissions,l as getCompany,h as getConfig,y as getCountries,n as initialize,d as removeFetchGraphQlHeader,u as setEndpoint,f as setFetchGraphQlHeader,C as setFetchGraphQlHeaders,b as updateCompany,e as validateCompanyEmail};
4
4
  //# sourceMappingURL=api.js.map
package/api.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"file":"api.js","sources":["/@dropins/storefront-company-management/src/api/initialize/initialize.ts","/@dropins/storefront-company-management/src/api/checkIsCompanyEnabled/checkIsCompanyEnabled.ts"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\n\nexport interface CompanyDropinConfig {\n langDefinitions?: Record<string, Record<string, string>>;\n models?: Record<string, any>;\n}\n\nexport const initialize = async (config: CompanyDropinConfig = {}) => {\n return {\n success: true,\n config,\n };\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { validateCompanyEmail } from '../validateCompanyEmail';\nimport { CheckIsCompanyEnabledResponse } from '../../types/api/checkIsCompanyEnabled.types';\n\nexport const checkIsCompanyEnabled = async (): Promise<CheckIsCompanyEnabledResponse> => {\n try {\n // Use validateCompanyEmail with a dummy email to check if Company functionality is available\n await validateCompanyEmail('test@test.com');\n \n // If the validation API works (regardless of email availability), Company functionality is enabled\n return {\n companyEnabled: true\n };\n } catch (error) {\n return {\n companyEnabled: false,\n error: 'Company functionality not available'\n };\n }\n};"],"names":["initialize","config","checkIsCompanyEnabled","validateCompanyEmail"],"mappings":"qOAuBO,MAAMA,EAAa,MAAOC,EAA8B,MACtD,CACL,QAAS,GACT,OAAAA,CAAA,GCPSC,EAAwB,SAAoD,CACvF,GAAI,CAEF,aAAMC,EAAqB,eAAe,EAGnC,CACL,eAAgB,EAAA,CAEpB,MAAgB,CACd,MAAO,CACL,eAAgB,GAChB,MAAO,qCAAA,CAEX,CACF"}
1
+ {"version":3,"file":"api.js","sources":["/@dropins/storefront-company-management/src/api/initialize/initialize.ts","/@dropins/storefront-company-management/src/api/checkIsCompanyEnabled/checkIsCompanyEnabled.ts"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\n// import { events } from '@adobe-commerce/event-bus';\n\n\nexport interface CompanyDropinConfig {\n langDefinitions?: Record<string, Record<string, string>>;\n models?: Record<string, any>;\n}\n\nexport const initialize = async (config: CompanyDropinConfig = {}) => {\n return {\n success: true,\n config,\n };\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { validateCompanyEmail } from '../validateCompanyEmail';\nimport { CheckIsCompanyEnabledResponse } from '../../types/api/checkIsCompanyEnabled.types';\n\nexport const checkIsCompanyEnabled = async (): Promise<CheckIsCompanyEnabledResponse> => {\n try {\n // Use validateCompanyEmail with a dummy email to check if Company functionality is available\n await validateCompanyEmail('test@test.com');\n \n // If the validation API works (regardless of email availability), Company functionality is enabled\n return {\n companyEnabled: true\n };\n } catch (error) {\n return {\n companyEnabled: false,\n error: 'Company functionality not available'\n };\n }\n};"],"names":["initialize","config","checkIsCompanyEnabled","validateCompanyEmail"],"mappings":"qOAyBO,MAAMA,EAAa,MAAOC,EAA8B,MACtD,CACL,QAAS,GACT,OAAAA,CAAA,GCTSC,EAAwB,SAAoD,CACvF,GAAI,CAEF,aAAMC,EAAqB,eAAe,EAGnC,CACL,eAAgB,EAAA,CAEpB,MAAgB,CACd,MAAO,CACL,eAAgB,GAChB,MAAO,qCAAA,CAEX,CACF"}
@@ -1,12 +1,6 @@
1
1
  /*! Copyright 2025 Adobe
2
2
  All Rights Reserved. */
3
- import{events as T}from"@dropins/tools/event-bus.js";import{FetchGraphQL as I}from"@dropins/tools/fetch-graphql.js";const{setEndpoint:U,setFetchGraphQlHeader:q,removeFetchGraphQlHeader:x,setFetchGraphQlHeaders:$,fetchGraphQl:p,getConfig:j}=new I().getMethods(),w=`
4
- query validateCompanyEmail($email: String!) {
5
- isCompanyEmailAvailable(email: $email) {
6
- is_email_available
7
- }
8
- }
9
- `,Q=async e=>{try{const a=await p(w,{variables:{email:e}});return a.errors?{isValid:!1,error:"Unable to validate email"}:{isValid:a.data.isCompanyEmailAvailable.is_email_available,error:a.data.isCompanyEmailAvailable.is_email_available?void 0:"This email is already used by another company"}}catch{return{isValid:!1,error:"Unable to validate email"}}},E=e=>{var A;if(!(e!=null&&e.data))throw new Error("Invalid response: missing data");const a="updateCompany"in e.data?(A=e.data.updateCompany)==null?void 0:A.company:e.data.company;if(!a)throw new Error("Invalid response: missing company data");const n="customer"in e.data?e.data.customer:void 0,o=a.legal_address?{street:Array.isArray(a.legal_address.street)?a.legal_address.street.filter(r=>r&&r.trim()!==""):[],city:(a.legal_address.city||"").trim(),region:a.legal_address.region?{region:(a.legal_address.region.region||"").trim(),regionCode:(a.legal_address.region.region_code||"").trim(),regionId:a.legal_address.region.region_id?Number(a.legal_address.region.region_id):0}:void 0,countryCode:(a.legal_address.country_code||"").toUpperCase().trim(),postcode:(a.legal_address.postcode||"").trim(),telephone:a.legal_address.telephone?a.legal_address.telephone.trim():void 0}:void 0,t=n==null?void 0:n.role,s=((r=[])=>{const m=new Set,g=[...r];for(;g.length;){const c=g.pop();if(c&&(typeof c.id=="string"&&m.add(c.id),Array.isArray(c.children)&&c.children.length))for(const h of c.children)g.push(h)}return m})((t==null?void 0:t.permissions)||[]),l=(t==null?void 0:t.id)==="0"||typeof(t==null?void 0:t.id)=="number"&&t.id===0||(t==null?void 0:t.name)==="Company Administrator",i={canViewAccount:l||s.has("Magento_Company::view_account"),canEditAccount:l||s.has("Magento_Company::edit_account"),canViewAddress:l||s.has("Magento_Company::view_address"),canEditAddress:l||s.has("Magento_Company::edit_address"),canViewContacts:l||s.has("Magento_Company::contacts"),canViewPaymentInformation:l||s.has("Magento_Company::payment_information"),canViewShippingInformation:l||s.has("Magento_Company::shipping_information")},d={id:(a.id||"").toString(),name:(a.name||"").trim(),email:(a.email||"").trim().toLowerCase(),legalName:a.legal_name?a.legal_name.trim():void 0,vatTaxId:a.vat_tax_id?a.vat_tax_id.trim():void 0,resellerId:a.reseller_id?a.reseller_id.trim():void 0,legalAddress:o,companyAdmin:a.company_admin?{id:(a.company_admin.id||"").toString(),firstname:(a.company_admin.firstname||"").trim(),lastname:(a.company_admin.lastname||"").trim(),email:(a.company_admin.email||"").trim().toLowerCase(),jobTitle:a.company_admin.job_title?a.company_admin.job_title.trim():void 0}:void 0,salesRepresentative:a.sales_representative?{firstname:(a.sales_representative.firstname||"").trim(),lastname:(a.sales_representative.lastname||"").trim(),email:(a.sales_representative.email||"").trim().toLowerCase()}:void 0,availablePaymentMethods:Array.isArray(a.available_payment_methods)?a.available_payment_methods.filter(r=>r&&typeof r.code=="string"&&typeof r.title=="string").map(r=>({code:r.code.trim(),title:r.title.trim()})).filter(r=>r.code.length>0&&r.title.length>0):void 0,availableShippingMethods:Array.isArray(a.available_shipping_methods)?a.available_shipping_methods.filter(r=>r&&typeof r.code=="string"&&typeof r.title=="string").map(r=>({code:r.code.trim(),title:r.title.trim()})).filter(r=>r.code.length>0&&r.title.length>0):void 0,canEditAccount:i.canEditAccount,canEditAddress:i.canEditAddress,permissionsFlags:i,customerRole:t,customerStatus:n==null?void 0:n.status};if(i.canViewAccount){if(!d.id)throw new Error("Company ID is required");if(!d.name)throw new Error("Company name is required");if(!d.email)throw new Error("Company email is required")}return d},O=e=>{var s,l;if(!((l=(s=e==null?void 0:e.data)==null?void 0:s.countries)!=null&&l.length))return{availableCountries:[],countriesWithRequiredRegion:[],optionalZipCountries:[]};const{countries:a,storeConfig:n}=e.data,o=n==null?void 0:n.countries_with_required_region.split(","),t=n==null?void 0:n.optional_zip_countries.split(",");return{availableCountries:a.filter(({two_letter_abbreviation:i,full_name_locale:d})=>!!(i&&d)).map(i=>{const{two_letter_abbreviation:d,full_name_locale:A,available_regions:r}=i,m=Array.isArray(r)&&r.length>0;return{value:d,text:A,availableRegions:m?r:void 0}}).sort((i,d)=>i.text.localeCompare(d.text)),countriesWithRequiredRegion:o,optionalZipCountries:t}},P=`
3
+ import{events as E}from"@dropins/tools/event-bus.js";import{FetchGraphQL as v}from"@dropins/tools/fetch-graphql.js";const{setEndpoint:D,setFetchGraphQlHeader:L,removeFetchGraphQlHeader:U,setFetchGraphQlHeaders:q,fetchGraphQl:c,getConfig:V}=new v().getMethods(),_=e=>{throw e instanceof DOMException&&e.name==="AbortError"||E.emit("error",{source:"company",type:"network",error:e}),e},g=e=>{const a=e.map(t=>t.message).join(" ");throw Error(a)},M=`
10
4
  query GET_CUSTOMER_ROLE_PERMISSIONS {
11
5
  customer {
12
6
  role {
@@ -29,7 +23,13 @@ import{events as T}from"@dropins/tools/event-bus.js";import{FetchGraphQL as I}fr
29
23
  status
30
24
  }
31
25
  }
32
- `,u=`
26
+ `,p=(e=[])=>{const a=new Set,t=[...e];for(;t.length;){const i=t.pop();if(i&&(typeof i.id=="string"&&a.add(i.id),Array.isArray(i.children)&&i.children.length))for(const r of i.children)t.push(r)}return a},h=e=>(e==null?void 0:e.id)==="0"||typeof(e==null?void 0:e.id)=="number"&&(e==null?void 0:e.id)===0||(e==null?void 0:e.name)==="Company Administrator",N=e=>{const a=p((e==null?void 0:e.permissions)||[]),t=h(e);return{canViewAccount:t||a.has("Magento_Company::view_account"),canEditAccount:t||a.has("Magento_Company::edit_account"),canViewAddress:t||a.has("Magento_Company::view_address"),canEditAddress:t||a.has("Magento_Company::edit_address"),canViewContacts:t||a.has("Magento_Company::contacts"),canViewPaymentInformation:t||a.has("Magento_Company::payment_information"),canViewShippingInformation:t||a.has("Magento_Company::shipping_information")}},A=async()=>await c(M,{method:"GET",cache:"no-cache"}).then(e=>{var r,d,o;if((r=e.errors)!=null&&r.length)return g(e.errors);const a=(o=(d=e==null?void 0:e.data)==null?void 0:d.customer)==null?void 0:o.role,t=p((a==null?void 0:a.permissions)||[]);return h(a)&&["Magento_Company::view_account","Magento_Company::edit_account","Magento_Company::view_address","Magento_Company::edit_address","Magento_Company::contacts","Magento_Company::payment_information","Magento_Company::shipping_information"].forEach(s=>t.add(s)),{allowedIds:t,roleResponse:e}}).catch(_),b=`
27
+ query validateCompanyEmail($email: String!) {
28
+ isCompanyEmailAvailable(email: $email) {
29
+ is_email_available
30
+ }
31
+ }
32
+ `,j=async e=>{try{const a=await c(b,{variables:{email:e}});return a.errors?{isValid:!1,error:"Unable to validate email"}:{isValid:a.data.isCompanyEmailAvailable.is_email_available,error:a.data.isCompanyEmailAvailable.is_email_available?void 0:"This email is already used by another company"}}catch{return{isValid:!1,error:"Unable to validate email"}}},u=e=>{var s;if(!(e!=null&&e.data))throw new Error("Invalid response: missing data");const a="updateCompany"in e.data?(s=e.data.updateCompany)==null?void 0:s.company:e.data.company;if(!a)throw new Error("Invalid response: missing company data");const t="customer"in e.data?e.data.customer:void 0,i=a.legal_address?{street:Array.isArray(a.legal_address.street)?a.legal_address.street.filter(n=>n&&n.trim()!==""):[],city:(a.legal_address.city||"").trim(),region:a.legal_address.region?{region:(a.legal_address.region.region||"").trim(),regionCode:(a.legal_address.region.region_code||"").trim(),regionId:a.legal_address.region.region_id?Number(a.legal_address.region.region_id):0}:void 0,countryCode:(a.legal_address.country_code||"").toUpperCase().trim(),postcode:(a.legal_address.postcode||"").trim(),telephone:a.legal_address.telephone?a.legal_address.telephone.trim():void 0}:void 0,r=t==null?void 0:t.role,d=N(r),o={id:(a.id||"").toString(),name:(a.name||"").trim(),email:(a.email||"").trim().toLowerCase(),legalName:a.legal_name?a.legal_name.trim():void 0,vatTaxId:a.vat_tax_id?a.vat_tax_id.trim():void 0,resellerId:a.reseller_id?a.reseller_id.trim():void 0,legalAddress:i,companyAdmin:a.company_admin?{id:(a.company_admin.id||"").toString(),firstname:(a.company_admin.firstname||"").trim(),lastname:(a.company_admin.lastname||"").trim(),email:(a.company_admin.email||"").trim().toLowerCase(),jobTitle:a.company_admin.job_title?a.company_admin.job_title.trim():void 0}:void 0,salesRepresentative:a.sales_representative?{firstname:(a.sales_representative.firstname||"").trim(),lastname:(a.sales_representative.lastname||"").trim(),email:(a.sales_representative.email||"").trim().toLowerCase()}:void 0,availablePaymentMethods:Array.isArray(a.available_payment_methods)?a.available_payment_methods.filter(n=>n&&typeof n.code=="string"&&typeof n.title=="string").map(n=>({code:n.code.trim(),title:n.title.trim()})).filter(n=>n.code.length>0&&n.title.length>0):void 0,availableShippingMethods:Array.isArray(a.available_shipping_methods)?a.available_shipping_methods.filter(n=>n&&typeof n.code=="string"&&typeof n.title=="string").map(n=>({code:n.code.trim(),title:n.title.trim()})).filter(n=>n.code.length>0&&n.title.length>0):void 0,canEditAccount:d.canEditAccount,canEditAddress:d.canEditAddress,permissionsFlags:d,customerRole:r,customerStatus:t==null?void 0:t.status};if(d.canViewAccount){if(!o.id)throw new Error("Company ID is required");if(!o.name)throw new Error("Company name is required");if(!o.email)throw new Error("Company email is required")}return o},w=e=>{var o,s;if(!((s=(o=e==null?void 0:e.data)==null?void 0:o.countries)!=null&&s.length))return{availableCountries:[],countriesWithRequiredRegion:[],optionalZipCountries:[]};const{countries:a,storeConfig:t}=e.data,i=t==null?void 0:t.countries_with_required_region.split(","),r=t==null?void 0:t.optional_zip_countries.split(",");return{availableCountries:a.filter(({two_letter_abbreviation:n,full_name_locale:m})=>!!(n&&m)).map(n=>{const{two_letter_abbreviation:m,full_name_locale:l,available_regions:y}=n,f=Array.isArray(y)&&y.length>0;return{value:m,text:l,availableRegions:f?y:void 0}}).sort((n,m)=>n.text.localeCompare(m.text)),countriesWithRequiredRegion:i,optionalZipCountries:r}},I=`
33
33
  fragment COMPANY_LEGAL_ADDRESS_FRAGMENT on CompanyLegalAddress {
34
34
  street
35
35
  city
@@ -42,7 +42,7 @@ import{events as T}from"@dropins/tools/event-bus.js";import{FetchGraphQL as I}fr
42
42
  postcode
43
43
  telephone
44
44
  }
45
- `,v=`
45
+ `,S=`
46
46
  fragment COMPANY_BASIC_INFO_FRAGMENT on Company {
47
47
  id
48
48
  name
@@ -51,68 +51,50 @@ import{events as T}from"@dropins/tools/event-bus.js";import{FetchGraphQL as I}fr
51
51
  vat_tax_id
52
52
  reseller_id
53
53
  }
54
- `,M=`
54
+ `,T=`
55
55
  fragment COMPANY_SALES_REPRESENTATIVE_FRAGMENT on CompanySalesRepresentative {
56
56
  firstname
57
57
  lastname
58
58
  email
59
59
  }
60
- `,N=`
60
+ `,O=`
61
61
  fragment COMPANY_ADMIN_FRAGMENT on Customer {
62
- id
63
62
  firstname
64
63
  lastname
65
64
  email
66
65
  job_title
67
66
  }
68
- `,G=`
69
- fragment COMPANY_FULL_FRAGMENT on Company {
70
- ...COMPANY_BASIC_INFO_FRAGMENT
71
- legal_address {
72
- ...COMPANY_LEGAL_ADDRESS_FRAGMENT
73
- }
74
- company_admin {
75
- ...COMPANY_ADMIN_FRAGMENT
76
- }
77
- sales_representative {
78
- ...COMPANY_SALES_REPRESENTATIVE_FRAGMENT
79
- }
80
- available_payment_methods {
81
- code
82
- title
83
- }
84
- available_shipping_methods {
85
- code
86
- title
87
- }
88
- }
89
- ${v}
90
- ${u}
91
- ${N}
92
- ${M}
93
- `,R=(e=[])=>{const a=new Set,n=[...e];for(;n.length;){const o=n.pop();if(o&&(typeof o.id=="string"&&a.add(o.id),Array.isArray(o.children)&&o.children.length))for(const t of o.children)n.push(t)}return a},F=e=>{const a=e.has("Magento_Company::view_account"),n=e.has("Magento_Company::view_address"),o=e.has("Magento_Company::contacts"),t=e.has("Magento_Company::payment_information"),_=e.has("Magento_Company::shipping_information"),s=[...a?["...COMPANY_BASIC_INFO_FRAGMENT"]:[]];if(n&&s.push("legal_address { ...COMPANY_LEGAL_ADDRESS_FRAGMENT }"),o&&(s.push("company_admin { ...COMPANY_ADMIN_FRAGMENT }"),s.push("sales_representative { ...COMPANY_SALES_REPRESENTATIVE_FRAGMENT }")),t&&s.push("available_payment_methods { code title }"),_&&s.push("available_shipping_methods { code title }"),s.length===0)return`
67
+ `,C=e=>{const a=e.has("Magento_Company::view_account"),t=e.has("Magento_Company::view_address"),i=e.has("Magento_Company::contacts"),r=e.has("Magento_Company::payment_information"),d=e.has("Magento_Company::shipping_information"),o=[],s=[];return a&&(o.push("...COMPANY_BASIC_INFO_FRAGMENT"),s.push(S)),t&&(o.push("legal_address { ...COMPANY_LEGAL_ADDRESS_FRAGMENT }"),s.push(I)),i&&(o.push("company_admin { ...COMPANY_ADMIN_FRAGMENT }"),o.push("sales_representative { ...COMPANY_SALES_REPRESENTATIVE_FRAGMENT }"),s.push(O),s.push(T)),r&&o.push("available_payment_methods { code title }"),d&&o.push("available_shipping_methods { code title }"),{fields:o,usedFragments:s}},P=e=>{const{fields:a,usedFragments:t}=C(e);return a.length===0?`
94
68
  query GET_COMPANY_DYNAMIC {
95
69
  company { __typename }
96
70
  }
97
- `;const l=`
71
+ `:`${`
98
72
  query GET_COMPANY_DYNAMIC {
99
73
  company {
100
- ${s.join(`
74
+ ${a.join(`
101
75
  `)}
102
76
  }
103
77
  }
104
- `,i=a?[v]:[];return s.some(d=>d.startsWith("legal_address"))&&i.push(u),s.some(d=>d.startsWith("company_admin"))&&i.push(N),s.some(d=>d.startsWith("sales_representative"))&&i.push(M),`${l}
105
- ${i.join(`
106
- `)}`};let y=null,f=null;const k=()=>{f=null},B=async(e=!0)=>e&&f?f:y||(y=(async()=>{var a,n,o,t,_,s;try{const l=await p(P,{method:"GET",cache:"no-cache"});if((a=l.errors)!=null&&a.length)return null;const i=(o=(n=l==null?void 0:l.data)==null?void 0:n.customer)==null?void 0:o.role,d=R((i==null?void 0:i.permissions)||[]);((i==null?void 0:i.id)==="0"||typeof(i==null?void 0:i.id)=="number"&&(i==null?void 0:i.id)===0||(i==null?void 0:i.name)==="Company Administrator")&&["Magento_Company::view_account","Magento_Company::view_address","Magento_Company::contacts","Magento_Company::payment_information","Magento_Company::shipping_information"].forEach(C=>d.add(C));const r=F(d),m=await p(r,{method:"GET",cache:"no-cache"});if((t=m.errors)!=null&&t.length)return null;const g=(_=m==null?void 0:m.data)==null?void 0:_.company;if(!(g&&Object.keys(g).some(C=>C!=="__typename")))return null;m.data.customer=(s=l==null?void 0:l.data)==null?void 0:s.customer;const h=E(m);return f=h,h}catch{return null}finally{y=null}})(),y),S=e=>{throw e instanceof DOMException&&e.name==="AbortError"||T.emit("error",{source:"company",type:"network",error:e}),e},b=e=>{const a=e.map(n=>n.message).join(" ");throw Error(a)},Y=`
107
- mutation UPDATE_COMPANY($input: CompanyUpdateInput!) {
108
- updateCompany(input: $input) {
109
- company {
110
- ...COMPANY_FULL_FRAGMENT
78
+ `}
79
+ ${t.join(`
80
+ `)}`},G=e=>{const{fields:a,usedFragments:t}=C(e);return a.length===0?`
81
+ mutation UPDATE_COMPANY_DYNAMIC($input: CompanyUpdateInput!) {
82
+ updateCompany(input: $input) {
83
+ company { __typename }
84
+ }
85
+ }
86
+ `:`${`
87
+ mutation UPDATE_COMPANY_DYNAMIC($input: CompanyUpdateInput!) {
88
+ updateCompany(input: $input) {
89
+ company {
90
+ ${a.join(`
91
+ `)}
92
+ }
111
93
  }
112
94
  }
113
- }
114
- ${G}
115
- `,W=async e=>{const a={};if(e.name!==void 0&&(a.company_name=e.name),e.email!==void 0&&(a.company_email=e.email),e.legalName!==void 0&&(a.legal_name=e.legalName),e.vatTaxId!==void 0&&(a.vat_tax_id=e.vatTaxId),e.resellerId!==void 0&&(a.reseller_id=e.resellerId),e.legalAddress!==void 0){let n;Array.isArray(e.legalAddress.street)?(n=[...e.legalAddress.street],e.legalAddress.street2&&n.push(e.legalAddress.street2)):n=[e.legalAddress.street,e.legalAddress.street2].filter(t=>typeof t=="string"&&t.trim().length>0),n=n.filter(t=>t&&typeof t=="string"&&t.trim().length>0);let o;if(e.legalAddress.region&&typeof e.legalAddress.region=="object"){const t=e.legalAddress.region;t.region===t.regionCode?o={region:t.region,region_code:t.regionCode,region_id:0}:o={region:t.region,region_code:t.regionCode}}else e.legalAddress.regionCode&&e.legalAddress.region!==e.legalAddress.regionCode?o={region:e.legalAddress.region||e.legalAddress.regionCode,region_code:e.legalAddress.regionCode}:e.legalAddress.region&&(o={region:e.legalAddress.region,region_code:e.legalAddress.region,region_id:0});a.legal_address={street:n,city:e.legalAddress.city,region:o,country_id:e.legalAddress.countryCode,postcode:e.legalAddress.postcode,telephone:e.legalAddress.telephone}}return await p(Y,{method:"POST",variables:{input:a}}).then(n=>{var o;return(o=n.errors)!=null&&o.length?b(n.errors):E(n)}).catch(S)},L=`
95
+ `}
96
+ ${t.join(`
97
+ `)}`},x=async()=>await A().then(async({allowedIds:e,roleResponse:a})=>{var o,s,n;const t=P(e),i=await c(t,{method:"GET",cache:"no-cache"});if((o=i.errors)!=null&&o.length)return g(i.errors);const r=(s=i==null?void 0:i.data)==null?void 0:s.company;return r&&Object.keys(r).some(m=>m!=="__typename")?(i.data.customer=(n=a==null?void 0:a.data)==null?void 0:n.customer,u(i)):null}).catch(_),$=async e=>await A().then(async({allowedIds:a,roleResponse:t})=>{var o,s;const i=G(a),r={};if(e.name!==void 0&&(r.company_name=e.name),e.email!==void 0&&(r.company_email=e.email),e.legalName!==void 0&&(r.legal_name=e.legalName),e.vatTaxId!==void 0&&(r.vat_tax_id=e.vatTaxId),e.resellerId!==void 0&&(r.reseller_id=e.resellerId),e.legalAddress!==void 0&&a.has("Magento_Company::edit_address")){let n;Array.isArray(e.legalAddress.street)?(n=[...e.legalAddress.street],e.legalAddress.street2&&n.push(e.legalAddress.street2)):n=[e.legalAddress.street,e.legalAddress.street2].filter(l=>typeof l=="string"&&l.trim().length>0),n=n.filter(l=>l&&typeof l=="string"&&l.trim().length>0);let m;if(e.legalAddress.region&&typeof e.legalAddress.region=="object"){const l=e.legalAddress.region;l.region===l.regionCode?m={region:l.region,region_code:l.regionCode,region_id:0}:m={region:l.region,region_code:l.regionCode}}else e.legalAddress.regionCode&&e.legalAddress.region!==e.legalAddress.regionCode?m={region:e.legalAddress.region||e.legalAddress.regionCode,region_code:e.legalAddress.regionCode}:e.legalAddress.region&&(m={region:e.legalAddress.region,region_code:e.legalAddress.region,region_id:0});r.legal_address={street:n,city:e.legalAddress.city,region:m,country_id:e.legalAddress.countryCode,postcode:e.legalAddress.postcode,telephone:e.legalAddress.telephone}}const d=await c(i,{method:"POST",variables:{input:r}});return(o=d.errors)!=null&&o.length?g(d.errors):(d.data.customer=(s=t==null?void 0:t.data)==null?void 0:s.customer,u(d))}).catch(_),F=`
116
98
  query getCountries {
117
99
  countries {
118
100
  id
@@ -131,5 +113,5 @@ ${i.join(`
131
113
  optional_zip_countries
132
114
  }
133
115
  }
134
- `,H=async()=>{const e="_company_countries",a=sessionStorage.getItem(e);return a?JSON.parse(a):await p(L,{method:"GET"}).then(n=>{var t;if((t=n.errors)!=null&&t.length)return b(n.errors);const o=O(n);return sessionStorage.setItem(e,JSON.stringify(o)),o}).catch(S)};export{B as a,q as b,x as c,$ as d,j as e,p as f,H as g,k as r,U as s,W as u,Q as v};
116
+ `,Q=async()=>{const e="_company_countries",a=sessionStorage.getItem(e);return a?JSON.parse(a):await c(F,{method:"GET"}).then(t=>{var r;if((r=t.errors)!=null&&r.length)return g(t.errors);const i=w(t);return sessionStorage.setItem(e,JSON.stringify(i)),i}).catch(_)};export{x as a,L as b,q as c,V as d,A as e,c as f,Q as g,U as r,D as s,$ as u,j as v};
135
117
  //# sourceMappingURL=getCountries.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"getCountries.js","sources":["/@dropins/storefront-company-management/src/api/fetch-graphql/fetch-graphql.ts","/@dropins/storefront-company-management/src/api/validateCompanyEmail/graphql/validateCompanyEmail.graphql.ts","/@dropins/storefront-company-management/src/api/validateCompanyEmail/validateCompanyEmail.ts","/@dropins/storefront-company-management/src/data/transforms/transform-company.ts","/@dropins/storefront-company-management/src/data/transforms/transform-countries.ts","/@dropins/storefront-company-management/src/api/getCompany/graphql/getCustomerRole.graphql.ts","/@dropins/storefront-company-management/src/api/graphql/CompanyFragment.graphql.ts","/@dropins/storefront-company-management/src/api/getCompany/getCompany.ts","/@dropins/storefront-company-management/src/lib/network-error.ts","/@dropins/storefront-company-management/src/lib/fetch-error.ts","/@dropins/storefront-company-management/src/api/updateCompany/graphql/updateCompany.graphql.ts","/@dropins/storefront-company-management/src/api/updateCompany/updateCompany.ts","/@dropins/storefront-company-management/src/api/getCountries/graphql/getCountries.graphql.ts","/@dropins/storefront-company-management/src/api/getCountries/getCountries.ts"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\n\nimport { FetchGraphQL } from '@adobe-commerce/fetch-graphql';\n\nexport const {\n setEndpoint,\n setFetchGraphQlHeader,\n removeFetchGraphQlHeader,\n setFetchGraphQlHeaders,\n fetchGraphQl,\n getConfig,\n} = new FetchGraphQL().getMethods();\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const VALIDATE_COMPANY_EMAIL_QUERY = /* GraphQL */ `\n query validateCompanyEmail($email: String!) {\n isCompanyEmailAvailable(email: $email) {\n is_email_available\n }\n }\n`;","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { VALIDATE_COMPANY_EMAIL_QUERY } from './graphql/validateCompanyEmail.graphql';\nimport { ValidateCompanyEmailQuery, ValidateCompanyEmailResponse } from '../../types/api/validateCompanyEmail.types';\n\nexport const validateCompanyEmail = async (email: string): Promise<ValidateCompanyEmailResponse> => {\n try {\n const response = await fetchGraphQl<ValidateCompanyEmailQuery>(VALIDATE_COMPANY_EMAIL_QUERY, {\n variables: { email },\n });\n\n if (response.errors) {\n return {\n isValid: false,\n error: 'Unable to validate email'\n };\n }\n\n return {\n isValid: response.data.isCompanyEmailAvailable.is_email_available,\n error: response.data.isCompanyEmailAvailable.is_email_available \n ? undefined \n : 'This email is already used by another company'\n };\n } catch (error) {\n return {\n isValid: false,\n error: 'Unable to validate email'\n };\n }\n};","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { getCompanyResponse } from '../../types/api/getCompany.types';\nimport { updateCompanyResponse } from '../../types/api/updateCompany.types';\nimport { CompanyModel } from '../models/company';\n\nexport const transformCompany = (\n response: getCompanyResponse | updateCompanyResponse\n): CompanyModel => {\n // Validate response structure\n if (!response?.data) {\n throw new Error('Invalid response: missing data');\n }\n\n // Handle both getCompany and updateCompany response structures\n const companyData: any = 'updateCompany' in response.data \n ? response.data.updateCompany?.company \n : response.data.company;\n \n if (!companyData) {\n throw new Error('Invalid response: missing company data');\n }\n \n const customerData = 'customer' in response.data ? response.data.customer : undefined;\n\n // Transform legal address with validation\n const legalAddress = companyData.legal_address ? {\n street: Array.isArray(companyData.legal_address.street) \n ? companyData.legal_address.street.filter((line: string) => line && line.trim() !== '') \n : [],\n city: (companyData.legal_address.city || '').trim(),\n region: companyData.legal_address.region ? {\n region: (companyData.legal_address.region.region || '').trim(),\n regionCode: (companyData.legal_address.region.region_code || '').trim(),\n regionId: companyData.legal_address.region.region_id ? Number(companyData.legal_address.region.region_id) : 0,\n } : undefined,\n countryCode: (companyData.legal_address.country_code || '').toUpperCase().trim(),\n postcode: (companyData.legal_address.postcode || '').trim(),\n telephone: companyData.legal_address.telephone ? \n companyData.legal_address.telephone.trim() : undefined,\n } : undefined;\n\n // Determine permissions\n const customerRole = customerData?.role;\n const flattenPermissionIds = (nodes: any[] = []): Set<string> => {\n const set = new Set<string>();\n const stack = [...nodes];\n while (stack.length) {\n const node = stack.pop();\n if (!node) continue;\n if (typeof node.id === 'string') set.add(node.id);\n if (Array.isArray(node.children) && node.children.length) {\n for (const child of node.children) stack.push(child);\n }\n }\n return set;\n };\n\n const allowedIds = flattenPermissionIds(customerRole?.permissions || []);\n const isAdmin = customerRole?.id === '0' ||\n (typeof customerRole?.id === 'number' && customerRole.id === 0) ||\n customerRole?.name === 'Company Administrator';\n\n const permissionsFlags = {\n canViewAccount: isAdmin || allowedIds.has('Magento_Company::view_account'),\n canEditAccount: isAdmin || allowedIds.has('Magento_Company::edit_account'),\n canViewAddress: isAdmin || allowedIds.has('Magento_Company::view_address'),\n canEditAddress: isAdmin || allowedIds.has('Magento_Company::edit_address'),\n canViewContacts: isAdmin || allowedIds.has('Magento_Company::contacts'),\n canViewPaymentInformation: isAdmin || allowedIds.has('Magento_Company::payment_information'),\n canViewShippingInformation: isAdmin || allowedIds.has('Magento_Company::shipping_information'),\n } as const;\n\n // Build the model with proper validation\n const model: CompanyModel = {\n id: (companyData.id || '').toString(),\n name: (companyData.name || '').trim(),\n email: (companyData.email || '').trim().toLowerCase(),\n legalName: companyData.legal_name ? companyData.legal_name.trim() : undefined,\n vatTaxId: companyData.vat_tax_id ? companyData.vat_tax_id.trim() : undefined,\n resellerId: companyData.reseller_id ? companyData.reseller_id.trim() : undefined,\n legalAddress,\n companyAdmin: companyData.company_admin ? {\n id: (companyData.company_admin.id || '').toString(),\n firstname: (companyData.company_admin.firstname || '').trim(),\n lastname: (companyData.company_admin.lastname || '').trim(),\n email: (companyData.company_admin.email || '').trim().toLowerCase(),\n jobTitle: companyData.company_admin.job_title ? companyData.company_admin.job_title.trim() : undefined,\n } : undefined,\n\n // Transform sales representative\n salesRepresentative: companyData.sales_representative ? {\n firstname: (companyData.sales_representative.firstname || '').trim(),\n lastname: (companyData.sales_representative.lastname || '').trim(),\n email: (companyData.sales_representative.email || '').trim().toLowerCase(),\n } : undefined,\n\n // New comprehensive payment methods with code and title\n availablePaymentMethods: Array.isArray(companyData.available_payment_methods)\n ? companyData.available_payment_methods\n .filter((m: any) => m && typeof m.code === 'string' && typeof m.title === 'string')\n .map((m: any) => ({ code: m.code.trim(), title: m.title.trim() }))\n .filter((m: any) => m.code.length > 0 && m.title.length > 0)\n : undefined,\n\n // New available shipping methods\n availableShippingMethods: Array.isArray(companyData.available_shipping_methods)\n ? companyData.available_shipping_methods\n .filter((m: any) => m && typeof m.code === 'string' && typeof m.title === 'string')\n .map((m: any) => ({ code: m.code.trim(), title: m.title.trim() }))\n .filter((m: any) => m.code.length > 0 && m.title.length > 0)\n : undefined,\n \n // Computed permission flags (single source of truth)\n canEditAccount: permissionsFlags.canEditAccount,\n canEditAddress: permissionsFlags.canEditAddress,\n permissionsFlags,\n customerRole,\n customerStatus: customerData?.status,\n };\n\n // Validate only when profile fields are permitted\n if (permissionsFlags.canViewAccount) {\n if (!model.id) {\n throw new Error('Company ID is required');\n }\n if (!model.name) {\n throw new Error('Company name is required');\n }\n if (!model.email) {\n throw new Error('Company email is required');\n }\n }\n\n return model;\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { CountriesFormResponse } from '../../types/api/getCountries.types';\nimport { Country } from '../models/country';\n\nexport const transformCountries = (\n response: CountriesFormResponse\n): {\n availableCountries: Country[] | [];\n countriesWithRequiredRegion: string[];\n optionalZipCountries: string[];\n} => {\n if (!response?.data?.countries?.length) {\n return {\n availableCountries: [],\n countriesWithRequiredRegion: [],\n optionalZipCountries: [],\n };\n }\n\n const { countries, storeConfig } = response.data;\n\n const countriesWithRequiredRegion =\n storeConfig?.countries_with_required_region.split(',');\n const optionalZipCountries = storeConfig?.optional_zip_countries.split(',');\n\n const availableCountries = countries\n .filter(({ two_letter_abbreviation, full_name_locale }) =>\n Boolean(two_letter_abbreviation && full_name_locale)\n )\n .map((country) => {\n const { two_letter_abbreviation, full_name_locale, available_regions } = country;\n\n const hasRegions = Array.isArray(available_regions) && available_regions.length > 0;\n return {\n value: two_letter_abbreviation,\n text: full_name_locale,\n availableRegions: hasRegions ? available_regions : undefined,\n };\n })\n .sort((a, b) => a.text.localeCompare(b.text));\n\n return {\n availableCountries,\n countriesWithRequiredRegion,\n optionalZipCountries,\n };\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const GET_CUSTOMER_ROLE_PERMISSIONS = /* GraphQL */ `\n query GET_CUSTOMER_ROLE_PERMISSIONS {\n customer {\n role {\n id\n name\n permissions {\n id\n children {\n id\n children {\n id\n children {\n id\n children { id }\n }\n }\n }\n }\n }\n status\n }\n }\n`;\n\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const COMPANY_LEGAL_ADDRESS_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_LEGAL_ADDRESS_FRAGMENT on CompanyLegalAddress {\n street\n city\n region {\n region\n region_code\n region_id\n }\n country_code\n postcode\n telephone\n }\n`;\n\nexport const COMPANY_BASIC_INFO_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_BASIC_INFO_FRAGMENT on Company {\n id\n name\n email\n legal_name\n vat_tax_id\n reseller_id\n }\n`;\n\nexport const COMPANY_SALES_REPRESENTATIVE_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_SALES_REPRESENTATIVE_FRAGMENT on CompanySalesRepresentative {\n firstname\n lastname\n email\n }\n`;\n\nexport const COMPANY_ADMIN_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_ADMIN_FRAGMENT on Customer {\n id\n firstname\n lastname\n email\n job_title\n }\n`;\n\nexport const COMPANY_FULL_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_FULL_FRAGMENT on Company {\n ...COMPANY_BASIC_INFO_FRAGMENT\n legal_address {\n ...COMPANY_LEGAL_ADDRESS_FRAGMENT\n }\n company_admin {\n ...COMPANY_ADMIN_FRAGMENT\n }\n sales_representative {\n ...COMPANY_SALES_REPRESENTATIVE_FRAGMENT\n }\n available_payment_methods {\n code\n title\n }\n available_shipping_methods {\n code\n title\n }\n }\n ${COMPANY_BASIC_INFO_FRAGMENT}\n ${COMPANY_LEGAL_ADDRESS_FRAGMENT}\n ${COMPANY_ADMIN_FRAGMENT}\n ${COMPANY_SALES_REPRESENTATIVE_FRAGMENT}\n`;\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { transformCompany } from '../../data/transforms';\nimport { CompanyModel } from '../../data/models/company';\nimport { getCompanyResponse } from '../../types/api/getCompany.types';\nimport { GET_CUSTOMER_ROLE_PERMISSIONS } from './graphql/getCustomerRole.graphql';\nimport {\n COMPANY_BASIC_INFO_FRAGMENT,\n COMPANY_LEGAL_ADDRESS_FRAGMENT,\n COMPANY_ADMIN_FRAGMENT,\n COMPANY_SALES_REPRESENTATIVE_FRAGMENT,\n} from '../graphql/CompanyFragment.graphql';\n\nconst flattenIds = (nodes: any[] = []): Set<string> => {\n const set = new Set<string>();\n const stack = [...nodes];\n while (stack.length) {\n const node = stack.pop();\n if (!node) continue;\n if (typeof node.id === 'string') set.add(node.id);\n if (Array.isArray(node.children) && node.children.length) {\n for (const child of node.children) stack.push(child);\n }\n }\n return set;\n};\n\nconst buildCompanyQuery = (allowed: Set<string>): string => {\n const wantProfile = allowed.has('Magento_Company::view_account');\n const wantAddress = allowed.has('Magento_Company::view_address');\n const wantContacts = allowed.has('Magento_Company::contacts');\n const wantPayment = allowed.has('Magento_Company::payment_information');\n const wantShipping = allowed.has('Magento_Company::shipping_information');\n\n const fields: string[] = [\n ...(wantProfile ? ['...COMPANY_BASIC_INFO_FRAGMENT'] : []),\n ];\n\n if (wantAddress) {\n fields.push(`legal_address { ...COMPANY_LEGAL_ADDRESS_FRAGMENT }`);\n }\n if (wantContacts) {\n fields.push(`company_admin { ...COMPANY_ADMIN_FRAGMENT }`);\n fields.push(`sales_representative { ...COMPANY_SALES_REPRESENTATIVE_FRAGMENT }`);\n }\n if (wantPayment) {\n fields.push(`available_payment_methods { code title }`);\n }\n if (wantShipping) {\n fields.push(`available_shipping_methods { code title }`);\n }\n\n // If no allowed company fields, still query company with __typename to keep response shape\n if (fields.length === 0) {\n return `\n query GET_COMPANY_DYNAMIC {\n company { __typename }\n }\n `;\n }\n\n const query = `\n query GET_COMPANY_DYNAMIC {\n company {\n ${fields.join('\\n ')}\n }\n }\n `;\n\n const usedFragments: string[] = wantProfile ? [COMPANY_BASIC_INFO_FRAGMENT] : [];\n if (fields.some((f) => f.startsWith('legal_address'))) usedFragments.push(COMPANY_LEGAL_ADDRESS_FRAGMENT);\n if (fields.some((f) => f.startsWith('company_admin'))) usedFragments.push(COMPANY_ADMIN_FRAGMENT);\n if (fields.some((f) => f.startsWith('sales_representative'))) usedFragments.push(COMPANY_SALES_REPRESENTATIVE_FRAGMENT);\n\n return `${query}\\n${usedFragments.join('\\n')}`;\n};\n\n// Prevent duplicate, concurrent requests across re-mounts (e.g., dev StrictMode)\nlet inflightGetCompany: Promise<CompanyModel | null> | null = null;\nlet cachedCompany: CompanyModel | null = null;\n\nexport const resetCompanyCache = (): void => {\n cachedCompany = null;\n};\n\nexport const getCompany = async (useCache: boolean = true): Promise<CompanyModel | null> => {\n if (useCache && cachedCompany) {\n return cachedCompany;\n }\n if (inflightGetCompany) {\n return inflightGetCompany;\n }\n\n inflightGetCompany = (async () => {\n try {\n // Step 1: fetch role permissions to know which fields are allowed\n const roleResponse: any = await fetchGraphQl(GET_CUSTOMER_ROLE_PERMISSIONS, { method: 'GET', cache: 'no-cache' });\n if (roleResponse.errors?.length) return null;\n\n const role = roleResponse?.data?.customer?.role;\n const allowedIds = flattenIds(role?.permissions || []);\n // Treat Company Administrator as having all view permissions even if the permissions tree is empty\n const isAdmin = role?.id === '0' || (typeof role?.id === 'number' && role?.id === 0) || role?.name === 'Company Administrator';\n if (isAdmin) {\n [\n 'Magento_Company::view_account',\n 'Magento_Company::view_address',\n 'Magento_Company::contacts',\n 'Magento_Company::payment_information',\n 'Magento_Company::shipping_information',\n ].forEach((id) => allowedIds.add(id));\n }\n\n // Step 2: build a company query that requests only allowed fields\n const GET_COMPANY_DYNAMIC = buildCompanyQuery(allowedIds);\n\n // Step 3: fetch company with dynamic selection\n const companyResponse: getCompanyResponse = await fetchGraphQl(GET_COMPANY_DYNAMIC, { method: 'GET', cache: 'no-cache' });\n if (companyResponse.errors?.length) return null;\n\n const companyNode: any = companyResponse?.data?.company;\n const hasAnyCompanyField = companyNode && Object.keys(companyNode).some((k) => k !== '__typename');\n if (!hasAnyCompanyField) {\n return null;\n }\n\n // Merge back minimal customer role info so transform can compute flags\n (companyResponse as any).data.customer = roleResponse?.data?.customer;\n\n const result = transformCompany(companyResponse);\n cachedCompany = result;\n return result;\n } catch (e) {\n return null;\n } finally {\n // Release inflight handle; subsequent calls can run again\n inflightGetCompany = null;\n }\n })();\n\n return inflightGetCompany;\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { events } from '@adobe-commerce/event-bus';\n\n/**\n * A function which can be attached to fetchGraphQL to handle thrown errors in\n * a generic way.\n */\nexport const handleNetworkError = (error: Error) => {\n const isAbortError =\n error instanceof DOMException && error.name === 'AbortError';\n\n if (!isAbortError) {\n // @ts-ignore\n events.emit('error', {\n source: 'company',\n type: 'network',\n error,\n });\n }\n throw error;\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n/** Actions */\nexport const handleFetchError = (errors: Array<{ message: string }>) => {\n const errorMessage = errors.map((e: any) => e.message).join(' ');\n\n throw Error(errorMessage);\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { COMPANY_FULL_FRAGMENT } from '../../graphql/CompanyFragment.graphql';\n\nexport const UPDATE_COMPANY = /* GraphQL */ `\n mutation UPDATE_COMPANY($input: CompanyUpdateInput!) {\n updateCompany(input: $input) {\n company {\n ...COMPANY_FULL_FRAGMENT\n }\n }\n }\n ${COMPANY_FULL_FRAGMENT}\n`;\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { handleNetworkError } from '../../lib/network-error';\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { handleFetchError } from '../../lib/fetch-error';\nimport { UPDATE_COMPANY } from './graphql/updateCompany.graphql';\nimport { transformCompany } from '../../data/transforms';\nimport { CompanyModel } from '../../data/models/company';\nimport { updateCompanyResponse, UpdateCompanyDto } from '../../types';\n\nexport const updateCompany = async (input: UpdateCompanyDto): Promise<CompanyModel> => {\n // Transform field names to match GraphQL schema expectations\n const transformedInput: Record<string, unknown> = {};\n \n // Map frontend field names to GraphQL schema field names\n if (input.name !== undefined) {\n transformedInput.company_name = input.name;\n }\n if (input.email !== undefined) {\n transformedInput.company_email = input.email;\n }\n if (input.legalName !== undefined) {\n transformedInput.legal_name = input.legalName;\n }\n if (input.vatTaxId !== undefined) {\n transformedInput.vat_tax_id = input.vatTaxId;\n }\n if (input.resellerId !== undefined) {\n transformedInput.reseller_id = input.resellerId;\n }\n \n // Transform legal address\n if (input.legalAddress !== undefined) {\n // Handle street field - ensure it's always a flat array of strings\n let streetArray: string[];\n if (Array.isArray(input.legalAddress.street)) {\n // If street is already an array, use it directly and add street_2 if present\n streetArray = [...input.legalAddress.street];\n if (input.legalAddress.street2) {\n streetArray.push(input.legalAddress.street2);\n }\n } else {\n // If street is a string, create array normally with type guard\n streetArray = [input.legalAddress.street, input.legalAddress.street2].filter(\n (s): s is string => typeof s === 'string' && s.trim().length > 0\n );\n }\n \n // Remove any empty strings and ensure all elements are strings\n streetArray = streetArray.filter(street => street && typeof street === 'string' && street.trim().length > 0);\n \n // Handle region - different approaches for dropdown vs custom regions\n let regionValue: { region: string; region_code: string; region_id?: number } | undefined;\n if (input.legalAddress.region && typeof input.legalAddress.region === 'object') {\n const regionObj = input.legalAddress.region;\n \n // Check if this is a custom region (region === regionCode) or predefined region\n if (regionObj.region === regionObj.regionCode) {\n // Custom region - send as object with region_id: 0\n regionValue = {\n region: regionObj.region,\n region_code: regionObj.regionCode,\n region_id: 0\n };\n } else {\n // Predefined region - send as object\n regionValue = {\n region: regionObj.region,\n region_code: regionObj.regionCode,\n };\n }\n } else if (input.legalAddress.regionCode && input.legalAddress.region !== input.legalAddress.regionCode) {\n // If we have different region and regionCode (dropdown case)\n regionValue = {\n region: input.legalAddress.region || input.legalAddress.regionCode,\n region_code: input.legalAddress.regionCode,\n };\n } else if (input.legalAddress.region) {\n // If we only have region string (fallback case)\n regionValue = {\n region: input.legalAddress.region,\n region_code: input.legalAddress.region,\n region_id: 0\n };\n }\n \n transformedInput.legal_address = {\n street: streetArray,\n city: input.legalAddress.city,\n region: regionValue,\n country_id: input.legalAddress.countryCode, // GraphQL expects country_id, not countryCode\n postcode: input.legalAddress.postcode,\n telephone: input.legalAddress.telephone,\n };\n }\n \n // Do not copy any other fields; only send explicitly allowed/mapped fields from the form\n\n return await fetchGraphQl(UPDATE_COMPANY, {\n method: 'POST',\n variables: { input: transformedInput },\n })\n .then((response: updateCompanyResponse) => {\n if (response.errors?.length) return handleFetchError(response.errors);\n\n return transformCompany(response);\n })\n .catch(handleNetworkError);\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const GET_COUNTRIES_QUERY = `\n query getCountries {\n countries {\n id\n two_letter_abbreviation\n three_letter_abbreviation\n full_name_locale\n full_name_english\n available_regions {\n id\n code\n name\n }\n }\n storeConfig {\n countries_with_required_region\n optional_zip_countries\n }\n }\n`;\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { GET_COUNTRIES_QUERY } from './graphql/getCountries.graphql';\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { handleNetworkError } from '../../lib/network-error';\nimport { handleFetchError } from '../../lib/fetch-error';\nimport { transformCountries } from '../../data/transforms/transform-countries';\nimport { CountriesFormResponse } from '../../types/api/getCountries.types';\nimport { Country } from '../../data/models/country';\n\nexport const getCountries = async (): Promise<{\n availableCountries: Country[] | [];\n countriesWithRequiredRegion: string[];\n optionalZipCountries: string[];\n}> => {\n const sessionStorageKey = '_company_countries';\n\n const sessionStorageCache = sessionStorage.getItem(sessionStorageKey);\n\n if (sessionStorageCache) {\n return JSON.parse(sessionStorageCache);\n }\n\n return await fetchGraphQl(GET_COUNTRIES_QUERY, {\n method: 'GET',\n })\n .then((response: CountriesFormResponse) => {\n if (response.errors?.length) return handleFetchError(response.errors);\n\n const transformedData = transformCountries(response);\n\n sessionStorage.setItem(\n sessionStorageKey,\n JSON.stringify(transformedData)\n );\n\n return transformedData;\n })\n .catch(handleNetworkError);\n};\n"],"names":["setEndpoint","setFetchGraphQlHeader","removeFetchGraphQlHeader","setFetchGraphQlHeaders","fetchGraphQl","getConfig","FetchGraphQL","VALIDATE_COMPANY_EMAIL_QUERY","validateCompanyEmail","email","response","transformCompany","companyData","_a","customerData","legalAddress","line","customerRole","allowedIds","nodes","set","stack","node","child","isAdmin","permissionsFlags","model","m","transformCountries","_b","countries","storeConfig","countriesWithRequiredRegion","optionalZipCountries","two_letter_abbreviation","full_name_locale","country","available_regions","hasRegions","a","b","GET_CUSTOMER_ROLE_PERMISSIONS","COMPANY_LEGAL_ADDRESS_FRAGMENT","COMPANY_BASIC_INFO_FRAGMENT","COMPANY_SALES_REPRESENTATIVE_FRAGMENT","COMPANY_ADMIN_FRAGMENT","COMPANY_FULL_FRAGMENT","flattenIds","buildCompanyQuery","allowed","wantProfile","wantAddress","wantContacts","wantPayment","wantShipping","fields","query","usedFragments","f","inflightGetCompany","cachedCompany","resetCompanyCache","getCompany","useCache","roleResponse","role","_c","id","GET_COMPANY_DYNAMIC","companyResponse","_d","companyNode","_e","k","_f","result","handleNetworkError","error","events","handleFetchError","errors","errorMessage","e","UPDATE_COMPANY","updateCompany","input","transformedInput","streetArray","s","street","regionValue","regionObj","GET_COUNTRIES_QUERY","getCountries","sessionStorageKey","sessionStorageCache","transformedData"],"mappings":"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"}
1
+ {"version":3,"file":"getCountries.js","sources":["/@dropins/storefront-company-management/src/api/fetch-graphql/fetch-graphql.ts","/@dropins/storefront-company-management/src/lib/network-error.ts","/@dropins/storefront-company-management/src/lib/fetch-error.ts","/@dropins/storefront-company-management/src/api/fetchUserPermissions/graphql/getCustomerRole.graphql.ts","/@dropins/storefront-company-management/src/lib/company-permissions.ts","/@dropins/storefront-company-management/src/api/fetchUserPermissions/fetchUserPermissions.ts","/@dropins/storefront-company-management/src/api/validateCompanyEmail/graphql/validateCompanyEmail.graphql.ts","/@dropins/storefront-company-management/src/api/validateCompanyEmail/validateCompanyEmail.ts","/@dropins/storefront-company-management/src/data/transforms/transform-company.ts","/@dropins/storefront-company-management/src/data/transforms/transform-countries.ts","/@dropins/storefront-company-management/src/api/graphql/CompanyFragment.graphql.ts","/@dropins/storefront-company-management/src/api/graphql/buildCompanyQueries.ts","/@dropins/storefront-company-management/src/api/getCompany/getCompany.ts","/@dropins/storefront-company-management/src/api/updateCompany/updateCompany.ts","/@dropins/storefront-company-management/src/api/getCountries/graphql/getCountries.graphql.ts","/@dropins/storefront-company-management/src/api/getCountries/getCountries.ts"],"sourcesContent":["/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\nimport { FetchGraphQL } from '@adobe-commerce/fetch-graphql';\n\nexport const {\n setEndpoint,\n setFetchGraphQlHeader,\n removeFetchGraphQlHeader,\n setFetchGraphQlHeaders,\n fetchGraphQl,\n getConfig,\n} = new FetchGraphQL().getMethods();\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { events } from '@adobe-commerce/event-bus';\n\n/**\n * A function which can be attached to fetchGraphQL to handle thrown errors in\n * a generic way.\n */\nexport const handleNetworkError = (error: Error) => {\n const isAbortError =\n error instanceof DOMException && error.name === 'AbortError';\n\n if (!isAbortError) {\n // @ts-ignore\n events.emit('error', {\n source: 'company',\n type: 'network',\n error,\n });\n }\n throw error;\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n/** Actions */\nexport const handleFetchError = (errors: Array<{ message: string }>) => {\n const errorMessage = errors.map((e: any) => e.message).join(' ');\n\n throw Error(errorMessage);\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const GET_CUSTOMER_ROLE_PERMISSIONS = /* GraphQL */ `\n query GET_CUSTOMER_ROLE_PERMISSIONS {\n customer {\n role {\n id\n name\n permissions {\n id\n children {\n id\n children {\n id\n children {\n id\n children { id }\n }\n }\n }\n }\n }\n status\n }\n }\n`;\n\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\n\n/**\n * Permission flags interface for company operations\n */\nexport interface CompanyPermissionFlags {\n canViewAccount: boolean;\n canEditAccount: boolean;\n canViewAddress: boolean;\n canEditAddress: boolean;\n canViewContacts: boolean;\n canViewPaymentInformation: boolean;\n canViewShippingInformation: boolean;\n}\n\n/**\n * Flattens a nested permissions tree into a Set of permission IDs\n * This is a pure utility function that can be used across the application\n */\nexport const flattenIds = (nodes: any[] = []): Set<string> => {\n const set = new Set<string>();\n const stack = [...nodes];\n while (stack.length) {\n const node = stack.pop();\n if (!node) continue;\n if (typeof node.id === 'string') set.add(node.id);\n if (Array.isArray(node.children) && node.children.length) {\n for (const child of node.children) stack.push(child);\n }\n }\n return set;\n};\n\n/**\n * Determines if a role is a Company Administrator\n */\nexport const isCompanyAdministrator = (role: any): boolean => {\n return role?.id === '0' || \n (typeof role?.id === 'number' && role?.id === 0) || \n role?.name === 'Company Administrator';\n};\n\n/**\n * Builds permission flags from role data\n */\nexport const buildPermissionFlags = (role: any): CompanyPermissionFlags => {\n const allowedIds = flattenIds(role?.permissions || []);\n const isAdmin = isCompanyAdministrator(role);\n\n return {\n canViewAccount: isAdmin || allowedIds.has('Magento_Company::view_account'),\n canEditAccount: isAdmin || allowedIds.has('Magento_Company::edit_account'),\n canViewAddress: isAdmin || allowedIds.has('Magento_Company::view_address'),\n canEditAddress: isAdmin || allowedIds.has('Magento_Company::edit_address'),\n canViewContacts: isAdmin || allowedIds.has('Magento_Company::contacts'),\n canViewPaymentInformation: isAdmin || allowedIds.has('Magento_Company::payment_information'),\n canViewShippingInformation: isAdmin || allowedIds.has('Magento_Company::shipping_information'),\n };\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { handleNetworkError } from '../../lib/network-error';\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { handleFetchError } from '../../lib/fetch-error';\nimport { GET_CUSTOMER_ROLE_PERMISSIONS } from './graphql/getCustomerRole.graphql';\nimport { flattenIds, isCompanyAdministrator } from '../../lib/company-permissions';\n\n/**\n * Fetches user permissions and returns both the allowed permission IDs and the role response\n * This is a general-purpose API function that can be used across the application\n */\nexport const fetchUserPermissions = async (): Promise<{ allowedIds: Set<string>; roleResponse: any }> => {\n return await fetchGraphQl(GET_CUSTOMER_ROLE_PERMISSIONS, { \n method: 'GET', \n cache: 'no-cache' \n })\n .then((roleResponse: any) => {\n if (roleResponse.errors?.length) {\n return handleFetchError(roleResponse.errors);\n }\n\n const role = roleResponse?.data?.customer?.role;\n const allowedIds = flattenIds(role?.permissions || []);\n \n // Treat Company Administrator as having all permissions even if the permissions tree is empty\n const isAdmin = isCompanyAdministrator(role);\n if (isAdmin) {\n [\n 'Magento_Company::view_account',\n 'Magento_Company::edit_account',\n 'Magento_Company::view_address',\n 'Magento_Company::edit_address',\n 'Magento_Company::contacts',\n 'Magento_Company::payment_information',\n 'Magento_Company::shipping_information',\n ].forEach((id) => allowedIds.add(id));\n }\n\n return { allowedIds, roleResponse };\n })\n .catch(handleNetworkError);\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const VALIDATE_COMPANY_EMAIL_QUERY = /* GraphQL */ `\n query validateCompanyEmail($email: String!) {\n isCompanyEmailAvailable(email: $email) {\n is_email_available\n }\n }\n`;","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { VALIDATE_COMPANY_EMAIL_QUERY } from './graphql/validateCompanyEmail.graphql';\nimport { ValidateCompanyEmailQuery, ValidateCompanyEmailResponse } from '../../types/api/validateCompanyEmail.types';\n\nexport const validateCompanyEmail = async (email: string): Promise<ValidateCompanyEmailResponse> => {\n try {\n const response = await fetchGraphQl<ValidateCompanyEmailQuery>(VALIDATE_COMPANY_EMAIL_QUERY, {\n variables: { email },\n });\n\n if (response.errors) {\n return {\n isValid: false,\n error: 'Unable to validate email'\n };\n }\n\n return {\n isValid: response.data.isCompanyEmailAvailable.is_email_available,\n error: response.data.isCompanyEmailAvailable.is_email_available \n ? undefined \n : 'This email is already used by another company'\n };\n } catch (error) {\n return {\n isValid: false,\n error: 'Unable to validate email'\n };\n }\n};","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { getCompanyResponse } from '../../types/api/getCompany.types';\nimport { updateCompanyResponse } from '../../types/api/updateCompany.types';\nimport { CompanyModel } from '../models/company';\nimport { buildPermissionFlags } from '../../lib/company-permissions';\n\nexport const transformCompany = (\n response: getCompanyResponse | updateCompanyResponse\n): CompanyModel => {\n // Validate response structure\n if (!response?.data) {\n throw new Error('Invalid response: missing data');\n }\n\n // Handle both getCompany and updateCompany response structures\n const companyData: any = 'updateCompany' in response.data \n ? response.data.updateCompany?.company \n : response.data.company;\n \n if (!companyData) {\n throw new Error('Invalid response: missing company data');\n }\n \n const customerData = 'customer' in response.data ? response.data.customer : undefined;\n\n // Transform legal address with validation\n const legalAddress = companyData.legal_address ? {\n street: Array.isArray(companyData.legal_address.street) \n ? companyData.legal_address.street.filter((line: string) => line && line.trim() !== '') \n : [],\n city: (companyData.legal_address.city || '').trim(),\n region: companyData.legal_address.region ? {\n region: (companyData.legal_address.region.region || '').trim(),\n regionCode: (companyData.legal_address.region.region_code || '').trim(),\n regionId: companyData.legal_address.region.region_id ? Number(companyData.legal_address.region.region_id) : 0,\n } : undefined,\n countryCode: (companyData.legal_address.country_code || '').toUpperCase().trim(),\n postcode: (companyData.legal_address.postcode || '').trim(),\n telephone: companyData.legal_address.telephone ? \n companyData.legal_address.telephone.trim() : undefined,\n } : undefined;\n\n // Determine permissions using shared utility\n const customerRole = customerData?.role;\n const permissionsFlags = buildPermissionFlags(customerRole);\n\n // Build the model with proper validation\n const model: CompanyModel = {\n id: (companyData.id || '').toString(),\n name: (companyData.name || '').trim(),\n email: (companyData.email || '').trim().toLowerCase(),\n legalName: companyData.legal_name ? companyData.legal_name.trim() : undefined,\n vatTaxId: companyData.vat_tax_id ? companyData.vat_tax_id.trim() : undefined,\n resellerId: companyData.reseller_id ? companyData.reseller_id.trim() : undefined,\n legalAddress,\n companyAdmin: companyData.company_admin ? {\n id: (companyData.company_admin.id || '').toString(),\n firstname: (companyData.company_admin.firstname || '').trim(),\n lastname: (companyData.company_admin.lastname || '').trim(),\n email: (companyData.company_admin.email || '').trim().toLowerCase(),\n jobTitle: companyData.company_admin.job_title ? companyData.company_admin.job_title.trim() : undefined,\n } : undefined,\n\n // Transform sales representative\n salesRepresentative: companyData.sales_representative ? {\n firstname: (companyData.sales_representative.firstname || '').trim(),\n lastname: (companyData.sales_representative.lastname || '').trim(),\n email: (companyData.sales_representative.email || '').trim().toLowerCase(),\n } : undefined,\n\n // New comprehensive payment methods with code and title\n availablePaymentMethods: Array.isArray(companyData.available_payment_methods)\n ? companyData.available_payment_methods\n .filter((m: any) => m && typeof m.code === 'string' && typeof m.title === 'string')\n .map((m: any) => ({ code: m.code.trim(), title: m.title.trim() }))\n .filter((m: any) => m.code.length > 0 && m.title.length > 0)\n : undefined,\n\n // New available shipping methods\n availableShippingMethods: Array.isArray(companyData.available_shipping_methods)\n ? companyData.available_shipping_methods\n .filter((m: any) => m && typeof m.code === 'string' && typeof m.title === 'string')\n .map((m: any) => ({ code: m.code.trim(), title: m.title.trim() }))\n .filter((m: any) => m.code.length > 0 && m.title.length > 0)\n : undefined,\n \n // Computed permission flags (single source of truth)\n canEditAccount: permissionsFlags.canEditAccount,\n canEditAddress: permissionsFlags.canEditAddress,\n permissionsFlags,\n customerRole,\n customerStatus: customerData?.status,\n };\n\n // Validate only when profile fields are permitted\n if (permissionsFlags.canViewAccount) {\n if (!model.id) {\n throw new Error('Company ID is required');\n }\n if (!model.name) {\n throw new Error('Company name is required');\n }\n if (!model.email) {\n throw new Error('Company email is required');\n }\n }\n\n return model;\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { CountriesFormResponse } from '../../types/api/getCountries.types';\nimport { Country } from '../models/country';\n\nexport const transformCountries = (\n response: CountriesFormResponse\n): {\n availableCountries: Country[] | [];\n countriesWithRequiredRegion: string[];\n optionalZipCountries: string[];\n} => {\n if (!response?.data?.countries?.length) {\n return {\n availableCountries: [],\n countriesWithRequiredRegion: [],\n optionalZipCountries: [],\n };\n }\n\n const { countries, storeConfig } = response.data;\n\n const countriesWithRequiredRegion =\n storeConfig?.countries_with_required_region.split(',');\n const optionalZipCountries = storeConfig?.optional_zip_countries.split(',');\n\n const availableCountries = countries\n .filter(({ two_letter_abbreviation, full_name_locale }) =>\n Boolean(two_letter_abbreviation && full_name_locale)\n )\n .map((country) => {\n const { two_letter_abbreviation, full_name_locale, available_regions } = country;\n\n const hasRegions = Array.isArray(available_regions) && available_regions.length > 0;\n return {\n value: two_letter_abbreviation,\n text: full_name_locale,\n availableRegions: hasRegions ? available_regions : undefined,\n };\n })\n .sort((a, b) => a.text.localeCompare(b.text));\n\n return {\n availableCountries,\n countriesWithRequiredRegion,\n optionalZipCountries,\n };\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const COMPANY_LEGAL_ADDRESS_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_LEGAL_ADDRESS_FRAGMENT on CompanyLegalAddress {\n street\n city\n region {\n region\n region_code\n region_id\n }\n country_code\n postcode\n telephone\n }\n`;\n\nexport const COMPANY_BASIC_INFO_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_BASIC_INFO_FRAGMENT on Company {\n id\n name\n email\n legal_name\n vat_tax_id\n reseller_id\n }\n`;\n\nexport const COMPANY_SALES_REPRESENTATIVE_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_SALES_REPRESENTATIVE_FRAGMENT on CompanySalesRepresentative {\n firstname\n lastname\n email\n }\n`;\n\nexport const COMPANY_ADMIN_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_ADMIN_FRAGMENT on Customer {\n firstname\n lastname\n email\n job_title\n }\n`;\n\nexport const COMPANY_FULL_FRAGMENT = /* GraphQL */ `\n fragment COMPANY_FULL_FRAGMENT on Company {\n ...COMPANY_BASIC_INFO_FRAGMENT\n legal_address {\n ...COMPANY_LEGAL_ADDRESS_FRAGMENT\n }\n company_admin {\n ...COMPANY_ADMIN_FRAGMENT\n }\n sales_representative {\n ...COMPANY_SALES_REPRESENTATIVE_FRAGMENT\n }\n available_payment_methods {\n code\n title\n }\n available_shipping_methods {\n code\n title\n }\n }\n ${COMPANY_BASIC_INFO_FRAGMENT}\n ${COMPANY_LEGAL_ADDRESS_FRAGMENT}\n ${COMPANY_ADMIN_FRAGMENT}\n ${COMPANY_SALES_REPRESENTATIVE_FRAGMENT}\n`;\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport {\n COMPANY_BASIC_INFO_FRAGMENT,\n COMPANY_LEGAL_ADDRESS_FRAGMENT,\n COMPANY_ADMIN_FRAGMENT,\n COMPANY_SALES_REPRESENTATIVE_FRAGMENT,\n} from './CompanyFragment.graphql';\n\n/**\n * Builds company fields based on user permissions\n */\nconst buildCompanyFields = (allowed: Set<string>): { fields: string[]; usedFragments: string[] } => {\n const wantProfile = allowed.has('Magento_Company::view_account');\n const wantAddress = allowed.has('Magento_Company::view_address');\n const wantContacts = allowed.has('Magento_Company::contacts');\n const wantPayment = allowed.has('Magento_Company::payment_information');\n const wantShipping = allowed.has('Magento_Company::shipping_information');\n\n const fields: string[] = [];\n const usedFragments: string[] = [];\n\n if (wantProfile) {\n fields.push('...COMPANY_BASIC_INFO_FRAGMENT');\n usedFragments.push(COMPANY_BASIC_INFO_FRAGMENT);\n }\n if (wantAddress) {\n fields.push(`legal_address { ...COMPANY_LEGAL_ADDRESS_FRAGMENT }`);\n usedFragments.push(COMPANY_LEGAL_ADDRESS_FRAGMENT);\n }\n if (wantContacts) {\n fields.push(`company_admin { ...COMPANY_ADMIN_FRAGMENT }`);\n fields.push(`sales_representative { ...COMPANY_SALES_REPRESENTATIVE_FRAGMENT }`);\n usedFragments.push(COMPANY_ADMIN_FRAGMENT);\n usedFragments.push(COMPANY_SALES_REPRESENTATIVE_FRAGMENT);\n }\n if (wantPayment) {\n fields.push(`available_payment_methods { code title }`);\n }\n if (wantShipping) {\n fields.push(`available_shipping_methods { code title }`);\n }\n\n return { fields, usedFragments };\n};\n\n/**\n * Builds a dynamic company query based on user permissions\n */\nexport const buildCompanyQuery = (allowed: Set<string>): string => {\n const { fields, usedFragments } = buildCompanyFields(allowed);\n\n // If no allowed company fields, still query company with __typename to keep response shape\n if (fields.length === 0) {\n return `\n query GET_COMPANY_DYNAMIC {\n company { __typename }\n }\n `;\n }\n\n const query = `\n query GET_COMPANY_DYNAMIC {\n company {\n ${fields.join('\\n ')}\n }\n }\n `;\n\n return `${query}\\n${usedFragments.join('\\n')}`;\n};\n\n/**\n * Builds a dynamic company update mutation based on user permissions\n */\nexport const buildUpdateCompanyMutation = (allowed: Set<string>): string => {\n const { fields, usedFragments } = buildCompanyFields(allowed);\n\n // If no allowed company fields, still query company with __typename to keep response shape\n if (fields.length === 0) {\n return `\n mutation UPDATE_COMPANY_DYNAMIC($input: CompanyUpdateInput!) {\n updateCompany(input: $input) {\n company { __typename }\n }\n }\n `;\n }\n\n const mutation = `\n mutation UPDATE_COMPANY_DYNAMIC($input: CompanyUpdateInput!) {\n updateCompany(input: $input) {\n company {\n ${fields.join('\\n ')}\n }\n }\n }\n `;\n\n return `${mutation}\\n${usedFragments.join('\\n')}`;\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { handleNetworkError } from '../../lib/network-error';\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { transformCompany } from '../../data/transforms';\nimport { CompanyModel } from '../../data/models/company';\nimport { getCompanyResponse } from '../../types/api/getCompany.types';\nimport { fetchUserPermissions } from '../fetchUserPermissions';\nimport { buildCompanyQuery } from '../graphql/buildCompanyQueries';\nimport { handleFetchError } from '../../lib/fetch-error';\n\nexport const getCompany = async (): Promise<CompanyModel | null> => {\n return await fetchUserPermissions()\n .then(async ({ allowedIds, roleResponse }) => {\n // Build a company query that requests only allowed fields\n const GET_COMPANY_DYNAMIC = buildCompanyQuery(allowedIds);\n\n // Fetch company with dynamic selection\n const companyResponse: getCompanyResponse = await fetchGraphQl(GET_COMPANY_DYNAMIC, { method: 'GET', cache: 'no-cache' });\n if (companyResponse.errors?.length) return handleFetchError(companyResponse.errors);\n\n const companyNode: any = companyResponse?.data?.company;\n const hasAnyCompanyField = companyNode && Object.keys(companyNode).some((k) => k !== '__typename');\n if (!hasAnyCompanyField) {\n return null;\n }\n\n // Merge back minimal customer role info so transform can compute flags\n (companyResponse as any).data.customer = roleResponse?.data?.customer;\n\n return transformCompany(companyResponse);\n })\n .catch(handleNetworkError);\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { handleNetworkError } from '../../lib/network-error';\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { handleFetchError } from '../../lib/fetch-error';\nimport { transformCompany } from '../../data/transforms';\nimport { CompanyModel } from '../../data/models/company';\nimport { updateCompanyResponse, UpdateCompanyDto } from '../../types';\nimport { fetchUserPermissions } from '../fetchUserPermissions';\nimport { buildUpdateCompanyMutation } from '../graphql/buildCompanyQueries';\n\n\nexport const updateCompany = async (input: UpdateCompanyDto): Promise<CompanyModel> => {\n return await fetchUserPermissions()\n .then(async ({ allowedIds, roleResponse }) => {\n // Build a dynamic mutation that requests only allowed fields in response\n const UPDATE_COMPANY_DYNAMIC = buildUpdateCompanyMutation(allowedIds);\n\n // Transform input (keep original logic for what to send)\n const transformedInput: Record<string, unknown> = {};\n \n // Map frontend field names to GraphQL schema field names\n if (input.name !== undefined) {\n transformedInput.company_name = input.name;\n }\n if (input.email !== undefined) {\n transformedInput.company_email = input.email;\n }\n if (input.legalName !== undefined) {\n transformedInput.legal_name = input.legalName;\n }\n if (input.vatTaxId !== undefined) {\n transformedInput.vat_tax_id = input.vatTaxId;\n }\n if (input.resellerId !== undefined) {\n transformedInput.reseller_id = input.resellerId;\n }\n \n // Transform legal address (only if user has edit_address permission)\n if (input.legalAddress !== undefined && allowedIds.has('Magento_Company::edit_address')) {\n // Handle street field - ensure it's always a flat array of strings\n let streetArray: string[];\n if (Array.isArray(input.legalAddress.street)) {\n // If street is already an array, use it directly and add street_2 if present\n streetArray = [...input.legalAddress.street];\n if (input.legalAddress.street2) {\n streetArray.push(input.legalAddress.street2);\n }\n } else {\n // If street is a string, create array normally with type guard\n streetArray = [input.legalAddress.street, input.legalAddress.street2].filter(\n (s): s is string => typeof s === 'string' && s.trim().length > 0\n );\n }\n \n // Remove any empty strings and ensure all elements are strings\n streetArray = streetArray.filter(street => street && typeof street === 'string' && street.trim().length > 0);\n \n // Handle region - different approaches for dropdown vs custom regions\n let regionValue: { region: string; region_code: string; region_id?: number } | undefined;\n if (input.legalAddress.region && typeof input.legalAddress.region === 'object') {\n const regionObj = input.legalAddress.region;\n \n // Check if this is a custom region (region === regionCode) or predefined region\n if (regionObj.region === regionObj.regionCode) {\n // Custom region - send as object with region_id: 0\n regionValue = {\n region: regionObj.region,\n region_code: regionObj.regionCode,\n region_id: 0\n };\n } else {\n // Predefined region - send as object\n regionValue = {\n region: regionObj.region,\n region_code: regionObj.regionCode,\n };\n }\n } else if (input.legalAddress.regionCode && input.legalAddress.region !== input.legalAddress.regionCode) {\n // If we have different region and regionCode (dropdown case)\n regionValue = {\n region: input.legalAddress.region || input.legalAddress.regionCode,\n region_code: input.legalAddress.regionCode,\n };\n } else if (input.legalAddress.region) {\n // If we only have region string (fallback case)\n regionValue = {\n region: input.legalAddress.region,\n region_code: input.legalAddress.region,\n region_id: 0\n };\n }\n \n transformedInput.legal_address = {\n street: streetArray,\n city: input.legalAddress.city,\n region: regionValue,\n country_id: input.legalAddress.countryCode, // GraphQL expects country_id, not countryCode\n postcode: input.legalAddress.postcode,\n telephone: input.legalAddress.telephone,\n };\n }\n\n // Execute the dynamic mutation\n const response: updateCompanyResponse = await fetchGraphQl(UPDATE_COMPANY_DYNAMIC, {\n method: 'POST',\n variables: { input: transformedInput },\n });\n\n if (response.errors?.length) return handleFetchError(response.errors);\n\n // Merge back minimal customer role info so transform can compute flags\n (response as any).data.customer = roleResponse?.data?.customer;\n\n return transformCompany(response);\n })\n .catch(handleNetworkError);\n};\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nexport const GET_COUNTRIES_QUERY = `\n query getCountries {\n countries {\n id\n two_letter_abbreviation\n three_letter_abbreviation\n full_name_locale\n full_name_english\n available_regions {\n id\n code\n name\n }\n }\n storeConfig {\n countries_with_required_region\n optional_zip_countries\n }\n }\n`;\n","/********************************************************************\n * ADOBE CONFIDENTIAL\n * __________________\n *\n * Copyright 2025 Adobe\n * All Rights Reserved.\n *\n * NOTICE: All information contained herein is, and remains\n * the property of Adobe and its suppliers, if any. The intellectual\n * and technical concepts contained herein are proprietary to Adobe\n * and its suppliers and are protected by all applicable intellectual\n * property laws, including trade secret and copyright laws.\n * Dissemination of this information or reproduction of this material\n * is strictly forbidden unless prior written permission is obtained\n * from Adobe.\n *******************************************************************/\nimport { GET_COUNTRIES_QUERY } from './graphql/getCountries.graphql';\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { handleNetworkError } from '../../lib/network-error';\nimport { handleFetchError } from '../../lib/fetch-error';\nimport { transformCountries } from '../../data/transforms/transform-countries';\nimport { CountriesFormResponse } from '../../types/api/getCountries.types';\nimport { Country } from '../../data/models/country';\n\nexport const getCountries = async (): Promise<{\n availableCountries: Country[] | [];\n countriesWithRequiredRegion: string[];\n optionalZipCountries: string[];\n}> => {\n const sessionStorageKey = '_company_countries';\n\n const sessionStorageCache = sessionStorage.getItem(sessionStorageKey);\n\n if (sessionStorageCache) {\n return JSON.parse(sessionStorageCache);\n }\n\n return await fetchGraphQl(GET_COUNTRIES_QUERY, {\n method: 'GET',\n })\n .then((response: CountriesFormResponse) => {\n if (response.errors?.length) return handleFetchError(response.errors);\n\n const transformedData = transformCountries(response);\n\n sessionStorage.setItem(\n sessionStorageKey,\n JSON.stringify(transformedData)\n );\n\n return transformedData;\n })\n .catch(handleNetworkError);\n};\n"],"names":["setEndpoint","setFetchGraphQlHeader","removeFetchGraphQlHeader","setFetchGraphQlHeaders","fetchGraphQl","getConfig","FetchGraphQL","handleNetworkError","error","events","handleFetchError","errors","errorMessage","e","GET_CUSTOMER_ROLE_PERMISSIONS","flattenIds","nodes","set","stack","node","child","isCompanyAdministrator","role","buildPermissionFlags","allowedIds","isAdmin","fetchUserPermissions","roleResponse","_a","_c","_b","id","VALIDATE_COMPANY_EMAIL_QUERY","validateCompanyEmail","email","response","transformCompany","companyData","customerData","legalAddress","line","customerRole","permissionsFlags","model","m","transformCountries","countries","storeConfig","countriesWithRequiredRegion","optionalZipCountries","two_letter_abbreviation","full_name_locale","country","available_regions","hasRegions","a","b","COMPANY_LEGAL_ADDRESS_FRAGMENT","COMPANY_BASIC_INFO_FRAGMENT","COMPANY_SALES_REPRESENTATIVE_FRAGMENT","COMPANY_ADMIN_FRAGMENT","buildCompanyFields","allowed","wantProfile","wantAddress","wantContacts","wantPayment","wantShipping","fields","usedFragments","buildCompanyQuery","buildUpdateCompanyMutation","getCompany","GET_COMPANY_DYNAMIC","companyResponse","companyNode","k","updateCompany","input","UPDATE_COMPANY_DYNAMIC","transformedInput","streetArray","s","street","regionValue","regionObj","GET_COUNTRIES_QUERY","getCountries","sessionStorageKey","sessionStorageCache","transformedData"],"mappings":"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"}