@cedros/login-react 0.0.29 → 0.0.31

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.
Files changed (177) hide show
  1. package/README.md +2 -0
  2. package/dist/{AdminDepositList-CyT4VBH8.js → AdminDepositList-BUm_ZcAW.js} +1 -1
  3. package/dist/{AdminDepositList-CyT4VBH8.js.map → AdminDepositList-BUm_ZcAW.js.map} +1 -1
  4. package/dist/{AdminDepositList-b2AXtLg0.cjs → AdminDepositList-B_z6x3j5.cjs} +1 -1
  5. package/dist/{AdminDepositList-b2AXtLg0.cjs.map → AdminDepositList-B_z6x3j5.cjs.map} +1 -1
  6. package/dist/{AdminWithdrawalHistory-DL9zbu2b.cjs → AdminWithdrawalHistory-B2EY2ZmH.cjs} +1 -1
  7. package/dist/{AdminWithdrawalHistory-DL9zbu2b.cjs.map → AdminWithdrawalHistory-B2EY2ZmH.cjs.map} +1 -1
  8. package/dist/{AdminWithdrawalHistory-Cud-yuWy.js → AdminWithdrawalHistory-C76bkbjX.js} +1 -1
  9. package/dist/{AdminWithdrawalHistory-Cud-yuWy.js.map → AdminWithdrawalHistory-C76bkbjX.js.map} +1 -1
  10. package/dist/{AuthenticationSettings-D6GvSw3g.cjs → AuthenticationSettings-C-aYDXNH.cjs} +1 -1
  11. package/dist/{AuthenticationSettings-D6GvSw3g.cjs.map → AuthenticationSettings-C-aYDXNH.cjs.map} +1 -1
  12. package/dist/AuthenticationSettings-CoTic-d_.cjs +1 -0
  13. package/dist/AuthenticationSettings-CoTic-d_.cjs.map +1 -0
  14. package/dist/{AuthenticationSettings-rb4Fksw5.js → AuthenticationSettings-CsPbxwP7.js} +1 -1
  15. package/dist/{AuthenticationSettings-rb4Fksw5.js.map → AuthenticationSettings-CsPbxwP7.js.map} +1 -1
  16. package/dist/AuthenticationSettings-DIVk0OP8.js +712 -0
  17. package/dist/AuthenticationSettings-DIVk0OP8.js.map +1 -0
  18. package/dist/AutosaveStatus-DGNI4lXn.cjs +1 -0
  19. package/dist/AutosaveStatus-DGNI4lXn.cjs.map +1 -0
  20. package/dist/{AutosaveStatus-vkJxtuEw.js → AutosaveStatus-f-jw25Ay.js} +141 -93
  21. package/dist/AutosaveStatus-f-jw25Ay.js.map +1 -0
  22. package/dist/{CreditSystemSettings-ChA_lbef.cjs → CreditSystemSettings-BNkvsgsk.cjs} +1 -1
  23. package/dist/{CreditSystemSettings-ChA_lbef.cjs.map → CreditSystemSettings-BNkvsgsk.cjs.map} +1 -1
  24. package/dist/{CreditSystemSettings-DsRipb2R.js → CreditSystemSettings-C6ed3yp7.js} +1 -1
  25. package/dist/{CreditSystemSettings-DsRipb2R.js.map → CreditSystemSettings-C6ed3yp7.js.map} +1 -1
  26. package/dist/{CreditSystemSettings-r3gnGjiU.cjs → CreditSystemSettings-DM9ep1TF.cjs} +1 -1
  27. package/dist/{CreditSystemSettings-r3gnGjiU.cjs.map → CreditSystemSettings-DM9ep1TF.cjs.map} +1 -1
  28. package/dist/{CreditSystemSettings-a31pqSYS.js → CreditSystemSettings-uinhzoha.js} +1 -1
  29. package/dist/{CreditSystemSettings-a31pqSYS.js.map → CreditSystemSettings-uinhzoha.js.map} +1 -1
  30. package/dist/{DepositsSection-DD9MKUFt.js → DepositsSection-Bb4ISzvE.js} +1 -1
  31. package/dist/{DepositsSection-DD9MKUFt.js.map → DepositsSection-Bb4ISzvE.js.map} +1 -1
  32. package/dist/{DepositsSection-BkKUS4vk.cjs → DepositsSection-uQUdGeVb.cjs} +1 -1
  33. package/dist/{DepositsSection-BkKUS4vk.cjs.map → DepositsSection-uQUdGeVb.cjs.map} +1 -1
  34. package/dist/EmailRegisterForm-B_TiJkD6.cjs +1 -0
  35. package/dist/EmailRegisterForm-B_TiJkD6.cjs.map +1 -0
  36. package/dist/EmailRegisterForm-CCEuQA-w.js +773 -0
  37. package/dist/EmailRegisterForm-CCEuQA-w.js.map +1 -0
  38. package/dist/{EmailSettings-BVJ4vz0Y.js → EmailSettings-BAuQtEfM.js} +1 -1
  39. package/dist/{EmailSettings-BVJ4vz0Y.js.map → EmailSettings-BAuQtEfM.js.map} +1 -1
  40. package/dist/{EmailSettings-Dg2SAiHj.cjs → EmailSettings-BC0f1PCI.cjs} +1 -1
  41. package/dist/{EmailSettings-Dg2SAiHj.cjs.map → EmailSettings-BC0f1PCI.cjs.map} +1 -1
  42. package/dist/{EmailSettings-CM5l8qqK.cjs → EmailSettings-BF5EiPl9.cjs} +1 -1
  43. package/dist/{EmailSettings-CM5l8qqK.cjs.map → EmailSettings-BF5EiPl9.cjs.map} +1 -1
  44. package/dist/{EmailSettings-xtVl4kXD.js → EmailSettings-BKuXy8sc.js} +1 -1
  45. package/dist/{EmailSettings-xtVl4kXD.js.map → EmailSettings-BKuXy8sc.js.map} +1 -1
  46. package/dist/{EmbeddedWalletSettings-Bmx8x21f.cjs → EmbeddedWalletSettings-BRjt2PAj.cjs} +1 -1
  47. package/dist/{EmbeddedWalletSettings-Bmx8x21f.cjs.map → EmbeddedWalletSettings-BRjt2PAj.cjs.map} +1 -1
  48. package/dist/{EmbeddedWalletSettings-BuDgqv-K.js → EmbeddedWalletSettings-C27X9He2.js} +1 -1
  49. package/dist/{EmbeddedWalletSettings-BuDgqv-K.js.map → EmbeddedWalletSettings-C27X9He2.js.map} +1 -1
  50. package/dist/{EmbeddedWalletSettings-BXN9VbNJ.cjs → EmbeddedWalletSettings-CJY39UZN.cjs} +1 -1
  51. package/dist/{EmbeddedWalletSettings-BXN9VbNJ.cjs.map → EmbeddedWalletSettings-CJY39UZN.cjs.map} +1 -1
  52. package/dist/{EmbeddedWalletSettings-DY5iJhS0.js → EmbeddedWalletSettings-Dmi-EQ7W.js} +1 -1
  53. package/dist/{EmbeddedWalletSettings-DY5iJhS0.js.map → EmbeddedWalletSettings-Dmi-EQ7W.js.map} +1 -1
  54. package/dist/GoogleLoginButton-BwiL1o6U.cjs +1 -0
  55. package/dist/GoogleLoginButton-BwiL1o6U.cjs.map +1 -0
  56. package/dist/GoogleLoginButton-CFlqxvU-.js +217 -0
  57. package/dist/GoogleLoginButton-CFlqxvU-.js.map +1 -0
  58. package/dist/LoadingSpinner-6vml-zwr.js.map +1 -1
  59. package/dist/LoadingSpinner-d6sSxgQN.cjs.map +1 -1
  60. package/dist/{PermissionsSection-BPbE-hNx.cjs → PermissionsSection-DEMVp7X3.cjs} +1 -1
  61. package/dist/PermissionsSection-DEMVp7X3.cjs.map +1 -0
  62. package/dist/{PermissionsSection-CighC1p6.js → PermissionsSection-DNzOL1xW.js} +27 -25
  63. package/dist/PermissionsSection-DNzOL1xW.js.map +1 -0
  64. package/dist/{ServerSettings-BAstMKHS.js → ServerSettings-BT9weFPz.js} +1 -1
  65. package/dist/{ServerSettings-BAstMKHS.js.map → ServerSettings-BT9weFPz.js.map} +1 -1
  66. package/dist/{ServerSettings-LIIP5TPz.cjs → ServerSettings-CKfiLfXi.cjs} +1 -1
  67. package/dist/{ServerSettings-LIIP5TPz.cjs.map → ServerSettings-CKfiLfXi.cjs.map} +1 -1
  68. package/dist/{ServerSettings-9Q091f3o.js → ServerSettings-CZfBdMxG.js} +1 -1
  69. package/dist/{ServerSettings-9Q091f3o.js.map → ServerSettings-CZfBdMxG.js.map} +1 -1
  70. package/dist/{ServerSettings-PH7T8JKI.cjs → ServerSettings-rHrVN8O8.cjs} +1 -1
  71. package/dist/{ServerSettings-PH7T8JKI.cjs.map → ServerSettings-rHrVN8O8.cjs.map} +1 -1
  72. package/dist/SolanaLoginButton-DHsiug1Y.js +195 -0
  73. package/dist/SolanaLoginButton-DHsiug1Y.js.map +1 -0
  74. package/dist/SolanaLoginButton-DNEcSSF_.cjs +1 -0
  75. package/dist/SolanaLoginButton-DNEcSSF_.cjs.map +1 -0
  76. package/dist/{TeamSection-BIECkp7g.js → TeamSection-CoMXyFtz.js} +2 -2
  77. package/dist/{TeamSection-BIECkp7g.js.map → TeamSection-CoMXyFtz.js.map} +1 -1
  78. package/dist/{TeamSection-BOH9pv_E.cjs → TeamSection-DopbZClq.cjs} +1 -1
  79. package/dist/{TeamSection-BOH9pv_E.cjs.map → TeamSection-DopbZClq.cjs.map} +1 -1
  80. package/dist/{UsersSection-t-zm0jZW.js → UsersSection--PAE1XRh.js} +1 -1
  81. package/dist/{UsersSection-t-zm0jZW.js.map → UsersSection--PAE1XRh.js.map} +1 -1
  82. package/dist/{UsersSection-e6q7FHzx.cjs → UsersSection-C7aRNkK2.cjs} +1 -1
  83. package/dist/{UsersSection-e6q7FHzx.cjs.map → UsersSection-C7aRNkK2.cjs.map} +1 -1
  84. package/dist/{WebhookSettings-D0F8ESlB.js → WebhookSettings-Bgld6D_T.js} +1 -1
  85. package/dist/{WebhookSettings-D0F8ESlB.js.map → WebhookSettings-Bgld6D_T.js.map} +1 -1
  86. package/dist/{WebhookSettings-2p9abGm5.cjs → WebhookSettings-DXjnq-c7.cjs} +1 -1
  87. package/dist/{WebhookSettings-2p9abGm5.cjs.map → WebhookSettings-DXjnq-c7.cjs.map} +1 -1
  88. package/dist/{WebhookSettings-CdFM7_V-.cjs → WebhookSettings-DnLk97Mr.cjs} +1 -1
  89. package/dist/{WebhookSettings-CdFM7_V-.cjs.map → WebhookSettings-DnLk97Mr.cjs.map} +1 -1
  90. package/dist/{WebhookSettings-CXMBju7N.js → WebhookSettings-ufiGTmbG.js} +1 -1
  91. package/dist/{WebhookSettings-CXMBju7N.js.map → WebhookSettings-ufiGTmbG.js.map} +1 -1
  92. package/dist/{WithdrawalsSection-yRDTVFsb.js → WithdrawalsSection-BN-FjTEV.js} +1 -1
  93. package/dist/{WithdrawalsSection-yRDTVFsb.js.map → WithdrawalsSection-BN-FjTEV.js.map} +1 -1
  94. package/dist/{WithdrawalsSection-sljIyeaz.cjs → WithdrawalsSection-BhuCwFat.cjs} +1 -1
  95. package/dist/{WithdrawalsSection-sljIyeaz.cjs.map → WithdrawalsSection-BhuCwFat.cjs.map} +1 -1
  96. package/dist/admin-only.cjs +1 -1
  97. package/dist/admin-only.js +1 -1
  98. package/dist/email-only.cjs +1 -1
  99. package/dist/email-only.d.ts +17 -1
  100. package/dist/email-only.js +3 -3
  101. package/dist/google-only.cjs +1 -1
  102. package/dist/google-only.d.ts +16 -0
  103. package/dist/google-only.js +3 -3
  104. package/dist/index.cjs +12 -12
  105. package/dist/index.cjs.map +1 -1
  106. package/dist/index.d.ts +248 -12
  107. package/dist/index.js +3433 -2562
  108. package/dist/index.js.map +1 -1
  109. package/dist/login-react.css +1 -1
  110. package/dist/{plugin-DbkijwEV.js → plugin-BbExid4E.js} +1 -1
  111. package/dist/{plugin-DbkijwEV.js.map → plugin-BbExid4E.js.map} +1 -1
  112. package/dist/{plugin-PU2vAozn.cjs → plugin-Xca67fp7.cjs} +1 -1
  113. package/dist/{plugin-PU2vAozn.cjs.map → plugin-Xca67fp7.cjs.map} +1 -1
  114. package/dist/{shamir-CiBczzDN.cjs → shamir-DBpHm7WN.cjs} +1 -1
  115. package/dist/{shamir-CiBczzDN.cjs.map → shamir-DBpHm7WN.cjs.map} +1 -1
  116. package/dist/{shamir-OAB2zD9Y.js → shamir-R8ddesFt.js} +1 -1
  117. package/dist/{shamir-OAB2zD9Y.js.map → shamir-R8ddesFt.js.map} +1 -1
  118. package/dist/{silentWalletEnroll-FqXS7Rvh.js → silentWalletEnroll-Dp1GTeNr.js} +3 -3
  119. package/dist/{silentWalletEnroll-FqXS7Rvh.js.map → silentWalletEnroll-Dp1GTeNr.js.map} +1 -1
  120. package/dist/{silentWalletEnroll-wnkcB9HP.cjs → silentWalletEnroll-HPvsbd2J.cjs} +1 -1
  121. package/dist/{silentWalletEnroll-wnkcB9HP.cjs.map → silentWalletEnroll-HPvsbd2J.cjs.map} +1 -1
  122. package/dist/solana-only.cjs +1 -1
  123. package/dist/solana-only.d.ts +18 -2
  124. package/dist/solana-only.js +3 -3
  125. package/dist/{useAdminDeposits-BTSyeAfg.js → useAdminDeposits-C76B2Q_8.js} +1 -1
  126. package/dist/{useAdminDeposits-BTSyeAfg.js.map → useAdminDeposits-C76B2Q_8.js.map} +1 -1
  127. package/dist/{useAdminDeposits-BkkCwHWp.cjs → useAdminDeposits-CpLd68oP.cjs} +1 -1
  128. package/dist/{useAdminDeposits-BkkCwHWp.cjs.map → useAdminDeposits-CpLd68oP.cjs.map} +1 -1
  129. package/dist/{useAuth-m5Hf89v8.js → useAuth-CVLv2oKA.js} +547 -545
  130. package/dist/useAuth-CVLv2oKA.js.map +1 -0
  131. package/dist/useAuth-XZaciuLg.cjs +1 -0
  132. package/dist/useAuth-XZaciuLg.cjs.map +1 -0
  133. package/dist/useCedrosLogin-CFfID-0i.js +228 -0
  134. package/dist/useCedrosLogin-CFfID-0i.js.map +1 -0
  135. package/dist/useCedrosLogin-DtJorrE7.cjs +1 -0
  136. package/dist/useCedrosLogin-DtJorrE7.cjs.map +1 -0
  137. package/dist/{useOrgs-C3pzMA9h.js → useOrgs-C90KT9KP.js} +1 -1
  138. package/dist/{useOrgs-C3pzMA9h.js.map → useOrgs-C90KT9KP.js.map} +1 -1
  139. package/dist/{useOrgs-DDVRCaVi.cjs → useOrgs-CNqfn-fk.cjs} +1 -1
  140. package/dist/{useOrgs-DDVRCaVi.cjs.map → useOrgs-CNqfn-fk.cjs.map} +1 -1
  141. package/dist/{useSystemSettings-DRrreszl.cjs → useSystemSettings-B2jY51ob.cjs} +1 -1
  142. package/dist/{useSystemSettings-DRrreszl.cjs.map → useSystemSettings-B2jY51ob.cjs.map} +1 -1
  143. package/dist/{useSystemSettings-DBlAMjFi.js → useSystemSettings-rgskaDqP.js} +1 -1
  144. package/dist/{useSystemSettings-DBlAMjFi.js.map → useSystemSettings-rgskaDqP.js.map} +1 -1
  145. package/dist/{useUsersStatsSummary-NjEFvWuz.js → useUsersStatsSummary-5DJwzntC.js} +2 -2
  146. package/dist/{useUsersStatsSummary-NjEFvWuz.js.map → useUsersStatsSummary-5DJwzntC.js.map} +1 -1
  147. package/dist/{useUsersStatsSummary-8qY7iP4G.cjs → useUsersStatsSummary-DgKaUIfs.cjs} +1 -1
  148. package/dist/{useUsersStatsSummary-8qY7iP4G.cjs.map → useUsersStatsSummary-DgKaUIfs.cjs.map} +1 -1
  149. package/package.json +1 -1
  150. package/dist/AuthenticationSettings-C9f5MKgj.cjs +0 -1
  151. package/dist/AuthenticationSettings-C9f5MKgj.cjs.map +0 -1
  152. package/dist/AuthenticationSettings-DC64o_J6.js +0 -525
  153. package/dist/AuthenticationSettings-DC64o_J6.js.map +0 -1
  154. package/dist/AutosaveStatus-BFj5GIab.cjs +0 -1
  155. package/dist/AutosaveStatus-BFj5GIab.cjs.map +0 -1
  156. package/dist/AutosaveStatus-vkJxtuEw.js.map +0 -1
  157. package/dist/EmailRegisterForm-B1DB-bqe.cjs +0 -1
  158. package/dist/EmailRegisterForm-B1DB-bqe.cjs.map +0 -1
  159. package/dist/EmailRegisterForm-BAX_uBIt.js +0 -927
  160. package/dist/EmailRegisterForm-BAX_uBIt.js.map +0 -1
  161. package/dist/GoogleLoginButton-B6qnNMZp.js +0 -230
  162. package/dist/GoogleLoginButton-B6qnNMZp.js.map +0 -1
  163. package/dist/GoogleLoginButton-D7CoMXLq.cjs +0 -1
  164. package/dist/GoogleLoginButton-D7CoMXLq.cjs.map +0 -1
  165. package/dist/PermissionsSection-BPbE-hNx.cjs.map +0 -1
  166. package/dist/PermissionsSection-CighC1p6.js.map +0 -1
  167. package/dist/mobileWalletAdapter-B6ELaZp1.cjs +0 -1
  168. package/dist/mobileWalletAdapter-B6ELaZp1.cjs.map +0 -1
  169. package/dist/mobileWalletAdapter-Cm_AUXhg.js +0 -191
  170. package/dist/mobileWalletAdapter-Cm_AUXhg.js.map +0 -1
  171. package/dist/useAuth-X6Ds6WW4.cjs +0 -1
  172. package/dist/useAuth-X6Ds6WW4.cjs.map +0 -1
  173. package/dist/useAuth-m5Hf89v8.js.map +0 -1
  174. package/dist/useCedrosLogin-C9MrcZvh.cjs +0 -1
  175. package/dist/useCedrosLogin-C9MrcZvh.cjs.map +0 -1
  176. package/dist/useCedrosLogin-_94MmGGq.js +0 -216
  177. package/dist/useCedrosLogin-_94MmGGq.js.map +0 -1
@@ -1 +0,0 @@
1
- {"version":3,"file":"AuthenticationSettings-C9f5MKgj.cjs","sources":["../src/hooks/useSsoProviders.ts","../src/components/admin/settings/SsoProvidersSettings.tsx","../src/components/admin/settings/AuthenticationSettings.tsx"],"sourcesContent":["/**\n * Hook for managing SSO providers (admin)\n */\nimport { useState, useCallback, useRef } from 'react';\nimport { useCedrosLogin } from '../context/useCedrosLogin';\n\nexport interface SsoProvider {\n id: string;\n orgId: string;\n name: string;\n issuerUrl: string;\n clientId: string;\n scopes: string[];\n enabled: boolean;\n allowRegistration: boolean;\n emailDomain: string | null;\n createdAt: string;\n updatedAt: string;\n}\n\nexport interface CreateSsoProviderInput {\n orgId: string;\n name: string;\n issuerUrl: string;\n clientId: string;\n clientSecret: string;\n scopes?: string[];\n enabled?: boolean;\n allowRegistration?: boolean;\n emailDomain?: string | null;\n}\n\nexport interface UpdateSsoProviderInput {\n name?: string;\n issuerUrl?: string;\n clientId?: string;\n clientSecret?: string;\n scopes?: string[];\n enabled?: boolean;\n allowRegistration?: boolean;\n emailDomain?: string | null;\n}\n\ninterface ListResponse {\n providers: SsoProvider[];\n total: number;\n limit: number;\n offset: number;\n}\n\nexport function useSsoProviders() {\n const { config, _internal } = useCedrosLogin();\n const serverUrl = config.serverUrl;\n\n // PERF-03: Stabilize getAccessToken reference using ref pattern\n // to prevent unnecessary re-creation of callbacks\n const getAccessTokenRef = useRef(_internal?.getAccessToken ?? (() => null));\n getAccessTokenRef.current = _internal?.getAccessToken ?? (() => null);\n\n const [providers, setProviders] = useState<SsoProvider[]>([]);\n const [total, setTotal] = useState(0);\n const [isLoading, setIsLoading] = useState(false);\n const [error, setError] = useState<Error | null>(null);\n\n // Memoize getHeaders with empty deps since it uses ref\n const getHeaders = useCallback(() => {\n const token = getAccessTokenRef.current();\n return {\n 'Content-Type': 'application/json',\n ...(token ? { Authorization: `Bearer ${token}` } : {}),\n };\n }, []);\n\n const fetchProviders = useCallback(\n async (orgId?: string, limit = 50, offset = 0) => {\n setIsLoading(true);\n setError(null);\n try {\n const params = new URLSearchParams();\n if (orgId) params.set('org_id', orgId);\n params.set('limit', String(limit));\n params.set('offset', String(offset));\n\n const res = await fetch(`${serverUrl}/admin/sso-providers?${params}`, {\n headers: getHeaders(),\n });\n\n if (!res.ok) {\n const err = await res.json().catch(() => ({}));\n throw new Error(err.error || `Failed to fetch SSO providers: ${res.status}`);\n }\n\n const data: ListResponse = await res.json();\n setProviders(data.providers);\n setTotal(data.total);\n return data;\n } catch (err) {\n const error = err instanceof Error ? err : new Error(String(err));\n setError(error);\n throw error;\n } finally {\n setIsLoading(false);\n }\n },\n [serverUrl, getHeaders]\n );\n\n const createProvider = useCallback(\n async (input: CreateSsoProviderInput): Promise<SsoProvider> => {\n setIsLoading(true);\n setError(null);\n try {\n const res = await fetch(`${serverUrl}/admin/sso-providers`, {\n method: 'POST',\n headers: getHeaders(),\n body: JSON.stringify(input),\n });\n\n if (!res.ok) {\n const err = await res.json().catch(() => ({}));\n throw new Error(err.error || `Failed to create SSO provider: ${res.status}`);\n }\n\n const provider: SsoProvider = await res.json();\n setProviders((prev) => [...prev, provider]);\n setTotal((prev) => prev + 1);\n return provider;\n } catch (err) {\n const error = err instanceof Error ? err : new Error(String(err));\n setError(error);\n throw error;\n } finally {\n setIsLoading(false);\n }\n },\n [serverUrl, getHeaders]\n );\n\n const updateProvider = useCallback(\n async (id: string, input: UpdateSsoProviderInput): Promise<SsoProvider> => {\n setIsLoading(true);\n setError(null);\n try {\n const res = await fetch(`${serverUrl}/admin/sso-providers/${id}`, {\n method: 'PUT',\n headers: getHeaders(),\n body: JSON.stringify(input),\n });\n\n if (!res.ok) {\n const err = await res.json().catch(() => ({}));\n throw new Error(err.error || `Failed to update SSO provider: ${res.status}`);\n }\n\n const provider: SsoProvider = await res.json();\n setProviders((prev) => prev.map((p) => (p.id === id ? provider : p)));\n return provider;\n } catch (err) {\n const error = err instanceof Error ? err : new Error(String(err));\n setError(error);\n throw error;\n } finally {\n setIsLoading(false);\n }\n },\n [serverUrl, getHeaders]\n );\n\n const deleteProvider = useCallback(\n async (id: string): Promise<void> => {\n setIsLoading(true);\n setError(null);\n try {\n const res = await fetch(`${serverUrl}/admin/sso-providers/${id}`, {\n method: 'DELETE',\n headers: getHeaders(),\n });\n\n if (!res.ok) {\n const err = await res.json().catch(() => ({}));\n throw new Error(err.error || `Failed to delete SSO provider: ${res.status}`);\n }\n\n setProviders((prev) => prev.filter((p) => p.id !== id));\n setTotal((prev) => prev - 1);\n } catch (err) {\n const error = err instanceof Error ? err : new Error(String(err));\n setError(error);\n throw error;\n } finally {\n setIsLoading(false);\n }\n },\n [serverUrl, getHeaders]\n );\n\n const toggleProvider = useCallback(\n async (id: string, enabled: boolean): Promise<SsoProvider> => {\n return updateProvider(id, { enabled });\n },\n [updateProvider]\n );\n\n return {\n providers,\n total,\n isLoading,\n error,\n fetchProviders,\n createProvider,\n updateProvider,\n deleteProvider,\n toggleProvider,\n };\n}\n","/**\n * SSO Providers settings - manage OIDC identity providers\n */\nimport { useState, useEffect, useCallback } from 'react';\nimport { LoadingSpinner } from '../../shared/LoadingSpinner';\nimport { ErrorMessage } from '../../shared/ErrorMessage';\nimport {\n useSsoProviders,\n type SsoProvider,\n type CreateSsoProviderInput,\n type UpdateSsoProviderInput,\n} from '../../../hooks/useSsoProviders';\nimport { useOrgs } from '../../../hooks/useOrgs';\n\nexport interface SsoProvidersSettingsProps {\n className?: string;\n}\n\ntype ViewMode = 'list' | 'add' | 'edit';\n\nexport function SsoProvidersSettings({ className }: SsoProvidersSettingsProps) {\n const {\n providers,\n isLoading,\n error,\n fetchProviders,\n createProvider,\n updateProvider,\n deleteProvider,\n toggleProvider,\n } = useSsoProviders();\n\n const { activeOrg } = useOrgs();\n const [viewMode, setViewMode] = useState<ViewMode>('list');\n const [editingProvider, setEditingProvider] = useState<SsoProvider | null>(null);\n const [formError, setFormError] = useState<string | null>(null);\n\n useEffect(() => {\n fetchProviders(activeOrg?.id);\n }, [fetchProviders, activeOrg?.id]);\n\n const handleAdd = () => {\n setEditingProvider(null);\n setFormError(null);\n setViewMode('add');\n };\n\n const handleEdit = (provider: SsoProvider) => {\n setEditingProvider(provider);\n setFormError(null);\n setViewMode('edit');\n };\n\n const handleCancel = () => {\n setViewMode('list');\n setEditingProvider(null);\n setFormError(null);\n };\n\n const handleDelete = async (provider: SsoProvider) => {\n if (!confirm(`Delete SSO provider \"${provider.name}\"? This cannot be undone.`)) {\n return;\n }\n try {\n await deleteProvider(provider.id);\n } catch {\n // Error is already set in hook\n }\n };\n\n const handleToggle = async (provider: SsoProvider) => {\n try {\n await toggleProvider(provider.id, !provider.enabled);\n } catch {\n // Error is already set in hook\n }\n };\n\n const handleSave = async (data: CreateSsoProviderInput | UpdateSsoProviderInput) => {\n setFormError(null);\n try {\n if (viewMode === 'add') {\n await createProvider(data as CreateSsoProviderInput);\n } else if (editingProvider) {\n await updateProvider(editingProvider.id, data as UpdateSsoProviderInput);\n }\n setViewMode('list');\n setEditingProvider(null);\n } catch (err) {\n setFormError(err instanceof Error ? err.message : 'Failed to save provider');\n }\n };\n\n if (isLoading && providers.length === 0) {\n return (\n <div className={`cedros-system-settings cedros-system-settings-loading ${className ?? ''}`}>\n <LoadingSpinner />\n <span>Loading SSO providers...</span>\n </div>\n );\n }\n\n if (viewMode === 'add' || viewMode === 'edit') {\n return (\n <div className={`cedros-system-settings ${className ?? ''}`}>\n <SsoProviderForm\n provider={editingProvider}\n orgId={activeOrg?.id}\n error={formError}\n isLoading={isLoading}\n onSave={handleSave}\n onCancel={handleCancel}\n />\n </div>\n );\n }\n\n return (\n <div className={`cedros-system-settings ${className ?? ''}`}>\n <div className=\"cedros-settings-page-header\">\n <div className=\"cedros-settings-page-header-content\">\n <h2 className=\"cedros-settings-page-title\">SSO Providers</h2>\n <p className=\"cedros-settings-page-description\">\n Configure OIDC identity providers for enterprise single sign-on.\n </p>\n </div>\n <button type=\"button\" className=\"cedros-btn cedros-btn-primary\" onClick={handleAdd}>\n Add Provider\n </button>\n </div>\n\n {error && <ErrorMessage error={error.message} />}\n\n {providers.length === 0 ? (\n <div className=\"cedros-system-settings-empty\">\n <p>No SSO providers configured.</p>\n <p className=\"cedros-text-muted\">\n Add an OIDC provider like Okta, Azure AD, or Auth0 to enable enterprise SSO.\n </p>\n </div>\n ) : (\n <div className=\"cedros-sso-provider-list\">\n {providers.map((provider) => (\n <SsoProviderCard\n key={provider.id}\n provider={provider}\n onEdit={() => handleEdit(provider)}\n onDelete={() => handleDelete(provider)}\n onToggle={() => handleToggle(provider)}\n />\n ))}\n </div>\n )}\n </div>\n );\n}\n\n// =============================================================================\n// Provider Card\n// =============================================================================\n\ninterface SsoProviderCardProps {\n provider: SsoProvider;\n onEdit: () => void;\n onDelete: () => void;\n onToggle: () => void;\n}\n\nfunction SsoProviderCard({ provider, onEdit, onDelete, onToggle }: SsoProviderCardProps) {\n return (\n <div\n className={`cedros-sso-provider-card ${provider.enabled ? '' : 'cedros-sso-provider-card--disabled'}`}\n >\n <div className=\"cedros-sso-provider-card-header\">\n <div className=\"cedros-sso-provider-card-info\">\n <h3 className=\"cedros-sso-provider-card-name\">{provider.name}</h3>\n <p className=\"cedros-sso-provider-card-issuer\">{provider.issuerUrl}</p>\n </div>\n <button\n type=\"button\"\n role=\"switch\"\n aria-checked={provider.enabled}\n className={`cedros-toggle ${provider.enabled ? 'cedros-toggle-on' : 'cedros-toggle-off'}`}\n onClick={onToggle}\n >\n <span className=\"cedros-toggle-track\">\n <span className=\"cedros-toggle-thumb\" />\n </span>\n <span className=\"cedros-toggle-label\">{provider.enabled ? 'Enabled' : 'Disabled'}</span>\n </button>\n </div>\n\n <div className=\"cedros-sso-provider-card-details\">\n <div className=\"cedros-sso-provider-card-detail\">\n <span className=\"cedros-sso-provider-card-detail-label\">Client ID</span>\n <code className=\"cedros-sso-provider-card-detail-value\">{provider.clientId}</code>\n </div>\n {provider.emailDomain && (\n <div className=\"cedros-sso-provider-card-detail\">\n <span className=\"cedros-sso-provider-card-detail-label\">Email Domain</span>\n <span className=\"cedros-sso-provider-card-detail-value\">@{provider.emailDomain}</span>\n </div>\n )}\n <div className=\"cedros-sso-provider-card-detail\">\n <span className=\"cedros-sso-provider-card-detail-label\">Registration</span>\n <span className=\"cedros-sso-provider-card-detail-value\">\n {provider.allowRegistration ? 'Allowed' : 'Existing users only'}\n </span>\n </div>\n </div>\n\n <div className=\"cedros-sso-provider-card-actions\">\n <button type=\"button\" className=\"cedros-btn cedros-btn-ghost\" onClick={onEdit}>\n Edit\n </button>\n <button\n type=\"button\"\n className=\"cedros-btn cedros-btn-ghost cedros-btn-danger\"\n onClick={onDelete}\n >\n Delete\n </button>\n </div>\n </div>\n );\n}\n\n// =============================================================================\n// Provider Form\n// =============================================================================\n\ninterface SsoProviderFormProps {\n provider: SsoProvider | null;\n orgId?: string;\n error: string | null;\n isLoading: boolean;\n onSave: (data: CreateSsoProviderInput | UpdateSsoProviderInput) => void;\n onCancel: () => void;\n}\n\nfunction SsoProviderForm({\n provider,\n orgId,\n error,\n isLoading,\n onSave,\n onCancel,\n}: SsoProviderFormProps) {\n const isEditing = Boolean(provider);\n\n const [name, setName] = useState(provider?.name ?? '');\n const [issuerUrl, setIssuerUrl] = useState(provider?.issuerUrl ?? '');\n const [clientId, setClientId] = useState(provider?.clientId ?? '');\n const [clientSecret, setClientSecret] = useState('');\n const [emailDomain, setEmailDomain] = useState(provider?.emailDomain ?? '');\n const [allowRegistration, setAllowRegistration] = useState(provider?.allowRegistration ?? true);\n const [enabled, setEnabled] = useState(provider?.enabled ?? true);\n\n const handleSubmit = useCallback(\n (e: React.FormEvent) => {\n e.preventDefault();\n\n if (isEditing) {\n const updates: UpdateSsoProviderInput = {\n name,\n issuerUrl,\n clientId,\n emailDomain: emailDomain || null,\n allowRegistration,\n enabled,\n };\n // Only include secret if changed\n if (clientSecret) {\n updates.clientSecret = clientSecret;\n }\n onSave(updates);\n } else {\n if (!orgId) {\n return;\n }\n const data: CreateSsoProviderInput = {\n orgId,\n name,\n issuerUrl,\n clientId,\n clientSecret,\n emailDomain: emailDomain || null,\n allowRegistration,\n enabled,\n };\n onSave(data);\n }\n },\n [\n isEditing,\n orgId,\n name,\n issuerUrl,\n clientId,\n clientSecret,\n emailDomain,\n allowRegistration,\n enabled,\n onSave,\n ]\n );\n\n return (\n <form className=\"cedros-sso-provider-form\" onSubmit={handleSubmit}>\n <div className=\"cedros-settings-page-header\">\n <div className=\"cedros-settings-page-header-content\">\n <h2 className=\"cedros-settings-page-title\">\n {isEditing ? 'Edit SSO Provider' : 'Add SSO Provider'}\n </h2>\n <p className=\"cedros-settings-page-description\">\n Configure an OIDC identity provider for enterprise single sign-on.\n </p>\n </div>\n </div>\n\n {error && <ErrorMessage error={error} />}\n\n <div className=\"cedros-form-section\">\n <div className=\"cedros-form-group\">\n <label className=\"cedros-form-label\" htmlFor=\"sso-name\">\n Provider Name\n </label>\n <input\n id=\"sso-name\"\n type=\"text\"\n className=\"cedros-form-input\"\n value={name}\n onChange={(e) => setName(e.target.value)}\n placeholder=\"e.g., Okta, Azure AD\"\n required\n />\n </div>\n\n <div className=\"cedros-form-group\">\n <label className=\"cedros-form-label\" htmlFor=\"sso-issuer\">\n Issuer URL\n </label>\n <input\n id=\"sso-issuer\"\n type=\"url\"\n className=\"cedros-form-input\"\n value={issuerUrl}\n onChange={(e) => setIssuerUrl(e.target.value)}\n placeholder=\"https://your-org.okta.com\"\n required\n />\n <p className=\"cedros-form-hint\">\n The OIDC issuer URL. Must support discovery at /.well-known/openid-configuration\n </p>\n </div>\n\n <div className=\"cedros-form-group\">\n <label className=\"cedros-form-label\" htmlFor=\"sso-client-id\">\n Client ID\n </label>\n <input\n id=\"sso-client-id\"\n type=\"text\"\n className=\"cedros-form-input\"\n value={clientId}\n onChange={(e) => setClientId(e.target.value)}\n placeholder=\"OAuth client ID\"\n required\n />\n </div>\n\n <div className=\"cedros-form-group\">\n <label className=\"cedros-form-label\" htmlFor=\"sso-client-secret\">\n Client Secret{' '}\n {isEditing && (\n <span className=\"cedros-form-hint-inline\">(leave blank to keep current)</span>\n )}\n </label>\n <input\n id=\"sso-client-secret\"\n type=\"password\"\n className=\"cedros-form-input\"\n value={clientSecret}\n onChange={(e) => setClientSecret(e.target.value)}\n placeholder={isEditing ? '••••••••' : 'OAuth client secret'}\n required={!isEditing}\n />\n </div>\n\n <div className=\"cedros-form-group\">\n <label className=\"cedros-form-label\" htmlFor=\"sso-email-domain\">\n Email Domain (optional)\n </label>\n <input\n id=\"sso-email-domain\"\n type=\"text\"\n className=\"cedros-form-input\"\n value={emailDomain}\n onChange={(e) => setEmailDomain(e.target.value)}\n placeholder=\"company.com\"\n />\n <p className=\"cedros-form-hint\">Restrict to users with emails from this domain</p>\n </div>\n\n <div className=\"cedros-form-group\">\n <label className=\"cedros-form-checkbox\">\n <input\n type=\"checkbox\"\n checked={allowRegistration}\n onChange={(e) => setAllowRegistration(e.target.checked)}\n />\n <span>Allow new user registration via SSO</span>\n </label>\n </div>\n\n <div className=\"cedros-form-group\">\n <label className=\"cedros-form-checkbox\">\n <input\n type=\"checkbox\"\n checked={enabled}\n onChange={(e) => setEnabled(e.target.checked)}\n />\n <span>Enable this provider</span>\n </label>\n </div>\n </div>\n\n <div className=\"cedros-form-actions\">\n <button\n type=\"button\"\n className=\"cedros-btn cedros-btn-ghost\"\n onClick={onCancel}\n disabled={isLoading}\n >\n Cancel\n </button>\n <button type=\"submit\" className=\"cedros-btn cedros-btn-primary\" disabled={isLoading}>\n {isLoading ? 'Saving...' : isEditing ? 'Save Changes' : 'Add Provider'}\n </button>\n </div>\n </form>\n );\n}\n","/**\n * Authentication settings page - configure auth providers with tabs\n */\nimport { useState, useEffect, useMemo } from 'react';\nimport { LoadingSpinner } from '../../shared/LoadingSpinner';\nimport { ErrorMessage } from '../../shared/ErrorMessage';\nimport { useSettingsAutosave } from '../../../hooks/useSettingsAutosave';\nimport { SettingsSection } from './settingsInputs';\nimport { AutosaveStatus } from './AutosaveStatus';\nimport { SsoProvidersSettings } from './SsoProvidersSettings';\n\ntype AuthTab = 'email' | 'google' | 'apple' | 'solana' | 'passkeys' | 'instantlink' | 'sso';\n\ninterface TabConfig {\n id: AuthTab;\n label: string;\n /** Categories to pull settings from (not used for 'sso' tab) */\n categories: string[];\n /** Optional list of specific keys to show (if omitted, show all in categories) */\n keys?: string[];\n /** If true, renders a custom component instead of settings section */\n isCustom?: boolean;\n}\n\nconst TABS: TabConfig[] = [\n { id: 'email', label: 'Email', categories: ['auth.email'],\n keys: ['auth_email_enabled', 'auth_email_require_verification', 'auth_email_block_disposable'] },\n { id: 'google', label: 'Google', categories: ['auth.google'],\n keys: ['auth_google_enabled', 'auth_google_client_id'] },\n { id: 'apple', label: 'Apple', categories: ['auth.apple'],\n keys: ['auth_apple_enabled', 'auth_apple_client_id', 'auth_apple_team_id'] },\n { id: 'solana', label: 'Solana', categories: ['auth.solana'],\n keys: ['auth_solana_enabled', 'auth_solana_challenge_expiry'] },\n { id: 'passkeys', label: 'Passkeys', categories: ['auth.webauthn'],\n keys: ['auth_webauthn_enabled', 'auth_webauthn_rp_id', 'auth_webauthn_rp_name', 'auth_webauthn_rp_origin'] },\n { id: 'instantlink', label: 'Instant Link', categories: ['auth.instantlink'],\n keys: ['auth_instantlink_enabled', 'auth_instantlink_expiry', 'auth_instantlink_rate_limit'] },\n { id: 'sso', label: 'SSO Providers', categories: [], isCustom: true },\n];\n\nexport interface AuthenticationSettingsProps {\n className?: string;\n}\n\nexport function AuthenticationSettings({ className }: AuthenticationSettingsProps) {\n const {\n settings,\n edits,\n isLoading,\n autosaveStatus,\n autosaveError,\n error,\n fetchSettings,\n handleChange,\n } = useSettingsAutosave();\n\n const [activeTab, setActiveTab] = useState<AuthTab>('email');\n\n useEffect(() => {\n fetchSettings();\n }, [fetchSettings]);\n\n // Get current tab config\n const currentTab = TABS.find((t) => t.id === activeTab);\n\n // Collect settings from all categories for the current tab\n const allTabSettings = useMemo(() => {\n if (!currentTab) return [];\n const allSettings: (typeof settings)[string] = [];\n for (const category of currentTab.categories) {\n const categorySettings = settings[category] ?? [];\n allSettings.push(...categorySettings);\n }\n return allSettings;\n }, [settings, currentTab]);\n\n const currentSettings = useMemo(() => {\n if (!currentTab?.keys) return allTabSettings;\n // Filter and sort by keys order\n return allTabSettings\n .filter((s) => currentTab.keys!.includes(s.key))\n .sort((a, b) => currentTab.keys!.indexOf(a.key) - currentTab.keys!.indexOf(b.key));\n }, [allTabSettings, currentTab]);\n\n if (isLoading && Object.keys(settings).length === 0) {\n return (\n <div className={`cedros-system-settings cedros-system-settings-loading ${className ?? ''}`}>\n <LoadingSpinner />\n <span>Loading settings...</span>\n </div>\n );\n }\n\n if (error) {\n return (\n <div className={`cedros-system-settings ${className ?? ''}`}>\n <ErrorMessage error={error.message} />\n </div>\n );\n }\n\n return (\n <div className={`cedros-system-settings ${className ?? ''}`}>\n <div className=\"cedros-settings-page-header\">\n <div className=\"cedros-settings-page-header-content\">\n <h2 className=\"cedros-settings-page-title\">Authentication</h2>\n <p className=\"cedros-settings-page-description\">\n Configure authentication providers and methods for user sign-in.\n </p>\n </div>\n <AutosaveStatus status={autosaveStatus} error={autosaveError} />\n </div>\n\n {/* Tabs */}\n <div className=\"cedros-admin-tabs cedros-admin-tabs--line\">\n {TABS.map((tab) => (\n <button\n key={tab.id}\n type=\"button\"\n className={`cedros-admin-tab ${activeTab === tab.id ? 'cedros-admin-tab-active' : ''}`}\n onClick={() => setActiveTab(tab.id)}\n aria-selected={activeTab === tab.id}\n role=\"tab\"\n >\n {tab.label}\n </button>\n ))}\n </div>\n\n {/* Tab content */}\n <div className=\"cedros-admin-tab-content\" role=\"tabpanel\">\n {currentTab?.isCustom ? (\n <SsoProvidersSettings />\n ) : currentSettings.length === 0 ? (\n <div className=\"cedros-system-settings-empty\">\n <p>No settings found for {currentTab?.label ?? 'this provider'}.</p>\n </div>\n ) : (\n <SettingsSection settings={currentSettings} edits={edits} onChange={handleChange} />\n )}\n </div>\n </div>\n );\n}\n"],"names":["useSsoProviders","config","_internal","useCedrosLogin","serverUrl","getAccessTokenRef","useRef","providers","setProviders","useState","total","setTotal","isLoading","setIsLoading","error","setError","getHeaders","useCallback","token","fetchProviders","orgId","limit","offset","params","res","err","data","createProvider","input","provider","prev","updateProvider","id","p","deleteProvider","toggleProvider","enabled","SsoProvidersSettings","className","activeOrg","useOrgs","viewMode","setViewMode","editingProvider","setEditingProvider","formError","setFormError","useEffect","handleAdd","handleEdit","handleCancel","handleDelete","handleToggle","handleSave","jsx","LoadingSpinner","SsoProviderForm","jsxs","ErrorMessage","SsoProviderCard","onEdit","onDelete","onToggle","onSave","onCancel","isEditing","name","setName","issuerUrl","setIssuerUrl","clientId","setClientId","clientSecret","setClientSecret","emailDomain","setEmailDomain","allowRegistration","setAllowRegistration","setEnabled","handleSubmit","e","updates","TABS","AuthenticationSettings","settings","edits","autosaveStatus","autosaveError","fetchSettings","handleChange","useSettingsAutosave","activeTab","setActiveTab","currentTab","t","allTabSettings","useMemo","allSettings","category","categorySettings","currentSettings","s","a","b","AutosaveStatus","tab","SettingsSection"],"mappings":"mRAkDO,SAASA,GAAkB,CAChC,KAAM,CAAE,OAAAC,EAAQ,UAAAC,CAAA,EAAcC,iBAAA,EACxBC,EAAYH,EAAO,UAInBI,EAAoBC,EAAAA,OAAOJ,GAAW,iBAAmB,IAAM,KAAK,EAC1EG,EAAkB,QAAUH,GAAW,iBAAmB,IAAM,MAEhE,KAAM,CAACK,EAAWC,CAAY,EAAIC,EAAAA,SAAwB,CAAA,CAAE,EACtD,CAACC,EAAOC,CAAQ,EAAIF,EAAAA,SAAS,CAAC,EAC9B,CAACG,EAAWC,CAAY,EAAIJ,EAAAA,SAAS,EAAK,EAC1C,CAACK,EAAOC,CAAQ,EAAIN,EAAAA,SAAuB,IAAI,EAG/CO,EAAaC,EAAAA,YAAY,IAAM,CACnC,MAAMC,EAAQb,EAAkB,QAAA,EAChC,MAAO,CACL,eAAgB,mBAChB,GAAIa,EAAQ,CAAE,cAAe,UAAUA,CAAK,IAAO,CAAA,CAAC,CAExD,EAAG,CAAA,CAAE,EAECC,EAAiBF,EAAAA,YACrB,MAAOG,EAAgBC,EAAQ,GAAIC,EAAS,IAAM,CAChDT,EAAa,EAAI,EACjBE,EAAS,IAAI,EACb,GAAI,CACF,MAAMQ,EAAS,IAAI,gBACfH,GAAOG,EAAO,IAAI,SAAUH,CAAK,EACrCG,EAAO,IAAI,QAAS,OAAOF,CAAK,CAAC,EACjCE,EAAO,IAAI,SAAU,OAAOD,CAAM,CAAC,EAEnC,MAAME,EAAM,MAAM,MAAM,GAAGpB,CAAS,wBAAwBmB,CAAM,GAAI,CACpE,QAASP,EAAA,CAAW,CACrB,EAED,GAAI,CAACQ,EAAI,GAAI,CACX,MAAMC,EAAM,MAAMD,EAAI,KAAA,EAAO,MAAM,KAAO,CAAA,EAAG,EAC7C,MAAM,IAAI,MAAMC,EAAI,OAAS,kCAAkCD,EAAI,MAAM,EAAE,CAC7E,CAEA,MAAME,EAAqB,MAAMF,EAAI,KAAA,EACrC,OAAAhB,EAAakB,EAAK,SAAS,EAC3Bf,EAASe,EAAK,KAAK,EACZA,CACT,OAASD,EAAK,CACZ,MAAMX,EAAQW,aAAe,MAAQA,EAAM,IAAI,MAAM,OAAOA,CAAG,CAAC,EAChE,MAAAV,EAASD,CAAK,EACRA,CACR,QAAA,CACED,EAAa,EAAK,CACpB,CACF,EACA,CAACT,EAAWY,CAAU,CAAA,EAGlBW,EAAiBV,EAAAA,YACrB,MAAOW,GAAwD,CAC7Df,EAAa,EAAI,EACjBE,EAAS,IAAI,EACb,GAAI,CACF,MAAMS,EAAM,MAAM,MAAM,GAAGpB,CAAS,uBAAwB,CAC1D,OAAQ,OACR,QAASY,EAAA,EACT,KAAM,KAAK,UAAUY,CAAK,CAAA,CAC3B,EAED,GAAI,CAACJ,EAAI,GAAI,CACX,MAAMC,EAAM,MAAMD,EAAI,KAAA,EAAO,MAAM,KAAO,CAAA,EAAG,EAC7C,MAAM,IAAI,MAAMC,EAAI,OAAS,kCAAkCD,EAAI,MAAM,EAAE,CAC7E,CAEA,MAAMK,EAAwB,MAAML,EAAI,KAAA,EACxC,OAAAhB,EAAcsB,GAAS,CAAC,GAAGA,EAAMD,CAAQ,CAAC,EAC1ClB,EAAUmB,GAASA,EAAO,CAAC,EACpBD,CACT,OAASJ,EAAK,CACZ,MAAMX,EAAQW,aAAe,MAAQA,EAAM,IAAI,MAAM,OAAOA,CAAG,CAAC,EAChE,MAAAV,EAASD,CAAK,EACRA,CACR,QAAA,CACED,EAAa,EAAK,CACpB,CACF,EACA,CAACT,EAAWY,CAAU,CAAA,EAGlBe,EAAiBd,EAAAA,YACrB,MAAOe,EAAYJ,IAAwD,CACzEf,EAAa,EAAI,EACjBE,EAAS,IAAI,EACb,GAAI,CACF,MAAMS,EAAM,MAAM,MAAM,GAAGpB,CAAS,wBAAwB4B,CAAE,GAAI,CAChE,OAAQ,MACR,QAAShB,EAAA,EACT,KAAM,KAAK,UAAUY,CAAK,CAAA,CAC3B,EAED,GAAI,CAACJ,EAAI,GAAI,CACX,MAAMC,EAAM,MAAMD,EAAI,KAAA,EAAO,MAAM,KAAO,CAAA,EAAG,EAC7C,MAAM,IAAI,MAAMC,EAAI,OAAS,kCAAkCD,EAAI,MAAM,EAAE,CAC7E,CAEA,MAAMK,EAAwB,MAAML,EAAI,KAAA,EACxC,OAAAhB,EAAcsB,GAASA,EAAK,IAAKG,GAAOA,EAAE,KAAOD,EAAKH,EAAWI,CAAE,CAAC,EAC7DJ,CACT,OAASJ,EAAK,CACZ,MAAMX,EAAQW,aAAe,MAAQA,EAAM,IAAI,MAAM,OAAOA,CAAG,CAAC,EAChE,MAAAV,EAASD,CAAK,EACRA,CACR,QAAA,CACED,EAAa,EAAK,CACpB,CACF,EACA,CAACT,EAAWY,CAAU,CAAA,EAGlBkB,EAAiBjB,EAAAA,YACrB,MAAOe,GAA8B,CACnCnB,EAAa,EAAI,EACjBE,EAAS,IAAI,EACb,GAAI,CACF,MAAMS,EAAM,MAAM,MAAM,GAAGpB,CAAS,wBAAwB4B,CAAE,GAAI,CAChE,OAAQ,SACR,QAAShB,EAAA,CAAW,CACrB,EAED,GAAI,CAACQ,EAAI,GAAI,CACX,MAAMC,EAAM,MAAMD,EAAI,KAAA,EAAO,MAAM,KAAO,CAAA,EAAG,EAC7C,MAAM,IAAI,MAAMC,EAAI,OAAS,kCAAkCD,EAAI,MAAM,EAAE,CAC7E,CAEAhB,EAAcsB,GAASA,EAAK,OAAQG,GAAMA,EAAE,KAAOD,CAAE,CAAC,EACtDrB,EAAUmB,GAASA,EAAO,CAAC,CAC7B,OAASL,EAAK,CACZ,MAAMX,EAAQW,aAAe,MAAQA,EAAM,IAAI,MAAM,OAAOA,CAAG,CAAC,EAChE,MAAAV,EAASD,CAAK,EACRA,CACR,QAAA,CACED,EAAa,EAAK,CACpB,CACF,EACA,CAACT,EAAWY,CAAU,CAAA,EAGlBmB,EAAiBlB,EAAAA,YACrB,MAAOe,EAAYI,IACVL,EAAeC,EAAI,CAAE,QAAAI,EAAS,EAEvC,CAACL,CAAc,CAAA,EAGjB,MAAO,CACL,UAAAxB,EACA,MAAAG,EACA,UAAAE,EACA,MAAAE,EACA,eAAAK,EACA,eAAAQ,EACA,eAAAI,EACA,eAAAG,EACA,eAAAC,CAAA,CAEJ,CClMO,SAASE,EAAqB,CAAE,UAAAC,GAAwC,CAC7E,KAAM,CACJ,UAAA/B,EACA,UAAAK,EACA,MAAAE,EACA,eAAAK,EACA,eAAAQ,EACA,eAAAI,EACA,eAAAG,EACA,eAAAC,CAAA,EACEnC,EAAA,EAEE,CAAE,UAAAuC,CAAA,EAAcC,UAAA,EAChB,CAACC,EAAUC,CAAW,EAAIjC,EAAAA,SAAmB,MAAM,EACnD,CAACkC,EAAiBC,CAAkB,EAAInC,EAAAA,SAA6B,IAAI,EACzE,CAACoC,EAAWC,CAAY,EAAIrC,EAAAA,SAAwB,IAAI,EAE9DsC,EAAAA,UAAU,IAAM,CACd5B,EAAeoB,GAAW,EAAE,CAC9B,EAAG,CAACpB,EAAgBoB,GAAW,EAAE,CAAC,EAElC,MAAMS,EAAY,IAAM,CACtBJ,EAAmB,IAAI,EACvBE,EAAa,IAAI,EACjBJ,EAAY,KAAK,CACnB,EAEMO,EAAcpB,GAA0B,CAC5Ce,EAAmBf,CAAQ,EAC3BiB,EAAa,IAAI,EACjBJ,EAAY,MAAM,CACpB,EAEMQ,EAAe,IAAM,CACzBR,EAAY,MAAM,EAClBE,EAAmB,IAAI,EACvBE,EAAa,IAAI,CACnB,EAEMK,EAAe,MAAOtB,GAA0B,CACpD,GAAK,QAAQ,wBAAwBA,EAAS,IAAI,2BAA2B,EAG7E,GAAI,CACF,MAAMK,EAAeL,EAAS,EAAE,CAClC,MAAQ,CAER,CACF,EAEMuB,EAAe,MAAOvB,GAA0B,CACpD,GAAI,CACF,MAAMM,EAAeN,EAAS,GAAI,CAACA,EAAS,OAAO,CACrD,MAAQ,CAER,CACF,EAEMwB,EAAa,MAAO3B,GAA0D,CAClFoB,EAAa,IAAI,EACjB,GAAI,CACEL,IAAa,MACf,MAAMd,EAAeD,CAA8B,EAC1CiB,GACT,MAAMZ,EAAeY,EAAgB,GAAIjB,CAA8B,EAEzEgB,EAAY,MAAM,EAClBE,EAAmB,IAAI,CACzB,OAASnB,EAAK,CACZqB,EAAarB,aAAe,MAAQA,EAAI,QAAU,yBAAyB,CAC7E,CACF,EAEA,OAAIb,GAAaL,EAAU,SAAW,SAEjC,MAAA,CAAI,UAAW,yDAAyD+B,GAAa,EAAE,GACtF,SAAA,CAAAgB,EAAAA,IAACC,EAAAA,eAAA,EAAe,EAChBD,EAAAA,IAAC,QAAK,SAAA,0BAAA,CAAwB,CAAA,EAChC,EAIAb,IAAa,OAASA,IAAa,aAElC,MAAA,CAAI,UAAW,0BAA0BH,GAAa,EAAE,GACvD,SAAAgB,EAAAA,IAACE,EAAA,CACC,SAAUb,EACV,MAAOJ,GAAW,GAClB,MAAOM,EACP,UAAAjC,EACA,OAAQyC,EACR,SAAUH,CAAA,CAAA,EAEd,SAKD,MAAA,CAAI,UAAW,0BAA0BZ,GAAa,EAAE,GACvD,SAAA,CAAAmB,EAAAA,KAAC,MAAA,CAAI,UAAU,8BACb,SAAA,CAAAA,EAAAA,KAAC,MAAA,CAAI,UAAU,sCACb,SAAA,CAAAH,EAAAA,IAAC,KAAA,CAAG,UAAU,6BAA6B,SAAA,gBAAa,EACxDA,EAAAA,IAAC,IAAA,CAAE,UAAU,mCAAmC,SAAA,kEAAA,CAEhD,CAAA,EACF,EACAA,EAAAA,IAAC,UAAO,KAAK,SAAS,UAAU,gCAAgC,QAASN,EAAW,SAAA,cAAA,CAEpF,CAAA,EACF,EAEClC,GAASwC,EAAAA,IAACI,EAAAA,aAAA,CAAa,MAAO5C,EAAM,QAAS,EAE7CP,EAAU,SAAW,EACpBkD,EAAAA,KAAC,MAAA,CAAI,UAAU,+BACb,SAAA,CAAAH,EAAAA,IAAC,KAAE,SAAA,8BAAA,CAA4B,EAC/BA,EAAAA,IAAC,IAAA,CAAE,UAAU,oBAAoB,SAAA,8EAAA,CAEjC,CAAA,CAAA,CACF,QAEC,MAAA,CAAI,UAAU,2BACZ,SAAA/C,EAAU,IAAKsB,GACdyB,EAAAA,IAACK,EAAA,CAEC,SAAA9B,EACA,OAAQ,IAAMoB,EAAWpB,CAAQ,EACjC,SAAU,IAAMsB,EAAatB,CAAQ,EACrC,SAAU,IAAMuB,EAAavB,CAAQ,CAAA,EAJhCA,EAAS,EAAA,CAMjB,CAAA,CACH,CAAA,EAEJ,CAEJ,CAaA,SAAS8B,EAAgB,CAAE,SAAA9B,EAAU,OAAA+B,EAAQ,SAAAC,EAAU,SAAAC,GAAkC,CACvF,OACEL,EAAAA,KAAC,MAAA,CACC,UAAW,4BAA4B5B,EAAS,QAAU,GAAK,oCAAoC,GAEnG,SAAA,CAAA4B,EAAAA,KAAC,MAAA,CAAI,UAAU,kCACb,SAAA,CAAAA,EAAAA,KAAC,MAAA,CAAI,UAAU,gCACb,SAAA,CAAAH,EAAAA,IAAC,KAAA,CAAG,UAAU,gCAAiC,SAAAzB,EAAS,KAAK,EAC7DyB,EAAAA,IAAC,IAAA,CAAE,UAAU,kCAAmC,WAAS,SAAA,CAAU,CAAA,EACrE,EACAG,EAAAA,KAAC,SAAA,CACC,KAAK,SACL,KAAK,SACL,eAAc5B,EAAS,QACvB,UAAW,iBAAiBA,EAAS,QAAU,mBAAqB,mBAAmB,GACvF,QAASiC,EAET,SAAA,CAAAR,EAAAA,IAAC,QAAK,UAAU,sBACd,eAAC,OAAA,CAAK,UAAU,sBAAsB,CAAA,CACxC,QACC,OAAA,CAAK,UAAU,sBAAuB,SAAAzB,EAAS,QAAU,UAAY,UAAA,CAAW,CAAA,CAAA,CAAA,CACnF,EACF,EAEA4B,EAAAA,KAAC,MAAA,CAAI,UAAU,mCACb,SAAA,CAAAA,EAAAA,KAAC,MAAA,CAAI,UAAU,kCACb,SAAA,CAAAH,EAAAA,IAAC,OAAA,CAAK,UAAU,wCAAwC,SAAA,YAAS,EACjEA,EAAAA,IAAC,OAAA,CAAK,UAAU,wCAAyC,WAAS,QAAA,CAAS,CAAA,EAC7E,EACCzB,EAAS,aACR4B,OAAC,MAAA,CAAI,UAAU,kCACb,SAAA,CAAAH,EAAAA,IAAC,OAAA,CAAK,UAAU,wCAAwC,SAAA,eAAY,EACpEG,EAAAA,KAAC,OAAA,CAAK,UAAU,wCAAwC,SAAA,CAAA,IAAE5B,EAAS,WAAA,CAAA,CAAY,CAAA,EACjF,EAEF4B,EAAAA,KAAC,MAAA,CAAI,UAAU,kCACb,SAAA,CAAAH,EAAAA,IAAC,OAAA,CAAK,UAAU,wCAAwC,SAAA,eAAY,QACnE,OAAA,CAAK,UAAU,wCACb,SAAAzB,EAAS,kBAAoB,UAAY,qBAAA,CAC5C,CAAA,CAAA,CACF,CAAA,EACF,EAEA4B,EAAAA,KAAC,MAAA,CAAI,UAAU,mCACb,SAAA,CAAAH,EAAAA,IAAC,UAAO,KAAK,SAAS,UAAU,8BAA8B,QAASM,EAAQ,SAAA,MAAA,CAE/E,EACAN,EAAAA,IAAC,SAAA,CACC,KAAK,SACL,UAAU,gDACV,QAASO,EACV,SAAA,QAAA,CAAA,CAED,CAAA,CACF,CAAA,CAAA,CAAA,CAGN,CAeA,SAASL,EAAgB,CACvB,SAAA3B,EACA,MAAAT,EACA,MAAAN,EACA,UAAAF,EACA,OAAAmD,EACA,SAAAC,CACF,EAAyB,CACvB,MAAMC,EAAY,EAAQpC,EAEpB,CAACqC,EAAMC,CAAO,EAAI1D,EAAAA,SAASoB,GAAU,MAAQ,EAAE,EAC/C,CAACuC,EAAWC,CAAY,EAAI5D,EAAAA,SAASoB,GAAU,WAAa,EAAE,EAC9D,CAACyC,EAAUC,CAAW,EAAI9D,EAAAA,SAASoB,GAAU,UAAY,EAAE,EAC3D,CAAC2C,EAAcC,CAAe,EAAIhE,EAAAA,SAAS,EAAE,EAC7C,CAACiE,EAAaC,CAAc,EAAIlE,EAAAA,SAASoB,GAAU,aAAe,EAAE,EACpE,CAAC+C,EAAmBC,CAAoB,EAAIpE,EAAAA,SAASoB,GAAU,mBAAqB,EAAI,EACxF,CAACO,EAAS0C,CAAU,EAAIrE,EAAAA,SAASoB,GAAU,SAAW,EAAI,EAE1DkD,EAAe9D,EAAAA,YAClB+D,GAAuB,CAGtB,GAFAA,EAAE,eAAA,EAEEf,EAAW,CACb,MAAMgB,EAAkC,CACtC,KAAAf,EACA,UAAAE,EACA,SAAAE,EACA,YAAaI,GAAe,KAC5B,kBAAAE,EACA,QAAAxC,CAAA,EAGEoC,IACFS,EAAQ,aAAeT,GAEzBT,EAAOkB,CAAO,CAChB,KAAO,CACL,GAAI,CAAC7D,EACH,OAYF2C,EAVqC,CACnC,MAAA3C,EACA,KAAA8C,EACA,UAAAE,EACA,SAAAE,EACA,aAAAE,EACA,YAAaE,GAAe,KAC5B,kBAAAE,EACA,QAAAxC,CAAA,CAES,CACb,CACF,EACA,CACE6B,EACA7C,EACA8C,EACAE,EACAE,EACAE,EACAE,EACAE,EACAxC,EACA2B,CAAA,CACF,EAGF,OACEN,EAAAA,KAAC,OAAA,CAAK,UAAU,2BAA2B,SAAUsB,EACnD,SAAA,CAAAzB,EAAAA,IAAC,OAAI,UAAU,8BACb,SAAAG,EAAAA,KAAC,MAAA,CAAI,UAAU,sCACb,SAAA,CAAAH,MAAC,KAAA,CAAG,UAAU,6BACX,SAAAW,EAAY,oBAAsB,mBACrC,EACAX,EAAAA,IAAC,IAAA,CAAE,UAAU,mCAAmC,SAAA,oEAAA,CAEhD,CAAA,CAAA,CACF,CAAA,CACF,EAECxC,GAASwC,EAAAA,IAACI,eAAA,CAAa,MAAA5C,CAAA,CAAc,EAEtC2C,EAAAA,KAAC,MAAA,CAAI,UAAU,sBACb,SAAA,CAAAA,EAAAA,KAAC,MAAA,CAAI,UAAU,oBACb,SAAA,CAAAH,MAAC,QAAA,CAAM,UAAU,oBAAoB,QAAQ,WAAW,SAAA,gBAExD,EACAA,EAAAA,IAAC,QAAA,CACC,GAAG,WACH,KAAK,OACL,UAAU,oBACV,MAAOY,EACP,SAAWc,GAAMb,EAAQa,EAAE,OAAO,KAAK,EACvC,YAAY,uBACZ,SAAQ,EAAA,CAAA,CACV,EACF,EAEAvB,EAAAA,KAAC,MAAA,CAAI,UAAU,oBACb,SAAA,CAAAH,MAAC,QAAA,CAAM,UAAU,oBAAoB,QAAQ,aAAa,SAAA,aAE1D,EACAA,EAAAA,IAAC,QAAA,CACC,GAAG,aACH,KAAK,MACL,UAAU,oBACV,MAAOc,EACP,SAAWY,GAAMX,EAAaW,EAAE,OAAO,KAAK,EAC5C,YAAY,4BACZ,SAAQ,EAAA,CAAA,EAEV1B,EAAAA,IAAC,IAAA,CAAE,UAAU,mBAAmB,SAAA,kFAAA,CAEhC,CAAA,EACF,EAEAG,EAAAA,KAAC,MAAA,CAAI,UAAU,oBACb,SAAA,CAAAH,MAAC,QAAA,CAAM,UAAU,oBAAoB,QAAQ,gBAAgB,SAAA,YAE7D,EACAA,EAAAA,IAAC,QAAA,CACC,GAAG,gBACH,KAAK,OACL,UAAU,oBACV,MAAOgB,EACP,SAAWU,GAAMT,EAAYS,EAAE,OAAO,KAAK,EAC3C,YAAY,kBACZ,SAAQ,EAAA,CAAA,CACV,EACF,EAEAvB,EAAAA,KAAC,MAAA,CAAI,UAAU,oBACb,SAAA,CAAAA,EAAAA,KAAC,QAAA,CAAM,UAAU,oBAAoB,QAAQ,oBAAoB,SAAA,CAAA,gBACjD,IACbQ,GACCX,EAAAA,IAAC,OAAA,CAAK,UAAU,0BAA0B,SAAA,+BAAA,CAA6B,CAAA,EAE3E,EACAA,EAAAA,IAAC,QAAA,CACC,GAAG,oBACH,KAAK,WACL,UAAU,oBACV,MAAOkB,EACP,SAAWQ,GAAMP,EAAgBO,EAAE,OAAO,KAAK,EAC/C,YAAaf,EAAY,WAAa,sBACtC,SAAU,CAACA,CAAA,CAAA,CACb,EACF,EAEAR,EAAAA,KAAC,MAAA,CAAI,UAAU,oBACb,SAAA,CAAAH,MAAC,QAAA,CAAM,UAAU,oBAAoB,QAAQ,mBAAmB,SAAA,0BAEhE,EACAA,EAAAA,IAAC,QAAA,CACC,GAAG,mBACH,KAAK,OACL,UAAU,oBACV,MAAOoB,EACP,SAAWM,GAAML,EAAeK,EAAE,OAAO,KAAK,EAC9C,YAAY,aAAA,CAAA,EAEd1B,EAAAA,IAAC,IAAA,CAAE,UAAU,mBAAmB,SAAA,gDAAA,CAA8C,CAAA,EAChF,QAEC,MAAA,CAAI,UAAU,oBACb,SAAAG,EAAAA,KAAC,QAAA,CAAM,UAAU,uBACf,SAAA,CAAAH,EAAAA,IAAC,QAAA,CACC,KAAK,WACL,QAASsB,EACT,SAAWI,GAAMH,EAAqBG,EAAE,OAAO,OAAO,CAAA,CAAA,EAExD1B,EAAAA,IAAC,QAAK,SAAA,qCAAA,CAAmC,CAAA,CAAA,CAC3C,CAAA,CACF,QAEC,MAAA,CAAI,UAAU,oBACb,SAAAG,EAAAA,KAAC,QAAA,CAAM,UAAU,uBACf,SAAA,CAAAH,EAAAA,IAAC,QAAA,CACC,KAAK,WACL,QAASlB,EACT,SAAW4C,GAAMF,EAAWE,EAAE,OAAO,OAAO,CAAA,CAAA,EAE9C1B,EAAAA,IAAC,QAAK,SAAA,sBAAA,CAAoB,CAAA,CAAA,CAC5B,CAAA,CACF,CAAA,EACF,EAEAG,EAAAA,KAAC,MAAA,CAAI,UAAU,sBACb,SAAA,CAAAH,EAAAA,IAAC,SAAA,CACC,KAAK,SACL,UAAU,8BACV,QAASU,EACT,SAAUpD,EACX,SAAA,QAAA,CAAA,EAGD0C,EAAAA,IAAC,SAAA,CAAO,KAAK,SAAS,UAAU,gCAAgC,SAAU1C,EACvE,SAAAA,EAAY,YAAcqD,EAAY,eAAiB,cAAA,CAC1D,CAAA,CAAA,CACF,CAAA,EACF,CAEJ,CClaA,MAAMiB,EAAoB,CACxB,CAAE,GAAI,QAAS,MAAO,QAAS,WAAY,CAAC,YAAY,EACtD,KAAM,CAAC,qBAAsB,kCAAmC,6BAA6B,CAAA,EAC/F,CAAE,GAAI,SAAU,MAAO,SAAU,WAAY,CAAC,aAAa,EACzD,KAAM,CAAC,sBAAuB,uBAAuB,CAAA,EACvD,CAAE,GAAI,QAAS,MAAO,QAAS,WAAY,CAAC,YAAY,EACtD,KAAM,CAAC,qBAAsB,uBAAwB,oBAAoB,CAAA,EAC3E,CAAE,GAAI,SAAU,MAAO,SAAU,WAAY,CAAC,aAAa,EACzD,KAAM,CAAC,sBAAuB,8BAA8B,CAAA,EAC9D,CAAE,GAAI,WAAY,MAAO,WAAY,WAAY,CAAC,eAAe,EAC/D,KAAM,CAAC,wBAAyB,sBAAuB,wBAAyB,yBAAyB,CAAA,EAC3G,CAAE,GAAI,cAAe,MAAO,eAAgB,WAAY,CAAC,kBAAkB,EACzE,KAAM,CAAC,2BAA4B,0BAA2B,6BAA6B,CAAA,EAC7F,CAAE,GAAI,MAAO,MAAO,gBAAiB,WAAY,CAAA,EAAI,SAAU,EAAA,CACjE,EAMO,SAASC,EAAuB,CAAE,UAAA7C,GAA0C,CACjF,KAAM,CACJ,SAAA8C,EACA,MAAAC,EACA,UAAAzE,EACA,eAAA0E,EACA,cAAAC,EACA,MAAAzE,EACA,cAAA0E,EACA,aAAAC,CAAA,EACEC,sBAAA,EAEE,CAACC,EAAWC,CAAY,EAAInF,EAAAA,SAAkB,OAAO,EAE3DsC,EAAAA,UAAU,IAAM,CACdyC,EAAA,CACF,EAAG,CAACA,CAAa,CAAC,EAGlB,MAAMK,EAAaX,EAAK,KAAMY,GAAMA,EAAE,KAAOH,CAAS,EAGhDI,EAAiBC,EAAAA,QAAQ,IAAM,CACnC,GAAI,CAACH,EAAY,MAAO,CAAA,EACxB,MAAMI,EAAyC,CAAA,EAC/C,UAAWC,KAAYL,EAAW,WAAY,CAC5C,MAAMM,EAAmBf,EAASc,CAAQ,GAAK,CAAA,EAC/CD,EAAY,KAAK,GAAGE,CAAgB,CACtC,CACA,OAAOF,CACT,EAAG,CAACb,EAAUS,CAAU,CAAC,EAEnBO,EAAkBJ,EAAAA,QAAQ,IACzBH,GAAY,KAEVE,EACJ,OAAQM,GAAMR,EAAW,KAAM,SAASQ,EAAE,GAAG,CAAC,EAC9C,KAAK,CAACC,EAAGC,IAAMV,EAAW,KAAM,QAAQS,EAAE,GAAG,EAAIT,EAAW,KAAM,QAAQU,EAAE,GAAG,CAAC,EAJrDR,EAK7B,CAACA,EAAgBF,CAAU,CAAC,EAE/B,OAAIjF,GAAa,OAAO,KAAKwE,CAAQ,EAAE,SAAW,SAE7C,MAAA,CAAI,UAAW,yDAAyD9C,GAAa,EAAE,GACtF,SAAA,CAAAgB,EAAAA,IAACC,EAAAA,eAAA,EAAe,EAChBD,EAAAA,IAAC,QAAK,SAAA,qBAAA,CAAmB,CAAA,EAC3B,EAIAxC,EAEAwC,EAAAA,IAAC,MAAA,CAAI,UAAW,0BAA0BhB,GAAa,EAAE,GACvD,SAAAgB,EAAAA,IAACI,EAAAA,aAAA,CAAa,MAAO5C,EAAM,OAAA,CAAS,EACtC,SAKD,MAAA,CAAI,UAAW,0BAA0BwB,GAAa,EAAE,GACvD,SAAA,CAAAmB,EAAAA,KAAC,MAAA,CAAI,UAAU,8BACb,SAAA,CAAAA,EAAAA,KAAC,MAAA,CAAI,UAAU,sCACb,SAAA,CAAAH,EAAAA,IAAC,KAAA,CAAG,UAAU,6BAA6B,SAAA,iBAAc,EACzDA,EAAAA,IAAC,IAAA,CAAE,UAAU,mCAAmC,SAAA,kEAAA,CAEhD,CAAA,EACF,EACAA,EAAAA,IAACkD,EAAAA,eAAA,CAAe,OAAQlB,EAAgB,MAAOC,CAAA,CAAe,CAAA,EAChE,QAGC,MAAA,CAAI,UAAU,4CACZ,SAAAL,EAAK,IAAKuB,GACTnD,EAAAA,IAAC,SAAA,CAEC,KAAK,SACL,UAAW,oBAAoBqC,IAAcc,EAAI,GAAK,0BAA4B,EAAE,GACpF,QAAS,IAAMb,EAAaa,EAAI,EAAE,EAClC,gBAAed,IAAcc,EAAI,GACjC,KAAK,MAEJ,SAAAA,EAAI,KAAA,EAPAA,EAAI,EAAA,CASZ,EACH,QAGC,MAAA,CAAI,UAAU,2BAA2B,KAAK,WAC5C,YAAY,SACXnD,EAAAA,IAACjB,IAAqB,EACpB+D,EAAgB,SAAW,EAC7B9C,EAAAA,IAAC,OAAI,UAAU,+BACb,gBAAC,IAAA,CAAE,SAAA,CAAA,yBAAuBuC,GAAY,OAAS,gBAAgB,GAAA,CAAA,CAAC,CAAA,CAClE,EAEAvC,EAAAA,IAACoD,kBAAA,CAAgB,SAAUN,EAAiB,MAAAf,EAAc,SAAUI,CAAA,CAAc,CAAA,CAEtF,CAAA,EACF,CAEJ"}
@@ -1,525 +0,0 @@
1
- import { jsxs as r, jsx as e } from "react/jsx-runtime";
2
- import { useRef as I, useState as v, useCallback as O, useEffect as $, useMemo as P } from "react";
3
- import { L as T } from "./LoadingSpinner-6vml-zwr.js";
4
- import { E as A } from "./ErrorMessage-CcEK0pYO.js";
5
- import { u as F, A as L, S as j } from "./AutosaveStatus-vkJxtuEw.js";
6
- import { u as R } from "./useCedrosLogin-_94MmGGq.js";
7
- import { u as U } from "./useOrgs-C3pzMA9h.js";
8
- function q() {
9
- const { config: o, _internal: g } = R(), h = o.serverUrl, b = I(g?.getAccessToken ?? (() => null));
10
- b.current = g?.getAccessToken ?? (() => null);
11
- const [S, k] = v([]), [f, y] = v(0), [C, c] = v(!1), [w, t] = v(null), m = O(() => {
12
- const d = b.current();
13
- return {
14
- "Content-Type": "application/json",
15
- ...d ? { Authorization: `Bearer ${d}` } : {}
16
- };
17
- }, []), p = O(
18
- async (d, a = 50, n = 0) => {
19
- c(!0), t(null);
20
- try {
21
- const i = new URLSearchParams();
22
- d && i.set("org_id", d), i.set("limit", String(a)), i.set("offset", String(n));
23
- const s = await fetch(`${h}/admin/sso-providers?${i}`, {
24
- headers: m()
25
- });
26
- if (!s.ok) {
27
- const x = await s.json().catch(() => ({}));
28
- throw new Error(x.error || `Failed to fetch SSO providers: ${s.status}`);
29
- }
30
- const N = await s.json();
31
- return k(N.providers), y(N.total), N;
32
- } catch (i) {
33
- const s = i instanceof Error ? i : new Error(String(i));
34
- throw t(s), s;
35
- } finally {
36
- c(!1);
37
- }
38
- },
39
- [h, m]
40
- ), l = O(
41
- async (d) => {
42
- c(!0), t(null);
43
- try {
44
- const a = await fetch(`${h}/admin/sso-providers`, {
45
- method: "POST",
46
- headers: m(),
47
- body: JSON.stringify(d)
48
- });
49
- if (!a.ok) {
50
- const i = await a.json().catch(() => ({}));
51
- throw new Error(i.error || `Failed to create SSO provider: ${a.status}`);
52
- }
53
- const n = await a.json();
54
- return k((i) => [...i, n]), y((i) => i + 1), n;
55
- } catch (a) {
56
- const n = a instanceof Error ? a : new Error(String(a));
57
- throw t(n), n;
58
- } finally {
59
- c(!1);
60
- }
61
- },
62
- [h, m]
63
- ), u = O(
64
- async (d, a) => {
65
- c(!0), t(null);
66
- try {
67
- const n = await fetch(`${h}/admin/sso-providers/${d}`, {
68
- method: "PUT",
69
- headers: m(),
70
- body: JSON.stringify(a)
71
- });
72
- if (!n.ok) {
73
- const s = await n.json().catch(() => ({}));
74
- throw new Error(s.error || `Failed to update SSO provider: ${n.status}`);
75
- }
76
- const i = await n.json();
77
- return k((s) => s.map((N) => N.id === d ? i : N)), i;
78
- } catch (n) {
79
- const i = n instanceof Error ? n : new Error(String(n));
80
- throw t(i), i;
81
- } finally {
82
- c(!1);
83
- }
84
- },
85
- [h, m]
86
- ), E = O(
87
- async (d) => {
88
- c(!0), t(null);
89
- try {
90
- const a = await fetch(`${h}/admin/sso-providers/${d}`, {
91
- method: "DELETE",
92
- headers: m()
93
- });
94
- if (!a.ok) {
95
- const n = await a.json().catch(() => ({}));
96
- throw new Error(n.error || `Failed to delete SSO provider: ${a.status}`);
97
- }
98
- k((n) => n.filter((i) => i.id !== d)), y((n) => n - 1);
99
- } catch (a) {
100
- const n = a instanceof Error ? a : new Error(String(a));
101
- throw t(n), n;
102
- } finally {
103
- c(!1);
104
- }
105
- },
106
- [h, m]
107
- ), _ = O(
108
- async (d, a) => u(d, { enabled: a }),
109
- [u]
110
- );
111
- return {
112
- providers: S,
113
- total: f,
114
- isLoading: C,
115
- error: w,
116
- fetchProviders: p,
117
- createProvider: l,
118
- updateProvider: u,
119
- deleteProvider: E,
120
- toggleProvider: _
121
- };
122
- }
123
- function M({ className: o }) {
124
- const {
125
- providers: g,
126
- isLoading: h,
127
- error: b,
128
- fetchProviders: S,
129
- createProvider: k,
130
- updateProvider: f,
131
- deleteProvider: y,
132
- toggleProvider: C
133
- } = q(), { activeOrg: c } = U(), [w, t] = v("list"), [m, p] = v(null), [l, u] = v(null);
134
- $(() => {
135
- S(c?.id);
136
- }, [S, c?.id]);
137
- const E = () => {
138
- p(null), u(null), t("add");
139
- }, _ = (s) => {
140
- p(s), u(null), t("edit");
141
- }, d = () => {
142
- t("list"), p(null), u(null);
143
- }, a = async (s) => {
144
- if (confirm(`Delete SSO provider "${s.name}"? This cannot be undone.`))
145
- try {
146
- await y(s.id);
147
- } catch {
148
- }
149
- }, n = async (s) => {
150
- try {
151
- await C(s.id, !s.enabled);
152
- } catch {
153
- }
154
- }, i = async (s) => {
155
- u(null);
156
- try {
157
- w === "add" ? await k(s) : m && await f(m.id, s), t("list"), p(null);
158
- } catch (N) {
159
- u(N instanceof Error ? N.message : "Failed to save provider");
160
- }
161
- };
162
- return h && g.length === 0 ? /* @__PURE__ */ r("div", { className: `cedros-system-settings cedros-system-settings-loading ${o ?? ""}`, children: [
163
- /* @__PURE__ */ e(T, {}),
164
- /* @__PURE__ */ e("span", { children: "Loading SSO providers..." })
165
- ] }) : w === "add" || w === "edit" ? /* @__PURE__ */ e("div", { className: `cedros-system-settings ${o ?? ""}`, children: /* @__PURE__ */ e(
166
- B,
167
- {
168
- provider: m,
169
- orgId: c?.id,
170
- error: l,
171
- isLoading: h,
172
- onSave: i,
173
- onCancel: d
174
- }
175
- ) }) : /* @__PURE__ */ r("div", { className: `cedros-system-settings ${o ?? ""}`, children: [
176
- /* @__PURE__ */ r("div", { className: "cedros-settings-page-header", children: [
177
- /* @__PURE__ */ r("div", { className: "cedros-settings-page-header-content", children: [
178
- /* @__PURE__ */ e("h2", { className: "cedros-settings-page-title", children: "SSO Providers" }),
179
- /* @__PURE__ */ e("p", { className: "cedros-settings-page-description", children: "Configure OIDC identity providers for enterprise single sign-on." })
180
- ] }),
181
- /* @__PURE__ */ e("button", { type: "button", className: "cedros-btn cedros-btn-primary", onClick: E, children: "Add Provider" })
182
- ] }),
183
- b && /* @__PURE__ */ e(A, { error: b.message }),
184
- g.length === 0 ? /* @__PURE__ */ r("div", { className: "cedros-system-settings-empty", children: [
185
- /* @__PURE__ */ e("p", { children: "No SSO providers configured." }),
186
- /* @__PURE__ */ e("p", { className: "cedros-text-muted", children: "Add an OIDC provider like Okta, Azure AD, or Auth0 to enable enterprise SSO." })
187
- ] }) : /* @__PURE__ */ e("div", { className: "cedros-sso-provider-list", children: g.map((s) => /* @__PURE__ */ e(
188
- z,
189
- {
190
- provider: s,
191
- onEdit: () => _(s),
192
- onDelete: () => a(s),
193
- onToggle: () => n(s)
194
- },
195
- s.id
196
- )) })
197
- ] });
198
- }
199
- function z({ provider: o, onEdit: g, onDelete: h, onToggle: b }) {
200
- return /* @__PURE__ */ r(
201
- "div",
202
- {
203
- className: `cedros-sso-provider-card ${o.enabled ? "" : "cedros-sso-provider-card--disabled"}`,
204
- children: [
205
- /* @__PURE__ */ r("div", { className: "cedros-sso-provider-card-header", children: [
206
- /* @__PURE__ */ r("div", { className: "cedros-sso-provider-card-info", children: [
207
- /* @__PURE__ */ e("h3", { className: "cedros-sso-provider-card-name", children: o.name }),
208
- /* @__PURE__ */ e("p", { className: "cedros-sso-provider-card-issuer", children: o.issuerUrl })
209
- ] }),
210
- /* @__PURE__ */ r(
211
- "button",
212
- {
213
- type: "button",
214
- role: "switch",
215
- "aria-checked": o.enabled,
216
- className: `cedros-toggle ${o.enabled ? "cedros-toggle-on" : "cedros-toggle-off"}`,
217
- onClick: b,
218
- children: [
219
- /* @__PURE__ */ e("span", { className: "cedros-toggle-track", children: /* @__PURE__ */ e("span", { className: "cedros-toggle-thumb" }) }),
220
- /* @__PURE__ */ e("span", { className: "cedros-toggle-label", children: o.enabled ? "Enabled" : "Disabled" })
221
- ]
222
- }
223
- )
224
- ] }),
225
- /* @__PURE__ */ r("div", { className: "cedros-sso-provider-card-details", children: [
226
- /* @__PURE__ */ r("div", { className: "cedros-sso-provider-card-detail", children: [
227
- /* @__PURE__ */ e("span", { className: "cedros-sso-provider-card-detail-label", children: "Client ID" }),
228
- /* @__PURE__ */ e("code", { className: "cedros-sso-provider-card-detail-value", children: o.clientId })
229
- ] }),
230
- o.emailDomain && /* @__PURE__ */ r("div", { className: "cedros-sso-provider-card-detail", children: [
231
- /* @__PURE__ */ e("span", { className: "cedros-sso-provider-card-detail-label", children: "Email Domain" }),
232
- /* @__PURE__ */ r("span", { className: "cedros-sso-provider-card-detail-value", children: [
233
- "@",
234
- o.emailDomain
235
- ] })
236
- ] }),
237
- /* @__PURE__ */ r("div", { className: "cedros-sso-provider-card-detail", children: [
238
- /* @__PURE__ */ e("span", { className: "cedros-sso-provider-card-detail-label", children: "Registration" }),
239
- /* @__PURE__ */ e("span", { className: "cedros-sso-provider-card-detail-value", children: o.allowRegistration ? "Allowed" : "Existing users only" })
240
- ] })
241
- ] }),
242
- /* @__PURE__ */ r("div", { className: "cedros-sso-provider-card-actions", children: [
243
- /* @__PURE__ */ e("button", { type: "button", className: "cedros-btn cedros-btn-ghost", onClick: g, children: "Edit" }),
244
- /* @__PURE__ */ e(
245
- "button",
246
- {
247
- type: "button",
248
- className: "cedros-btn cedros-btn-ghost cedros-btn-danger",
249
- onClick: h,
250
- children: "Delete"
251
- }
252
- )
253
- ] })
254
- ]
255
- }
256
- );
257
- }
258
- function B({
259
- provider: o,
260
- orgId: g,
261
- error: h,
262
- isLoading: b,
263
- onSave: S,
264
- onCancel: k
265
- }) {
266
- const f = !!o, [y, C] = v(o?.name ?? ""), [c, w] = v(o?.issuerUrl ?? ""), [t, m] = v(o?.clientId ?? ""), [p, l] = v(""), [u, E] = v(o?.emailDomain ?? ""), [_, d] = v(o?.allowRegistration ?? !0), [a, n] = v(o?.enabled ?? !0), i = O(
267
- (s) => {
268
- if (s.preventDefault(), f) {
269
- const N = {
270
- name: y,
271
- issuerUrl: c,
272
- clientId: t,
273
- emailDomain: u || null,
274
- allowRegistration: _,
275
- enabled: a
276
- };
277
- p && (N.clientSecret = p), S(N);
278
- } else {
279
- if (!g)
280
- return;
281
- S({
282
- orgId: g,
283
- name: y,
284
- issuerUrl: c,
285
- clientId: t,
286
- clientSecret: p,
287
- emailDomain: u || null,
288
- allowRegistration: _,
289
- enabled: a
290
- });
291
- }
292
- },
293
- [
294
- f,
295
- g,
296
- y,
297
- c,
298
- t,
299
- p,
300
- u,
301
- _,
302
- a,
303
- S
304
- ]
305
- );
306
- return /* @__PURE__ */ r("form", { className: "cedros-sso-provider-form", onSubmit: i, children: [
307
- /* @__PURE__ */ e("div", { className: "cedros-settings-page-header", children: /* @__PURE__ */ r("div", { className: "cedros-settings-page-header-content", children: [
308
- /* @__PURE__ */ e("h2", { className: "cedros-settings-page-title", children: f ? "Edit SSO Provider" : "Add SSO Provider" }),
309
- /* @__PURE__ */ e("p", { className: "cedros-settings-page-description", children: "Configure an OIDC identity provider for enterprise single sign-on." })
310
- ] }) }),
311
- h && /* @__PURE__ */ e(A, { error: h }),
312
- /* @__PURE__ */ r("div", { className: "cedros-form-section", children: [
313
- /* @__PURE__ */ r("div", { className: "cedros-form-group", children: [
314
- /* @__PURE__ */ e("label", { className: "cedros-form-label", htmlFor: "sso-name", children: "Provider Name" }),
315
- /* @__PURE__ */ e(
316
- "input",
317
- {
318
- id: "sso-name",
319
- type: "text",
320
- className: "cedros-form-input",
321
- value: y,
322
- onChange: (s) => C(s.target.value),
323
- placeholder: "e.g., Okta, Azure AD",
324
- required: !0
325
- }
326
- )
327
- ] }),
328
- /* @__PURE__ */ r("div", { className: "cedros-form-group", children: [
329
- /* @__PURE__ */ e("label", { className: "cedros-form-label", htmlFor: "sso-issuer", children: "Issuer URL" }),
330
- /* @__PURE__ */ e(
331
- "input",
332
- {
333
- id: "sso-issuer",
334
- type: "url",
335
- className: "cedros-form-input",
336
- value: c,
337
- onChange: (s) => w(s.target.value),
338
- placeholder: "https://your-org.okta.com",
339
- required: !0
340
- }
341
- ),
342
- /* @__PURE__ */ e("p", { className: "cedros-form-hint", children: "The OIDC issuer URL. Must support discovery at /.well-known/openid-configuration" })
343
- ] }),
344
- /* @__PURE__ */ r("div", { className: "cedros-form-group", children: [
345
- /* @__PURE__ */ e("label", { className: "cedros-form-label", htmlFor: "sso-client-id", children: "Client ID" }),
346
- /* @__PURE__ */ e(
347
- "input",
348
- {
349
- id: "sso-client-id",
350
- type: "text",
351
- className: "cedros-form-input",
352
- value: t,
353
- onChange: (s) => m(s.target.value),
354
- placeholder: "OAuth client ID",
355
- required: !0
356
- }
357
- )
358
- ] }),
359
- /* @__PURE__ */ r("div", { className: "cedros-form-group", children: [
360
- /* @__PURE__ */ r("label", { className: "cedros-form-label", htmlFor: "sso-client-secret", children: [
361
- "Client Secret",
362
- " ",
363
- f && /* @__PURE__ */ e("span", { className: "cedros-form-hint-inline", children: "(leave blank to keep current)" })
364
- ] }),
365
- /* @__PURE__ */ e(
366
- "input",
367
- {
368
- id: "sso-client-secret",
369
- type: "password",
370
- className: "cedros-form-input",
371
- value: p,
372
- onChange: (s) => l(s.target.value),
373
- placeholder: f ? "••••••••" : "OAuth client secret",
374
- required: !f
375
- }
376
- )
377
- ] }),
378
- /* @__PURE__ */ r("div", { className: "cedros-form-group", children: [
379
- /* @__PURE__ */ e("label", { className: "cedros-form-label", htmlFor: "sso-email-domain", children: "Email Domain (optional)" }),
380
- /* @__PURE__ */ e(
381
- "input",
382
- {
383
- id: "sso-email-domain",
384
- type: "text",
385
- className: "cedros-form-input",
386
- value: u,
387
- onChange: (s) => E(s.target.value),
388
- placeholder: "company.com"
389
- }
390
- ),
391
- /* @__PURE__ */ e("p", { className: "cedros-form-hint", children: "Restrict to users with emails from this domain" })
392
- ] }),
393
- /* @__PURE__ */ e("div", { className: "cedros-form-group", children: /* @__PURE__ */ r("label", { className: "cedros-form-checkbox", children: [
394
- /* @__PURE__ */ e(
395
- "input",
396
- {
397
- type: "checkbox",
398
- checked: _,
399
- onChange: (s) => d(s.target.checked)
400
- }
401
- ),
402
- /* @__PURE__ */ e("span", { children: "Allow new user registration via SSO" })
403
- ] }) }),
404
- /* @__PURE__ */ e("div", { className: "cedros-form-group", children: /* @__PURE__ */ r("label", { className: "cedros-form-checkbox", children: [
405
- /* @__PURE__ */ e(
406
- "input",
407
- {
408
- type: "checkbox",
409
- checked: a,
410
- onChange: (s) => n(s.target.checked)
411
- }
412
- ),
413
- /* @__PURE__ */ e("span", { children: "Enable this provider" })
414
- ] }) })
415
- ] }),
416
- /* @__PURE__ */ r("div", { className: "cedros-form-actions", children: [
417
- /* @__PURE__ */ e(
418
- "button",
419
- {
420
- type: "button",
421
- className: "cedros-btn cedros-btn-ghost",
422
- onClick: k,
423
- disabled: b,
424
- children: "Cancel"
425
- }
426
- ),
427
- /* @__PURE__ */ e("button", { type: "submit", className: "cedros-btn cedros-btn-primary", disabled: b, children: b ? "Saving..." : f ? "Save Changes" : "Add Provider" })
428
- ] })
429
- ] });
430
- }
431
- const D = [
432
- {
433
- id: "email",
434
- label: "Email",
435
- categories: ["auth.email"],
436
- keys: ["auth_email_enabled", "auth_email_require_verification", "auth_email_block_disposable"]
437
- },
438
- {
439
- id: "google",
440
- label: "Google",
441
- categories: ["auth.google"],
442
- keys: ["auth_google_enabled", "auth_google_client_id"]
443
- },
444
- {
445
- id: "apple",
446
- label: "Apple",
447
- categories: ["auth.apple"],
448
- keys: ["auth_apple_enabled", "auth_apple_client_id", "auth_apple_team_id"]
449
- },
450
- {
451
- id: "solana",
452
- label: "Solana",
453
- categories: ["auth.solana"],
454
- keys: ["auth_solana_enabled", "auth_solana_challenge_expiry"]
455
- },
456
- {
457
- id: "passkeys",
458
- label: "Passkeys",
459
- categories: ["auth.webauthn"],
460
- keys: ["auth_webauthn_enabled", "auth_webauthn_rp_id", "auth_webauthn_rp_name", "auth_webauthn_rp_origin"]
461
- },
462
- {
463
- id: "instantlink",
464
- label: "Instant Link",
465
- categories: ["auth.instantlink"],
466
- keys: ["auth_instantlink_enabled", "auth_instantlink_expiry", "auth_instantlink_rate_limit"]
467
- },
468
- { id: "sso", label: "SSO Providers", categories: [], isCustom: !0 }
469
- ];
470
- function X({ className: o }) {
471
- const {
472
- settings: g,
473
- edits: h,
474
- isLoading: b,
475
- autosaveStatus: S,
476
- autosaveError: k,
477
- error: f,
478
- fetchSettings: y,
479
- handleChange: C
480
- } = F(), [c, w] = v("email");
481
- $(() => {
482
- y();
483
- }, [y]);
484
- const t = D.find((l) => l.id === c), m = P(() => {
485
- if (!t) return [];
486
- const l = [];
487
- for (const u of t.categories) {
488
- const E = g[u] ?? [];
489
- l.push(...E);
490
- }
491
- return l;
492
- }, [g, t]), p = P(() => t?.keys ? m.filter((l) => t.keys.includes(l.key)).sort((l, u) => t.keys.indexOf(l.key) - t.keys.indexOf(u.key)) : m, [m, t]);
493
- return b && Object.keys(g).length === 0 ? /* @__PURE__ */ r("div", { className: `cedros-system-settings cedros-system-settings-loading ${o ?? ""}`, children: [
494
- /* @__PURE__ */ e(T, {}),
495
- /* @__PURE__ */ e("span", { children: "Loading settings..." })
496
- ] }) : f ? /* @__PURE__ */ e("div", { className: `cedros-system-settings ${o ?? ""}`, children: /* @__PURE__ */ e(A, { error: f.message }) }) : /* @__PURE__ */ r("div", { className: `cedros-system-settings ${o ?? ""}`, children: [
497
- /* @__PURE__ */ r("div", { className: "cedros-settings-page-header", children: [
498
- /* @__PURE__ */ r("div", { className: "cedros-settings-page-header-content", children: [
499
- /* @__PURE__ */ e("h2", { className: "cedros-settings-page-title", children: "Authentication" }),
500
- /* @__PURE__ */ e("p", { className: "cedros-settings-page-description", children: "Configure authentication providers and methods for user sign-in." })
501
- ] }),
502
- /* @__PURE__ */ e(L, { status: S, error: k })
503
- ] }),
504
- /* @__PURE__ */ e("div", { className: "cedros-admin-tabs cedros-admin-tabs--line", children: D.map((l) => /* @__PURE__ */ e(
505
- "button",
506
- {
507
- type: "button",
508
- className: `cedros-admin-tab ${c === l.id ? "cedros-admin-tab-active" : ""}`,
509
- onClick: () => w(l.id),
510
- "aria-selected": c === l.id,
511
- role: "tab",
512
- children: l.label
513
- },
514
- l.id
515
- )) }),
516
- /* @__PURE__ */ e("div", { className: "cedros-admin-tab-content", role: "tabpanel", children: t?.isCustom ? /* @__PURE__ */ e(M, {}) : p.length === 0 ? /* @__PURE__ */ e("div", { className: "cedros-system-settings-empty", children: /* @__PURE__ */ r("p", { children: [
517
- "No settings found for ",
518
- t?.label ?? "this provider",
519
- "."
520
- ] }) }) : /* @__PURE__ */ e(j, { settings: p, edits: h, onChange: C }) })
521
- ] });
522
- }
523
- export {
524
- X as A
525
- };