@dropins/storefront-company-management 1.0.0-beta21 → 1.0.0-beta22
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/api/acceptCompanyInvitation/acceptCompanyInvitation.d.ts +9 -0
- package/api/acceptCompanyInvitation/graphql/acceptCompanyInvitation.graphql.d.ts +18 -0
- package/api/acceptCompanyInvitation/index.d.ts +18 -0
- package/api/createCompanyUser/graphql/createCompanyUser.graphql.d.ts +1 -1
- package/api/getCompanyStructure/graphql/getCompanyStructure.graphql.d.ts +1 -1
- package/api/index.d.ts +4 -3
- package/api.js +8 -8
- package/api.js.map +1 -1
- package/chunks/CompanyUserForm.js +1 -1
- package/chunks/CompanyUserForm.js.map +1 -1
- package/chunks/acceptCompanyInvitation.js +10 -0
- package/chunks/acceptCompanyInvitation.js.map +1 -0
- package/chunks/{transform-store-config.js → createCompany.js} +10 -10
- package/chunks/createCompany.js.map +1 -0
- package/chunks/getCompanyUsers.js +36 -0
- package/chunks/getCompanyUsers.js.map +1 -0
- package/chunks/getCustomerCompany.js +3 -3
- package/chunks/getCustomerCompany.js.map +1 -1
- package/chunks/updateCompanyTeam.js +8 -8
- package/chunks/updateCompanyTeam.js.map +1 -1
- package/chunks/updateCompanyUserStatus.js +25 -24
- package/chunks/updateCompanyUserStatus.js.map +1 -1
- package/components/AcceptInvitationForm/AcceptInvitationForm.d.ts +5 -0
- package/components/AcceptInvitationForm/index.d.ts +18 -0
- package/components/index.d.ts +1 -0
- package/containers/AcceptInvitation/AcceptInvitation.d.ts +5 -0
- package/containers/AcceptInvitation/index.d.ts +18 -0
- package/containers/AcceptInvitation.d.ts +1 -0
- package/containers/AcceptInvitation.js +4 -0
- package/containers/AcceptInvitation.js.map +1 -0
- package/containers/CompanyRegistration.js +1 -1
- package/containers/CompanyRegistration.js.map +1 -1
- package/containers/CompanyStructure.js +1 -1
- package/containers/CompanyStructure.js.map +1 -1
- package/containers/CompanyUsers.js +1 -1
- package/containers/CompanyUsers.js.map +1 -1
- package/containers/index.d.ts +1 -1
- package/data/models/customer-company-info.d.ts +1 -0
- package/data/transforms/transform-company-structure.d.ts +2 -0
- package/hooks/index.d.ts +1 -0
- package/hooks/useAcceptInvitation.d.ts +10 -0
- package/hooks/useCompanyUserForm.d.ts +2 -0
- package/i18n/en_US.json.d.ts +11 -0
- package/lib/index.d.ts +1 -0
- package/lib/switchCompanyContext.d.ts +29 -0
- package/package.json +1 -1
- package/render.js +9 -7
- package/render.js.map +1 -1
- package/types/acceptInvitation.types.d.ts +41 -0
- package/types/api/acceptCompanyInvitation.types.d.ts +32 -0
- package/types/api/createCompanyUser.types.d.ts +1 -0
- package/types/api/getCompanyStructure.types.d.ts +1 -0
- package/types/companyForm.types.d.ts +2 -0
- package/types/index.d.ts +2 -0
- package/chunks/transform-store-config.js.map +0 -1
- package/chunks/updateCompanyUser.js +0 -37
- package/chunks/updateCompanyUser.js.map +0 -1
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import { AcceptCompanyInvitationInput, AcceptCompanyInvitationResult } from '../../types';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Accepts a company invitation using the invitation code and user information
|
|
5
|
+
* @param input - Invitation code, user information (customer_id, company_id, etc.), and optional role_id
|
|
6
|
+
* @returns Promise resolving to result indicating success or failure
|
|
7
|
+
*/
|
|
8
|
+
export declare function acceptCompanyInvitation(input: AcceptCompanyInvitationInput): Promise<AcceptCompanyInvitationResult | null>;
|
|
9
|
+
//# sourceMappingURL=acceptCompanyInvitation.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 declare const ACCEPT_COMPANY_INVITATION = "\n mutation acceptCompanyInvitation($input: CompanyInvitationInput!) {\n acceptCompanyInvitation(input: $input) {\n success\n }\n }\n";
|
|
18
|
+
//# sourceMappingURL=acceptCompanyInvitation.graphql.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 * from './acceptCompanyInvitation';
|
|
18
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -14,5 +14,5 @@
|
|
|
14
14
|
* is strictly forbidden unless prior written permission is obtained
|
|
15
15
|
* from Adobe.
|
|
16
16
|
*******************************************************************/
|
|
17
|
-
export declare const CREATE_COMPANY_USER = "\n mutation createCompanyUser($input: CompanyUserCreateInput!) {\n createCompanyUser(input: $input) { __typename user { id structure_id email firstname lastname } }\n }\n";
|
|
17
|
+
export declare const CREATE_COMPANY_USER = "\n mutation createCompanyUser($input: CompanyUserCreateInput!) {\n createCompanyUser(input: $input) { __typename user { id structure_id email firstname lastname job_title } }\n }\n";
|
|
18
18
|
//# sourceMappingURL=createCompanyUser.graphql.d.ts.map
|
|
@@ -14,5 +14,5 @@
|
|
|
14
14
|
* is strictly forbidden unless prior written permission is obtained
|
|
15
15
|
* from Adobe.
|
|
16
16
|
*******************************************************************/
|
|
17
|
-
export declare const GET_COMPANY_STRUCTURE = "\n query getCompanyStructure {\n company {\n structure {\n items {\n id\n parent_id\n entity {\n __typename\n ... on CompanyTeam { companyTeamId: id structure_id name description }\n ... on Customer { customerId: id structure_id firstname lastname }\n }\n }\n }\n }\n }\n";
|
|
17
|
+
export declare const GET_COMPANY_STRUCTURE = "\n query getCompanyStructure {\n company {\n structure {\n items {\n id\n parent_id\n entity {\n __typename\n ... on CompanyTeam { companyTeamId: id structure_id name description }\n ... on Customer { customerId: id structure_id firstname lastname status job_title }\n }\n }\n }\n }\n }\n";
|
|
18
18
|
//# sourceMappingURL=getCompanyStructure.graphql.d.ts.map
|
package/api/index.d.ts
CHANGED
|
@@ -17,7 +17,9 @@
|
|
|
17
17
|
export * from './initialize';
|
|
18
18
|
export * from './fetch-graphql';
|
|
19
19
|
export * from './fetchUserPermissions';
|
|
20
|
+
export * from './acceptCompanyInvitation';
|
|
20
21
|
export * from './allowCompanyRegistration';
|
|
22
|
+
export * from './checkCompanyCreditEnabled';
|
|
21
23
|
export * from './companyEnabled';
|
|
22
24
|
export * from './createCompany';
|
|
23
25
|
export * from './createCompanyTeam';
|
|
@@ -25,6 +27,8 @@ export * from './createCompanyUser';
|
|
|
25
27
|
export * from './deleteCompanyTeam';
|
|
26
28
|
export * from './deleteCompanyUser';
|
|
27
29
|
export * from './getCompany';
|
|
30
|
+
export * from './getCompanyCredit';
|
|
31
|
+
export * from './getCompanyCreditHistory';
|
|
28
32
|
export * from './getCompanyStructure';
|
|
29
33
|
export * from './getCompanyTeam';
|
|
30
34
|
export * from './getCompanyUser';
|
|
@@ -41,8 +45,5 @@ export * from './updateCompanyTeam';
|
|
|
41
45
|
export * from './updateCompanyUser';
|
|
42
46
|
export * from './updateCompanyUserStatus';
|
|
43
47
|
export * from './validateCompanyEmail';
|
|
44
|
-
export * from './getCompanyCredit';
|
|
45
|
-
export * from './getCompanyCreditHistory';
|
|
46
|
-
export * from './checkCompanyCreditEnabled';
|
|
47
48
|
export * from './companyRoles';
|
|
48
49
|
//# sourceMappingURL=index.d.ts.map
|
package/api.js
CHANGED
|
@@ -1,6 +1,12 @@
|
|
|
1
1
|
/*! Copyright 2025 Adobe
|
|
2
2
|
All Rights Reserved. */
|
|
3
|
-
import{f as m,h as c}from"./chunks/network-error.js";import{g as I,r as P,s as G,a as L,b as M}from"./chunks/network-error.js";import{f as D}from"./chunks/fetchUserPermissions.js";import{a as w,i as
|
|
3
|
+
import{f as m,h as c}from"./chunks/network-error.js";import{g as I,r as P,s as G,a as L,b as M}from"./chunks/network-error.js";import{f as D}from"./chunks/fetchUserPermissions.js";import{a as w}from"./chunks/acceptCompanyInvitation.js";import{a as k,i as B}from"./chunks/isCompanyUser.js";import{c as Y,g as q}from"./chunks/getCustomerCompany.js";import{D as W,S as z,c as j,g as J}from"./chunks/createCompany.js";import{c as X,d as Z,a as $,g as ee,b as ae,u as re}from"./chunks/updateCompanyTeam.js";import{c as oe,g as ne,i as se,a as me,u as ie}from"./chunks/updateCompanyUserStatus.js";import{d as pe,g as le}from"./chunks/getCompanyUsers.js";import{g as Ce,u as ue}from"./chunks/updateCompany.js";import{a as ye,g as Ee}from"./chunks/getCompanyCreditHistory.js";import{g as he,v as Re}from"./chunks/validateCompanyEmail.js";import{G as p,t as l}from"./chunks/isCompanyRoleNameAvailable.js";import{c as Ae,d as _e,a as Ue,g as Se,i as be,u as Ne}from"./chunks/isCompanyRoleNameAvailable.js";import{f as d}from"./chunks/company-permissions.js";import"@dropins/tools/fetch-graphql.js";import"@dropins/tools/event-bus.js";import"./chunks/fetch-error.js";const A=async e=>{try{const a=await m(p,{variables:e,method:"GET",cache:"no-cache"});return l(a)}catch(a){return c(a)}},_=e=>d(e),U=(e,a)=>{const n=new Set(a),r=t=>{var o;const s=((o=t.children)==null?void 0:o.map(r).filter(i=>i!==null))||[];return n.has(t.id)||s.length>0?{...t,children:s}:null};return e.map(r).filter(t=>t!==null)},S=async(e={})=>({success:!0,config:e}),C=`
|
|
4
|
+
query CHECK_COMPANY_CREDIT_ENABLED {
|
|
5
|
+
storeConfig{
|
|
6
|
+
company_credit_enabled
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
`,b=async()=>{var e,a,n;try{const r=await m(C,{method:"GET",cache:"no-cache"});return(e=r.errors)!=null&&e.length?{creditEnabled:!1,error:"Unable to check company credit configuration"}:((n=(a=r.data)==null?void 0:a.storeConfig)==null?void 0:n.company_credit_enabled)===!0?{creditEnabled:!0}:{creditEnabled:!1,error:"Company credit is not enabled in store configuration"}}catch{return{creditEnabled:!1,error:"Company credit functionality not available"}}};var u=(e=>(e.ALLOCATION="ALLOCATION",e.UPDATE="UPDATE",e.PURCHASE="PURCHASE",e.REIMBURSEMENT="REIMBURSEMENT",e))(u||{});const f=`
|
|
4
10
|
query GET_CUSTOMER_COMPANIES_WITH_ROLES {
|
|
5
11
|
customer {
|
|
6
12
|
companies(input: {}) {
|
|
@@ -15,11 +21,5 @@ import{f as m,h as c}from"./chunks/network-error.js";import{g as I,r as P,s as G
|
|
|
15
21
|
}
|
|
16
22
|
}
|
|
17
23
|
}
|
|
18
|
-
`,
|
|
19
|
-
query CHECK_COMPANY_CREDIT_ENABLED {
|
|
20
|
-
storeConfig{
|
|
21
|
-
company_credit_enabled
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
`,N=async()=>{var e,r,n;try{const a=await m(f,{method:"GET",cache:"no-cache"});return(e=a.errors)!=null&&e.length?{creditEnabled:!1,error:"Unable to check company credit configuration"}:((n=(r=a.data)==null?void 0:r.storeConfig)==null?void 0:n.company_credit_enabled)===!0?{creditEnabled:!0}:{creditEnabled:!1,error:"Company credit is not enabled in store configuration"}}catch{return{creditEnabled:!1,error:"Company credit functionality not available"}}};export{u as CompanyCreditOperationType,q as DEFAULT_COUNTRY,K as STORE_CONFIG_DEFAULTS,w as allowCompanyRegistration,U as buildPermissionTree,N as checkCompanyCreditEnabled,B as companyEnabled,W as createCompany,Re as createCompanyRole,J as createCompanyTeam,ae as createCompanyUser,Te as deleteCompanyRole,V as deleteCompanyTeam,te as deleteCompanyUser,m as fetchGraphQl,D as fetchUserPermissions,_ as flattenPermissionIds,ie as getCompany,Ae as getCompanyAclResources,Ee as getCompanyCredit,ge as getCompanyCreditHistory,A as getCompanyRole,_e as getCompanyRoles,X as getCompanyStructure,Z as getCompanyTeam,oe as getCompanyUser,pe as getCompanyUsers,I as getConfig,ue as getCountries,Q as getCustomerCompany,z as getStoreConfig,S as initialize,b as isCompanyAdmin,Ue as isCompanyRoleNameAvailable,F as isCompanyUser,ne as isCompanyUserEmailAvailable,P as removeFetchGraphQlHeader,G as setEndpoint,L as setFetchGraphQlHeader,M as setFetchGraphQlHeaders,ce as updateCompany,Se as updateCompanyRole,$ as updateCompanyStructure,ee as updateCompanyTeam,se as updateCompanyUser,de as updateCompanyUserStatus,fe as validateCompanyEmail};
|
|
24
|
+
`,N=async()=>{var e,a,n;try{const r=await m(f,{method:"POST"});if((e=r.errors)!=null&&e.length)return!1;const t=(a=r.data)==null?void 0:a.customer;if(!t)return!1;const s=((n=t.companies)==null?void 0:n.items)??[];if(!Array.isArray(s)||s.length===0)return!1;const o=t.role;return o?o.id==="0"||typeof o.id=="number"&&o.id===0||o.name==="Company Administrator":!1}catch(r){return console.error("Error checking if customer is company admin:",r),!1}};export{u as CompanyCreditOperationType,W as DEFAULT_COUNTRY,z as STORE_CONFIG_DEFAULTS,w as acceptCompanyInvitation,k as allowCompanyRegistration,U as buildPermissionTree,b as checkCompanyCreditEnabled,Y as companyEnabled,j as createCompany,Ae as createCompanyRole,X as createCompanyTeam,oe as createCompanyUser,_e as deleteCompanyRole,Z as deleteCompanyTeam,pe as deleteCompanyUser,m as fetchGraphQl,D as fetchUserPermissions,_ as flattenPermissionIds,Ce as getCompany,Ue as getCompanyAclResources,ye as getCompanyCredit,Ee as getCompanyCreditHistory,A as getCompanyRole,Se as getCompanyRoles,$ as getCompanyStructure,ee as getCompanyTeam,ne as getCompanyUser,le as getCompanyUsers,I as getConfig,he as getCountries,q as getCustomerCompany,J as getStoreConfig,S as initialize,N as isCompanyAdmin,be as isCompanyRoleNameAvailable,B as isCompanyUser,se as isCompanyUserEmailAvailable,P as removeFetchGraphQlHeader,G as setEndpoint,L as setFetchGraphQlHeader,M as setFetchGraphQlHeaders,ue as updateCompany,Ne as updateCompanyRole,ae as updateCompanyStructure,re as updateCompanyTeam,me as updateCompanyUser,ie as updateCompanyUserStatus,Re as validateCompanyEmail};
|
|
25
25
|
//# sourceMappingURL=api.js.map
|
package/api.js.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"api.js","sources":["/@dropins/storefront-company-management/src/api/companyRoles/getCompanyRole.ts","/@dropins/storefront-company-management/src/api/companyRoles/utils.ts","/@dropins/storefront-company-management/src/api/initialize/initialize.ts","/@dropins/storefront-company-management/src/api/isCompanyAdmin/graphql/isCompanyAdmin.graphql.ts","/@dropins/storefront-company-management/src/api/isCompanyAdmin/isCompanyAdmin.ts","/@dropins/storefront-company-management/src/types/api/getCompanyCreditHistoryParams.types.ts","/@dropins/storefront-company-management/src/api/checkCompanyCreditEnabled/graphql/checkCompanyCreditEnabled.graphql.ts","/@dropins/storefront-company-management/src/api/checkCompanyCreditEnabled/checkCompanyCreditEnabled.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 '../fetch-graphql';\nimport { handleNetworkError } from '../../lib/network-error';\nimport { GET_COMPANY_ROLE } from './graphql/queries';\nimport { GetCompanyRoleVariables, GetCompanyRoleResponse } from '../../types/api/companyRoles.types';\nimport { CompanyRoleModel } from '../../data/models/company-role';\nimport { transformGetCompanyRoleResponse } from '../../data/transforms/transform-company-roles';\n\n/**\n * Fetch a single company role by ID\n */\nexport const getCompanyRole = async (\n variables: GetCompanyRoleVariables\n): Promise<CompanyRoleModel> => {\n try {\n const response: GetCompanyRoleResponse = await fetchGraphQl(GET_COMPANY_ROLE, {\n variables,\n method: 'GET',\n cache: 'no-cache',\n });\n\n return transformGetCompanyRoleResponse(response);\n } catch (error) {\n return handleNetworkError(error as Error);\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\nimport { flattenIdsToArray } from '../../lib/company-permissions';\nimport { CompanyAclResourceModel } from '../../data/models/company-role';\n\n/**\n * Helper function to flatten ACL resources into a list of permission IDs\n */\nexport const flattenPermissionIds = (resources: CompanyAclResourceModel[]): string[] => {\n return flattenIdsToArray(resources);\n};\n\n/**\n * Helper function to build a permission tree from flat permission IDs\n */\nexport const buildPermissionTree = (\n allResources: CompanyAclResourceModel[],\n selectedIds: string[]\n): CompanyAclResourceModel[] => {\n const selectedSet = new Set(selectedIds);\n \n const filterTree = (resource: CompanyAclResourceModel): CompanyAclResourceModel | null => {\n const filteredChildren = resource.children\n ?.map(filterTree)\n .filter((child): child is CompanyAclResourceModel => child !== null) || [];\n \n if (selectedSet.has(resource.id) || filteredChildren.length > 0) {\n return {\n ...resource,\n children: filteredChildren,\n };\n }\n \n return null;\n };\n \n return allResources\n .map(filterTree)\n .filter((resource): resource is CompanyAclResourceModel => resource !== null);\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// import { events } from '@adobe-commerce/event-bus';\n\n\nimport { CompanyDropinConfig } from '../../types/api/initialize.types';\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 *******************************************************************/\n\nexport const GET_CUSTOMER_COMPANIES_WITH_ROLES = /* GraphQL */ `\n query GET_CUSTOMER_COMPANIES_WITH_ROLES {\n customer {\n companies(input: {}) {\n items {\n id\n name\n }\n }\n role {\n id\n name\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 \nimport { fetchGraphQl } from '../fetch-graphql';\nimport { GET_CUSTOMER_COMPANIES_WITH_ROLES } from './graphql/isCompanyAdmin.graphql';\n\ninterface CompanyRole {\n id: string;\n name: string;\n}\n\ninterface CompanyBasicInfo {\n id: string;\n name: string;\n}\n\ninterface CustomerCompaniesWithRolesResponse {\n customer: {\n companies: {\n items: CompanyBasicInfo[];\n };\n role: CompanyRole | null;\n } | null;\n}\n\n/**\n * Check if the current authenticated customer is a company administrator in any company\n * @returns Promise<boolean> - true if customer is a company admin in at least one company, false otherwise\n */\nexport const isCompanyAdmin = async (): Promise<boolean> => {\n try {\n const response = await fetchGraphQl<CustomerCompaniesWithRolesResponse>(GET_CUSTOMER_COMPANIES_WITH_ROLES, {\n method: 'POST',\n });\n\n if (response.errors?.length) {\n return false;\n }\n\n const customer = response.data?.customer;\n if (!customer) {\n return false;\n }\n\n // Check if user is part of at least one company\n const companies = customer.companies?.items ?? [];\n if (!Array.isArray(companies) || companies.length === 0) {\n return false;\n }\n\n // Check if user has admin role\n const customerRole = customer.role;\n if (!customerRole) {\n return false;\n }\n\n // Check if user is company administrator by role ID or name\n return customerRole.id === '0' || \n (typeof customerRole.id === 'number' && customerRole.id === 0) ||\n customerRole.name === 'Company Administrator';\n } catch (error) {\n console.error('Error checking if customer is company admin:', error);\n return false;\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\nexport enum CompanyCreditOperationType {\n ALLOCATION = 'ALLOCATION',\n UPDATE = 'UPDATE',\n PURCHASE = 'PURCHASE',\n REIMBURSEMENT = 'REIMBURSEMENT'\n}\n\nexport interface CompanyCreditHistoryFilterInput {\n /**\n * The purchase order number associated with the company credit operation.\n */\n customReferenceNumber?: string;\n\n /**\n * The type of the company credit operation.\n */\n operationType?: CompanyCreditOperationType;\n\n /**\n * The name of the person submitting the company credit operation.\n */\n updatedBy?: string;\n}\n\nexport interface GetCompanyCreditHistoryParams {\n /**\n * Filter criteria for narrowing the results of a credit history search.\n */\n filter?: CompanyCreditHistoryFilterInput;\n\n /**\n * Number of items to return per page.\n * @default 20\n */\n pageSize?: number;\n\n /**\n * Current page number.\n * @default 1\n */\n currentPage?: number;\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\nexport const CHECK_COMPANY_CREDIT_ENABLED = /* GraphQL */ `\n query CHECK_COMPANY_CREDIT_ENABLED {\n storeConfig{\n company_credit_enabled\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\nimport { CHECK_COMPANY_CREDIT_ENABLED } from \"./graphql/checkCompanyCreditEnabled.graphql\";\nimport { CheckCompanyCreditEnabledResponse } from '../../types/api/checkCompanyCreditEnabled.types';\nimport { fetchGraphQl } from '../fetch-graphql';\n\nexport const checkCompanyCreditEnabled = async (): Promise<CheckCompanyCreditEnabledResponse> => {\n try {\n const response = await fetchGraphQl(CHECK_COMPANY_CREDIT_ENABLED, {\n method: 'GET',\n cache: 'no-cache',\n });\n\n // If there are errors, return false with error message\n if (response.errors?.length) {\n return {\n creditEnabled: false,\n error: 'Unable to check company credit configuration'\n };\n }\n\n // Check if company credit is enabled in store config\n const companyCreditEnabled = response.data?.storeConfig?.company_credit_enabled;\n \n if (companyCreditEnabled === true) {\n return {\n creditEnabled: true\n };\n }\n\n // If company credit is disabled or not configured\n return {\n creditEnabled: false,\n error: 'Company credit is not enabled in store configuration'\n };\n\n } catch (error) {\n return {\n creditEnabled: false,\n error: 'Company credit functionality not available'\n };\n }\n};\n"],"names":["getCompanyRole","variables","response","fetchGraphQl","GET_COMPANY_ROLE","transformGetCompanyRoleResponse","error","handleNetworkError","flattenPermissionIds","resources","flattenIdsToArray","buildPermissionTree","allResources","selectedIds","selectedSet","filterTree","resource","filteredChildren","_a","child","initialize","config","GET_CUSTOMER_COMPANIES_WITH_ROLES","isCompanyAdmin","customer","_b","companies","_c","customerRole","CompanyCreditOperationType","CHECK_COMPANY_CREDIT_ENABLED","checkCompanyCreditEnabled"],"mappings":"qlCA2BO,MAAMA,EAAiB,MAC5BC,GAC8B,CAC9B,GAAI,CACF,MAAMC,EAAmC,MAAMC,EAAaC,EAAkB,CAC5E,UAAAH,EACA,OAAQ,MACR,MAAO,UAAA,CACR,EAED,OAAOI,EAAgCH,CAAQ,CACjD,OAASI,EAAO,CACd,OAAOC,EAAmBD,CAAc,CAC1C,CACF,EClBaE,EAAwBC,GAC5BC,EAAkBD,CAAS,EAMvBE,EAAsB,CACjCC,EACAC,IAC8B,CAC9B,MAAMC,EAAc,IAAI,IAAID,CAAW,EAEjCE,EAAcC,GAAsE,OACxF,MAAMC,IAAmBC,EAAAF,EAAS,WAAT,YAAAE,EACrB,IAAIH,GACL,OAAQI,GAA4CA,IAAU,QAAS,CAAA,EAE1E,OAAIL,EAAY,IAAIE,EAAS,EAAE,GAAKC,EAAiB,OAAS,EACrD,CACL,GAAGD,EACH,SAAUC,CAAA,EAIP,IACT,EAEA,OAAOL,EACJ,IAAIG,CAAU,EACd,OAAQC,GAAkDA,IAAa,IAAI,CAChF,EChCaI,EAAa,MAAOC,EAA8B,MACtD,CACL,QAAS,GACT,OAAAA,CAAA,GCRSC,EAAkD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EC0BlDC,EAAiB,SAA8B,WAC1D,GAAI,CACF,MAAMrB,EAAW,MAAMC,EAAiDmB,EAAmC,CACzG,OAAQ,MAAA,CACT,EAED,IAAIJ,EAAAhB,EAAS,SAAT,MAAAgB,EAAiB,OACnB,MAAO,GAGT,MAAMM,GAAWC,EAAAvB,EAAS,OAAT,YAAAuB,EAAe,SAChC,GAAI,CAACD,EACH,MAAO,GAIT,MAAME,IAAYC,EAAAH,EAAS,YAAT,YAAAG,EAAoB,QAAS,CAAA,EAC/C,GAAI,CAAC,MAAM,QAAQD,CAAS,GAAKA,EAAU,SAAW,EACpD,MAAO,GAIT,MAAME,EAAeJ,EAAS,KAC9B,OAAKI,EAKEA,EAAa,KAAO,KACnB,OAAOA,EAAa,IAAO,UAAYA,EAAa,KAAO,GAC5DA,EAAa,OAAS,wBANpB,EAOX,OAAStB,EAAO,CACd,eAAQ,MAAM,+CAAgDA,CAAK,EAC5D,EACT,CACF,EC7DO,IAAKuB,GAAAA,IACVA,EAAA,WAAa,aACbA,EAAA,OAAS,SACTA,EAAA,SAAW,WACXA,EAAA,cAAgB,gBAJNA,IAAAA,GAAA,CAAA,CAAA,ECAL,MAAMC,EAA6C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,ECI7CC,EAA4B,SAAwD,WAC/F,GAAI,CACF,MAAM7B,EAAW,MAAMC,EAAa2B,EAA8B,CAChE,OAAQ,MACR,MAAO,UAAA,CACR,EAGD,OAAIZ,EAAAhB,EAAS,SAAT,MAAAgB,EAAiB,OACZ,CACL,cAAe,GACf,MAAO,8CAAA,IAKkBS,GAAAF,EAAAvB,EAAS,OAAT,YAAAuB,EAAe,cAAf,YAAAE,EAA4B,0BAE5B,GACpB,CACL,cAAe,EAAA,EAKZ,CACL,cAAe,GACf,MAAO,sDAAA,CAGX,MAAgB,CACd,MAAO,CACL,cAAe,GACf,MAAO,4CAAA,CAEX,CACF"}
|
|
1
|
+
{"version":3,"file":"api.js","sources":["/@dropins/storefront-company-management/src/api/companyRoles/getCompanyRole.ts","/@dropins/storefront-company-management/src/api/companyRoles/utils.ts","/@dropins/storefront-company-management/src/api/initialize/initialize.ts","/@dropins/storefront-company-management/src/api/checkCompanyCreditEnabled/graphql/checkCompanyCreditEnabled.graphql.ts","/@dropins/storefront-company-management/src/api/checkCompanyCreditEnabled/checkCompanyCreditEnabled.ts","/@dropins/storefront-company-management/src/types/api/getCompanyCreditHistoryParams.types.ts","/@dropins/storefront-company-management/src/api/isCompanyAdmin/graphql/isCompanyAdmin.graphql.ts","/@dropins/storefront-company-management/src/api/isCompanyAdmin/isCompanyAdmin.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 '../fetch-graphql';\nimport { handleNetworkError } from '../../lib/network-error';\nimport { GET_COMPANY_ROLE } from './graphql/queries';\nimport { GetCompanyRoleVariables, GetCompanyRoleResponse } from '../../types/api/companyRoles.types';\nimport { CompanyRoleModel } from '../../data/models/company-role';\nimport { transformGetCompanyRoleResponse } from '../../data/transforms/transform-company-roles';\n\n/**\n * Fetch a single company role by ID\n */\nexport const getCompanyRole = async (\n variables: GetCompanyRoleVariables\n): Promise<CompanyRoleModel> => {\n try {\n const response: GetCompanyRoleResponse = await fetchGraphQl(GET_COMPANY_ROLE, {\n variables,\n method: 'GET',\n cache: 'no-cache',\n });\n\n return transformGetCompanyRoleResponse(response);\n } catch (error) {\n return handleNetworkError(error as Error);\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\nimport { flattenIdsToArray } from '../../lib/company-permissions';\nimport { CompanyAclResourceModel } from '../../data/models/company-role';\n\n/**\n * Helper function to flatten ACL resources into a list of permission IDs\n */\nexport const flattenPermissionIds = (resources: CompanyAclResourceModel[]): string[] => {\n return flattenIdsToArray(resources);\n};\n\n/**\n * Helper function to build a permission tree from flat permission IDs\n */\nexport const buildPermissionTree = (\n allResources: CompanyAclResourceModel[],\n selectedIds: string[]\n): CompanyAclResourceModel[] => {\n const selectedSet = new Set(selectedIds);\n \n const filterTree = (resource: CompanyAclResourceModel): CompanyAclResourceModel | null => {\n const filteredChildren = resource.children\n ?.map(filterTree)\n .filter((child): child is CompanyAclResourceModel => child !== null) || [];\n \n if (selectedSet.has(resource.id) || filteredChildren.length > 0) {\n return {\n ...resource,\n children: filteredChildren,\n };\n }\n \n return null;\n };\n \n return allResources\n .map(filterTree)\n .filter((resource): resource is CompanyAclResourceModel => resource !== null);\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// import { events } from '@adobe-commerce/event-bus';\n\n\nimport { CompanyDropinConfig } from '../../types/api/initialize.types';\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 *******************************************************************/\n\nexport const CHECK_COMPANY_CREDIT_ENABLED = /* GraphQL */ `\n query CHECK_COMPANY_CREDIT_ENABLED {\n storeConfig{\n company_credit_enabled\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\nimport { CHECK_COMPANY_CREDIT_ENABLED } from \"./graphql/checkCompanyCreditEnabled.graphql\";\nimport { CheckCompanyCreditEnabledResponse } from '../../types/api/checkCompanyCreditEnabled.types';\nimport { fetchGraphQl } from '../fetch-graphql';\n\nexport const checkCompanyCreditEnabled = async (): Promise<CheckCompanyCreditEnabledResponse> => {\n try {\n const response = await fetchGraphQl(CHECK_COMPANY_CREDIT_ENABLED, {\n method: 'GET',\n cache: 'no-cache',\n });\n\n // If there are errors, return false with error message\n if (response.errors?.length) {\n return {\n creditEnabled: false,\n error: 'Unable to check company credit configuration'\n };\n }\n\n // Check if company credit is enabled in store config\n const companyCreditEnabled = response.data?.storeConfig?.company_credit_enabled;\n \n if (companyCreditEnabled === true) {\n return {\n creditEnabled: true\n };\n }\n\n // If company credit is disabled or not configured\n return {\n creditEnabled: false,\n error: 'Company credit is not enabled in store configuration'\n };\n\n } catch (error) {\n return {\n creditEnabled: false,\n error: 'Company credit functionality not available'\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\nexport enum CompanyCreditOperationType {\n ALLOCATION = 'ALLOCATION',\n UPDATE = 'UPDATE',\n PURCHASE = 'PURCHASE',\n REIMBURSEMENT = 'REIMBURSEMENT'\n}\n\nexport interface CompanyCreditHistoryFilterInput {\n /**\n * The purchase order number associated with the company credit operation.\n */\n customReferenceNumber?: string;\n\n /**\n * The type of the company credit operation.\n */\n operationType?: CompanyCreditOperationType;\n\n /**\n * The name of the person submitting the company credit operation.\n */\n updatedBy?: string;\n}\n\nexport interface GetCompanyCreditHistoryParams {\n /**\n * Filter criteria for narrowing the results of a credit history search.\n */\n filter?: CompanyCreditHistoryFilterInput;\n\n /**\n * Number of items to return per page.\n * @default 20\n */\n pageSize?: number;\n\n /**\n * Current page number.\n * @default 1\n */\n currentPage?: number;\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\nexport const GET_CUSTOMER_COMPANIES_WITH_ROLES = /* GraphQL */ `\n query GET_CUSTOMER_COMPANIES_WITH_ROLES {\n customer {\n companies(input: {}) {\n items {\n id\n name\n }\n }\n role {\n id\n name\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 \nimport { fetchGraphQl } from '../fetch-graphql';\nimport { GET_CUSTOMER_COMPANIES_WITH_ROLES } from './graphql/isCompanyAdmin.graphql';\n\ninterface CompanyRole {\n id: string;\n name: string;\n}\n\ninterface CompanyBasicInfo {\n id: string;\n name: string;\n}\n\ninterface CustomerCompaniesWithRolesResponse {\n customer: {\n companies: {\n items: CompanyBasicInfo[];\n };\n role: CompanyRole | null;\n } | null;\n}\n\n/**\n * Check if the current authenticated customer is a company administrator in any company\n * @returns Promise<boolean> - true if customer is a company admin in at least one company, false otherwise\n */\nexport const isCompanyAdmin = async (): Promise<boolean> => {\n try {\n const response = await fetchGraphQl<CustomerCompaniesWithRolesResponse>(GET_CUSTOMER_COMPANIES_WITH_ROLES, {\n method: 'POST',\n });\n\n if (response.errors?.length) {\n return false;\n }\n\n const customer = response.data?.customer;\n if (!customer) {\n return false;\n }\n\n // Check if user is part of at least one company\n const companies = customer.companies?.items ?? [];\n if (!Array.isArray(companies) || companies.length === 0) {\n return false;\n }\n\n // Check if user has admin role\n const customerRole = customer.role;\n if (!customerRole) {\n return false;\n }\n\n // Check if user is company administrator by role ID or name\n return customerRole.id === '0' || \n (typeof customerRole.id === 'number' && customerRole.id === 0) ||\n customerRole.name === 'Company Administrator';\n } catch (error) {\n console.error('Error checking if customer is company admin:', error);\n return false;\n }\n};\n"],"names":["getCompanyRole","variables","response","fetchGraphQl","GET_COMPANY_ROLE","transformGetCompanyRoleResponse","error","handleNetworkError","flattenPermissionIds","resources","flattenIdsToArray","buildPermissionTree","allResources","selectedIds","selectedSet","filterTree","resource","filteredChildren","_a","child","initialize","config","CHECK_COMPANY_CREDIT_ENABLED","checkCompanyCreditEnabled","_c","_b","CompanyCreditOperationType","GET_CUSTOMER_COMPANIES_WITH_ROLES","isCompanyAdmin","customer","companies","customerRole"],"mappings":"ooCA2BO,MAAMA,EAAiB,MAC5BC,GAC8B,CAC9B,GAAI,CACF,MAAMC,EAAmC,MAAMC,EAAaC,EAAkB,CAC5E,UAAAH,EACA,OAAQ,MACR,MAAO,UAAA,CACR,EAED,OAAOI,EAAgCH,CAAQ,CACjD,OAASI,EAAO,CACd,OAAOC,EAAmBD,CAAc,CAC1C,CACF,EClBaE,EAAwBC,GAC5BC,EAAkBD,CAAS,EAMvBE,EAAsB,CACjCC,EACAC,IAC8B,CAC9B,MAAMC,EAAc,IAAI,IAAID,CAAW,EAEjCE,EAAcC,GAAsE,OACxF,MAAMC,IAAmBC,EAAAF,EAAS,WAAT,YAAAE,EACrB,IAAIH,GACL,OAAQI,GAA4CA,IAAU,QAAS,CAAA,EAE1E,OAAIL,EAAY,IAAIE,EAAS,EAAE,GAAKC,EAAiB,OAAS,EACrD,CACL,GAAGD,EACH,SAAUC,CAAA,EAIP,IACT,EAEA,OAAOL,EACJ,IAAIG,CAAU,EACd,OAAQC,GAAkDA,IAAa,IAAI,CAChF,EChCaI,EAAa,MAAOC,EAA8B,MACtD,CACL,QAAS,GACT,OAAAA,CAAA,GCRSC,EAA6C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,ECI7CC,EAA4B,SAAwD,WAC/F,GAAI,CACF,MAAMrB,EAAW,MAAMC,EAAamB,EAA8B,CAChE,OAAQ,MACR,MAAO,UAAA,CACR,EAGD,OAAIJ,EAAAhB,EAAS,SAAT,MAAAgB,EAAiB,OACZ,CACL,cAAe,GACf,MAAO,8CAAA,IAKkBM,GAAAC,EAAAvB,EAAS,OAAT,YAAAuB,EAAe,cAAf,YAAAD,EAA4B,0BAE5B,GACpB,CACL,cAAe,EAAA,EAKZ,CACL,cAAe,GACf,MAAO,sDAAA,CAGX,MAAgB,CACd,MAAO,CACL,cAAe,GACf,MAAO,4CAAA,CAEX,CACF,ECxCO,IAAKE,GAAAA,IACVA,EAAA,WAAa,aACbA,EAAA,OAAS,SACTA,EAAA,SAAW,WACXA,EAAA,cAAgB,gBAJNA,IAAAA,GAAA,CAAA,CAAA,ECAL,MAAMC,EAAkD;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,EC0BlDC,EAAiB,SAA8B,WAC1D,GAAI,CACF,MAAM1B,EAAW,MAAMC,EAAiDwB,EAAmC,CACzG,OAAQ,MAAA,CACT,EAED,IAAIT,EAAAhB,EAAS,SAAT,MAAAgB,EAAiB,OACnB,MAAO,GAGT,MAAMW,GAAWJ,EAAAvB,EAAS,OAAT,YAAAuB,EAAe,SAChC,GAAI,CAACI,EACH,MAAO,GAIT,MAAMC,IAAYN,EAAAK,EAAS,YAAT,YAAAL,EAAoB,QAAS,CAAA,EAC/C,GAAI,CAAC,MAAM,QAAQM,CAAS,GAAKA,EAAU,SAAW,EACpD,MAAO,GAIT,MAAMC,EAAeF,EAAS,KAC9B,OAAKE,EAKEA,EAAa,KAAO,KACnB,OAAOA,EAAa,IAAO,UAAYA,EAAa,KAAO,GAC5DA,EAAa,OAAS,wBANpB,EAOX,OAASzB,EAAO,CACd,eAAQ,MAAM,+CAAgDA,CAAK,EAC5D,EACT,CACF"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
1
|
/*! Copyright 2025 Adobe
|
|
2
2
|
All Rights Reserved. */
|
|
3
|
-
import{jsxs as F,jsx as s}from"@dropins/tools/preact-jsx-runtime.js";import{memo as X}from"@dropins/tools/preact-compat.js";import{useState as p,useEffect as J}from"@dropins/tools/preact-hooks.js";import{Card as K,InLineAlert as Q,ProgressSpinner as W,Field as
|
|
3
|
+
import{jsxs as F,jsx as s}from"@dropins/tools/preact-jsx-runtime.js";import{memo as X}from"@dropins/tools/preact-compat.js";import{useState as p,useEffect as J}from"@dropins/tools/preact-hooks.js";import{Card as K,InLineAlert as Q,ProgressSpinner as W,Field as I,Input as A,Picker as P,Button as D}from"@dropins/tools/components.js";import{i as Y}from"./company-permissions.js";import{g as Z,c as ee,a as te,i as ae}from"./updateCompanyUserStatus.js";import{useText as H}from"@dropins/tools/i18n.js";import{u as re}from"./useCompanyRoles.js";import{b as se}from"./CompanyLoaders.js";const y={firstName:255,lastName:255,email:254,jobTitle:255,telephone:20};function oe(M){const{mode:x,entityId:g,parentStructureId:E,onSaved:q,onError:b,onSuccess:v}=M,l=H({firstNameRequired:"Company.CompanyStructure.shared.validation.firstNameRequired",lastNameRequired:"Company.CompanyStructure.shared.validation.lastNameRequired",emailRequired:"Company.CompanyStructure.shared.validation.emailRequired",emailInvalid:"Company.CompanyStructure.shared.validation.emailInvalid",jobTitleRequired:"Company.CompanyStructure.shared.validation.jobTitleRequired",workPhoneRequired:"Company.CompanyStructure.shared.validation.workPhoneRequired",selectRole:"Company.CompanyStructure.shared.validation.selectRole",firstNameMaxLength:"Company.CompanyStructure.shared.validation.firstNameMaxLength",lastNameMaxLength:"Company.CompanyStructure.shared.validation.lastNameMaxLength",emailMaxLength:"Company.CompanyStructure.shared.validation.emailMaxLength",jobTitleMaxLength:"Company.CompanyStructure.shared.validation.jobTitleMaxLength",telephoneMaxLength:"Company.CompanyStructure.shared.validation.telephoneMaxLength",createUserError:"Company.CompanyStructure.messages.createUserError",saveUserError:"Company.CompanyStructure.messages.saveUserError",createUserSuccess:"Company.CompanyStructure.messages.createUserSuccess",updateUserSuccess:"Company.CompanyStructure.messages.updateUserSuccess"}),[r,L]=p({firstName:"",lastName:"",email:"",jobTitle:"",telephone:"",roleId:"",status:"ACTIVE"}),[w,d]=p({}),[m,h]=p({}),[V,U]=p(!1),[f,R]=p(null),[_,j]=p(null),[S,k]=p(""),[n,a]=p(""),[o,B]=p(!1);J(()=>{x!=="edit"||!g||(U(!0),Z(g).then(e=>{var C;if(!e)return;const t=e.email||"";L(N=>({...N,firstName:e.firstName||"",lastName:e.lastName||"",email:t,jobTitle:e.jobTitle||"",telephone:e.telephone||"",status:e.status||"ACTIVE"})),a(t),(C=e==null?void 0:e.role)!=null&&C.id&&L(N=>({...N,roleId:e.role.id})),B((e==null?void 0:e.isCompanyAdmin)??!1)}).finally(()=>U(!1)))},[x,g]);const z=e=>/.+@.+\..+/.test(e),$=(e,t)=>e==="firstName"?t!=null&&t.trim()?t.length>y.firstName?l.firstNameMaxLength:null:l.firstNameRequired:e==="lastName"?t!=null&&t.trim()?t.length>y.lastName?l.lastNameMaxLength:null:l.lastNameRequired:e==="email"?t!=null&&t.trim()?t.length>y.email?l.emailMaxLength:z(t.trim())?null:l.emailInvalid:l.emailRequired:e==="jobTitle"?t&&t.length>y.jobTitle?l.jobTitleMaxLength:null:e==="telephone"?t&&t.length>y.telephone?l.telephoneMaxLength:null:e==="roleId"?t?null:l.selectRole:null,G=(e,t)=>{L(C=>({...C,[e]:t})),e==="email"&&j(null),f&&R(null)};return{values:r,errors:w,touched:m,loading:V,setValue:G,onBlur:async(e,t)=>{t!==void 0&&G(e,t),h(T=>({...T,[e]:!0}));const C=t!==void 0?t:r[e],N=$(e,C);if(d(N?T=>({...T,[e]:N}):T=>{const u={...T};return delete u[e],u}),e==="email"){const u=(t!==void 0?t:r.email||"").trim();if(x==="edit"&&u.toLowerCase()===(n||"").trim().toLowerCase()){j(null);return}if(z(u)&&u!==S){const i=await ae(u);k(u),j(i),i===!1&&d(c=>({...c,email:"A user with this email address is already a member of your company."}))}}},submit:async()=>{const e=["firstName","lastName","email","roleId","jobTitle","telephone"],t={},C={};for(const i of e){C[i]=!0;const c=$(i,r[i]);c&&(t[i]=c)}if(d(t),h(C),Object.keys(t).length||_===!1){setTimeout(()=>{const i=document.querySelector(".company-user-form__content .dropin-field__hint--error");if(i){const c=i.closest(".dropin-field");if(c){c.scrollIntoView({behavior:"smooth",block:"center"});const O=c.querySelector("input, select");O&&O.focus()}}},100);return}const N=`${r.firstName||""} ${r.lastName||""}`.trim()||r.email||"",u=o||Y({id:r.roleId})?"ACTIVE":r.status;try{if(x==="add"){const i=await ee({email:r.email||"",firstName:r.firstName||"",lastName:r.lastName||"",jobTitle:r.jobTitle||"",telephone:r.telephone||"",roleId:r.roleId,status:u,targetId:E??null});if(!i){const c=l.createUserError;b?b(c):R(c);return}q({label:N,structureId:i.structureId,entityId:i.id,type:"user",status:u,jobTitle:i.jobTitle}),v&&v(l.createUserSuccess)}else g&&(await te({id:g,email:r.email||"",firstName:r.firstName||"",lastName:r.lastName||"",jobTitle:r.jobTitle||"",telephone:r.telephone||"",status:u,roleId:r.roleId}),q({label:N,entityId:g,type:"user",status:u,jobTitle:r.jobTitle}),v&&v(l.updateUserSuccess))}catch(i){const c=i instanceof Error?i.message:l.saveUserError;b?b(c):R(c)}},isCompanyAdmin:o,generalError:f}}const Ce=X(({mode:M,entityId:x,parentStructureId:g,permissions:E,onSaved:q,onCancel:b,onError:v,onSuccess:l})=>{const r=(E==null?void 0:E.canEditUsers)??!1,{roles:L,isLoading:w}=re(),{values:d,errors:m,touched:h,loading:V,setValue:U,onBlur:f,submit:R,isCompanyAdmin:_,generalError:j}=oe({mode:M,entityId:x,parentStructureId:g,onSaved:q,onError:v?a=>{v(a),b()}:void 0,onSuccess:l}),[S,k]=p(!1),n=H({addUser:"Company.CompanyStructure.shared.titles.addUser",editUser:"Company.CompanyStructure.shared.titles.editUser",jobTitle:"Company.CompanyStructure.shared.fields.jobTitle",userRole:"Company.CompanyStructure.shared.fields.userRole",firstName:"Company.CompanyStructure.shared.fields.firstName",lastName:"Company.CompanyStructure.shared.fields.lastName",email:"Company.CompanyStructure.shared.fields.email",workPhoneNumber:"Company.CompanyStructure.shared.fields.workPhoneNumber",status:"Company.CompanyStructure.shared.fields.status",selectRole:"Company.CompanyStructure.shared.options.selectRole",active:"Company.CompanyStructure.shared.options.active",inactive:"Company.CompanyStructure.shared.options.inactive",companyAdministrator:"Company.CompanyStructure.shared.options.companyAdministrator",save:"Company.CompanyStructure.shared.buttons.save",cancel:"Company.CompanyStructure.shared.buttons.cancel"});return F("div",{children:[s("h3",{className:"acm-structure-panel__title",children:M==="add"?n.addUser:n.editUser}),F(K,{variant:"secondary",className:`company-user-form__card ${S?"is-working":""}`,children:[!v&&j?s(Q,{className:"company-user-form__notification",type:"error",variant:"secondary",heading:j}):null,S?s("div",{className:"company-user-form__overlay","aria-live":"polite",children:s(W,{size:"small"})}):null,V||w?s(se,{}):F("div",{className:"company-user-form__content",children:[s(I,{label:n.jobTitle,className:"acm-structure-panel__field",error:h.jobTitle&&m.jobTitle?m.jobTitle:void 0,children:s(A,{name:"job_title",type:"text",value:d.jobTitle||"",onBlur:a=>{const o=a.target;f("jobTitle",o.value)},variant:"primary",size:"medium",maxLength:y.jobTitle})}),s(I,{label:n.userRole,required:!0,className:"acm-structure-panel__field",error:!_&&h.roleId&&m.roleId?m.roleId:void 0,disabled:_,children:_?s(P,{name:"role",value:"MA==",options:[{value:"MA==",text:n.companyAdministrator}]}):s(P,{name:"role",value:d.roleId||"placeholder",onChange:a=>{var o,B;return U("roleId",String(((o=a==null?void 0:a.target)==null?void 0:o.value)==="placeholder"?"":((B=a==null?void 0:a.target)==null?void 0:B.value)??""))},onBlur:a=>{const o=a.target;f("roleId",o.value==="placeholder"?"":o.value)},options:[{value:"placeholder",text:n.selectRole,disabled:!0},...L.map(a=>({value:a.id,text:a.name}))]})}),s(I,{label:n.firstName,required:!0,className:"acm-structure-panel__field",error:h.firstName&&m.firstName?m.firstName:void 0,children:s(A,{name:"first_name",type:"text",value:d.firstName,onBlur:a=>{const o=a.target;f("firstName",o.value)},variant:"primary",size:"medium",maxLength:y.firstName})}),s(I,{label:n.lastName,required:!0,className:"acm-structure-panel__field",error:h.lastName&&m.lastName?m.lastName:void 0,children:s(A,{name:"last_name",type:"text",value:d.lastName,onBlur:a=>{const o=a.target;f("lastName",o.value)},variant:"primary",size:"medium",maxLength:y.lastName})}),s(I,{label:n.email,required:!0,className:"acm-structure-panel__field",error:h.email&&m.email?m.email:void 0,children:s(A,{name:"email",type:"email",value:d.email,onBlur:a=>{const o=a.target;f("email",o.value)},placeholder:"jdoe@example.com",variant:"primary",size:"medium",maxLength:y.email})}),s(I,{label:n.workPhoneNumber,className:"acm-structure-panel__field",error:h.telephone&&m.telephone?m.telephone:void 0,children:s(A,{name:"telephone",type:"text",value:d.telephone||"",onBlur:a=>{const o=a.target;f("telephone",o.value)},variant:"primary",size:"medium",maxLength:y.telephone})}),s(I,{label:n.status,className:"acm-structure-panel__field",disabled:_||!r,children:s(P,{name:"status",value:d.status,onChange:a=>{var o;return U("status",String(((o=a==null?void 0:a.target)==null?void 0:o.value)??"ACTIVE"))},options:[{value:"ACTIVE",text:n.active},{value:"INACTIVE",text:n.inactive}]})})]})]}),V||w?null:F("div",{className:"acm-structure-modal__actions",children:[s(D,{type:"button",variant:"primary",disabled:S||!r,onClick:async()=>{if(!S){k(!0);try{await R()}finally{k(!1)}}},children:n.save}),s(D,{type:"button",variant:"secondary",disabled:S,onClick:b,children:n.cancel})]})]})});export{Ce as C};
|
|
4
4
|
//# sourceMappingURL=CompanyUserForm.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"CompanyUserForm.js","sources":["/@dropins/storefront-company-management/src/hooks/useCompanyUserForm.ts","/@dropins/storefront-company-management/src/components/CompanyUserForm/CompanyUserForm.tsx"],"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 *******************************************************************/\nimport { useEffect, useState } from 'preact/hooks';\nimport { createCompanyUser, getCompanyUser, isCompanyUserEmailAvailable, updateCompanyUser } from '@/company-management/api';\nimport { isCompanyAdministrator } from '@/company-management/lib';\nimport { CompanyUserModel } from '@/company-management/data/models';\nimport { useText } from '@adobe-commerce/elsie/i18n';\n\nexport type UserStatus = 'ACTIVE' | 'INACTIVE';\n\n// Field length constants (based on Magento backend validation)\nexport const FIELD_MAX_LENGTHS = {\n firstName: 255,\n lastName: 255,\n email: 254,\n jobTitle: 255,\n telephone: 20,\n} as const;\n\nexport function useCompanyUserForm(opts: {\n mode: 'add' | 'edit';\n entityId?: string;\n parentStructureId?: string | null;\n onSaved: (result: { label: string; structureId?: string; entityId?: string; type: 'user' }) => void;\n onError?: (error: string) => void;\n onSuccess?: (message: string) => void;\n}) {\n const { mode, entityId, parentStructureId, onSaved, onError, onSuccess } = opts;\n \n const translations = useText({\n firstNameRequired: 'Company.CompanyStructure.shared.validation.firstNameRequired',\n lastNameRequired: 'Company.CompanyStructure.shared.validation.lastNameRequired',\n emailRequired: 'Company.CompanyStructure.shared.validation.emailRequired',\n emailInvalid: 'Company.CompanyStructure.shared.validation.emailInvalid',\n jobTitleRequired: 'Company.CompanyStructure.shared.validation.jobTitleRequired',\n workPhoneRequired: 'Company.CompanyStructure.shared.validation.workPhoneRequired',\n selectRole: 'Company.CompanyStructure.shared.validation.selectRole',\n firstNameMaxLength: 'Company.CompanyStructure.shared.validation.firstNameMaxLength',\n lastNameMaxLength: 'Company.CompanyStructure.shared.validation.lastNameMaxLength',\n emailMaxLength: 'Company.CompanyStructure.shared.validation.emailMaxLength',\n jobTitleMaxLength: 'Company.CompanyStructure.shared.validation.jobTitleMaxLength',\n telephoneMaxLength: 'Company.CompanyStructure.shared.validation.telephoneMaxLength',\n createUserError: 'Company.CompanyStructure.messages.createUserError',\n saveUserError: 'Company.CompanyStructure.messages.saveUserError',\n createUserSuccess: 'Company.CompanyStructure.messages.createUserSuccess',\n updateUserSuccess: 'Company.CompanyStructure.messages.updateUserSuccess',\n });\n const [values, setValues] = useState<Partial<CompanyUserModel> & { roleId: string; status: UserStatus }>({ \n firstName: '', \n lastName: '', \n email: '', \n jobTitle: '', \n telephone: '', \n roleId: '', \n status: 'ACTIVE' \n });\n const [errors, setErrors] = useState<Record<string, string>>({});\n const [touched, setTouched] = useState<Record<string, boolean>>({});\n const [loading, setLoading] = useState(false);\n const [generalError, setGeneralError] = useState<string | null>(null);\n const [emailAvailable, setEmailAvailable] = useState<boolean | null>(null);\n const [emailChecked, setEmailChecked] = useState<string>('');\n const [originalEmail, setOriginalEmail] = useState<string>('');\n const [isCompanyAdmin, setIsCompanyAdmin] = useState<boolean>(false);\n\n useEffect(() => {\n if (mode !== 'edit' || !entityId) return;\n setLoading(true);\n void getCompanyUser(entityId).then((u) => {\n if (!u) return;\n const loadedEmail = u.email || '';\n setValues((v) => ({ ...v, firstName: u.firstName || '', lastName: u.lastName || '', email: loadedEmail, jobTitle: u.jobTitle || '', telephone: u.telephone || '', status: (u.status || 'ACTIVE') as UserStatus }));\n setOriginalEmail(loadedEmail);\n if (u?.role?.id) setValues((v) => ({ ...v, roleId: u.role!.id }));\n setIsCompanyAdmin(u?.isCompanyAdmin ?? false);\n }).finally(() => setLoading(false));\n }, [mode, entityId]);\n\n const isEmailValid = (value: string): boolean => /.+@.+\\..+/.test(value);\n const validateField = (field: keyof CompanyUserModel | 'roleId', value: any): string | null => {\n if (field === 'firstName') {\n if (!value?.trim()) return translations.firstNameRequired;\n if (value.length > FIELD_MAX_LENGTHS.firstName) return translations.firstNameMaxLength;\n return null;\n }\n if (field === 'lastName') {\n if (!value?.trim()) return translations.lastNameRequired;\n if (value.length > FIELD_MAX_LENGTHS.lastName) return translations.lastNameMaxLength;\n return null;\n }\n if (field === 'email') {\n if (!value?.trim()) return translations.emailRequired;\n if (value.length > FIELD_MAX_LENGTHS.email) return translations.emailMaxLength;\n return isEmailValid(value.trim()) ? null : translations.emailInvalid;\n }\n // jobTitle and telephone are now optional fields (USF-3012)\n if (field === 'jobTitle') {\n if (value && value.length > FIELD_MAX_LENGTHS.jobTitle) return translations.jobTitleMaxLength;\n return null;\n }\n if (field === 'telephone') {\n if (value && value.length > FIELD_MAX_LENGTHS.telephone) return translations.telephoneMaxLength;\n return null;\n }\n if (field === 'roleId') return value ? null : translations.selectRole;\n return null;\n };\n\n const setValue = (field: keyof CompanyUserModel | 'roleId', value: any) => {\n setValues((v) => ({ ...v, [field]: value }));\n if (field === 'email') setEmailAvailable(null);\n if (generalError) setGeneralError(null);\n };\n\n const onBlur = async (field: keyof CompanyUserModel | 'roleId', value?: any) => {\n // Update form data if value is provided (this preserves spaces and other characters)\n if (value !== undefined) {\n setValue(field, value);\n }\n \n setTouched((t) => ({ ...t, [field]: true }));\n \n // Use provided value or current state value for validation\n const valueToValidate = value !== undefined ? value : values[field];\n const err = validateField(field, valueToValidate);\n if (err) {\n setErrors((p) => ({ ...p, [field]: err }));\n } else {\n // Clear error if field is now valid\n setErrors((p) => {\n const newErrors = { ...p };\n delete newErrors[field];\n return newErrors;\n });\n }\n \n if (field === 'email') {\n const emailValue = value !== undefined ? value : (values.email || '');\n const trimmed = emailValue.trim();\n if (mode === 'edit' && trimmed.toLowerCase() === (originalEmail || '').trim().toLowerCase()) {\n setEmailAvailable(null);\n return;\n }\n if (isEmailValid(trimmed) && trimmed !== emailChecked) {\n const available = await isCompanyUserEmailAvailable(trimmed);\n setEmailChecked(trimmed);\n setEmailAvailable(available);\n if (available === false) setErrors((p) => ({ ...p, email: 'A user with this email address is already a member of your company.' }));\n }\n }\n };\n\n const submit = async () => {\n // Validate all fields including optional ones for length (USF-3474)\n const fields: (keyof CompanyUserModel | 'roleId')[] = ['firstName', 'lastName', 'email', 'roleId', 'jobTitle', 'telephone'];\n const next: Record<string, string> = {};\n const touchedFields: Record<string, boolean> = {};\n \n for (const f of fields) {\n touchedFields[f as string] = true;\n const err = validateField(f, values[f]);\n if (err) next[f as string] = err;\n }\n \n setErrors(next);\n setTouched(touchedFields);\n \n if (Object.keys(next).length || emailAvailable === false) {\n // Scroll to the first error field\n setTimeout(() => {\n const firstErrorField = document.querySelector('.company-user-form__content .dropin-field__hint--error');\n if (firstErrorField) {\n const fieldContainer = firstErrorField.closest('.dropin-field');\n if (fieldContainer) {\n fieldContainer.scrollIntoView({ behavior: 'smooth', block: 'center' });\n const input = fieldContainer.querySelector('input, select') as HTMLElement;\n if (input) {\n input.focus();\n }\n }\n }\n }, 100);\n return;\n }\n\n const label = `${values.firstName || ''} ${values.lastName || ''}`.trim() || values.email || '';\n const adminEffective = isCompanyAdmin || isCompanyAdministrator({ id: values.roleId });\n const effectiveStatus = adminEffective ? 'ACTIVE' : values.status;\n try {\n if (mode === 'add') {\n const res = await createCompanyUser({ email: values.email || '', firstName: values.firstName || '', lastName: values.lastName || '', jobTitle: values.jobTitle || '', telephone: values.telephone || '', roleId: values.roleId, status: effectiveStatus, targetId: parentStructureId ?? null });\n if (!res) {\n const errorMessage = translations.createUserError;\n if (onError) {\n onError(errorMessage);\n } else {\n setGeneralError(errorMessage);\n }\n return;\n }\n onSaved({ label, structureId: res.structureId, entityId: res.id, type: 'user' });\n if (onSuccess) {\n onSuccess(translations.createUserSuccess);\n }\n } else if (entityId) {\n await updateCompanyUser({ id: entityId, email: values.email || '', firstName: values.firstName || '', lastName: values.lastName || '', jobTitle: values.jobTitle || '', telephone: values.telephone || '', status: effectiveStatus, roleId: values.roleId });\n onSaved({ label, entityId, type: 'user' });\n if (onSuccess) {\n onSuccess(translations.updateUserSuccess);\n }\n }\n } catch (error: unknown) {\n const errorMessage = error instanceof Error ? error.message : translations.saveUserError;\n if (onError) {\n onError(errorMessage);\n } else {\n setGeneralError(errorMessage);\n }\n }\n };\n\n return { values, errors, touched, loading, setValue, onBlur, submit, isCompanyAdmin, generalError };\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 { FunctionComponent } from 'preact';\nimport { memo } from 'preact/compat';\nimport { useState } from 'preact/hooks';\nimport { Field, Input, Button, Card, Picker, ProgressSpinner, InLineAlert } from '@adobe-commerce/elsie/components';\nimport { useText } from '@adobe-commerce/elsie/i18n';\nimport { CompanyUserFormLoader } from '@/company-management/components/CompanyLoaders';\nimport { useCompanyUserForm, FIELD_MAX_LENGTHS } from '@/company-management/hooks/useCompanyUserForm';\nimport { useCompanyRoles } from '@/company-management/hooks/useCompanyRoles';\nimport { CompanyUserFormProps } from '@/company-management/types/companyForm.types';\nimport './CompanyUserForm.css';\n\n/**\n * CompanyUserForm component for creating and editing company users\n * Provides form fields for user information including name, email, role, and status\n */\nexport const CompanyUserForm: FunctionComponent<CompanyUserFormProps> = memo(({ mode, entityId, parentStructureId, permissions, onSaved, onCancel, onError, onSuccess }) => {\n const canEditUsers = permissions?.canEditUsers ?? false;\n const { roles, isLoading: rolesLoading } = useCompanyRoles();\n const { values, errors, touched, loading, setValue, onBlur, submit, isCompanyAdmin, generalError } = useCompanyUserForm({ \n mode, \n entityId, \n parentStructureId, \n onSaved,\n onError: onError ? (error: string) => {\n onError(error);\n onCancel();\n } : undefined,\n onSuccess\n });\n const [saving, setSaving] = useState(false);\n \n const translations = useText({\n addUser: 'Company.CompanyStructure.shared.titles.addUser',\n editUser: 'Company.CompanyStructure.shared.titles.editUser',\n jobTitle: 'Company.CompanyStructure.shared.fields.jobTitle',\n userRole: 'Company.CompanyStructure.shared.fields.userRole',\n firstName: 'Company.CompanyStructure.shared.fields.firstName',\n lastName: 'Company.CompanyStructure.shared.fields.lastName',\n email: 'Company.CompanyStructure.shared.fields.email',\n workPhoneNumber: 'Company.CompanyStructure.shared.fields.workPhoneNumber',\n status: 'Company.CompanyStructure.shared.fields.status',\n selectRole: 'Company.CompanyStructure.shared.options.selectRole',\n active: 'Company.CompanyStructure.shared.options.active',\n inactive: 'Company.CompanyStructure.shared.options.inactive',\n companyAdministrator: 'Company.CompanyStructure.shared.options.companyAdministrator',\n save: 'Company.CompanyStructure.shared.buttons.save',\n cancel: 'Company.CompanyStructure.shared.buttons.cancel',\n });\n\n return (\n <div>\n <h3 className=\"acm-structure-panel__title\">{mode === 'add' ? translations.addUser : translations.editUser}</h3>\n <Card variant=\"secondary\" className={`company-user-form__card ${saving ? 'is-working' : ''}`}>\n {!onError && generalError ? (\n <InLineAlert \n className=\"company-user-form__notification\" \n type=\"error\" \n variant=\"secondary\" \n heading={generalError} \n />\n ) : null}\n {saving ? <div className=\"company-user-form__overlay\" aria-live=\"polite\"><ProgressSpinner size=\"small\" /></div> : null}\n {loading || rolesLoading ? (\n <CompanyUserFormLoader />\n ) : (\n <div className=\"company-user-form__content\">\n\n <Field label={translations.jobTitle} className=\"acm-structure-panel__field\" error={touched.jobTitle && errors.jobTitle ? errors.jobTitle : undefined}>\n <Input name=\"job_title\" type=\"text\" value={values.jobTitle || ''} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('jobTitle', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.jobTitle} />\n </Field>\n\n <Field label={translations.userRole} required className=\"acm-structure-panel__field\" error={!isCompanyAdmin && touched.roleId && errors.roleId ? errors.roleId : undefined} disabled={isCompanyAdmin}>\n {isCompanyAdmin ? (\n <Picker name=\"role\" value={'MA=='} options={[{ value: 'MA==', text: translations.companyAdministrator }]} />\n ) : (\n <Picker\n name=\"role\"\n value={values.roleId || 'placeholder'}\n onChange={(e: any) => setValue('roleId', String(e?.target?.value === 'placeholder' ? '' : e?.target?.value ?? ''))}\n onBlur={(e: Event) => { const target = e.target as HTMLSelectElement; void onBlur('roleId', target.value === 'placeholder' ? '' : target.value); }}\n options={[{ value: 'placeholder', text: translations.selectRole, disabled: true }, ...roles.map((r) => ({ value: r.id, text: r.name }))]}\n />\n )}\n </Field>\n\n <Field label={translations.firstName} required className=\"acm-structure-panel__field\" error={touched.firstName && errors.firstName ? errors.firstName : undefined}>\n <Input name=\"first_name\" type=\"text\" value={values.firstName} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('firstName', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.firstName} />\n </Field>\n\n <Field label={translations.lastName} required className=\"acm-structure-panel__field\" error={touched.lastName && errors.lastName ? errors.lastName : undefined}>\n <Input name=\"last_name\" type=\"text\" value={values.lastName} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('lastName', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.lastName} />\n </Field>\n\n <Field label={translations.email} required className=\"acm-structure-panel__field\" error={touched.email && errors.email ? errors.email : undefined}>\n <Input name=\"email\" type=\"email\" value={values.email} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; void onBlur('email', target.value); }} placeholder=\"jdoe@example.com\" variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.email} />\n </Field>\n\n <Field label={translations.workPhoneNumber} className=\"acm-structure-panel__field\" error={touched.telephone && errors.telephone ? errors.telephone : undefined}>\n <Input name=\"telephone\" type=\"text\" value={values.telephone || ''} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('telephone', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.telephone} />\n </Field>\n\n <Field label={translations.status} className=\"acm-structure-panel__field\" disabled={isCompanyAdmin || !canEditUsers}>\n <Picker\n name=\"status\"\n value={values.status}\n onChange={(e: any) => setValue('status', String(e?.target?.value ?? 'ACTIVE'))}\n options={[{ value: 'ACTIVE', text: translations.active }, { value: 'INACTIVE', text: translations.inactive }]}\n />\n </Field>\n </div>\n )}\n </Card>\n {!(loading || rolesLoading) ? (\n <div className=\"acm-structure-modal__actions\">\n <Button type=\"button\" variant=\"primary\" disabled={saving || !canEditUsers} onClick={async () => { if (saving) return; setSaving(true); try { await submit(); } finally { setSaving(false); } }}>\n {translations.save}\n </Button>\n <Button\n type=\"button\"\n variant=\"secondary\"\n disabled={saving}\n onClick={onCancel}\n >\n {translations.cancel}\n </Button>\n </div>\n ) : null}\n </div>\n );\n});\n\nexport default CompanyUserForm;\n"],"names":["FIELD_MAX_LENGTHS","useCompanyUserForm","opts","mode","entityId","parentStructureId","onSaved","onError","onSuccess","translations","useText","values","setValues","useState","errors","setErrors","touched","setTouched","loading","setLoading","generalError","setGeneralError","emailAvailable","setEmailAvailable","emailChecked","setEmailChecked","originalEmail","setOriginalEmail","isCompanyAdmin","setIsCompanyAdmin","useEffect","getCompanyUser","u","loadedEmail","v","_a","isEmailValid","value","validateField","field","setValue","t","valueToValidate","err","p","newErrors","trimmed","available","isCompanyUserEmailAvailable","fields","next","touchedFields","f","firstErrorField","fieldContainer","input","label","effectiveStatus","isCompanyAdministrator","res","createCompanyUser","errorMessage","updateCompanyUser","error","CompanyUserForm","memo","permissions","onCancel","canEditUsers","roles","rolesLoading","useCompanyRoles","onBlur","submit","saving","setSaving","jsx","jsxs","Card","InLineAlert","ProgressSpinner","CompanyUserFormLoader","Field","Input","e","target","Picker","_b","r","Button"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"CompanyUserForm.js","sources":["/@dropins/storefront-company-management/src/hooks/useCompanyUserForm.ts","/@dropins/storefront-company-management/src/components/CompanyUserForm/CompanyUserForm.tsx"],"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 *******************************************************************/\nimport { useEffect, useState } from 'preact/hooks';\nimport { createCompanyUser, getCompanyUser, isCompanyUserEmailAvailable, updateCompanyUser } from '@/company-management/api';\nimport { isCompanyAdministrator } from '@/company-management/lib';\nimport { CompanyUserModel } from '@/company-management/data/models';\nimport { useText } from '@adobe-commerce/elsie/i18n';\n\nexport type UserStatus = 'ACTIVE' | 'INACTIVE';\n\n// Field length constants (based on Magento backend validation)\nexport const FIELD_MAX_LENGTHS = {\n firstName: 255,\n lastName: 255,\n email: 254,\n jobTitle: 255,\n telephone: 20,\n} as const;\n\nexport function useCompanyUserForm(opts: {\n mode: 'add' | 'edit';\n entityId?: string;\n parentStructureId?: string | null;\n onSaved: (result: { label: string; structureId?: string; entityId?: string; type: 'user'; status?: UserStatus; jobTitle?: string | null }) => void;\n onError?: (error: string) => void;\n onSuccess?: (message: string) => void;\n}) {\n const { mode, entityId, parentStructureId, onSaved, onError, onSuccess } = opts;\n \n const translations = useText({\n firstNameRequired: 'Company.CompanyStructure.shared.validation.firstNameRequired',\n lastNameRequired: 'Company.CompanyStructure.shared.validation.lastNameRequired',\n emailRequired: 'Company.CompanyStructure.shared.validation.emailRequired',\n emailInvalid: 'Company.CompanyStructure.shared.validation.emailInvalid',\n jobTitleRequired: 'Company.CompanyStructure.shared.validation.jobTitleRequired',\n workPhoneRequired: 'Company.CompanyStructure.shared.validation.workPhoneRequired',\n selectRole: 'Company.CompanyStructure.shared.validation.selectRole',\n firstNameMaxLength: 'Company.CompanyStructure.shared.validation.firstNameMaxLength',\n lastNameMaxLength: 'Company.CompanyStructure.shared.validation.lastNameMaxLength',\n emailMaxLength: 'Company.CompanyStructure.shared.validation.emailMaxLength',\n jobTitleMaxLength: 'Company.CompanyStructure.shared.validation.jobTitleMaxLength',\n telephoneMaxLength: 'Company.CompanyStructure.shared.validation.telephoneMaxLength',\n createUserError: 'Company.CompanyStructure.messages.createUserError',\n saveUserError: 'Company.CompanyStructure.messages.saveUserError',\n createUserSuccess: 'Company.CompanyStructure.messages.createUserSuccess',\n updateUserSuccess: 'Company.CompanyStructure.messages.updateUserSuccess',\n });\n const [values, setValues] = useState<Partial<CompanyUserModel> & { roleId: string; status: UserStatus }>({ \n firstName: '', \n lastName: '', \n email: '', \n jobTitle: '', \n telephone: '', \n roleId: '', \n status: 'ACTIVE' \n });\n const [errors, setErrors] = useState<Record<string, string>>({});\n const [touched, setTouched] = useState<Record<string, boolean>>({});\n const [loading, setLoading] = useState(false);\n const [generalError, setGeneralError] = useState<string | null>(null);\n const [emailAvailable, setEmailAvailable] = useState<boolean | null>(null);\n const [emailChecked, setEmailChecked] = useState<string>('');\n const [originalEmail, setOriginalEmail] = useState<string>('');\n const [isCompanyAdmin, setIsCompanyAdmin] = useState<boolean>(false);\n\n useEffect(() => {\n if (mode !== 'edit' || !entityId) return;\n setLoading(true);\n void getCompanyUser(entityId).then((u) => {\n if (!u) return;\n const loadedEmail = u.email || '';\n setValues((v) => ({ ...v, firstName: u.firstName || '', lastName: u.lastName || '', email: loadedEmail, jobTitle: u.jobTitle || '', telephone: u.telephone || '', status: (u.status || 'ACTIVE') as UserStatus }));\n setOriginalEmail(loadedEmail);\n if (u?.role?.id) setValues((v) => ({ ...v, roleId: u.role!.id }));\n setIsCompanyAdmin(u?.isCompanyAdmin ?? false);\n }).finally(() => setLoading(false));\n }, [mode, entityId]);\n\n const isEmailValid = (value: string): boolean => /.+@.+\\..+/.test(value);\n const validateField = (field: keyof CompanyUserModel | 'roleId', value: any): string | null => {\n if (field === 'firstName') {\n if (!value?.trim()) return translations.firstNameRequired;\n if (value.length > FIELD_MAX_LENGTHS.firstName) return translations.firstNameMaxLength;\n return null;\n }\n if (field === 'lastName') {\n if (!value?.trim()) return translations.lastNameRequired;\n if (value.length > FIELD_MAX_LENGTHS.lastName) return translations.lastNameMaxLength;\n return null;\n }\n if (field === 'email') {\n if (!value?.trim()) return translations.emailRequired;\n if (value.length > FIELD_MAX_LENGTHS.email) return translations.emailMaxLength;\n return isEmailValid(value.trim()) ? null : translations.emailInvalid;\n }\n // jobTitle and telephone are now optional fields (USF-3012)\n if (field === 'jobTitle') {\n if (value && value.length > FIELD_MAX_LENGTHS.jobTitle) return translations.jobTitleMaxLength;\n return null;\n }\n if (field === 'telephone') {\n if (value && value.length > FIELD_MAX_LENGTHS.telephone) return translations.telephoneMaxLength;\n return null;\n }\n if (field === 'roleId') return value ? null : translations.selectRole;\n return null;\n };\n\n const setValue = (field: keyof CompanyUserModel | 'roleId', value: any) => {\n setValues((v) => ({ ...v, [field]: value }));\n if (field === 'email') setEmailAvailable(null);\n if (generalError) setGeneralError(null);\n };\n\n const onBlur = async (field: keyof CompanyUserModel | 'roleId', value?: any) => {\n // Update form data if value is provided (this preserves spaces and other characters)\n if (value !== undefined) {\n setValue(field, value);\n }\n \n setTouched((t) => ({ ...t, [field]: true }));\n \n // Use provided value or current state value for validation\n const valueToValidate = value !== undefined ? value : values[field];\n const err = validateField(field, valueToValidate);\n if (err) {\n setErrors((p) => ({ ...p, [field]: err }));\n } else {\n // Clear error if field is now valid\n setErrors((p) => {\n const newErrors = { ...p };\n delete newErrors[field];\n return newErrors;\n });\n }\n \n if (field === 'email') {\n const emailValue = value !== undefined ? value : (values.email || '');\n const trimmed = emailValue.trim();\n if (mode === 'edit' && trimmed.toLowerCase() === (originalEmail || '').trim().toLowerCase()) {\n setEmailAvailable(null);\n return;\n }\n if (isEmailValid(trimmed) && trimmed !== emailChecked) {\n const available = await isCompanyUserEmailAvailable(trimmed);\n setEmailChecked(trimmed);\n setEmailAvailable(available);\n if (available === false) setErrors((p) => ({ ...p, email: 'A user with this email address is already a member of your company.' }));\n }\n }\n };\n\n const submit = async () => {\n // Validate all fields including optional ones for length (USF-3474)\n const fields: (keyof CompanyUserModel | 'roleId')[] = ['firstName', 'lastName', 'email', 'roleId', 'jobTitle', 'telephone'];\n const next: Record<string, string> = {};\n const touchedFields: Record<string, boolean> = {};\n \n for (const f of fields) {\n touchedFields[f as string] = true;\n const err = validateField(f, values[f]);\n if (err) next[f as string] = err;\n }\n \n setErrors(next);\n setTouched(touchedFields);\n \n if (Object.keys(next).length || emailAvailable === false) {\n // Scroll to the first error field\n setTimeout(() => {\n const firstErrorField = document.querySelector('.company-user-form__content .dropin-field__hint--error');\n if (firstErrorField) {\n const fieldContainer = firstErrorField.closest('.dropin-field');\n if (fieldContainer) {\n fieldContainer.scrollIntoView({ behavior: 'smooth', block: 'center' });\n const input = fieldContainer.querySelector('input, select') as HTMLElement;\n if (input) {\n input.focus();\n }\n }\n }\n }, 100);\n return;\n }\n\n const label = `${values.firstName || ''} ${values.lastName || ''}`.trim() || values.email || '';\n const adminEffective = isCompanyAdmin || isCompanyAdministrator({ id: values.roleId });\n const effectiveStatus = adminEffective ? 'ACTIVE' : values.status;\n try {\n if (mode === 'add') {\n const res = await createCompanyUser({ email: values.email || '', firstName: values.firstName || '', lastName: values.lastName || '', jobTitle: values.jobTitle || '', telephone: values.telephone || '', roleId: values.roleId, status: effectiveStatus, targetId: parentStructureId ?? null });\n if (!res) {\n const errorMessage = translations.createUserError;\n if (onError) {\n onError(errorMessage);\n } else {\n setGeneralError(errorMessage);\n }\n return;\n }\n onSaved({ label, structureId: res.structureId, entityId: res.id, type: 'user', status: effectiveStatus, jobTitle: res.jobTitle });\n if (onSuccess) {\n onSuccess(translations.createUserSuccess);\n }\n } else if (entityId) {\n await updateCompanyUser({ id: entityId, email: values.email || '', firstName: values.firstName || '', lastName: values.lastName || '', jobTitle: values.jobTitle || '', telephone: values.telephone || '', status: effectiveStatus, roleId: values.roleId });\n onSaved({ label, entityId, type: 'user', status: effectiveStatus, jobTitle: values.jobTitle });\n if (onSuccess) {\n onSuccess(translations.updateUserSuccess);\n }\n }\n } catch (error: unknown) {\n const errorMessage = error instanceof Error ? error.message : translations.saveUserError;\n if (onError) {\n onError(errorMessage);\n } else {\n setGeneralError(errorMessage);\n }\n }\n };\n\n return { values, errors, touched, loading, setValue, onBlur, submit, isCompanyAdmin, generalError };\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 { FunctionComponent } from 'preact';\nimport { memo } from 'preact/compat';\nimport { useState } from 'preact/hooks';\nimport { Field, Input, Button, Card, Picker, ProgressSpinner, InLineAlert } from '@adobe-commerce/elsie/components';\nimport { useText } from '@adobe-commerce/elsie/i18n';\nimport { CompanyUserFormLoader } from '@/company-management/components/CompanyLoaders';\nimport { useCompanyUserForm, FIELD_MAX_LENGTHS } from '@/company-management/hooks/useCompanyUserForm';\nimport { useCompanyRoles } from '@/company-management/hooks/useCompanyRoles';\nimport { CompanyUserFormProps } from '@/company-management/types/companyForm.types';\nimport './CompanyUserForm.css';\n\n/**\n * CompanyUserForm component for creating and editing company users\n * Provides form fields for user information including name, email, role, and status\n */\nexport const CompanyUserForm: FunctionComponent<CompanyUserFormProps> = memo(({ mode, entityId, parentStructureId, permissions, onSaved, onCancel, onError, onSuccess }) => {\n const canEditUsers = permissions?.canEditUsers ?? false;\n const { roles, isLoading: rolesLoading } = useCompanyRoles();\n const { values, errors, touched, loading, setValue, onBlur, submit, isCompanyAdmin, generalError } = useCompanyUserForm({ \n mode, \n entityId, \n parentStructureId, \n onSaved,\n onError: onError ? (error: string) => {\n onError(error);\n onCancel();\n } : undefined,\n onSuccess\n });\n const [saving, setSaving] = useState(false);\n \n const translations = useText({\n addUser: 'Company.CompanyStructure.shared.titles.addUser',\n editUser: 'Company.CompanyStructure.shared.titles.editUser',\n jobTitle: 'Company.CompanyStructure.shared.fields.jobTitle',\n userRole: 'Company.CompanyStructure.shared.fields.userRole',\n firstName: 'Company.CompanyStructure.shared.fields.firstName',\n lastName: 'Company.CompanyStructure.shared.fields.lastName',\n email: 'Company.CompanyStructure.shared.fields.email',\n workPhoneNumber: 'Company.CompanyStructure.shared.fields.workPhoneNumber',\n status: 'Company.CompanyStructure.shared.fields.status',\n selectRole: 'Company.CompanyStructure.shared.options.selectRole',\n active: 'Company.CompanyStructure.shared.options.active',\n inactive: 'Company.CompanyStructure.shared.options.inactive',\n companyAdministrator: 'Company.CompanyStructure.shared.options.companyAdministrator',\n save: 'Company.CompanyStructure.shared.buttons.save',\n cancel: 'Company.CompanyStructure.shared.buttons.cancel',\n });\n\n return (\n <div>\n <h3 className=\"acm-structure-panel__title\">{mode === 'add' ? translations.addUser : translations.editUser}</h3>\n <Card variant=\"secondary\" className={`company-user-form__card ${saving ? 'is-working' : ''}`}>\n {!onError && generalError ? (\n <InLineAlert \n className=\"company-user-form__notification\" \n type=\"error\" \n variant=\"secondary\" \n heading={generalError} \n />\n ) : null}\n {saving ? <div className=\"company-user-form__overlay\" aria-live=\"polite\"><ProgressSpinner size=\"small\" /></div> : null}\n {loading || rolesLoading ? (\n <CompanyUserFormLoader />\n ) : (\n <div className=\"company-user-form__content\">\n\n <Field label={translations.jobTitle} className=\"acm-structure-panel__field\" error={touched.jobTitle && errors.jobTitle ? errors.jobTitle : undefined}>\n <Input name=\"job_title\" type=\"text\" value={values.jobTitle || ''} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('jobTitle', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.jobTitle} />\n </Field>\n\n <Field label={translations.userRole} required className=\"acm-structure-panel__field\" error={!isCompanyAdmin && touched.roleId && errors.roleId ? errors.roleId : undefined} disabled={isCompanyAdmin}>\n {isCompanyAdmin ? (\n <Picker name=\"role\" value={'MA=='} options={[{ value: 'MA==', text: translations.companyAdministrator }]} />\n ) : (\n <Picker\n name=\"role\"\n value={values.roleId || 'placeholder'}\n onChange={(e: any) => setValue('roleId', String(e?.target?.value === 'placeholder' ? '' : e?.target?.value ?? ''))}\n onBlur={(e: Event) => { const target = e.target as HTMLSelectElement; void onBlur('roleId', target.value === 'placeholder' ? '' : target.value); }}\n options={[{ value: 'placeholder', text: translations.selectRole, disabled: true }, ...roles.map((r) => ({ value: r.id, text: r.name }))]}\n />\n )}\n </Field>\n\n <Field label={translations.firstName} required className=\"acm-structure-panel__field\" error={touched.firstName && errors.firstName ? errors.firstName : undefined}>\n <Input name=\"first_name\" type=\"text\" value={values.firstName} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('firstName', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.firstName} />\n </Field>\n\n <Field label={translations.lastName} required className=\"acm-structure-panel__field\" error={touched.lastName && errors.lastName ? errors.lastName : undefined}>\n <Input name=\"last_name\" type=\"text\" value={values.lastName} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('lastName', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.lastName} />\n </Field>\n\n <Field label={translations.email} required className=\"acm-structure-panel__field\" error={touched.email && errors.email ? errors.email : undefined}>\n <Input name=\"email\" type=\"email\" value={values.email} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; void onBlur('email', target.value); }} placeholder=\"jdoe@example.com\" variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.email} />\n </Field>\n\n <Field label={translations.workPhoneNumber} className=\"acm-structure-panel__field\" error={touched.telephone && errors.telephone ? errors.telephone : undefined}>\n <Input name=\"telephone\" type=\"text\" value={values.telephone || ''} onBlur={(e: Event) => { const target = e.target as HTMLInputElement; onBlur('telephone', target.value); }} variant=\"primary\" size=\"medium\" maxLength={FIELD_MAX_LENGTHS.telephone} />\n </Field>\n\n <Field label={translations.status} className=\"acm-structure-panel__field\" disabled={isCompanyAdmin || !canEditUsers}>\n <Picker\n name=\"status\"\n value={values.status}\n onChange={(e: any) => setValue('status', String(e?.target?.value ?? 'ACTIVE'))}\n options={[{ value: 'ACTIVE', text: translations.active }, { value: 'INACTIVE', text: translations.inactive }]}\n />\n </Field>\n </div>\n )}\n </Card>\n {!(loading || rolesLoading) ? (\n <div className=\"acm-structure-modal__actions\">\n <Button type=\"button\" variant=\"primary\" disabled={saving || !canEditUsers} onClick={async () => { if (saving) return; setSaving(true); try { await submit(); } finally { setSaving(false); } }}>\n {translations.save}\n </Button>\n <Button\n type=\"button\"\n variant=\"secondary\"\n disabled={saving}\n onClick={onCancel}\n >\n {translations.cancel}\n </Button>\n </div>\n ) : null}\n </div>\n );\n});\n\nexport default CompanyUserForm;\n"],"names":["FIELD_MAX_LENGTHS","useCompanyUserForm","opts","mode","entityId","parentStructureId","onSaved","onError","onSuccess","translations","useText","values","setValues","useState","errors","setErrors","touched","setTouched","loading","setLoading","generalError","setGeneralError","emailAvailable","setEmailAvailable","emailChecked","setEmailChecked","originalEmail","setOriginalEmail","isCompanyAdmin","setIsCompanyAdmin","useEffect","getCompanyUser","u","loadedEmail","v","_a","isEmailValid","value","validateField","field","setValue","t","valueToValidate","err","p","newErrors","trimmed","available","isCompanyUserEmailAvailable","fields","next","touchedFields","f","firstErrorField","fieldContainer","input","label","effectiveStatus","isCompanyAdministrator","res","createCompanyUser","errorMessage","updateCompanyUser","error","CompanyUserForm","memo","permissions","onCancel","canEditUsers","roles","rolesLoading","useCompanyRoles","onBlur","submit","saving","setSaving","jsx","jsxs","Card","InLineAlert","ProgressSpinner","CompanyUserFormLoader","Field","Input","e","target","Picker","_b","r","Button"],"mappings":"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"}
|
|
@@ -0,0 +1,10 @@
|
|
|
1
|
+
/*! Copyright 2025 Adobe
|
|
2
|
+
All Rights Reserved. */
|
|
3
|
+
import{h as c}from"./fetch-error.js";import{g as i,r as l,f as p,h as u,a as d}from"./network-error.js";const m=`
|
|
4
|
+
mutation acceptCompanyInvitation($input: CompanyInvitationInput!) {
|
|
5
|
+
acceptCompanyInvitation(input: $input) {
|
|
6
|
+
success
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
`;async function I(e){const a=i().fetchGraphQlHeaders["X-Adobe-Company"];l("X-Adobe-Company");try{const s={code:e.code,user:{customer_id:btoa(e.user.customerId),company_id:btoa(e.user.companyId),job_title:e.user.jobTitle,telephone:e.user.telephone,status:e.user.status},role_id:e.roleId?btoa(e.roleId):null};return await p(m,{variables:{input:s}}).then(t=>{var r,n;if((r=t.errors)!=null&&r.length)return c(t.errors);const o=(n=t==null?void 0:t.data)==null?void 0:n.acceptCompanyInvitation;return o?{success:o.success}:null}).catch(u)}finally{a!=null&&d("X-Adobe-Company",a)}}export{I as a};
|
|
10
|
+
//# sourceMappingURL=acceptCompanyInvitation.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"acceptCompanyInvitation.js","sources":["/@dropins/storefront-company-management/src/api/acceptCompanyInvitation/graphql/acceptCompanyInvitation.graphql.ts","/@dropins/storefront-company-management/src/api/acceptCompanyInvitation/acceptCompanyInvitation.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\nexport const ACCEPT_COMPANY_INVITATION = /* GraphQL */ `\n mutation acceptCompanyInvitation($input: CompanyInvitationInput!) {\n acceptCompanyInvitation(input: $input) {\n success\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 { handleNetworkError, handleFetchError } from '@/company-management/lib';\nimport { AcceptCompanyInvitationInput, AcceptCompanyInvitationResult } from '@/company-management/types';\nimport { ACCEPT_COMPANY_INVITATION } from './graphql/acceptCompanyInvitation.graphql';\nimport { \n fetchGraphQl, \n removeFetchGraphQlHeader, \n setFetchGraphQlHeader,\n getConfig \n} from '@/company-management/api/fetch-graphql';\n\n/**\n * Accepts a company invitation using the invitation code and user information\n * @param input - Invitation code, user information (customer_id, company_id, etc.), and optional role_id\n * @returns Promise resolving to result indicating success or failure\n */\nexport async function acceptCompanyInvitation(\n input: AcceptCompanyInvitationInput\n): Promise<AcceptCompanyInvitationResult | null> {\n // Save the current X-Adobe-Company header value (if any)\n const previousCompanyHeader = getConfig().fetchGraphQlHeaders['X-Adobe-Company'];\n \n // Temporarily remove X-Adobe-Company header to avoid backend validation error\n // The acceptCompanyInvitation mutation doesn't allow this header to be set\n removeFetchGraphQlHeader('X-Adobe-Company');\n\n try {\n // GraphQL expects base64-encoded UIDs for IDs\n const transformedInput = {\n code: input.code,\n user: {\n customer_id: btoa(input.user.customerId),\n company_id: btoa(input.user.companyId),\n job_title: input.user.jobTitle,\n telephone: input.user.telephone,\n status: input.user.status,\n },\n role_id: input.roleId ? btoa(input.roleId) : null,\n };\n\n return await fetchGraphQl<{ acceptCompanyInvitation?: { success: boolean } }>(ACCEPT_COMPANY_INVITATION, {\n variables: { input: transformedInput },\n })\n .then((res) => {\n if (res.errors?.length) return handleFetchError(res.errors);\n\n const result = res?.data?.acceptCompanyInvitation;\n if (!result) return null;\n\n return {\n success: result.success,\n };\n })\n .catch(handleNetworkError);\n } finally {\n // Restore the X-Adobe-Company header if it existed before\n if (previousCompanyHeader !== null && previousCompanyHeader !== undefined) {\n setFetchGraphQlHeader('X-Adobe-Company', previousCompanyHeader);\n }\n }\n}\n"],"names":["ACCEPT_COMPANY_INVITATION","acceptCompanyInvitation","input","previousCompanyHeader","getConfig","removeFetchGraphQlHeader","transformedInput","fetchGraphQl","res","_a","handleFetchError","result","_b","handleNetworkError","setFetchGraphQlHeader"],"mappings":"wGAiBO,MAAMA,EAA0C;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,ECcvD,eAAsBC,EACpBC,EAC+C,CAE/C,MAAMC,EAAwBC,IAAY,oBAAoB,iBAAiB,EAI/EC,EAAyB,iBAAiB,EAE1C,GAAI,CAEF,MAAMC,EAAmB,CACvB,KAAMJ,EAAM,KACZ,KAAM,CACJ,YAAa,KAAKA,EAAM,KAAK,UAAU,EACvC,WAAY,KAAKA,EAAM,KAAK,SAAS,EACrC,UAAWA,EAAM,KAAK,SACtB,UAAWA,EAAM,KAAK,UACtB,OAAQA,EAAM,KAAK,MAAA,EAErB,QAASA,EAAM,OAAS,KAAKA,EAAM,MAAM,EAAI,IAAA,EAG/C,OAAO,MAAMK,EAAiEP,EAA2B,CACvG,UAAW,CAAE,MAAOM,CAAA,CAAiB,CACtC,EACE,KAAME,GAAQ,SACb,IAAIC,EAAAD,EAAI,SAAJ,MAAAC,EAAY,OAAQ,OAAOC,EAAiBF,EAAI,MAAM,EAE1D,MAAMG,GAASC,EAAAJ,GAAA,YAAAA,EAAK,OAAL,YAAAI,EAAW,wBAC1B,OAAKD,EAEE,CACL,QAASA,EAAO,OAAA,EAHE,IAKtB,CAAC,EACA,MAAME,CAAkB,CAC7B,QAAA,CAEMV,GAA0B,MAC5BW,EAAsB,kBAAmBX,CAAqB,CAElE,CACF"}
|
|
@@ -1,6 +1,13 @@
|
|
|
1
1
|
/*! Copyright 2025 Adobe
|
|
2
2
|
All Rights Reserved. */
|
|
3
|
-
import{
|
|
3
|
+
import{f as d,h as a}from"./network-error.js";import{h as l}from"./fetch-error.js";import{t as g}from"./validateCompanyEmail.js";const u=`
|
|
4
|
+
query getStoreConfig {
|
|
5
|
+
storeConfig {
|
|
6
|
+
default_country
|
|
7
|
+
store_code
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
`,p="US",s={defaultCountry:p,storeCode:""},T=async()=>await d(u,{method:"GET"}).then(e=>{var r;return(r=e.errors)!=null&&r.length?l(e.errors):m(e)}).catch(a),m=e=>{var t;if(!((t=e==null?void 0:e.data)!=null&&t.storeConfig))return s;const{default_country:r,store_code:o}=e.data.storeConfig;return{defaultCountry:r||s.defaultCountry,storeCode:o||s.storeCode}},_=`
|
|
4
11
|
mutation CreateCompany($input: CompanyCreateInput!) {
|
|
5
12
|
createCompany(input: $input) {
|
|
6
13
|
company {
|
|
@@ -33,12 +40,5 @@ import{t as a}from"./validateCompanyEmail.js";import{f as d,h as l}from"./networ
|
|
|
33
40
|
}
|
|
34
41
|
}
|
|
35
42
|
}
|
|
36
|
-
`,
|
|
37
|
-
|
|
38
|
-
storeConfig {
|
|
39
|
-
default_country
|
|
40
|
-
store_code
|
|
41
|
-
}
|
|
42
|
-
}
|
|
43
|
-
`,_="US",s={defaultCountry:_,storeCode:""},E=async()=>await d(m,{method:"GET"}).then(e=>{var r;return(r=e.errors)!=null&&r.length?g(e.errors):y(e)}).catch(l),y=e=>{var t;if(!((t=e==null?void 0:e.data)!=null&&t.storeConfig))return s;const{default_country:r,store_code:o}=e.data.storeConfig;return{defaultCountry:r||s.defaultCountry,storeCode:o||s.storeCode}};export{_ as D,s as S,T as c,E as g};
|
|
44
|
-
//# sourceMappingURL=transform-store-config.js.map
|
|
43
|
+
`,y=e=>{var o,t,i;const r={};if(e.regionCode&&e.regionCode.trim())r.region_code=e.regionCode.trim(),e.regionId&&(r.region_id=typeof e.regionId=="string"?parseInt(e.regionId,10):e.regionId);else if(e.region&&typeof e.region=="string"&&e.region.includes(",")){const[n,c]=e.region.split(",");r.region_code=n.trim(),r.region_id=parseInt(c.trim(),10)}else if(e.region&&e.region.trim()){const n=e.region.trim();if(/^\d+$/.test(n))throw new Error("Region selection error: Missing region code. Please ensure regions are properly loaded.");r.region=n,r.region_code=n}if(!r.region_code)throw new Error("Region code is required. Please select a state/province or enter a region name.");return{company_name:e.companyName,company_email:e.companyEmail,legal_name:e.legalName,vat_tax_id:e.vatTaxId,reseller_id:e.resellerId,legal_address:{street:Array.isArray(e.street)?e.street.filter(n=>n&&n.trim()!==""):[e.street].filter(n=>n&&n.trim()!==""),city:e.city,region:r,postcode:e.postcode,country_id:e.countryCode,telephone:e.addressTelephone},company_admin:{email:e.adminEmail,firstname:((o=e.adminFirstname)==null?void 0:o.trim())||"",lastname:((t=e.adminLastname)==null?void 0:t.trim())||"",job_title:e.adminJobTitle,telephone:e.adminWorkTelephone,gender:e.adminGender?typeof e.adminGender=="string"?parseInt(e.adminGender,10):e.adminGender:void 0,custom_attributes:((i=e.adminCustomAttributes)==null?void 0:i.map(n=>({attribute_code:n.attribute_code,value:n.value})))||[]}}},E=async e=>{var r;try{const o=y(e),t=await d(_,{method:"POST",variables:{input:o}});return(r=t.errors)!=null&&r.length?{success:!1,errors:t.errors.map(n=>n.message)}:{success:!0,company:g(t)}}catch(o){return console.error("Failed to create company:",o),{success:!1,errors:["Failed to create company. Please try again."]}}};export{p as D,s as S,E as c,T as g};
|
|
44
|
+
//# sourceMappingURL=createCompany.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"createCompany.js","sources":["/@dropins/storefront-company-management/src/api/getStoreConfig/graphql/getStoreConfig.graphql.ts","/@dropins/storefront-company-management/src/api/getStoreConfig/getStoreConfig.ts","/@dropins/storefront-company-management/src/data/transforms/transform-store-config.ts","/@dropins/storefront-company-management/src/api/createCompany/graphql/createCompany.graphql.ts","/@dropins/storefront-company-management/src/data/transforms/company.ts","/@dropins/storefront-company-management/src/api/createCompany/createCompany.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\nexport const GET_STORE_CONFIG_QUERY = /* GraphQL */ `\n query getStoreConfig {\n storeConfig {\n default_country\n store_code\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\nimport { fetchGraphQl } from '../fetch-graphql';\nimport { GET_STORE_CONFIG_QUERY } from './graphql/getStoreConfig.graphql';\nimport { handleNetworkError } from '@/company-management/lib/network-error';\nimport { handleFetchError } from '@/company-management/lib/fetch-error';\nimport { GetStoreConfigResponse, StoreConfigModel } from '@/company-management/types';\nimport { transformStoreConfig } from '@/company-management/data/transforms';\n\nexport const DEFAULT_COUNTRY = 'US';\n\nexport const STORE_CONFIG_DEFAULTS: StoreConfigModel = {\n defaultCountry: DEFAULT_COUNTRY,\n storeCode: '',\n};\n\nexport const getStoreConfig = async (): Promise<StoreConfigModel> => {\n return await fetchGraphQl(GET_STORE_CONFIG_QUERY, {\n method: 'GET',\n })\n .then((response: GetStoreConfigResponse) => {\n if (response.errors?.length) return handleFetchError(response.errors);\n\n return transformStoreConfig(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 *******************************************************************/\n\nimport { GetStoreConfigResponse, StoreConfigModel } from '@/company-management/types';\nimport { STORE_CONFIG_DEFAULTS } from '@/company-management/api/getStoreConfig/getStoreConfig';\n\nexport const transformStoreConfig = (\n response: GetStoreConfigResponse\n): StoreConfigModel => {\n if (!response?.data?.storeConfig) return STORE_CONFIG_DEFAULTS;\n\n const { default_country, store_code } = response.data.storeConfig;\n\n return {\n defaultCountry: default_country || STORE_CONFIG_DEFAULTS.defaultCountry,\n storeCode: store_code || STORE_CONFIG_DEFAULTS.storeCode,\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\nexport const CREATE_COMPANY_MUTATION = /* GraphQL */ `\n mutation CreateCompany($input: CompanyCreateInput!) {\n createCompany(input: $input) {\n company {\n id\n name\n email\n legal_name\n vat_tax_id\n reseller_id\n legal_address {\n street\n city\n region {\n region_code\n region\n region_id\n }\n postcode\n country_code\n telephone\n }\n company_admin {\n id\n firstname\n lastname\n email\n job_title\n telephone\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\nimport { CompanyFormData } from '../models/company';\nimport { CompanyCreateInput } from '@/company-management/api/createCompany';\n\nexport const transformFormDataToCreateInput = (formData: CompanyFormData): CompanyCreateInput => {\n // Build region object - ensure we have at least one region field\n const regionInput: any = {};\n \n // Handle region data based on what we receive from the form\n if (formData.regionCode && formData.regionCode.trim()) {\n // We have regionCode (preferred path)\n regionInput.region_code = formData.regionCode.trim();\n if (formData.regionId) {\n regionInput.region_id = typeof formData.regionId === 'string' ? parseInt(formData.regionId, 10) : formData.regionId;\n }\n } else if (formData.region && typeof formData.region === 'string' && formData.region.includes(',')) {\n // Dropdown selection: parse \"AL,4\" format as fallback\n const [regionCode, regionId] = formData.region.split(',');\n regionInput.region_code = regionCode.trim();\n regionInput.region_id = parseInt(regionId.trim(), 10);\n } else if (formData.region && formData.region.trim()) {\n const regionValue = formData.region.trim();\n // Check if this is a numeric regionId (from dropdown) or text region name\n if (/^\\d+$/.test(regionValue)) {\n // This is likely a regionId from dropdown, but we only have the ID\n // We need both region_code and region_id for GraphQL, but we can't proceed without region_code\n throw new Error('Region selection error: Missing region code. Please ensure regions are properly loaded.');\n } else {\n // Text input: free-form region name (countries without predefined regions)\n regionInput.region = regionValue;\n regionInput.region_code = regionValue;\n }\n }\n \n // Ensure we have at least region_code (required by GraphQL)\n if (!regionInput.region_code) {\n throw new Error('Region code is required. Please select a state/province or enter a region name.');\n }\n\n return {\n company_name: formData.companyName,\n company_email: formData.companyEmail,\n legal_name: formData.legalName,\n vat_tax_id: formData.vatTaxId,\n reseller_id: formData.resellerId,\n legal_address: {\n street: Array.isArray(formData.street) \n ? formData.street.filter((line: string) => line && line.trim() !== '') // Remove empty lines\n : [formData.street].filter((line: string) => line && line.trim() !== ''), // Handle case where street is not an array\n city: formData.city,\n region: regionInput,\n postcode: formData.postcode,\n country_id: formData.countryCode,\n telephone: formData.addressTelephone,\n },\n company_admin: {\n email: formData.adminEmail,\n firstname: formData.adminFirstname?.trim() || '',\n lastname: formData.adminLastname?.trim() || '',\n job_title: formData.adminJobTitle,\n telephone: formData.adminWorkTelephone,\n gender: formData.adminGender ? (typeof formData.adminGender === 'string' ? parseInt(formData.adminGender, 10) : formData.adminGender) : undefined,\n custom_attributes: formData.adminCustomAttributes?.map(attr => ({\n attribute_code: attr.attribute_code,\n value: attr.value,\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\nimport { fetchGraphQl } from '@/company-management/api/fetch-graphql';\nimport { CREATE_COMPANY_MUTATION } from './graphql/createCompany.graphql';\nimport { CompanyRegistrationModel } from '@/company-management/data/models/company';\nimport { transformFormDataToCreateInput } from '@/company-management/data/transforms/company';\nimport { transformCreateCompanyResponse } from '@/company-management/data/transforms/transform-company';\n\nexport interface CompanyCreateInput {\n company_name: string;\n company_email: string;\n legal_name?: string;\n vat_tax_id?: string;\n reseller_id?: string;\n legal_address: {\n street: string[];\n city: string;\n region: {\n region_code: string;\n region?: string;\n region_id?: number;\n };\n postcode: string;\n country_id: string;\n telephone?: string;\n };\n company_admin: {\n email: string;\n firstname: string;\n lastname: string;\n job_title?: string;\n telephone?: string;\n gender?: number;\n custom_attributes?: Array<{\n attribute_code: string;\n value: string;\n }>;\n };\n}\n\n\nexport const createCompany = async (formData: any): Promise<{ success: boolean; company?: CompanyRegistrationModel; errors?: string[] }> => {\n try {\n const input = transformFormDataToCreateInput(formData);\n const response = await fetchGraphQl(CREATE_COMPANY_MUTATION, {\n method: 'POST',\n variables: { input },\n });\n\n if (response.errors?.length) {\n return {\n success: false,\n errors: response.errors.map((error: any) => error.message),\n };\n }\n\n // Transform the GraphQL response using the dedicated transformer\n const transformedCompany = transformCreateCompanyResponse(response);\n\n return {\n success: true,\n company: transformedCompany,\n };\n } catch (error) {\n console.error('Failed to create company:', error);\n return {\n success: false,\n errors: ['Failed to create company. Please try again.'],\n };\n }\n};"],"names":["GET_STORE_CONFIG_QUERY","DEFAULT_COUNTRY","STORE_CONFIG_DEFAULTS","getStoreConfig","fetchGraphQl","response","_a","handleFetchError","transformStoreConfig","handleNetworkError","default_country","store_code","CREATE_COMPANY_MUTATION","transformFormDataToCreateInput","formData","regionInput","regionCode","regionId","regionValue","line","_b","_c","attr","createCompany","input","error","transformCreateCompanyResponse"],"mappings":"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"}
|
|
@@ -0,0 +1,36 @@
|
|
|
1
|
+
/*! Copyright 2025 Adobe
|
|
2
|
+
All Rights Reserved. */
|
|
3
|
+
import{h as u}from"./fetch-error.js";import{f as l,h as m}from"./network-error.js";const g=`
|
|
4
|
+
mutation DELETE_COMPANY_USER($id: ID!) {
|
|
5
|
+
deleteCompanyUserV2(id: $id) {
|
|
6
|
+
success
|
|
7
|
+
}
|
|
8
|
+
}
|
|
9
|
+
`,y=async o=>{var n,s;const{id:t}=o;if(!t)throw new Error("User ID is required to delete a company user");const a=await l(g,{method:"POST",cache:"no-cache",variables:{id:t}}).catch(m);return(n=a.errors)!=null&&n.length&&u(a.errors),(s=a.data)!=null&&s.deleteCompanyUserV2?{success:a.data.deleteCompanyUserV2.success}:{success:!1}},d=`
|
|
10
|
+
query COMPANY_USERS($pageSize: Int!, $currentPage: Int!, $filter: CompanyUsersFilterInput) {
|
|
11
|
+
company {
|
|
12
|
+
users(pageSize: $pageSize, currentPage: $currentPage, filter: $filter) {
|
|
13
|
+
items {
|
|
14
|
+
id
|
|
15
|
+
firstname
|
|
16
|
+
lastname
|
|
17
|
+
email
|
|
18
|
+
role {
|
|
19
|
+
name
|
|
20
|
+
}
|
|
21
|
+
status
|
|
22
|
+
team {
|
|
23
|
+
name
|
|
24
|
+
}
|
|
25
|
+
}
|
|
26
|
+
page_info {
|
|
27
|
+
page_size
|
|
28
|
+
current_page
|
|
29
|
+
total_pages
|
|
30
|
+
}
|
|
31
|
+
total_count
|
|
32
|
+
}
|
|
33
|
+
}
|
|
34
|
+
}
|
|
35
|
+
`,E=async(o={})=>{var s,c,p,i;const{pageSize:t=20,currentPage:a=1,filter:n}=o;try{const e=await l(d,{method:"GET",cache:"no-cache",variables:{pageSize:t,currentPage:a,filter:n}}).catch(m);return(s=e.errors)!=null&&s.length&&u(e.errors),(i=(p=(c=e.data)==null?void 0:c.company)==null?void 0:p.users)!=null&&i.items?{users:e.data.company.users.items.map(r=>({id:r.id,firstName:r.firstname,lastName:r.lastname,email:r.email,role:r.role.name,status:r.status,...r.team&&{team:r.team.name}})),pageInfo:{pageSize:e.data.company.users.page_info.page_size,currentPage:e.data.company.users.page_info.current_page,totalPages:e.data.company.users.page_info.total_pages},totalCount:e.data.company.users.total_count}:{users:[],pageInfo:{pageSize:t,currentPage:a,totalPages:1}}}catch{return{users:[],pageInfo:{pageSize:t,currentPage:a,totalPages:1}}}};export{y as d,E as g};
|
|
36
|
+
//# sourceMappingURL=getCompanyUsers.js.map
|