@glowlabs-org/utils 0.2.5 → 0.2.8
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +5 -5
- package/dist/cjs/browser.d.ts +2 -2
- package/dist/cjs/browser.js +12 -359
- package/dist/cjs/browser.js.map +1 -1
- package/dist/cjs/index.d.ts +2 -0
- package/dist/cjs/index.js +33 -31
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/lib/{hooks/use-control-api.d.ts → control-api/control-router.d.ts} +1 -1
- package/dist/{esm/lib/hooks/use-regions.d.ts → cjs/lib/control-api/region-router.d.ts} +1 -1
- package/dist/cjs/{use-forwarder-CVlJS4UY.js → region-router-6Tfi1vcZ.js} +350 -1
- package/dist/cjs/region-router-6Tfi1vcZ.js.map +1 -0
- package/dist/esm/browser.d.ts +2 -2
- package/dist/esm/browser.js +2 -349
- package/dist/esm/browser.js.map +1 -1
- package/dist/esm/index.d.ts +2 -0
- package/dist/esm/index.js +2 -2
- package/dist/esm/lib/{hooks/use-control-api.d.ts → control-api/control-router.d.ts} +1 -1
- package/dist/{cjs/lib/hooks/use-regions.d.ts → esm/lib/control-api/region-router.d.ts} +1 -1
- package/dist/esm/{use-forwarder-DD_5ZFZg.js → region-router-ClCO6Pac.js} +349 -2
- package/dist/esm/region-router-ClCO6Pac.js.map +1 -0
- package/package.json +1 -1
- package/src/browser.ts +2 -2
- package/src/index.ts +2 -0
- package/src/lib/{hooks/use-control-api.ts → control-api/control-router.ts} +1 -1
- package/src/lib/{hooks/use-regions.ts → control-api/region-router.ts} +1 -1
- package/dist/cjs/use-forwarder-CVlJS4UY.js.map +0 -1
- package/dist/esm/use-forwarder-DD_5ZFZg.js.map +0 -1
@@ -573,5 +573,352 @@ function useForwarder(signer, CHAIN_ID) {
|
|
573
573
|
};
|
574
574
|
}
|
575
575
|
|
576
|
-
|
577
|
-
|
576
|
+
// --------------------------------------------------------------------------
|
577
|
+
/**
|
578
|
+
* Extract a useful error message from an unknown error value.
|
579
|
+
*/
|
580
|
+
function parseApiError$1(error) {
|
581
|
+
if (!error)
|
582
|
+
return "Unknown error";
|
583
|
+
if (error instanceof Error)
|
584
|
+
return error.message;
|
585
|
+
const possible = error;
|
586
|
+
return possible?.error?.message ?? possible?.message ?? "Unknown error";
|
587
|
+
}
|
588
|
+
// --------------------------------------------------------------------------
|
589
|
+
// Public Factory
|
590
|
+
// --------------------------------------------------------------------------
|
591
|
+
function ControlRouter(baseUrl) {
|
592
|
+
// ----------------------- Internal helpers --------------------------------
|
593
|
+
const request = async (path, init) => {
|
594
|
+
const res = await fetch(`${baseUrl}${path}`, init);
|
595
|
+
if (!res.ok) {
|
596
|
+
const errData = await res.json().catch(() => ({}));
|
597
|
+
throw new Error(errData?.error || `Request to ${path} failed`);
|
598
|
+
}
|
599
|
+
return (await res.json());
|
600
|
+
};
|
601
|
+
// ----------------------- GETters -----------------------------------------
|
602
|
+
const fetchGctlBalance = async (wallet) => {
|
603
|
+
try {
|
604
|
+
const data = await request(`/balance/${wallet}`);
|
605
|
+
return (data?.gctl_balance ?? "0").toString();
|
606
|
+
}
|
607
|
+
catch (error) {
|
608
|
+
throw new Error(parseApiError$1(error));
|
609
|
+
}
|
610
|
+
};
|
611
|
+
const fetchGctlPrice = async () => {
|
612
|
+
try {
|
613
|
+
const data = await request(`/price`);
|
614
|
+
return data.currentPriceUsdc;
|
615
|
+
}
|
616
|
+
catch (error) {
|
617
|
+
throw new Error(parseApiError$1(error));
|
618
|
+
}
|
619
|
+
};
|
620
|
+
const fetchMintedEvents = async () => {
|
621
|
+
try {
|
622
|
+
const data = await request(`/events/minted?page=1&limit=50`);
|
623
|
+
return data.events ?? [];
|
624
|
+
}
|
625
|
+
catch (error) {
|
626
|
+
throw new Error(parseApiError$1(error));
|
627
|
+
}
|
628
|
+
};
|
629
|
+
const fetchStakeEvents = async () => {
|
630
|
+
try {
|
631
|
+
const data = await request(`/events/stake?page=1&limit=50`);
|
632
|
+
return data.events ?? [];
|
633
|
+
}
|
634
|
+
catch (error) {
|
635
|
+
throw new Error(parseApiError$1(error));
|
636
|
+
}
|
637
|
+
};
|
638
|
+
const fetchPendingTransfers = async () => {
|
639
|
+
try {
|
640
|
+
const data = await request(`/transfers/pending?page=1&limit=50`);
|
641
|
+
return data.transfers ?? [];
|
642
|
+
}
|
643
|
+
catch (error) {
|
644
|
+
throw new Error(parseApiError$1(error));
|
645
|
+
}
|
646
|
+
};
|
647
|
+
const fetchTransferDetails = async (txId) => {
|
648
|
+
try {
|
649
|
+
return await request(`/transfer/${txId}`);
|
650
|
+
}
|
651
|
+
catch (error) {
|
652
|
+
throw new Error(parseApiError$1(error));
|
653
|
+
}
|
654
|
+
};
|
655
|
+
const fetchFailedOperations = async () => {
|
656
|
+
try {
|
657
|
+
const data = await request(`/operations/failed?page=1&limit=50`);
|
658
|
+
return data.operations ?? [];
|
659
|
+
}
|
660
|
+
catch (error) {
|
661
|
+
throw new Error(parseApiError$1(error));
|
662
|
+
}
|
663
|
+
};
|
664
|
+
// Exposed query with error parsing
|
665
|
+
const getTransferDetails = async (txId) => {
|
666
|
+
try {
|
667
|
+
return await fetchTransferDetails(txId);
|
668
|
+
}
|
669
|
+
catch (error) {
|
670
|
+
throw new Error(parseApiError$1(error));
|
671
|
+
}
|
672
|
+
};
|
673
|
+
const fetchRegions = async () => {
|
674
|
+
const data = await request(`/regions`);
|
675
|
+
return data.regions.filter((r) => r.id !== 998 && r.id !== 999) ?? [];
|
676
|
+
};
|
677
|
+
const fetchRegionStake = async (regionId) => {
|
678
|
+
try {
|
679
|
+
return await request(`/region/${regionId}/stake`);
|
680
|
+
}
|
681
|
+
catch (error) {
|
682
|
+
throw new Error(parseApiError$1(error));
|
683
|
+
}
|
684
|
+
};
|
685
|
+
const fetchWalletRegionStake = async (wallet, regionId) => {
|
686
|
+
try {
|
687
|
+
return await request(`/wallet/${wallet}/region/${regionId}/stake`);
|
688
|
+
}
|
689
|
+
catch (error) {
|
690
|
+
throw new Error(parseApiError$1(error));
|
691
|
+
}
|
692
|
+
};
|
693
|
+
const fetchWalletRegionUnlocked = async (wallet, regionId) => {
|
694
|
+
try {
|
695
|
+
return await request(`/wallet/${wallet}/region/${regionId}/unlocked`);
|
696
|
+
}
|
697
|
+
catch (error) {
|
698
|
+
throw new Error(parseApiError$1(error));
|
699
|
+
}
|
700
|
+
};
|
701
|
+
// ----------------------- Mutations ---------------------------------------
|
702
|
+
let isStaking = false;
|
703
|
+
let isUnstaking = false;
|
704
|
+
let isRetryingFailedOperation = false;
|
705
|
+
const stakeGctl = async (wallet, regionId, amount) => {
|
706
|
+
isStaking = true;
|
707
|
+
try {
|
708
|
+
const stakeRequest = { wallet, regionId, amount };
|
709
|
+
await request(`/stake`, {
|
710
|
+
method: "POST",
|
711
|
+
headers: { "Content-Type": "application/json" },
|
712
|
+
body: JSON.stringify(stakeRequest),
|
713
|
+
});
|
714
|
+
return true;
|
715
|
+
}
|
716
|
+
catch (error) {
|
717
|
+
throw new Error(parseApiError$1(error));
|
718
|
+
}
|
719
|
+
finally {
|
720
|
+
isStaking = false;
|
721
|
+
}
|
722
|
+
};
|
723
|
+
const unstakeGctl = async (wallet, regionId, amount) => {
|
724
|
+
isUnstaking = true;
|
725
|
+
try {
|
726
|
+
const unstakeRequest = { wallet, regionId, amount };
|
727
|
+
await request(`/unstake`, {
|
728
|
+
method: "POST",
|
729
|
+
headers: { "Content-Type": "application/json" },
|
730
|
+
body: JSON.stringify(unstakeRequest),
|
731
|
+
});
|
732
|
+
return true;
|
733
|
+
}
|
734
|
+
catch (error) {
|
735
|
+
throw new Error(parseApiError$1(error));
|
736
|
+
}
|
737
|
+
finally {
|
738
|
+
isUnstaking = false;
|
739
|
+
}
|
740
|
+
};
|
741
|
+
const retryFailedOperation = async (operationId) => {
|
742
|
+
isRetryingFailedOperation = true;
|
743
|
+
try {
|
744
|
+
await request(`/operations/failed/${operationId}/retry`, {
|
745
|
+
method: "POST",
|
746
|
+
headers: { "Content-Type": "application/json" },
|
747
|
+
});
|
748
|
+
return true;
|
749
|
+
}
|
750
|
+
catch (error) {
|
751
|
+
throw new Error(parseApiError$1(error));
|
752
|
+
}
|
753
|
+
finally {
|
754
|
+
isRetryingFailedOperation = false;
|
755
|
+
}
|
756
|
+
};
|
757
|
+
// --------------------------- Public API ----------------------------------
|
758
|
+
return {
|
759
|
+
// Queries
|
760
|
+
fetchGctlBalance,
|
761
|
+
fetchGctlPrice,
|
762
|
+
fetchMintedEvents,
|
763
|
+
fetchStakeEvents,
|
764
|
+
fetchPendingTransfers,
|
765
|
+
fetchFailedOperations,
|
766
|
+
fetchRegions,
|
767
|
+
fetchRegionStake,
|
768
|
+
fetchWalletRegionStake,
|
769
|
+
fetchWalletRegionUnlocked,
|
770
|
+
fetchTransferDetails: getTransferDetails,
|
771
|
+
// Mutations
|
772
|
+
stakeGctl,
|
773
|
+
unstakeGctl,
|
774
|
+
retryFailedOperation,
|
775
|
+
// Processing flags
|
776
|
+
get isStaking() {
|
777
|
+
return isStaking;
|
778
|
+
},
|
779
|
+
get isUnstaking() {
|
780
|
+
return isUnstaking;
|
781
|
+
},
|
782
|
+
get isRetryingFailedOperation() {
|
783
|
+
return isRetryingFailedOperation;
|
784
|
+
},
|
785
|
+
};
|
786
|
+
}
|
787
|
+
|
788
|
+
// ---------------------------------------------------------------------------
|
789
|
+
// Helpers
|
790
|
+
// ---------------------------------------------------------------------------
|
791
|
+
function parseApiError(error) {
|
792
|
+
if (!error)
|
793
|
+
return "Unknown error";
|
794
|
+
if (error instanceof Error)
|
795
|
+
return error.message;
|
796
|
+
const possible = error;
|
797
|
+
return possible?.error?.message ?? possible?.message ?? "Unknown error";
|
798
|
+
}
|
799
|
+
// ---------------------------------------------------------------------------
|
800
|
+
// Factory
|
801
|
+
// ---------------------------------------------------------------------------
|
802
|
+
function RegionRouter(baseUrl) {
|
803
|
+
if (!baseUrl)
|
804
|
+
throw new Error("CONTROL API base URL is not set");
|
805
|
+
const request = async (path, init) => {
|
806
|
+
const res = await fetch(`${baseUrl}${path}`, init);
|
807
|
+
if (!res.ok) {
|
808
|
+
const errData = await res.json().catch(() => ({}));
|
809
|
+
throw new Error(errData?.error || `Request to ${path} failed`);
|
810
|
+
}
|
811
|
+
return (await res.json());
|
812
|
+
};
|
813
|
+
// -------------------------------------------------------------------------
|
814
|
+
// Local cache / state flags
|
815
|
+
// -------------------------------------------------------------------------
|
816
|
+
let cachedRegions = [];
|
817
|
+
let isLoading = false;
|
818
|
+
let isCreatingRegion = false;
|
819
|
+
// -------------------------------------------------------------------------
|
820
|
+
// Queries
|
821
|
+
// -------------------------------------------------------------------------
|
822
|
+
const fetchRegions = async () => {
|
823
|
+
isLoading = true;
|
824
|
+
try {
|
825
|
+
const data = await request(`/regions`);
|
826
|
+
cachedRegions = data.regions ?? [];
|
827
|
+
return cachedRegions;
|
828
|
+
}
|
829
|
+
catch (error) {
|
830
|
+
throw new Error(parseApiError(error));
|
831
|
+
}
|
832
|
+
finally {
|
833
|
+
isLoading = false;
|
834
|
+
}
|
835
|
+
};
|
836
|
+
const fetchActivationConfig = async (regionCode) => {
|
837
|
+
try {
|
838
|
+
return await request(`/regions/activation-config?code=${regionCode}`);
|
839
|
+
}
|
840
|
+
catch (error) {
|
841
|
+
throw new Error(parseApiError(error));
|
842
|
+
}
|
843
|
+
};
|
844
|
+
// -------------------------------------------------------------------------
|
845
|
+
// Mutations
|
846
|
+
// -------------------------------------------------------------------------
|
847
|
+
const createRegion = async (payload) => {
|
848
|
+
isCreatingRegion = true;
|
849
|
+
try {
|
850
|
+
await request(`/regions/create`, {
|
851
|
+
method: "POST",
|
852
|
+
headers: { "Content-Type": "application/json" },
|
853
|
+
body: JSON.stringify(payload),
|
854
|
+
});
|
855
|
+
// Refresh the local cache after successful creation
|
856
|
+
await fetchRegions();
|
857
|
+
}
|
858
|
+
catch (error) {
|
859
|
+
throw new Error(parseApiError(error));
|
860
|
+
}
|
861
|
+
finally {
|
862
|
+
isCreatingRegion = false;
|
863
|
+
}
|
864
|
+
};
|
865
|
+
// -------------------------------------------------------------------------
|
866
|
+
// Helpers (derived)
|
867
|
+
// -------------------------------------------------------------------------
|
868
|
+
// NOTE: regionMetadata is imported lazily to avoid circular deps at load time.
|
869
|
+
// eslint-disable-next-line @typescript-eslint/no-var-requires
|
870
|
+
const { regionMetadata } = require("@/lib/region-metadata");
|
871
|
+
const getRegionByCode = (code) => {
|
872
|
+
const metadata = regionMetadata[code];
|
873
|
+
if (!metadata)
|
874
|
+
return null;
|
875
|
+
const existingRegion = cachedRegions.find((r) => r.name.toLowerCase() === metadata.name.toLowerCase());
|
876
|
+
if (existingRegion) {
|
877
|
+
return {
|
878
|
+
...existingRegion,
|
879
|
+
code: metadata.code,
|
880
|
+
description: metadata.description,
|
881
|
+
flag: metadata.flag,
|
882
|
+
};
|
883
|
+
}
|
884
|
+
// Placeholder if region does not yet exist in DB
|
885
|
+
return {
|
886
|
+
id: -1,
|
887
|
+
name: metadata.name,
|
888
|
+
code: metadata.code,
|
889
|
+
description: metadata.description,
|
890
|
+
flag: metadata.flag,
|
891
|
+
isUs: metadata.isUs,
|
892
|
+
isActive: false,
|
893
|
+
stake: "0",
|
894
|
+
stakeProgress: 0,
|
895
|
+
solarFarmCount: 0,
|
896
|
+
solarFarmProgress: 0,
|
897
|
+
installerCount: 0,
|
898
|
+
installerProgress: 0,
|
899
|
+
};
|
900
|
+
};
|
901
|
+
// -------------------------------------------------------------------------
|
902
|
+
// Public API
|
903
|
+
// -------------------------------------------------------------------------
|
904
|
+
return {
|
905
|
+
// Data access
|
906
|
+
fetchRegions,
|
907
|
+
fetchActivationConfig,
|
908
|
+
getRegionByCode,
|
909
|
+
createRegion,
|
910
|
+
// Cached data & flags
|
911
|
+
get regions() {
|
912
|
+
return cachedRegions;
|
913
|
+
},
|
914
|
+
get isLoading() {
|
915
|
+
return isLoading;
|
916
|
+
},
|
917
|
+
get isCreatingRegion() {
|
918
|
+
return isCreatingRegion;
|
919
|
+
},
|
920
|
+
};
|
921
|
+
}
|
922
|
+
|
923
|
+
export { ControlRouter as C, DECIMALS_BY_TOKEN as D, ForwarderError as F, GLOW_WEIGHT_DECIMAL_PRECISION as G, HUB_URL as H, MAX_WEIGHT as M, RegionRouter as R, USDG_WEIGHT_DECIMAL_PRECISION as U, GCA_URLS as a, getAddresses as g, useForwarder as u };
|
924
|
+
//# sourceMappingURL=region-router-ClCO6Pac.js.map
|
@@ -0,0 +1 @@
|
|
1
|
+
{"version":3,"file":"region-router-ClCO6Pac.js","sources":["../../src/constants/urls.ts","../../src/constants/weights.ts","../../src/lib/abis/forwarderABI.ts","../../src/lib/abis/erc20.abi.ts","../../src/constants/addresses.ts","../../src/lib/hooks/use-forwarder.ts","../../src/lib/control-api/control-router.ts","../../src/lib/control-api/region-router.ts"],"sourcesContent":["export const HUB_URL = \"https://glow.org\";\n\nexport const GCA_URLS = [\"http://95.217.194.59:35015\"];\n","/**\n * @dev This is actually not as intuitive as it seems.\n * Glow actually has 18 decimals, but glow weight is based on the amount of protocol fees (USDC) that the farm paid\n * Therefore, the weight is based on the amount of USDC that was paid, which has 8 decimals\n */\nexport const GLOW_WEIGHT_DECIMAL_PRECISION = 8;\n\n/**\n * @dev This is actually not as intuitive as it seems.\n * USDG weight is based on the amount of carbon credits produced, but the max value of a weight is ((2*64)-1) / 5 so we need to choose sensible precision to make sure that number never overflows\n */\nexport const USDG_WEIGHT_DECIMAL_PRECISION = 8;\n\nexport const MAX_WEIGHT: bigint =\n (BigInt(2) ** BigInt(64) - BigInt(1)) / BigInt(5);\n","export const FORWARDER_ABI = [\n {\n inputs: [{ internalType: \"address\", name: \"_forwarder\", type: \"address\" }],\n stateMutability: \"nonpayable\",\n type: \"constructor\",\n },\n {\n inputs: [{ internalType: \"address\", name: \"target\", type: \"address\" }],\n name: \"AddressEmptyCode\",\n type: \"error\",\n },\n {\n inputs: [{ internalType: \"address\", name: \"account\", type: \"address\" }],\n name: \"AddressInsufficientBalance\",\n type: \"error\",\n },\n { inputs: [], name: \"FailedInnerCall\", type: \"error\" },\n {\n inputs: [{ internalType: \"address\", name: \"token\", type: \"address\" }],\n name: \"SafeERC20FailedOperation\",\n type: \"error\",\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: \"address\", name: \"from\", type: \"address\" },\n { indexed: true, internalType: \"address\", name: \"to\", type: \"address\" },\n {\n indexed: true,\n internalType: \"address\",\n name: \"token\",\n type: \"address\",\n },\n {\n indexed: false,\n internalType: \"uint256\",\n name: \"amount\",\n type: \"uint256\",\n },\n {\n indexed: false,\n internalType: \"string\",\n name: \"message\",\n type: \"string\",\n },\n ],\n name: \"Forward\",\n type: \"event\",\n },\n {\n inputs: [],\n name: \"FORWARD_ADDRESS\",\n outputs: [{ internalType: \"address\", name: \"\", type: \"address\" }],\n stateMutability: \"view\",\n type: \"function\",\n },\n {\n inputs: [\n { internalType: \"address\", name: \"token\", type: \"address\" },\n { internalType: \"address\", name: \"to\", type: \"address\" },\n { internalType: \"uint256\", name: \"amount\", type: \"uint256\" },\n { internalType: \"string\", name: \"message\", type: \"string\" },\n ],\n name: \"forward\",\n outputs: [],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n] as const;\n","export const ERC20_ABI = [\n {\n inputs: [\n { name: \"spender\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n name: \"approve\",\n outputs: [{ name: \"\", type: \"bool\" }],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n {\n inputs: [\n { name: \"owner\", type: \"address\" },\n { name: \"spender\", type: \"address\" },\n ],\n name: \"allowance\",\n outputs: [{ name: \"\", type: \"uint256\" }],\n stateMutability: \"view\",\n type: \"function\",\n },\n {\n inputs: [\n { name: \"to\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n name: \"transfer\",\n outputs: [{ name: \"\", type: \"bool\" }],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n {\n inputs: [{ name: \"account\", type: \"address\" }],\n name: \"balanceOf\",\n outputs: [{ name: \"\", type: \"uint256\" }],\n stateMutability: \"view\",\n type: \"function\",\n },\n {\n inputs: [\n { name: \"account\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n name: \"mint\",\n outputs: [{ name: \"\", type: \"bool\" }],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n];\n","type ContractKeys = \"USDC\" | \"FORWARDER\" | \"FOUNDATION_WALLET\" | \"GLW\" | \"USDG\";\n\n// Contract-specific addresses\nconst mainnetAddresses: Record<ContractKeys, `0x${string}`> = {\n USDG: \"0xe010ec500720bE9EF3F82129E7eD2Ee1FB7955F2\",\n GLW: \"0xf4fbC617A5733EAAF9af08E1Ab816B103388d8B6\",\n USDC: \"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48\",\n FORWARDER: \"0x0000000000000000000000000000000000000000\", // TODO: Update with actual mainnet address\n FOUNDATION_WALLET: \"0x0000000000000000000000000000000000000000\", // TODO: Update with actual mainnet foundation wallet\n};\n\nconst sepoliaAddresses: Record<ContractKeys, `0x${string}`> = {\n USDG: \"0xda78313A3fF949890112c1B746AB1c75d1b1c17B\",\n GLW: \"0x2039161fcE4C8e5CF5FE64e17Fd290E8dFF3c9BD\",\n USDC: \"0x93c898be98cd2618ba84a6dccf5003d3bbe40356\",\n FORWARDER: \"0x9c1d61303D46BFAb1eC5F25c12A1Bf4cB3d06416\",\n FOUNDATION_WALLET: \"0x5e230FED487c86B90f6508104149F087d9B1B0A7\",\n};\n\nexport const getAddresses = (\n CHAIN_ID: number\n): Record<ContractKeys, `0x${string}`> => {\n switch (CHAIN_ID) {\n case 1:\n return mainnetAddresses;\n case 11155111:\n return sepoliaAddresses;\n default:\n console.warn(\n `Unsupported chain ID: ${CHAIN_ID}, falling back to mainnet addresses`\n );\n return mainnetAddresses;\n }\n};\n\nexport const DECIMALS_BY_TOKEN: Record<string, number> = {\n USDC: 6,\n USDG: 6,\n GLW: 18,\n};\n","import { BigNumber, ethers } from \"ethers\";\nimport { FORWARDER_ABI } from \"../abis/forwarderABI\";\nimport { ERC20_ABI } from \"../abis/erc20.abi\";\nimport { getAddresses } from \"../../constants/addresses\";\n\nexport enum ForwarderError {\n CONTRACT_NOT_AVAILABLE = \"Contract not available\",\n SIGNER_NOT_AVAILABLE = \"Signer not available\",\n UNKNOWN_ERROR = \"Unknown error\",\n INVALID_FORWARD_TYPE = \"Invalid forward type\",\n MISSING_REQUIRED_PARAMS = \"Missing required parameters\",\n}\n\n// Forward types based on API router documentation\nexport type ForwardType =\n | \"PayProtocolFeeAndMintGCTLAndStake\"\n | \"PayProtocolFee\"\n | \"MintGCTLAndStake\"\n | \"MintGCTL\"\n | \"BuySolarFarm\";\n\n// Currency types\nexport type Currency = \"USDC\" | \"GLW\" | \"USDG\";\n\n// Forward parameters interface\nexport interface ForwardParams {\n amount: BigNumber;\n userAddress: string;\n type: ForwardType;\n currency?: Currency;\n applicationId?: string;\n farmId?: string;\n regionId?: number;\n}\n\n// Utility to extract the most useful revert reason from an ethers error object\nfunction parseEthersError(error: unknown): string {\n if (!error) return \"Unknown error\";\n const possibleError: any = error;\n\n // If the error originates from a callStatic it will often be found at `error?.error?.body`\n if (possibleError?.error?.body) {\n try {\n const body = JSON.parse(possibleError.error.body);\n // Hardhat style errors\n if (body?.error?.message) return body.error.message as string;\n } catch {}\n }\n\n // Found on MetaMask/Alchemy shape errors\n if (possibleError?.data?.message) return possibleError.data.message as string;\n if (possibleError?.error?.message)\n return possibleError.error.message as string;\n\n // Standard ethers v5 message\n if (possibleError?.reason) return possibleError.reason as string;\n if (possibleError?.message) return possibleError.message as string;\n\n return ForwarderError.UNKNOWN_ERROR;\n}\n\n// Type-guard style helper to ensure a signer exists throughout the rest of the function.\nfunction assertSigner(\n maybeSigner: ethers.providers.JsonRpcSigner | undefined\n): asserts maybeSigner is ethers.providers.JsonRpcSigner {\n if (!maybeSigner) {\n throw new Error(ForwarderError.SIGNER_NOT_AVAILABLE);\n }\n}\n\nexport function useForwarder(\n signer: ethers.providers.JsonRpcSigner | undefined,\n CHAIN_ID: number\n) {\n // Use dynamic addresses based on chain configuration\n const ADDRESSES = getAddresses(CHAIN_ID);\n\n // Framework-agnostic processing flag\n let isProcessing = false;\n const setIsProcessing = (value: boolean) => {\n isProcessing = value;\n };\n\n // Returns a contract instance for Forwarder\n function getForwarderContract() {\n assertSigner(signer);\n return new ethers.Contract(ADDRESSES.FORWARDER, FORWARDER_ABI, signer);\n }\n\n /**\n * Construct the message for the forward call based on type and parameters\n */\n function constructForwardMessage(params: ForwardParams): string {\n const { type, applicationId, farmId, regionId, userAddress } = params;\n\n switch (type) {\n case \"PayProtocolFeeAndMintGCTLAndStake\":\n if (!applicationId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `PayProtocolFeeAndMintGCTLAndStake::${applicationId}`;\n\n case \"PayProtocolFee\":\n if (!applicationId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `PayProtocolFee::${applicationId}`;\n\n case \"MintGCTLAndStake\":\n if (!regionId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `MintGCTLAndStake::${regionId}`;\n\n case \"MintGCTL\":\n if (!userAddress) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `MintGCTL::${userAddress}`;\n\n case \"BuySolarFarm\":\n if (!farmId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `BuySolarFarm::${farmId}`;\n\n default:\n throw new Error(ForwarderError.INVALID_FORWARD_TYPE);\n }\n }\n\n /**\n * Get the appropriate token contract based on currency\n */\n function getTokenContract(currency: Currency = \"USDC\") {\n assertSigner(signer);\n\n let tokenAddress: string;\n switch (currency) {\n case \"USDC\":\n tokenAddress = ADDRESSES.USDC;\n break;\n case \"GLW\":\n tokenAddress = ADDRESSES.GLW;\n break;\n case \"USDG\":\n tokenAddress = ADDRESSES.USDG;\n break;\n default:\n throw new Error(\n `Currency ${currency} not yet supported. Only USDC, GLW, and USDG are currently supported.`\n );\n }\n\n return new ethers.Contract(tokenAddress, ERC20_ABI, signer);\n }\n\n /**\n * Check current token allowance for the forwarder contract\n * @param owner The wallet address to check allowance for\n * @param currency The currency to check allowance for\n */\n async function checkTokenAllowance(\n owner: string,\n currency: Currency = \"USDC\"\n ): Promise<BigNumber> {\n assertSigner(signer);\n\n try {\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const allowance: BigNumber = await tokenContract.allowance(\n owner,\n ADDRESSES.FORWARDER\n );\n return allowance;\n } catch (error) {\n throw new Error(parseEthersError(error));\n }\n }\n\n /**\n * Check user's token balance\n * @param owner The wallet address to check balance for\n * @param currency The currency to check balance for\n */\n async function checkTokenBalance(\n owner: string,\n currency: Currency = \"USDC\"\n ): Promise<BigNumber> {\n assertSigner(signer);\n\n try {\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const balance: BigNumber = await tokenContract.balanceOf(owner);\n return balance;\n } catch (error) {\n throw new Error(parseEthersError(error));\n }\n }\n\n /**\n * Approve tokens for the forwarder contract\n * @param amount Amount to approve (BigNumber)\n * @param currency The currency to approve\n */\n async function approveToken(\n amount: BigNumber,\n currency: Currency = \"USDC\"\n ): Promise<boolean> {\n assertSigner(signer);\n\n try {\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n setIsProcessing(true);\n\n // Approve only the specific amount needed\n const approveTx = await tokenContract.approve(\n ADDRESSES.FORWARDER,\n amount\n );\n await approveTx.wait();\n\n return true;\n } catch (error) {\n throw new Error(parseEthersError(error));\n } finally {\n setIsProcessing(false);\n }\n }\n\n /**\n * Forward tokens through the forwarder contract with type-specific handling\n * @param params Forward parameters including type, amount, and required fields\n */\n async function forwardTokens(params: ForwardParams): Promise<string> {\n assertSigner(signer);\n\n try {\n const forwarderContract = getForwarderContract();\n if (!forwarderContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n setIsProcessing(true);\n\n const { amount, currency = \"USDC\" } = params;\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const owner = await signer.getAddress();\n\n // Construct the appropriate message for this forward type\n const message = constructForwardMessage(params);\n\n // Check allowance and approve if necessary\n const allowance: BigNumber = await tokenContract.allowance(\n owner,\n ADDRESSES.FORWARDER\n );\n\n if (allowance.lt(amount)) {\n try {\n const approveTx = await tokenContract.approve(\n ADDRESSES.FORWARDER,\n ethers.constants.MaxUint256\n );\n await approveTx.wait();\n } catch (approveError) {\n throw new Error(\n parseEthersError(approveError) || \"Token approval failed\"\n );\n }\n }\n\n // Get the token address based on currency\n let tokenAddress: string;\n switch (currency) {\n case \"USDC\":\n tokenAddress = ADDRESSES.USDC;\n break;\n case \"USDG\":\n tokenAddress = ADDRESSES.USDG;\n break;\n case \"GLW\":\n tokenAddress = ADDRESSES.GLW;\n break;\n default:\n throw new Error(`Unsupported currency for forwarding: ${currency}`);\n }\n\n // Run a static call first to surface any revert reason\n try {\n await forwarderContract.callStatic.forward(\n tokenAddress,\n ADDRESSES.FOUNDATION_WALLET,\n amount,\n message,\n { from: owner }\n );\n } catch (staticError) {\n throw new Error(parseEthersError(staticError));\n }\n\n // Execute the forward transaction\n const tx = await forwarderContract.forward(\n tokenAddress,\n ADDRESSES.FOUNDATION_WALLET,\n amount,\n message\n );\n await tx.wait();\n\n return tx.hash;\n } catch (txError: any) {\n throw new Error(parseEthersError(txError));\n } finally {\n setIsProcessing(false);\n }\n }\n\n /**\n * Forward tokens for protocol fee payment and GCTL minting with staking\n */\n async function payProtocolFeeAndMintGCTLAndStake(\n amount: BigNumber,\n userAddress: string,\n applicationId: string,\n regionId?: number,\n currency: Currency = \"USDC\"\n ): Promise<string> {\n assertSigner(signer);\n\n // GCTL minting only supports USDC and USDG\n if (currency === \"GLW\") {\n throw new Error(\n \"GCTL minting is not supported with GLW payment. Use USDC or USDG.\"\n );\n }\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"PayProtocolFeeAndMintGCTLAndStake\",\n currency,\n applicationId,\n regionId,\n });\n }\n\n /**\n * Forward tokens for protocol fee payment only\n */\n async function payProtocolFee(\n amount: BigNumber,\n userAddress: string,\n applicationId: string,\n currency: Currency = \"USDC\"\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"PayProtocolFee\",\n currency,\n applicationId,\n });\n }\n\n /**\n * Forward USDC to mint GCTL and stake to a region\n */\n async function mintGCTLAndStake(\n amount: BigNumber,\n userAddress: string,\n regionId?: number\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"MintGCTLAndStake\",\n currency: \"USDC\",\n regionId,\n });\n }\n\n /**\n * Forward USDC to mint GCTL (existing functionality, keeping for compatibility)\n */\n async function mintGCTL(\n amount: BigNumber,\n userAddress: string\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"MintGCTL\",\n currency: \"USDC\",\n });\n }\n\n /**\n * Forward tokens to buy a solar farm\n */\n async function buySolarFarm(\n amount: BigNumber,\n userAddress: string,\n farmId: string,\n currency: Currency = \"USDC\"\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"BuySolarFarm\",\n currency,\n farmId,\n });\n }\n\n /**\n * Estimate gas for forwarding with type-specific handling\n * @param params Forward parameters\n * @param ethPriceInUSD Current ETH price in USD (for cost estimation)\n */\n async function estimateGasForForward(\n params: ForwardParams,\n ethPriceInUSD: number | null\n ): Promise<string> {\n assertSigner(signer);\n\n try {\n const forwarderContract = getForwarderContract();\n if (!forwarderContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const { amount, currency = \"USDC\" } = params;\n\n // Construct the appropriate message for this forward type\n const message = constructForwardMessage(params);\n\n // Get token address\n let tokenAddress: string;\n switch (currency) {\n case \"USDC\":\n tokenAddress = ADDRESSES.USDC;\n break;\n case \"USDG\":\n tokenAddress = ADDRESSES.USDG;\n break;\n case \"GLW\":\n tokenAddress = ADDRESSES.GLW;\n break;\n default:\n throw new Error(\n `Unsupported currency for gas estimation: ${currency}`\n );\n }\n\n const gasPrice = await signer.getGasPrice();\n const estimatedGas = await forwarderContract.estimateGas.forward(\n tokenAddress,\n ADDRESSES.FOUNDATION_WALLET,\n amount,\n message\n );\n const estimatedCost = estimatedGas.mul(gasPrice);\n\n if (ethPriceInUSD) {\n const estimatedCostInEth = ethers.utils.formatEther(estimatedCost);\n const estimatedCostInUSD = (\n parseFloat(estimatedCostInEth) * ethPriceInUSD\n ).toFixed(2);\n return estimatedCostInUSD;\n } else {\n throw new Error(\n \"Could not fetch the ETH price to calculate cost in USD.\"\n );\n }\n } catch (error: any) {\n throw new Error(parseEthersError(error));\n }\n }\n\n /**\n * Mint test USDC (only works on testnets with mintable USDC contracts)\n * @param amount Amount of USDC to mint (BigNumber, 6 decimals)\n * @param recipient Address to mint USDC to\n */\n async function mintTestUSDC(\n amount: BigNumber,\n recipient: string\n ): Promise<string> {\n assertSigner(signer);\n if (CHAIN_ID !== 11155111) {\n throw new Error(\"Minting test USDC is only supported on Sepolia\");\n }\n\n try {\n const usdcContract = getTokenContract(\"USDC\"); // Use getTokenContract for consistency\n if (!usdcContract) throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n setIsProcessing(true);\n\n // Try to call mint function (common for test tokens)\n const tx = await usdcContract.mint(recipient, amount);\n await tx.wait();\n\n return tx.hash;\n } catch (error: any) {\n // If mint function doesn't exist or fails, provide helpful error\n const errorMessage = parseEthersError(error);\n if (errorMessage.includes(\"mint\")) {\n throw new Error(\"This USDC contract doesn't support minting\");\n }\n throw new Error(errorMessage);\n } finally {\n setIsProcessing(false);\n }\n }\n\n return {\n // New methods for different forward types\n forwardTokens,\n payProtocolFeeAndMintGCTLAndStake,\n payProtocolFee,\n mintGCTLAndStake,\n mintGCTL,\n buySolarFarm,\n\n // Token operations\n approveToken,\n checkTokenAllowance,\n checkTokenBalance,\n\n // Utility methods\n estimateGasForForward,\n mintTestUSDC,\n constructForwardMessage,\n\n // State\n get isProcessing() {\n return isProcessing;\n },\n addresses: ADDRESSES,\n\n // Signer availability\n isSignerAvailable: !!signer,\n };\n}\n","\"use strict\";\n\nimport type {\n MintedEvent,\n StakedEvent,\n PendingTransfer,\n FailedOperation,\n GctlPrice,\n StakeRequest,\n RegionStake,\n WalletRegionStake,\n WalletRegionUnlocked,\n Region,\n TransferDetails,\n} from \"../types\";\n\n// --------------------------------------------------------------------------\n\n/**\n * Extract a useful error message from an unknown error value.\n */\nfunction parseApiError(error: unknown): string {\n if (!error) return \"Unknown error\";\n if (error instanceof Error) return error.message;\n const possible: any = error;\n return possible?.error?.message ?? possible?.message ?? \"Unknown error\";\n}\n\n// --------------------------------------------------------------------------\n// Public Factory\n// --------------------------------------------------------------------------\n\nexport function ControlRouter(baseUrl: string) {\n // ----------------------- Internal helpers --------------------------------\n const request = async <T>(path: string, init?: RequestInit): Promise<T> => {\n const res = await fetch(`${baseUrl}${path}`, init);\n if (!res.ok) {\n const errData = await res.json().catch(() => ({}));\n throw new Error(errData?.error || `Request to ${path} failed`);\n }\n return (await res.json()) as T;\n };\n\n // ----------------------- GETters -----------------------------------------\n const fetchGctlBalance = async (wallet: string): Promise<string> => {\n try {\n const data = await request<{ gctl_balance: string }>(\n `/balance/${wallet}`\n );\n return (data?.gctl_balance ?? \"0\").toString();\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchGctlPrice = async (): Promise<number> => {\n try {\n const data = await request<GctlPrice>(`/price`);\n return data.currentPriceUsdc;\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchMintedEvents = async (): Promise<MintedEvent[]> => {\n try {\n const data = await request<{ events: MintedEvent[] }>(\n `/events/minted?page=1&limit=50`\n );\n return data.events ?? [];\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchStakeEvents = async (): Promise<StakedEvent[]> => {\n try {\n const data = await request<{ events: StakedEvent[] }>(\n `/events/stake?page=1&limit=50`\n );\n return data.events ?? [];\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchPendingTransfers = async (): Promise<PendingTransfer[]> => {\n try {\n const data = await request<{ transfers: PendingTransfer[] }>(\n `/transfers/pending?page=1&limit=50`\n );\n return data.transfers ?? [];\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchTransferDetails = async (\n txId: string\n ): Promise<TransferDetails> => {\n try {\n return await request<TransferDetails>(`/transfer/${txId}`);\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchFailedOperations = async (): Promise<FailedOperation[]> => {\n try {\n const data = await request<{ operations: FailedOperation[] }>(\n `/operations/failed?page=1&limit=50`\n );\n return data.operations ?? [];\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n // Exposed query with error parsing\n const getTransferDetails = async (txId: string): Promise<TransferDetails> => {\n try {\n return await fetchTransferDetails(txId);\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchRegions = async (): Promise<Region[]> => {\n const data = await request<{ regions: Region[] }>(`/regions`);\n return data.regions.filter((r) => r.id !== 998 && r.id !== 999) ?? [];\n };\n\n const fetchRegionStake = async (regionId: number): Promise<RegionStake> => {\n try {\n return await request<RegionStake>(`/region/${regionId}/stake`);\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchWalletRegionStake = async (\n wallet: string,\n regionId: number\n ): Promise<WalletRegionStake> => {\n try {\n return await request<WalletRegionStake>(\n `/wallet/${wallet}/region/${regionId}/stake`\n );\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n const fetchWalletRegionUnlocked = async (\n wallet: string,\n regionId: number\n ): Promise<WalletRegionUnlocked> => {\n try {\n return await request<WalletRegionUnlocked>(\n `/wallet/${wallet}/region/${regionId}/unlocked`\n );\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n // ----------------------- Mutations ---------------------------------------\n let isStaking = false;\n let isUnstaking = false;\n let isRetryingFailedOperation = false;\n\n const stakeGctl = async (\n wallet: string,\n regionId: number,\n amount: string\n ): Promise<boolean> => {\n isStaking = true;\n try {\n const stakeRequest: StakeRequest = { wallet, regionId, amount };\n await request(`/stake`, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify(stakeRequest),\n });\n return true;\n } catch (error) {\n throw new Error(parseApiError(error));\n } finally {\n isStaking = false;\n }\n };\n\n const unstakeGctl = async (\n wallet: string,\n regionId: number,\n amount: string\n ): Promise<boolean> => {\n isUnstaking = true;\n try {\n const unstakeRequest: StakeRequest = { wallet, regionId, amount };\n await request(`/unstake`, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify(unstakeRequest),\n });\n return true;\n } catch (error) {\n throw new Error(parseApiError(error));\n } finally {\n isUnstaking = false;\n }\n };\n\n const retryFailedOperation = async (\n operationId: string\n ): Promise<boolean> => {\n isRetryingFailedOperation = true;\n try {\n await request(`/operations/failed/${operationId}/retry`, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n });\n return true;\n } catch (error) {\n throw new Error(parseApiError(error));\n } finally {\n isRetryingFailedOperation = false;\n }\n };\n\n // --------------------------- Public API ----------------------------------\n return {\n // Queries\n fetchGctlBalance,\n fetchGctlPrice,\n fetchMintedEvents,\n fetchStakeEvents,\n fetchPendingTransfers,\n fetchFailedOperations,\n fetchRegions,\n fetchRegionStake,\n fetchWalletRegionStake,\n fetchWalletRegionUnlocked,\n fetchTransferDetails: getTransferDetails,\n\n // Mutations\n stakeGctl,\n unstakeGctl,\n retryFailedOperation,\n\n // Processing flags\n get isStaking() {\n return isStaking;\n },\n get isUnstaking() {\n return isUnstaking;\n },\n get isRetryingFailedOperation() {\n return isRetryingFailedOperation;\n },\n } as const;\n}\n","\"use strict\";\n\nimport type {\n Region,\n RegionWithMetadata,\n ActivationConfig,\n CreateRegionPayload,\n} from \"../types\";\n\n// ---------------------------------------------------------------------------\n// Helpers\n// ---------------------------------------------------------------------------\n\nfunction parseApiError(error: unknown): string {\n if (!error) return \"Unknown error\";\n if (error instanceof Error) return error.message;\n const possible: any = error;\n return possible?.error?.message ?? possible?.message ?? \"Unknown error\";\n}\n\n// ---------------------------------------------------------------------------\n// Factory\n// ---------------------------------------------------------------------------\n\nexport function RegionRouter(baseUrl: string) {\n if (!baseUrl) throw new Error(\"CONTROL API base URL is not set\");\n\n const request = async <T>(path: string, init?: RequestInit): Promise<T> => {\n const res = await fetch(`${baseUrl}${path}`, init);\n if (!res.ok) {\n const errData = await res.json().catch(() => ({}));\n throw new Error(errData?.error || `Request to ${path} failed`);\n }\n return (await res.json()) as T;\n };\n\n // -------------------------------------------------------------------------\n // Local cache / state flags\n // -------------------------------------------------------------------------\n let cachedRegions: Region[] = [];\n let isLoading = false;\n let isCreatingRegion = false;\n\n // -------------------------------------------------------------------------\n // Queries\n // -------------------------------------------------------------------------\n const fetchRegions = async (): Promise<Region[]> => {\n isLoading = true;\n try {\n const data = await request<{ regions: Region[] }>(`/regions`);\n cachedRegions = data.regions ?? [];\n return cachedRegions;\n } catch (error) {\n throw new Error(parseApiError(error));\n } finally {\n isLoading = false;\n }\n };\n\n const fetchActivationConfig = async (\n regionCode: string\n ): Promise<ActivationConfig> => {\n try {\n return await request<ActivationConfig>(\n `/regions/activation-config?code=${regionCode}`\n );\n } catch (error) {\n throw new Error(parseApiError(error));\n }\n };\n\n // -------------------------------------------------------------------------\n // Mutations\n // -------------------------------------------------------------------------\n const createRegion = async (payload: CreateRegionPayload): Promise<void> => {\n isCreatingRegion = true;\n try {\n await request(`/regions/create`, {\n method: \"POST\",\n headers: { \"Content-Type\": \"application/json\" },\n body: JSON.stringify(payload),\n });\n // Refresh the local cache after successful creation\n await fetchRegions();\n } catch (error) {\n throw new Error(parseApiError(error));\n } finally {\n isCreatingRegion = false;\n }\n };\n\n // -------------------------------------------------------------------------\n // Helpers (derived)\n // -------------------------------------------------------------------------\n // NOTE: regionMetadata is imported lazily to avoid circular deps at load time.\n // eslint-disable-next-line @typescript-eslint/no-var-requires\n const { regionMetadata } = require(\"@/lib/region-metadata\");\n\n const getRegionByCode = (code: string): RegionWithMetadata | null => {\n const metadata = regionMetadata[code];\n if (!metadata) return null;\n\n const existingRegion = cachedRegions.find(\n (r) => r.name.toLowerCase() === metadata.name.toLowerCase()\n );\n\n if (existingRegion) {\n return {\n ...existingRegion,\n code: metadata.code,\n description: metadata.description,\n flag: metadata.flag,\n };\n }\n\n // Placeholder if region does not yet exist in DB\n return {\n id: -1,\n name: metadata.name,\n code: metadata.code,\n description: metadata.description,\n flag: metadata.flag,\n isUs: metadata.isUs,\n isActive: false,\n stake: \"0\",\n stakeProgress: 0,\n solarFarmCount: 0,\n solarFarmProgress: 0,\n installerCount: 0,\n installerProgress: 0,\n };\n };\n\n // -------------------------------------------------------------------------\n // Public API\n // -------------------------------------------------------------------------\n return {\n // Data access\n fetchRegions,\n fetchActivationConfig,\n getRegionByCode,\n createRegion,\n\n // Cached data & flags\n get regions() {\n return cachedRegions;\n },\n get isLoading() {\n return isLoading;\n },\n get isCreatingRegion() {\n return isCreatingRegion;\n },\n } as const;\n}\n"],"names":["parseApiError"],"mappings":"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"}
|
package/package.json
CHANGED
package/src/browser.ts
CHANGED
@@ -1,6 +1,6 @@
|
|
1
1
|
export * from "./lib/hooks/use-forwarder";
|
2
|
-
export * from "./lib/
|
3
|
-
export * from "./lib/
|
2
|
+
export * from "./lib/control-api/control-router";
|
3
|
+
export * from "./lib/control-api/region-router";
|
4
4
|
export * from "./lib/types";
|
5
5
|
export * from "./lib/region-metadata";
|
6
6
|
export * from "./constants/addresses";
|
package/src/index.ts
CHANGED
@@ -30,7 +30,7 @@ function parseApiError(error: unknown): string {
|
|
30
30
|
// Public Factory
|
31
31
|
// --------------------------------------------------------------------------
|
32
32
|
|
33
|
-
export function
|
33
|
+
export function ControlRouter(baseUrl: string) {
|
34
34
|
// ----------------------- Internal helpers --------------------------------
|
35
35
|
const request = async <T>(path: string, init?: RequestInit): Promise<T> => {
|
36
36
|
const res = await fetch(`${baseUrl}${path}`, init);
|
@@ -22,7 +22,7 @@ function parseApiError(error: unknown): string {
|
|
22
22
|
// Factory
|
23
23
|
// ---------------------------------------------------------------------------
|
24
24
|
|
25
|
-
export function
|
25
|
+
export function RegionRouter(baseUrl: string) {
|
26
26
|
if (!baseUrl) throw new Error("CONTROL API base URL is not set");
|
27
27
|
|
28
28
|
const request = async <T>(path: string, init?: RequestInit): Promise<T> => {
|
@@ -1 +0,0 @@
|
|
1
|
-
{"version":3,"file":"use-forwarder-CVlJS4UY.js","sources":["../../src/constants/urls.ts","../../src/constants/weights.ts","../../src/lib/abis/forwarderABI.ts","../../src/lib/abis/erc20.abi.ts","../../src/constants/addresses.ts","../../src/lib/hooks/use-forwarder.ts"],"sourcesContent":["export const HUB_URL = \"https://glow.org\";\n\nexport const GCA_URLS = [\"http://95.217.194.59:35015\"];\n","/**\n * @dev This is actually not as intuitive as it seems.\n * Glow actually has 18 decimals, but glow weight is based on the amount of protocol fees (USDC) that the farm paid\n * Therefore, the weight is based on the amount of USDC that was paid, which has 8 decimals\n */\nexport const GLOW_WEIGHT_DECIMAL_PRECISION = 8;\n\n/**\n * @dev This is actually not as intuitive as it seems.\n * USDG weight is based on the amount of carbon credits produced, but the max value of a weight is ((2*64)-1) / 5 so we need to choose sensible precision to make sure that number never overflows\n */\nexport const USDG_WEIGHT_DECIMAL_PRECISION = 8;\n\nexport const MAX_WEIGHT: bigint =\n (BigInt(2) ** BigInt(64) - BigInt(1)) / BigInt(5);\n","export const FORWARDER_ABI = [\n {\n inputs: [{ internalType: \"address\", name: \"_forwarder\", type: \"address\" }],\n stateMutability: \"nonpayable\",\n type: \"constructor\",\n },\n {\n inputs: [{ internalType: \"address\", name: \"target\", type: \"address\" }],\n name: \"AddressEmptyCode\",\n type: \"error\",\n },\n {\n inputs: [{ internalType: \"address\", name: \"account\", type: \"address\" }],\n name: \"AddressInsufficientBalance\",\n type: \"error\",\n },\n { inputs: [], name: \"FailedInnerCall\", type: \"error\" },\n {\n inputs: [{ internalType: \"address\", name: \"token\", type: \"address\" }],\n name: \"SafeERC20FailedOperation\",\n type: \"error\",\n },\n {\n anonymous: false,\n inputs: [\n { indexed: true, internalType: \"address\", name: \"from\", type: \"address\" },\n { indexed: true, internalType: \"address\", name: \"to\", type: \"address\" },\n {\n indexed: true,\n internalType: \"address\",\n name: \"token\",\n type: \"address\",\n },\n {\n indexed: false,\n internalType: \"uint256\",\n name: \"amount\",\n type: \"uint256\",\n },\n {\n indexed: false,\n internalType: \"string\",\n name: \"message\",\n type: \"string\",\n },\n ],\n name: \"Forward\",\n type: \"event\",\n },\n {\n inputs: [],\n name: \"FORWARD_ADDRESS\",\n outputs: [{ internalType: \"address\", name: \"\", type: \"address\" }],\n stateMutability: \"view\",\n type: \"function\",\n },\n {\n inputs: [\n { internalType: \"address\", name: \"token\", type: \"address\" },\n { internalType: \"address\", name: \"to\", type: \"address\" },\n { internalType: \"uint256\", name: \"amount\", type: \"uint256\" },\n { internalType: \"string\", name: \"message\", type: \"string\" },\n ],\n name: \"forward\",\n outputs: [],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n] as const;\n","export const ERC20_ABI = [\n {\n inputs: [\n { name: \"spender\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n name: \"approve\",\n outputs: [{ name: \"\", type: \"bool\" }],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n {\n inputs: [\n { name: \"owner\", type: \"address\" },\n { name: \"spender\", type: \"address\" },\n ],\n name: \"allowance\",\n outputs: [{ name: \"\", type: \"uint256\" }],\n stateMutability: \"view\",\n type: \"function\",\n },\n {\n inputs: [\n { name: \"to\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n name: \"transfer\",\n outputs: [{ name: \"\", type: \"bool\" }],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n {\n inputs: [{ name: \"account\", type: \"address\" }],\n name: \"balanceOf\",\n outputs: [{ name: \"\", type: \"uint256\" }],\n stateMutability: \"view\",\n type: \"function\",\n },\n {\n inputs: [\n { name: \"account\", type: \"address\" },\n { name: \"amount\", type: \"uint256\" },\n ],\n name: \"mint\",\n outputs: [{ name: \"\", type: \"bool\" }],\n stateMutability: \"nonpayable\",\n type: \"function\",\n },\n];\n","type ContractKeys = \"USDC\" | \"FORWARDER\" | \"FOUNDATION_WALLET\" | \"GLW\" | \"USDG\";\n\n// Contract-specific addresses\nconst mainnetAddresses: Record<ContractKeys, `0x${string}`> = {\n USDG: \"0xe010ec500720bE9EF3F82129E7eD2Ee1FB7955F2\",\n GLW: \"0xf4fbC617A5733EAAF9af08E1Ab816B103388d8B6\",\n USDC: \"0xA0b86991c6218b36c1d19D4a2e9Eb0cE3606eB48\",\n FORWARDER: \"0x0000000000000000000000000000000000000000\", // TODO: Update with actual mainnet address\n FOUNDATION_WALLET: \"0x0000000000000000000000000000000000000000\", // TODO: Update with actual mainnet foundation wallet\n};\n\nconst sepoliaAddresses: Record<ContractKeys, `0x${string}`> = {\n USDG: \"0xda78313A3fF949890112c1B746AB1c75d1b1c17B\",\n GLW: \"0x2039161fcE4C8e5CF5FE64e17Fd290E8dFF3c9BD\",\n USDC: \"0x93c898be98cd2618ba84a6dccf5003d3bbe40356\",\n FORWARDER: \"0x9c1d61303D46BFAb1eC5F25c12A1Bf4cB3d06416\",\n FOUNDATION_WALLET: \"0x5e230FED487c86B90f6508104149F087d9B1B0A7\",\n};\n\nexport const getAddresses = (\n CHAIN_ID: number\n): Record<ContractKeys, `0x${string}`> => {\n switch (CHAIN_ID) {\n case 1:\n return mainnetAddresses;\n case 11155111:\n return sepoliaAddresses;\n default:\n console.warn(\n `Unsupported chain ID: ${CHAIN_ID}, falling back to mainnet addresses`\n );\n return mainnetAddresses;\n }\n};\n\nexport const DECIMALS_BY_TOKEN: Record<string, number> = {\n USDC: 6,\n USDG: 6,\n GLW: 18,\n};\n","import { BigNumber, ethers } from \"ethers\";\nimport { FORWARDER_ABI } from \"../abis/forwarderABI\";\nimport { ERC20_ABI } from \"../abis/erc20.abi\";\nimport { getAddresses } from \"../../constants/addresses\";\n\nexport enum ForwarderError {\n CONTRACT_NOT_AVAILABLE = \"Contract not available\",\n SIGNER_NOT_AVAILABLE = \"Signer not available\",\n UNKNOWN_ERROR = \"Unknown error\",\n INVALID_FORWARD_TYPE = \"Invalid forward type\",\n MISSING_REQUIRED_PARAMS = \"Missing required parameters\",\n}\n\n// Forward types based on API router documentation\nexport type ForwardType =\n | \"PayProtocolFeeAndMintGCTLAndStake\"\n | \"PayProtocolFee\"\n | \"MintGCTLAndStake\"\n | \"MintGCTL\"\n | \"BuySolarFarm\";\n\n// Currency types\nexport type Currency = \"USDC\" | \"GLW\" | \"USDG\";\n\n// Forward parameters interface\nexport interface ForwardParams {\n amount: BigNumber;\n userAddress: string;\n type: ForwardType;\n currency?: Currency;\n applicationId?: string;\n farmId?: string;\n regionId?: number;\n}\n\n// Utility to extract the most useful revert reason from an ethers error object\nfunction parseEthersError(error: unknown): string {\n if (!error) return \"Unknown error\";\n const possibleError: any = error;\n\n // If the error originates from a callStatic it will often be found at `error?.error?.body`\n if (possibleError?.error?.body) {\n try {\n const body = JSON.parse(possibleError.error.body);\n // Hardhat style errors\n if (body?.error?.message) return body.error.message as string;\n } catch {}\n }\n\n // Found on MetaMask/Alchemy shape errors\n if (possibleError?.data?.message) return possibleError.data.message as string;\n if (possibleError?.error?.message)\n return possibleError.error.message as string;\n\n // Standard ethers v5 message\n if (possibleError?.reason) return possibleError.reason as string;\n if (possibleError?.message) return possibleError.message as string;\n\n return ForwarderError.UNKNOWN_ERROR;\n}\n\n// Type-guard style helper to ensure a signer exists throughout the rest of the function.\nfunction assertSigner(\n maybeSigner: ethers.providers.JsonRpcSigner | undefined\n): asserts maybeSigner is ethers.providers.JsonRpcSigner {\n if (!maybeSigner) {\n throw new Error(ForwarderError.SIGNER_NOT_AVAILABLE);\n }\n}\n\nexport function useForwarder(\n signer: ethers.providers.JsonRpcSigner | undefined,\n CHAIN_ID: number\n) {\n // Use dynamic addresses based on chain configuration\n const ADDRESSES = getAddresses(CHAIN_ID);\n\n // Framework-agnostic processing flag\n let isProcessing = false;\n const setIsProcessing = (value: boolean) => {\n isProcessing = value;\n };\n\n // Returns a contract instance for Forwarder\n function getForwarderContract() {\n assertSigner(signer);\n return new ethers.Contract(ADDRESSES.FORWARDER, FORWARDER_ABI, signer);\n }\n\n /**\n * Construct the message for the forward call based on type and parameters\n */\n function constructForwardMessage(params: ForwardParams): string {\n const { type, applicationId, farmId, regionId, userAddress } = params;\n\n switch (type) {\n case \"PayProtocolFeeAndMintGCTLAndStake\":\n if (!applicationId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `PayProtocolFeeAndMintGCTLAndStake::${applicationId}`;\n\n case \"PayProtocolFee\":\n if (!applicationId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `PayProtocolFee::${applicationId}`;\n\n case \"MintGCTLAndStake\":\n if (!regionId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `MintGCTLAndStake::${regionId}`;\n\n case \"MintGCTL\":\n if (!userAddress) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `MintGCTL::${userAddress}`;\n\n case \"BuySolarFarm\":\n if (!farmId) {\n throw new Error(ForwarderError.MISSING_REQUIRED_PARAMS);\n }\n return `BuySolarFarm::${farmId}`;\n\n default:\n throw new Error(ForwarderError.INVALID_FORWARD_TYPE);\n }\n }\n\n /**\n * Get the appropriate token contract based on currency\n */\n function getTokenContract(currency: Currency = \"USDC\") {\n assertSigner(signer);\n\n let tokenAddress: string;\n switch (currency) {\n case \"USDC\":\n tokenAddress = ADDRESSES.USDC;\n break;\n case \"GLW\":\n tokenAddress = ADDRESSES.GLW;\n break;\n case \"USDG\":\n tokenAddress = ADDRESSES.USDG;\n break;\n default:\n throw new Error(\n `Currency ${currency} not yet supported. Only USDC, GLW, and USDG are currently supported.`\n );\n }\n\n return new ethers.Contract(tokenAddress, ERC20_ABI, signer);\n }\n\n /**\n * Check current token allowance for the forwarder contract\n * @param owner The wallet address to check allowance for\n * @param currency The currency to check allowance for\n */\n async function checkTokenAllowance(\n owner: string,\n currency: Currency = \"USDC\"\n ): Promise<BigNumber> {\n assertSigner(signer);\n\n try {\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const allowance: BigNumber = await tokenContract.allowance(\n owner,\n ADDRESSES.FORWARDER\n );\n return allowance;\n } catch (error) {\n throw new Error(parseEthersError(error));\n }\n }\n\n /**\n * Check user's token balance\n * @param owner The wallet address to check balance for\n * @param currency The currency to check balance for\n */\n async function checkTokenBalance(\n owner: string,\n currency: Currency = \"USDC\"\n ): Promise<BigNumber> {\n assertSigner(signer);\n\n try {\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const balance: BigNumber = await tokenContract.balanceOf(owner);\n return balance;\n } catch (error) {\n throw new Error(parseEthersError(error));\n }\n }\n\n /**\n * Approve tokens for the forwarder contract\n * @param amount Amount to approve (BigNumber)\n * @param currency The currency to approve\n */\n async function approveToken(\n amount: BigNumber,\n currency: Currency = \"USDC\"\n ): Promise<boolean> {\n assertSigner(signer);\n\n try {\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n setIsProcessing(true);\n\n // Approve only the specific amount needed\n const approveTx = await tokenContract.approve(\n ADDRESSES.FORWARDER,\n amount\n );\n await approveTx.wait();\n\n return true;\n } catch (error) {\n throw new Error(parseEthersError(error));\n } finally {\n setIsProcessing(false);\n }\n }\n\n /**\n * Forward tokens through the forwarder contract with type-specific handling\n * @param params Forward parameters including type, amount, and required fields\n */\n async function forwardTokens(params: ForwardParams): Promise<string> {\n assertSigner(signer);\n\n try {\n const forwarderContract = getForwarderContract();\n if (!forwarderContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n setIsProcessing(true);\n\n const { amount, currency = \"USDC\" } = params;\n const tokenContract = getTokenContract(currency);\n if (!tokenContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const owner = await signer.getAddress();\n\n // Construct the appropriate message for this forward type\n const message = constructForwardMessage(params);\n\n // Check allowance and approve if necessary\n const allowance: BigNumber = await tokenContract.allowance(\n owner,\n ADDRESSES.FORWARDER\n );\n\n if (allowance.lt(amount)) {\n try {\n const approveTx = await tokenContract.approve(\n ADDRESSES.FORWARDER,\n ethers.constants.MaxUint256\n );\n await approveTx.wait();\n } catch (approveError) {\n throw new Error(\n parseEthersError(approveError) || \"Token approval failed\"\n );\n }\n }\n\n // Get the token address based on currency\n let tokenAddress: string;\n switch (currency) {\n case \"USDC\":\n tokenAddress = ADDRESSES.USDC;\n break;\n case \"USDG\":\n tokenAddress = ADDRESSES.USDG;\n break;\n case \"GLW\":\n tokenAddress = ADDRESSES.GLW;\n break;\n default:\n throw new Error(`Unsupported currency for forwarding: ${currency}`);\n }\n\n // Run a static call first to surface any revert reason\n try {\n await forwarderContract.callStatic.forward(\n tokenAddress,\n ADDRESSES.FOUNDATION_WALLET,\n amount,\n message,\n { from: owner }\n );\n } catch (staticError) {\n throw new Error(parseEthersError(staticError));\n }\n\n // Execute the forward transaction\n const tx = await forwarderContract.forward(\n tokenAddress,\n ADDRESSES.FOUNDATION_WALLET,\n amount,\n message\n );\n await tx.wait();\n\n return tx.hash;\n } catch (txError: any) {\n throw new Error(parseEthersError(txError));\n } finally {\n setIsProcessing(false);\n }\n }\n\n /**\n * Forward tokens for protocol fee payment and GCTL minting with staking\n */\n async function payProtocolFeeAndMintGCTLAndStake(\n amount: BigNumber,\n userAddress: string,\n applicationId: string,\n regionId?: number,\n currency: Currency = \"USDC\"\n ): Promise<string> {\n assertSigner(signer);\n\n // GCTL minting only supports USDC and USDG\n if (currency === \"GLW\") {\n throw new Error(\n \"GCTL minting is not supported with GLW payment. Use USDC or USDG.\"\n );\n }\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"PayProtocolFeeAndMintGCTLAndStake\",\n currency,\n applicationId,\n regionId,\n });\n }\n\n /**\n * Forward tokens for protocol fee payment only\n */\n async function payProtocolFee(\n amount: BigNumber,\n userAddress: string,\n applicationId: string,\n currency: Currency = \"USDC\"\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"PayProtocolFee\",\n currency,\n applicationId,\n });\n }\n\n /**\n * Forward USDC to mint GCTL and stake to a region\n */\n async function mintGCTLAndStake(\n amount: BigNumber,\n userAddress: string,\n regionId?: number\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"MintGCTLAndStake\",\n currency: \"USDC\",\n regionId,\n });\n }\n\n /**\n * Forward USDC to mint GCTL (existing functionality, keeping for compatibility)\n */\n async function mintGCTL(\n amount: BigNumber,\n userAddress: string\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"MintGCTL\",\n currency: \"USDC\",\n });\n }\n\n /**\n * Forward tokens to buy a solar farm\n */\n async function buySolarFarm(\n amount: BigNumber,\n userAddress: string,\n farmId: string,\n currency: Currency = \"USDC\"\n ): Promise<string> {\n assertSigner(signer);\n\n return forwardTokens({\n amount,\n userAddress,\n type: \"BuySolarFarm\",\n currency,\n farmId,\n });\n }\n\n /**\n * Estimate gas for forwarding with type-specific handling\n * @param params Forward parameters\n * @param ethPriceInUSD Current ETH price in USD (for cost estimation)\n */\n async function estimateGasForForward(\n params: ForwardParams,\n ethPriceInUSD: number | null\n ): Promise<string> {\n assertSigner(signer);\n\n try {\n const forwarderContract = getForwarderContract();\n if (!forwarderContract)\n throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n const { amount, currency = \"USDC\" } = params;\n\n // Construct the appropriate message for this forward type\n const message = constructForwardMessage(params);\n\n // Get token address\n let tokenAddress: string;\n switch (currency) {\n case \"USDC\":\n tokenAddress = ADDRESSES.USDC;\n break;\n case \"USDG\":\n tokenAddress = ADDRESSES.USDG;\n break;\n case \"GLW\":\n tokenAddress = ADDRESSES.GLW;\n break;\n default:\n throw new Error(\n `Unsupported currency for gas estimation: ${currency}`\n );\n }\n\n const gasPrice = await signer.getGasPrice();\n const estimatedGas = await forwarderContract.estimateGas.forward(\n tokenAddress,\n ADDRESSES.FOUNDATION_WALLET,\n amount,\n message\n );\n const estimatedCost = estimatedGas.mul(gasPrice);\n\n if (ethPriceInUSD) {\n const estimatedCostInEth = ethers.utils.formatEther(estimatedCost);\n const estimatedCostInUSD = (\n parseFloat(estimatedCostInEth) * ethPriceInUSD\n ).toFixed(2);\n return estimatedCostInUSD;\n } else {\n throw new Error(\n \"Could not fetch the ETH price to calculate cost in USD.\"\n );\n }\n } catch (error: any) {\n throw new Error(parseEthersError(error));\n }\n }\n\n /**\n * Mint test USDC (only works on testnets with mintable USDC contracts)\n * @param amount Amount of USDC to mint (BigNumber, 6 decimals)\n * @param recipient Address to mint USDC to\n */\n async function mintTestUSDC(\n amount: BigNumber,\n recipient: string\n ): Promise<string> {\n assertSigner(signer);\n if (CHAIN_ID !== 11155111) {\n throw new Error(\"Minting test USDC is only supported on Sepolia\");\n }\n\n try {\n const usdcContract = getTokenContract(\"USDC\"); // Use getTokenContract for consistency\n if (!usdcContract) throw new Error(ForwarderError.CONTRACT_NOT_AVAILABLE);\n\n setIsProcessing(true);\n\n // Try to call mint function (common for test tokens)\n const tx = await usdcContract.mint(recipient, amount);\n await tx.wait();\n\n return tx.hash;\n } catch (error: any) {\n // If mint function doesn't exist or fails, provide helpful error\n const errorMessage = parseEthersError(error);\n if (errorMessage.includes(\"mint\")) {\n throw new Error(\"This USDC contract doesn't support minting\");\n }\n throw new Error(errorMessage);\n } finally {\n setIsProcessing(false);\n }\n }\n\n return {\n // New methods for different forward types\n forwardTokens,\n payProtocolFeeAndMintGCTLAndStake,\n payProtocolFee,\n mintGCTLAndStake,\n mintGCTL,\n buySolarFarm,\n\n // Token operations\n approveToken,\n checkTokenAllowance,\n checkTokenBalance,\n\n // Utility methods\n estimateGasForForward,\n mintTestUSDC,\n constructForwardMessage,\n\n // State\n get isProcessing() {\n return isProcessing;\n },\n addresses: ADDRESSES,\n\n // Signer availability\n isSignerAvailable: !!signer,\n };\n}\n"],"names":["ForwarderError","ethers"],"mappings":";;;;AAAO,MAAM,OAAO,GAAG;AAEhB,MAAM,QAAQ,GAAG,CAAC,4BAA4B;;ACFrD;;;;AAIG;AACI,MAAM,6BAA6B,GAAG;AAE7C;;;AAGG;AACI,MAAM,6BAA6B,GAAG;AAEtC,MAAM,UAAU,GACrB,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,EAAE,CAAC,GAAG,MAAM,CAAC,CAAC,CAAC,IAAI,MAAM,CAAC,CAAC;;ACd3C,MAAM,aAAa,GAAG;AAC3B,IAAA;AACE,QAAA,MAAM,EAAE,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,YAAY,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AAC1E,QAAA,eAAe,EAAE,YAAY;AAC7B,QAAA,IAAI,EAAE,aAAa;AACpB,KAAA;AACD,IAAA;AACE,QAAA,MAAM,EAAE,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AACtE,QAAA,IAAI,EAAE,kBAAkB;AACxB,QAAA,IAAI,EAAE,OAAO;AACd,KAAA;AACD,IAAA;AACE,QAAA,MAAM,EAAE,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AACvE,QAAA,IAAI,EAAE,4BAA4B;AAClC,QAAA,IAAI,EAAE,OAAO;AACd,KAAA;IACD,EAAE,MAAM,EAAE,EAAE,EAAE,IAAI,EAAE,iBAAiB,EAAE,IAAI,EAAE,OAAO,EAAE;AACtD,IAAA;AACE,QAAA,MAAM,EAAE,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AACrE,QAAA,IAAI,EAAE,0BAA0B;AAChC,QAAA,IAAI,EAAE,OAAO;AACd,KAAA;AACD,IAAA;AACE,QAAA,SAAS,EAAE,KAAK;AAChB,QAAA,MAAM,EAAE;AACN,YAAA,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,MAAM,EAAE,IAAI,EAAE,SAAS,EAAE;AACzE,YAAA,EAAE,OAAO,EAAE,IAAI,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE;AACvE,YAAA;AACE,gBAAA,OAAO,EAAE,IAAI;AACb,gBAAA,YAAY,EAAE,SAAS;AACvB,gBAAA,IAAI,EAAE,OAAO;AACb,gBAAA,IAAI,EAAE,SAAS;AAChB,aAAA;AACD,YAAA;AACE,gBAAA,OAAO,EAAE,KAAK;AACd,gBAAA,YAAY,EAAE,SAAS;AACvB,gBAAA,IAAI,EAAE,QAAQ;AACd,gBAAA,IAAI,EAAE,SAAS;AAChB,aAAA;AACD,YAAA;AACE,gBAAA,OAAO,EAAE,KAAK;AACd,gBAAA,YAAY,EAAE,QAAQ;AACtB,gBAAA,IAAI,EAAE,SAAS;AACf,gBAAA,IAAI,EAAE,QAAQ;AACf,aAAA;AACF,SAAA;AACD,QAAA,IAAI,EAAE,SAAS;AACf,QAAA,IAAI,EAAE,OAAO;AACd,KAAA;AACD,IAAA;AACE,QAAA,MAAM,EAAE,EAAE;AACV,QAAA,IAAI,EAAE,iBAAiB;AACvB,QAAA,OAAO,EAAE,CAAC,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AACjE,QAAA,eAAe,EAAE,MAAM;AACvB,QAAA,IAAI,EAAE,UAAU;AACjB,KAAA;AACD,IAAA;AACE,QAAA,MAAM,EAAE;YACN,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE;YAC3D,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE;YACxD,EAAE,YAAY,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE;YAC5D,EAAE,YAAY,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,QAAQ,EAAE;AAC5D,SAAA;AACD,QAAA,IAAI,EAAE,SAAS;AACf,QAAA,OAAO,EAAE,EAAE;AACX,QAAA,eAAe,EAAE,YAAY;AAC7B,QAAA,IAAI,EAAE,UAAU;AACjB,KAAA;CACO;;ACpEH,MAAM,SAAS,GAAG;AACvB,IAAA;AACE,QAAA,MAAM,EAAE;AACN,YAAA,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE;AACpC,YAAA,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE;AACpC,SAAA;AACD,QAAA,IAAI,EAAE,SAAS;QACf,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AACrC,QAAA,eAAe,EAAE,YAAY;AAC7B,QAAA,IAAI,EAAE,UAAU;AACjB,KAAA;AACD,IAAA;AACE,QAAA,MAAM,EAAE;AACN,YAAA,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,SAAS,EAAE;AAClC,YAAA,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE;AACrC,SAAA;AACD,QAAA,IAAI,EAAE,WAAW;QACjB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AACxC,QAAA,eAAe,EAAE,MAAM;AACvB,QAAA,IAAI,EAAE,UAAU;AACjB,KAAA;AACD,IAAA;AACE,QAAA,MAAM,EAAE;AACN,YAAA,EAAE,IAAI,EAAE,IAAI,EAAE,IAAI,EAAE,SAAS,EAAE;AAC/B,YAAA,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE;AACpC,SAAA;AACD,QAAA,IAAI,EAAE,UAAU;QAChB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AACrC,QAAA,eAAe,EAAE,YAAY;AAC7B,QAAA,IAAI,EAAE,UAAU;AACjB,KAAA;AACD,IAAA;QACE,MAAM,EAAE,CAAC,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AAC9C,QAAA,IAAI,EAAE,WAAW;QACjB,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,SAAS,EAAE,CAAC;AACxC,QAAA,eAAe,EAAE,MAAM;AACvB,QAAA,IAAI,EAAE,UAAU;AACjB,KAAA;AACD,IAAA;AACE,QAAA,MAAM,EAAE;AACN,YAAA,EAAE,IAAI,EAAE,SAAS,EAAE,IAAI,EAAE,SAAS,EAAE;AACpC,YAAA,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,SAAS,EAAE;AACpC,SAAA;AACD,QAAA,IAAI,EAAE,MAAM;QACZ,OAAO,EAAE,CAAC,EAAE,IAAI,EAAE,EAAE,EAAE,IAAI,EAAE,MAAM,EAAE,CAAC;AACrC,QAAA,eAAe,EAAE,YAAY;AAC7B,QAAA,IAAI,EAAE,UAAU;AACjB,KAAA;CACF;;AC9CD;AACA,MAAM,gBAAgB,GAAwC;AAC5D,IAAA,IAAI,EAAE,4CAA4C;AAClD,IAAA,GAAG,EAAE,4CAA4C;AACjD,IAAA,IAAI,EAAE,4CAA4C;IAClD,SAAS,EAAE,4CAA4C;IACvD,iBAAiB,EAAE,4CAA4C;CAChE;AAED,MAAM,gBAAgB,GAAwC;AAC5D,IAAA,IAAI,EAAE,4CAA4C;AAClD,IAAA,GAAG,EAAE,4CAA4C;AACjD,IAAA,IAAI,EAAE,4CAA4C;AAClD,IAAA,SAAS,EAAE,4CAA4C;AACvD,IAAA,iBAAiB,EAAE,4CAA4C;CAChE;AAEM,MAAM,YAAY,GAAG,CAC1B,QAAgB,KACuB;IACvC,QAAQ,QAAQ;AACd,QAAA,KAAK,CAAC;AACJ,YAAA,OAAO,gBAAgB;AACzB,QAAA,KAAK,QAAQ;AACX,YAAA,OAAO,gBAAgB;AACzB,QAAA;AACE,YAAA,OAAO,CAAC,IAAI,CACV,yBAAyB,QAAQ,CAAA,mCAAA,CAAqC,CACvE;AACD,YAAA,OAAO,gBAAgB;;AAE7B;AAEO,MAAM,iBAAiB,GAA2B;AACvD,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,IAAI,EAAE,CAAC;AACP,IAAA,GAAG,EAAE,EAAE;;;ACjCGA;AAAZ,CAAA,UAAY,cAAc,EAAA;AACxB,IAAA,cAAA,CAAA,wBAAA,CAAA,GAAA,wBAAiD;AACjD,IAAA,cAAA,CAAA,sBAAA,CAAA,GAAA,sBAA6C;AAC7C,IAAA,cAAA,CAAA,eAAA,CAAA,GAAA,eAA+B;AAC/B,IAAA,cAAA,CAAA,sBAAA,CAAA,GAAA,sBAA6C;AAC7C,IAAA,cAAA,CAAA,yBAAA,CAAA,GAAA,6BAAuD;AACzD,CAAC,EANWA,sBAAc,KAAdA,sBAAc,GAAA,EAAA,CAAA,CAAA;AA8B1B;AACA,SAAS,gBAAgB,CAAC,KAAc,EAAA;AACtC,IAAA,IAAI,CAAC,KAAK;AAAE,QAAA,OAAO,eAAe;IAClC,MAAM,aAAa,GAAQ,KAAK;;AAGhC,IAAA,IAAI,aAAa,EAAE,KAAK,EAAE,IAAI,EAAE;AAC9B,QAAA,IAAI;AACF,YAAA,MAAM,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,CAAC;;AAEjD,YAAA,IAAI,IAAI,EAAE,KAAK,EAAE,OAAO;AAAE,gBAAA,OAAO,IAAI,CAAC,KAAK,CAAC,OAAiB;QAC/D;QAAE,MAAM,EAAC;IACX;;AAGA,IAAA,IAAI,aAAa,EAAE,IAAI,EAAE,OAAO;AAAE,QAAA,OAAO,aAAa,CAAC,IAAI,CAAC,OAAiB;AAC7E,IAAA,IAAI,aAAa,EAAE,KAAK,EAAE,OAAO;AAC/B,QAAA,OAAO,aAAa,CAAC,KAAK,CAAC,OAAiB;;IAG9C,IAAI,aAAa,EAAE,MAAM;QAAE,OAAO,aAAa,CAAC,MAAgB;IAChE,IAAI,aAAa,EAAE,OAAO;QAAE,OAAO,aAAa,CAAC,OAAiB;IAElE,OAAOA,sBAAc,CAAC,aAAa;AACrC;AAEA;AACA,SAAS,YAAY,CACnB,WAAuD,EAAA;IAEvD,IAAI,CAAC,WAAW,EAAE;AAChB,QAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,oBAAoB,CAAC;IACtD;AACF;AAEM,SAAU,YAAY,CAC1B,MAAkD,EAClD,QAAgB,EAAA;;AAGhB,IAAA,MAAM,SAAS,GAAG,YAAY,CAAC,QAAQ,CAAC;;IAGxC,IAAI,YAAY,GAAG,KAAK;AACxB,IAAA,MAAM,eAAe,GAAG,CAAC,KAAc,KAAI;QACzC,YAAY,GAAG,KAAK;AACtB,IAAA,CAAC;;AAGD,IAAA,SAAS,oBAAoB,GAAA;QAC3B,YAAY,CAAC,MAAM,CAAC;AACpB,QAAA,OAAO,IAAIC,aAAM,CAAC,QAAQ,CAAC,SAAS,CAAC,SAAS,EAAE,aAAa,EAAE,MAAM,CAAC;IACxE;AAEA;;AAEG;IACH,SAAS,uBAAuB,CAAC,MAAqB,EAAA;AACpD,QAAA,MAAM,EAAE,IAAI,EAAE,aAAa,EAAE,MAAM,EAAE,QAAQ,EAAE,WAAW,EAAE,GAAG,MAAM;QAErE,QAAQ,IAAI;AACV,YAAA,KAAK,mCAAmC;gBACtC,IAAI,CAAC,aAAa,EAAE;AAClB,oBAAA,MAAM,IAAI,KAAK,CAACD,sBAAc,CAAC,uBAAuB,CAAC;gBACzD;gBACA,OAAO,CAAA,mCAAA,EAAsC,aAAa,CAAA,CAAE;AAE9D,YAAA,KAAK,gBAAgB;gBACnB,IAAI,CAAC,aAAa,EAAE;AAClB,oBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,uBAAuB,CAAC;gBACzD;gBACA,OAAO,CAAA,gBAAA,EAAmB,aAAa,CAAA,CAAE;AAE3C,YAAA,KAAK,kBAAkB;gBACrB,IAAI,CAAC,QAAQ,EAAE;AACb,oBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,uBAAuB,CAAC;gBACzD;gBACA,OAAO,CAAA,kBAAA,EAAqB,QAAQ,CAAA,CAAE;AAExC,YAAA,KAAK,UAAU;gBACb,IAAI,CAAC,WAAW,EAAE;AAChB,oBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,uBAAuB,CAAC;gBACzD;gBACA,OAAO,CAAA,UAAA,EAAa,WAAW,CAAA,CAAE;AAEnC,YAAA,KAAK,cAAc;gBACjB,IAAI,CAAC,MAAM,EAAE;AACX,oBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,uBAAuB,CAAC;gBACzD;gBACA,OAAO,CAAA,cAAA,EAAiB,MAAM,CAAA,CAAE;AAElC,YAAA;AACE,gBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,oBAAoB,CAAC;;IAE1D;AAEA;;AAEG;IACH,SAAS,gBAAgB,CAAC,QAAA,GAAqB,MAAM,EAAA;QACnD,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,IAAI,YAAoB;QACxB,QAAQ,QAAQ;AACd,YAAA,KAAK,MAAM;AACT,gBAAA,YAAY,GAAG,SAAS,CAAC,IAAI;gBAC7B;AACF,YAAA,KAAK,KAAK;AACR,gBAAA,YAAY,GAAG,SAAS,CAAC,GAAG;gBAC5B;AACF,YAAA,KAAK,MAAM;AACT,gBAAA,YAAY,GAAG,SAAS,CAAC,IAAI;gBAC7B;AACF,YAAA;AACE,gBAAA,MAAM,IAAI,KAAK,CACb,YAAY,QAAQ,CAAA,qEAAA,CAAuE,CAC5F;;QAGL,OAAO,IAAIC,aAAM,CAAC,QAAQ,CAAC,YAAY,EAAE,SAAS,EAAE,MAAM,CAAC;IAC7D;AAEA;;;;AAIG;AACH,IAAA,eAAe,mBAAmB,CAChC,KAAa,EACb,WAAqB,MAAM,EAAA;QAE3B,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,IAAI;AACF,YAAA,MAAM,aAAa,GAAG,gBAAgB,CAAC,QAAQ,CAAC;AAChD,YAAA,IAAI,CAAC,aAAa;AAChB,gBAAA,MAAM,IAAI,KAAK,CAACD,sBAAc,CAAC,sBAAsB,CAAC;AAExD,YAAA,MAAM,SAAS,GAAc,MAAM,aAAa,CAAC,SAAS,CACxD,KAAK,EACL,SAAS,CAAC,SAAS,CACpB;AACD,YAAA,OAAO,SAAS;QAClB;QAAE,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC1C;IACF;AAEA;;;;AAIG;AACH,IAAA,eAAe,iBAAiB,CAC9B,KAAa,EACb,WAAqB,MAAM,EAAA;QAE3B,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,IAAI;AACF,YAAA,MAAM,aAAa,GAAG,gBAAgB,CAAC,QAAQ,CAAC;AAChD,YAAA,IAAI,CAAC,aAAa;AAChB,gBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,sBAAsB,CAAC;YAExD,MAAM,OAAO,GAAc,MAAM,aAAa,CAAC,SAAS,CAAC,KAAK,CAAC;AAC/D,YAAA,OAAO,OAAO;QAChB;QAAE,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC1C;IACF;AAEA;;;;AAIG;AACH,IAAA,eAAe,YAAY,CACzB,MAAiB,EACjB,WAAqB,MAAM,EAAA;QAE3B,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,IAAI;AACF,YAAA,MAAM,aAAa,GAAG,gBAAgB,CAAC,QAAQ,CAAC;AAChD,YAAA,IAAI,CAAC,aAAa;AAChB,gBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,sBAAsB,CAAC;YAExD,eAAe,CAAC,IAAI,CAAC;;AAGrB,YAAA,MAAM,SAAS,GAAG,MAAM,aAAa,CAAC,OAAO,CAC3C,SAAS,CAAC,SAAS,EACnB,MAAM,CACP;AACD,YAAA,MAAM,SAAS,CAAC,IAAI,EAAE;AAEtB,YAAA,OAAO,IAAI;QACb;QAAE,OAAO,KAAK,EAAE;YACd,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC1C;gBAAU;YACR,eAAe,CAAC,KAAK,CAAC;QACxB;IACF;AAEA;;;AAGG;IACH,eAAe,aAAa,CAAC,MAAqB,EAAA;QAChD,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,IAAI;AACF,YAAA,MAAM,iBAAiB,GAAG,oBAAoB,EAAE;AAChD,YAAA,IAAI,CAAC,iBAAiB;AACpB,gBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,sBAAsB,CAAC;YAExD,eAAe,CAAC,IAAI,CAAC;YAErB,MAAM,EAAE,MAAM,EAAE,QAAQ,GAAG,MAAM,EAAE,GAAG,MAAM;AAC5C,YAAA,MAAM,aAAa,GAAG,gBAAgB,CAAC,QAAQ,CAAC;AAChD,YAAA,IAAI,CAAC,aAAa;AAChB,gBAAA,MAAM,IAAI,KAAK,CAACA,sBAAc,CAAC,sBAAsB,CAAC;AAExD,YAAA,MAAM,KAAK,GAAG,MAAM,MAAM,CAAC,UAAU,EAAE;;AAGvC,YAAA,MAAM,OAAO,GAAG,uBAAuB,CAAC,MAAM,CAAC;;AAG/C,YAAA,MAAM,SAAS,GAAc,MAAM,aAAa,CAAC,SAAS,CACxD,KAAK,EACL,SAAS,CAAC,SAAS,CACpB;AAED,YAAA,IAAI,SAAS,CAAC,EAAE,CAAC,MAAM,CAAC,EAAE;AACxB,gBAAA,IAAI;AACF,oBAAA,MAAM,SAAS,GAAG,MAAM,aAAa,CAAC,OAAO,CAC3C,SAAS,CAAC,SAAS,EACnBC,aAAM,CAAC,SAAS,CAAC,UAAU,CAC5B;AACD,oBAAA,MAAM,SAAS,CAAC,IAAI,EAAE;gBACxB;gBAAE,OAAO,YAAY,EAAE;oBACrB,MAAM,IAAI,KAAK,CACb,gBAAgB,CAAC,YAAY,CAAC,IAAI,uBAAuB,CAC1D;gBACH;YACF;;AAGA,YAAA,IAAI,YAAoB;YACxB,QAAQ,QAAQ;AACd,gBAAA,KAAK,MAAM;AACT,oBAAA,YAAY,GAAG,SAAS,CAAC,IAAI;oBAC7B;AACF,gBAAA,KAAK,MAAM;AACT,oBAAA,YAAY,GAAG,SAAS,CAAC,IAAI;oBAC7B;AACF,gBAAA,KAAK,KAAK;AACR,oBAAA,YAAY,GAAG,SAAS,CAAC,GAAG;oBAC5B;AACF,gBAAA;AACE,oBAAA,MAAM,IAAI,KAAK,CAAC,wCAAwC,QAAQ,CAAA,CAAE,CAAC;;;AAIvE,YAAA,IAAI;gBACF,MAAM,iBAAiB,CAAC,UAAU,CAAC,OAAO,CACxC,YAAY,EACZ,SAAS,CAAC,iBAAiB,EAC3B,MAAM,EACN,OAAO,EACP,EAAE,IAAI,EAAE,KAAK,EAAE,CAChB;YACH;YAAE,OAAO,WAAW,EAAE;gBACpB,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAC;YAChD;;AAGA,YAAA,MAAM,EAAE,GAAG,MAAM,iBAAiB,CAAC,OAAO,CACxC,YAAY,EACZ,SAAS,CAAC,iBAAiB,EAC3B,MAAM,EACN,OAAO,CACR;AACD,YAAA,MAAM,EAAE,CAAC,IAAI,EAAE;YAEf,OAAO,EAAE,CAAC,IAAI;QAChB;QAAE,OAAO,OAAY,EAAE;YACrB,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,OAAO,CAAC,CAAC;QAC5C;gBAAU;YACR,eAAe,CAAC,KAAK,CAAC;QACxB;IACF;AAEA;;AAEG;AACH,IAAA,eAAe,iCAAiC,CAC9C,MAAiB,EACjB,WAAmB,EACnB,aAAqB,EACrB,QAAiB,EACjB,QAAA,GAAqB,MAAM,EAAA;QAE3B,YAAY,CAAC,MAAM,CAAC;;AAGpB,QAAA,IAAI,QAAQ,KAAK,KAAK,EAAE;AACtB,YAAA,MAAM,IAAI,KAAK,CACb,mEAAmE,CACpE;QACH;AAEA,QAAA,OAAO,aAAa,CAAC;YACnB,MAAM;YACN,WAAW;AACX,YAAA,IAAI,EAAE,mCAAmC;YACzC,QAAQ;YACR,aAAa;YACb,QAAQ;AACT,SAAA,CAAC;IACJ;AAEA;;AAEG;IACH,eAAe,cAAc,CAC3B,MAAiB,EACjB,WAAmB,EACnB,aAAqB,EACrB,QAAA,GAAqB,MAAM,EAAA;QAE3B,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,OAAO,aAAa,CAAC;YACnB,MAAM;YACN,WAAW;AACX,YAAA,IAAI,EAAE,gBAAgB;YACtB,QAAQ;YACR,aAAa;AACd,SAAA,CAAC;IACJ;AAEA;;AAEG;AACH,IAAA,eAAe,gBAAgB,CAC7B,MAAiB,EACjB,WAAmB,EACnB,QAAiB,EAAA;QAEjB,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,OAAO,aAAa,CAAC;YACnB,MAAM;YACN,WAAW;AACX,YAAA,IAAI,EAAE,kBAAkB;AACxB,YAAA,QAAQ,EAAE,MAAM;YAChB,QAAQ;AACT,SAAA,CAAC;IACJ;AAEA;;AAEG;AACH,IAAA,eAAe,QAAQ,CACrB,MAAiB,EACjB,WAAmB,EAAA;QAEnB,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,OAAO,aAAa,CAAC;YACnB,MAAM;YACN,WAAW;AACX,YAAA,IAAI,EAAE,UAAU;AAChB,YAAA,QAAQ,EAAE,MAAM;AACjB,SAAA,CAAC;IACJ;AAEA;;AAEG;IACH,eAAe,YAAY,CACzB,MAAiB,EACjB,WAAmB,EACnB,MAAc,EACd,QAAA,GAAqB,MAAM,EAAA;QAE3B,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,OAAO,aAAa,CAAC;YACnB,MAAM;YACN,WAAW;AACX,YAAA,IAAI,EAAE,cAAc;YACpB,QAAQ;YACR,MAAM;AACP,SAAA,CAAC;IACJ;AAEA;;;;AAIG;AACH,IAAA,eAAe,qBAAqB,CAClC,MAAqB,EACrB,aAA4B,EAAA;QAE5B,YAAY,CAAC,MAAM,CAAC;AAEpB,QAAA,IAAI;AACF,YAAA,MAAM,iBAAiB,GAAG,oBAAoB,EAAE;AAChD,YAAA,IAAI,CAAC,iBAAiB;AACpB,gBAAA,MAAM,IAAI,KAAK,CAACD,sBAAc,CAAC,sBAAsB,CAAC;YAExD,MAAM,EAAE,MAAM,EAAE,QAAQ,GAAG,MAAM,EAAE,GAAG,MAAM;;AAG5C,YAAA,MAAM,OAAO,GAAG,uBAAuB,CAAC,MAAM,CAAC;;AAG/C,YAAA,IAAI,YAAoB;YACxB,QAAQ,QAAQ;AACd,gBAAA,KAAK,MAAM;AACT,oBAAA,YAAY,GAAG,SAAS,CAAC,IAAI;oBAC7B;AACF,gBAAA,KAAK,MAAM;AACT,oBAAA,YAAY,GAAG,SAAS,CAAC,IAAI;oBAC7B;AACF,gBAAA,KAAK,KAAK;AACR,oBAAA,YAAY,GAAG,SAAS,CAAC,GAAG;oBAC5B;AACF,gBAAA;AACE,oBAAA,MAAM,IAAI,KAAK,CACb,4CAA4C,QAAQ,CAAA,CAAE,CACvD;;AAGL,YAAA,MAAM,QAAQ,GAAG,MAAM,MAAM,CAAC,WAAW,EAAE;AAC3C,YAAA,MAAM,YAAY,GAAG,MAAM,iBAAiB,CAAC,WAAW,CAAC,OAAO,CAC9D,YAAY,EACZ,SAAS,CAAC,iBAAiB,EAC3B,MAAM,EACN,OAAO,CACR;YACD,MAAM,aAAa,GAAG,YAAY,CAAC,GAAG,CAAC,QAAQ,CAAC;YAEhD,IAAI,aAAa,EAAE;gBACjB,MAAM,kBAAkB,GAAGC,aAAM,CAAC,KAAK,CAAC,WAAW,CAAC,aAAa,CAAC;AAClE,gBAAA,MAAM,kBAAkB,GAAG,CACzB,UAAU,CAAC,kBAAkB,CAAC,GAAG,aAAa,EAC9C,OAAO,CAAC,CAAC,CAAC;AACZ,gBAAA,OAAO,kBAAkB;YAC3B;iBAAO;AACL,gBAAA,MAAM,IAAI,KAAK,CACb,yDAAyD,CAC1D;YACH;QACF;QAAE,OAAO,KAAU,EAAE;YACnB,MAAM,IAAI,KAAK,CAAC,gBAAgB,CAAC,KAAK,CAAC,CAAC;QAC1C;IACF;AAEA;;;;AAIG;AACH,IAAA,eAAe,YAAY,CACzB,MAAiB,EACjB,SAAiB,EAAA;QAEjB,YAAY,CAAC,MAAM,CAAC;AACpB,QAAA,IAAI,QAAQ,KAAK,QAAQ,EAAE;AACzB,YAAA,MAAM,IAAI,KAAK,CAAC,gDAAgD,CAAC;QACnE;AAEA,QAAA,IAAI;YACF,MAAM,YAAY,GAAG,gBAAgB,CAAC,MAAM,CAAC,CAAC;AAC9C,YAAA,IAAI,CAAC,YAAY;AAAE,gBAAA,MAAM,IAAI,KAAK,CAACD,sBAAc,CAAC,sBAAsB,CAAC;YAEzE,eAAe,CAAC,IAAI,CAAC;;YAGrB,MAAM,EAAE,GAAG,MAAM,YAAY,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC;AACrD,YAAA,MAAM,EAAE,CAAC,IAAI,EAAE;YAEf,OAAO,EAAE,CAAC,IAAI;QAChB;QAAE,OAAO,KAAU,EAAE;;AAEnB,YAAA,MAAM,YAAY,GAAG,gBAAgB,CAAC,KAAK,CAAC;AAC5C,YAAA,IAAI,YAAY,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAE;AACjC,gBAAA,MAAM,IAAI,KAAK,CAAC,4CAA4C,CAAC;YAC/D;AACA,YAAA,MAAM,IAAI,KAAK,CAAC,YAAY,CAAC;QAC/B;gBAAU;YACR,eAAe,CAAC,KAAK,CAAC;QACxB;IACF;IAEA,OAAO;;QAEL,aAAa;QACb,iCAAiC;QACjC,cAAc;QACd,gBAAgB;QAChB,QAAQ;QACR,YAAY;;QAGZ,YAAY;QACZ,mBAAmB;QACnB,iBAAiB;;QAGjB,qBAAqB;QACrB,YAAY;QACZ,uBAAuB;;AAGvB,QAAA,IAAI,YAAY,GAAA;AACd,YAAA,OAAO,YAAY;QACrB,CAAC;AACD,QAAA,SAAS,EAAE,SAAS;;QAGpB,iBAAiB,EAAE,CAAC,CAAC,MAAM;KAC5B;AACH;;;;;;;;;;;"}
|