@zemyth/raise-sdk 0.1.6 → 0.2.0

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.
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/constants/index.ts"],"names":["InvestmentTier"],"mappings":"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","file":"index.cjs","sourcesContent":["/**\n * Raise Constants\n *\n * Mirrors the on-chain program constants for client-side validation\n * and display purposes.\n */\n\n// =============================================================================\n// PDA Seeds\n// =============================================================================\n\nexport const SEEDS = {\n PROJECT: 'project',\n MILESTONE: 'milestone',\n INVESTMENT: 'investment',\n VOTE: 'vote',\n ESCROW: 'escrow',\n PIVOT: 'pivot',\n PIVOT_PROPOSAL: 'pivot_proposal',\n TGE_ESCROW: 'tge_escrow',\n TGE_ESCROW_VAULT: 'tge_escrow_vault',\n SCAM_REPORT: 'scam_report',\n ADMIN_CONFIG: 'admin-config',\n NFT_MINT: 'nft_mint',\n AUTHORITY: 'authority',\n FUTURE_ROUND_VAULT: 'future_round_vault',\n FUTURE_ROUND_STATE: 'future_round_state',\n // Multi-Round Fundraising seeds\n FUNDING_ROUND: 'funding_round',\n ROUND_ESCROW: 'round_escrow',\n INVESTOR_MS_VESTING: 'investor_ms_vesting',\n} as const;\n\n// =============================================================================\n// Validation Constants\n// =============================================================================\n\nexport const VALIDATION = {\n /** Minimum number of milestones per project */\n MIN_MILESTONES: 2,\n /** Maximum number of milestones per project */\n MAX_MILESTONES: 10,\n /** Milestone percentages must sum to this value */\n MILESTONE_PERCENTAGE_SUM: 100,\n /** Maximum funding buffer (110% of goal) */\n MAX_FUNDING_BUFFER_PERCENT: 110,\n /** Maximum metadata URI length */\n MAX_METADATA_URI_LENGTH: 200,\n /** Maximum pivot description length */\n MAX_PIVOT_DESCRIPTION_LEN: 256,\n /** Maximum pivot vision length */\n MAX_PIVOT_VISION_LEN: 512,\n /** Maximum pivot justification length */\n MAX_PIVOT_JUSTIFICATION_LEN: 512,\n} as const;\n\n// =============================================================================\n// Timing Constants (in seconds)\n// =============================================================================\n\nexport const TIMING = {\n /** Production voting period (14 days) */\n VOTING_PERIOD_SECONDS: 1_209_600,\n /** Production hold period (7 days) */\n HOLD_PERIOD_SECONDS: 604_800,\n /** Inactivity timeout (90 days) */\n INACTIVITY_TIMEOUT_SECONDS: 7_776_000,\n /** Abandonment timeout (90 days) */\n ABANDONMENT_TIMEOUT_SECONDS: 7_776_000,\n /** Refund window (14 days) */\n REFUND_WINDOW_SECONDS: 1_209_600,\n /** Pivot withdrawal window (7 days) */\n PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604_800,\n /** Minimum TGE date (15 days from now) */\n TGE_MIN_DAYS: 1_296_000,\n /** Maximum TGE date (90 days from now) */\n TGE_MAX_DAYS: 7_776_000,\n /** Post-TGE holdback period (30 days) */\n POST_TGE_HOLDBACK_DAYS: 2_592_000,\n} as const;\n\n// =============================================================================\n// Tier Configuration Constraints\n// =============================================================================\n\nexport const TIER_CONSTRAINTS = {\n /** Minimum number of tiers */\n MIN_TIERS: 1,\n /** Maximum number of tiers */\n MAX_TIERS: 10,\n /** Minimum tier amount (10 USDC in lamports) */\n MIN_TIER_AMOUNT: 10_000_000n,\n /** Minimum max_lots per tier */\n MIN_TIER_MAX_LOTS: 1,\n /** Minimum token ratio */\n MIN_TIER_TOKEN_RATIO: 1n,\n /** Minimum vote multiplier (100 = 1.0x) */\n MIN_TIER_VOTE_MULTIPLIER: 100,\n} as const;\n\n// =============================================================================\n// Progressive Pricing Constants (add-linear-progressive-pricing)\n// =============================================================================\n\nexport const PROGRESSIVE_PRICING = {\n /** Base price multiplier (10000 BPS = 1.0x) */\n PRICE_MULTIPLIER_BASE: 10000,\n /** Maximum price multiplier (20000 BPS = 2.0x) */\n MAX_MULTIPLIER_BPS: 20000,\n /** Percentage of ZEMYTH increment allocated to time-based component */\n TIME_ALLOCATION_PERCENT: 50,\n /** Percentage of ZEMYTH increment allocated to milestone spike component */\n MILESTONE_ALLOCATION_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// Investment Tiers (Legacy - kept for backwards compatibility)\n// =============================================================================\n\nexport enum InvestmentTier {\n Bronze = 'Bronze',\n Silver = 'Silver',\n Gold = 'Gold',\n Platinum = 'Platinum',\n Diamond = 'Diamond',\n}\n\n/** Investment tier minimum amounts in USDC lamports (6 decimals) - LEGACY */\nexport const TIER_MINIMUMS = {\n [InvestmentTier.Bronze]: 100_000_000n, // 100 USDC\n [InvestmentTier.Silver]: 500_000_000n, // 500 USDC\n [InvestmentTier.Gold]: 1_000_000_000n, // 1,000 USDC\n [InvestmentTier.Platinum]: 5_000_000_000n, // 5,000 USDC\n [InvestmentTier.Diamond]: 10_000_000_000n, // 10,000 USDC\n} as const;\n\n/** Vote weight multipliers (scaled by 100) - LEGACY */\nexport const TIER_VOTE_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100, // 1.0x\n [InvestmentTier.Silver]: 120, // 1.2x\n [InvestmentTier.Gold]: 150, // 1.5x\n [InvestmentTier.Platinum]: 200, // 2.0x\n [InvestmentTier.Diamond]: 300, // 3.0x\n} as const;\n\n/** Token allocation multipliers (same as vote multipliers) - LEGACY */\nexport const TIER_TOKEN_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100,\n [InvestmentTier.Silver]: 120,\n [InvestmentTier.Gold]: 150,\n [InvestmentTier.Platinum]: 200,\n [InvestmentTier.Diamond]: 300,\n} as const;\n\n/** Get tier from investment amount (in lamports) - LEGACY, use project.tiers instead */\nexport function getTierFromAmount(amount: bigint): InvestmentTier {\n if (amount >= TIER_MINIMUMS[InvestmentTier.Diamond]) return InvestmentTier.Diamond;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Platinum]) return InvestmentTier.Platinum;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Gold]) return InvestmentTier.Gold;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Silver]) return InvestmentTier.Silver;\n return InvestmentTier.Bronze;\n}\n\n/** Get vote multiplier for an investment amount - LEGACY */\nexport function getVoteMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_VOTE_MULTIPLIERS[tier] / 100;\n}\n\n/** Get token multiplier for an investment amount - LEGACY */\nexport function getTokenMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_TOKEN_MULTIPLIERS[tier] / 100;\n}\n\n/**\n * Find matching tier index for an investment amount (threshold-based)\n * Returns the highest tier where amount >= tier.amount\n */\nexport function findTierIndex(tiers: Array<{ amount: bigint }>, amount: bigint): number | null {\n for (let i = tiers.length - 1; i >= 0; i--) {\n if (amount >= tiers[i].amount) {\n return i;\n }\n }\n return null;\n}\n\n// =============================================================================\n// Voting and Governance\n// =============================================================================\n\nexport const GOVERNANCE = {\n /** Scam report threshold (30%) */\n SCAM_THRESHOLD_PERCENT: 30,\n /** Consecutive milestone failures before exit window eligible */\n CONSECUTIVE_FAILURES_THRESHOLD: 3,\n /** Milestone approval threshold (>50% weighted approval per whitepaper voting.md:100-101) */\n MILESTONE_APPROVAL_THRESHOLD_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// NFT Constants\n// =============================================================================\n\nexport const NFT = {\n /** NFT symbol */\n SYMBOL: 'ZRI',\n /** NFT name prefix */\n NAME_PREFIX: 'Zemyth Raise Investment #',\n /** Royalty basis points (2%) */\n ROYALTY_BASIS_POINTS: 200,\n} as const;\n\n// =============================================================================\n// USDC Constants\n// =============================================================================\n\nexport const USDC = {\n /** USDC decimals */\n DECIMALS: 6,\n /** Convert USDC to lamports */\n toAmount: (usdc: number): bigint => BigInt(Math.floor(usdc * 10 ** 6)),\n /** Convert lamports to USDC */\n fromAmount: (lamports: bigint): number => Number(lamports) / 10 ** 6,\n} as const;\n\n// =============================================================================\n// Tokenomics Allocation Constants\n// =============================================================================\n\nexport const TOKENOMICS = {\n /** Minimum investor allocation (20%) */\n MIN_INVESTOR_ALLOCATION_BPS: 2000,\n /** Minimum founder allocation (5%) if > 0 */\n MIN_FOUNDER_ALLOCATION_BPS: 500,\n /** Minimum LP token allocation (5%) */\n MIN_LP_TOKEN_ALLOCATION_BPS: 500,\n /** Minimum LP USDC allocation (5%) */\n MIN_LP_USDC_BPS: 500,\n /** Minimum Zemyth allocation (1%) */\n MIN_ZEMYTH_ALLOCATION_BPS: 100,\n /** Default Zemyth allocation (1%) */\n DEFAULT_ZEMYTH_ALLOCATION_BPS: 100,\n /** Minimum future round allocation (10%) if > 0 */\n MIN_FUTURE_ROUND_ALLOCATION_BPS: 1000,\n /** Maximum token symbol length */\n MAX_TOKEN_SYMBOL_LEN: 8,\n /** Total allocation must sum to this (100% = 10000 bps) */\n TOTAL_ALLOCATION_BPS: 10000,\n} as const;\n"]}
1
+ {"version":3,"sources":["../../src/constants/index.ts"],"names":["InvestmentTier"],"mappings":"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","file":"index.cjs","sourcesContent":["/**\n * Raise Constants\n *\n * Mirrors the on-chain program constants for client-side validation\n * and display purposes.\n */\n\n// =============================================================================\n// PDA Seeds\n// =============================================================================\n\nexport const SEEDS = {\n PROJECT: 'project',\n MILESTONE: 'milestone',\n INVESTMENT: 'investment',\n VOTE: 'vote',\n ESCROW: 'escrow',\n ESCROW_TOKEN: 'escrow_token',\n PIVOT: 'pivot',\n PIVOT_PROPOSAL: 'pivot_proposal',\n TGE_ESCROW: 'tge_escrow',\n TGE_ESCROW_VAULT: 'tge_escrow_vault',\n SCAM_REPORT: 'scam_report',\n ADMIN_CONFIG: 'admin-config',\n NFT_MINT: 'nft_mint',\n AUTHORITY: 'authority',\n FUTURE_ROUND_VAULT: 'future_round_vault',\n FUTURE_ROUND_STATE: 'future_round_state',\n // Multi-Round Fundraising seeds\n FUNDING_ROUND: 'funding_round',\n ROUND_ESCROW: 'round_escrow',\n INVESTOR_MS_VESTING: 'investor_ms_vesting',\n} as const;\n\n// =============================================================================\n// Validation Constants\n// =============================================================================\n\nexport const VALIDATION = {\n /** Minimum number of milestones per project */\n MIN_MILESTONES: 2,\n /** Maximum number of milestones per project */\n MAX_MILESTONES: 10,\n /** Milestone percentages must sum to this value */\n MILESTONE_PERCENTAGE_SUM: 100,\n /** Maximum funding buffer (110% of goal) */\n MAX_FUNDING_BUFFER_PERCENT: 110,\n /** Maximum metadata URI length */\n MAX_METADATA_URI_LENGTH: 200,\n /** Maximum pivot description length */\n MAX_PIVOT_DESCRIPTION_LEN: 256,\n /** Maximum pivot vision length */\n MAX_PIVOT_VISION_LEN: 512,\n /** Maximum pivot justification length */\n MAX_PIVOT_JUSTIFICATION_LEN: 512,\n} as const;\n\n// =============================================================================\n// Timing Constants (in seconds)\n// =============================================================================\n\n/** Production timing constants (mainnet) */\nexport const TIMING_PRODUCTION = {\n /** Voting period (14 days) */\n VOTING_PERIOD_SECONDS: 1_209_600,\n /** Hold period (7 days) */\n HOLD_PERIOD_SECONDS: 604_800,\n /** Inactivity timeout (90 days) */\n INACTIVITY_TIMEOUT_SECONDS: 7_776_000,\n /** Abandonment timeout (90 days) */\n ABANDONMENT_TIMEOUT_SECONDS: 7_776_000,\n /** Refund window (14 days) */\n REFUND_WINDOW_SECONDS: 1_209_600,\n /** Pivot withdrawal window (7 days) */\n PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604_800,\n /** Early token cooling period (24 hours) */\n EARLY_TOKEN_COOLING_PERIOD: 86_400,\n /** Exit window period (7 days) */\n EXIT_WINDOW_PERIOD: 604_800,\n /** Wallet update timelock (7 days) */\n WALLET_UPDATE_TIMELOCK: 604_800,\n /** Minimum deadline duration (7 days) */\n MIN_DEADLINE_DURATION_SECONDS: 604_800,\n /** Maximum deadline duration (90 days) */\n MAX_DEADLINE_DURATION_SECONDS: 90 * 24 * 60 * 60,\n /** Deadline grace period (90 days) */\n DEADLINE_GRACE_PERIOD_SECONDS: 7_776_000,\n} as const;\n\n/** Dev timing constants (localnet/devnet) - matches Solana program dev mode */\nexport const TIMING_DEV = {\n /** Voting period (60 seconds) */\n VOTING_PERIOD_SECONDS: 60,\n /** Hold period (1 second) */\n HOLD_PERIOD_SECONDS: 1,\n /** Inactivity timeout (10 seconds) */\n INACTIVITY_TIMEOUT_SECONDS: 10,\n /** Abandonment timeout (60 seconds) */\n ABANDONMENT_TIMEOUT_SECONDS: 60,\n /** Refund window (2 minutes) */\n REFUND_WINDOW_SECONDS: 120,\n /** Pivot withdrawal window (10 seconds) */\n PIVOT_WITHDRAWAL_WINDOW_SECONDS: 10,\n /** Early token cooling period (10 seconds) */\n EARLY_TOKEN_COOLING_PERIOD: 10,\n /** Exit window period (20 seconds) */\n EXIT_WINDOW_PERIOD: 20,\n /** Wallet update timelock (60 seconds) */\n WALLET_UPDATE_TIMELOCK: 60,\n /** Minimum deadline duration (60 seconds) */\n MIN_DEADLINE_DURATION_SECONDS: 60,\n /** Maximum deadline duration (90 days) */\n MAX_DEADLINE_DURATION_SECONDS: 90 * 24 * 60 * 60,\n /** Deadline grace period (5 seconds) */\n DEADLINE_GRACE_PERIOD_SECONDS: 5,\n} as const;\n\n/**\n * Get timing constants based on environment\n * @param isDev - Whether to use dev mode constants (localnet/devnet)\n */\nexport function getTimingConstants(isDev: boolean = false) {\n return isDev ? TIMING_DEV : TIMING_PRODUCTION;\n}\n\n/** @deprecated Use TIMING_PRODUCTION or TIMING_DEV instead */\nexport const TIMING = TIMING_PRODUCTION;\n\n// =============================================================================\n// Tier Configuration Constraints\n// =============================================================================\n\nexport const TIER_CONSTRAINTS = {\n /** Minimum number of tiers */\n MIN_TIERS: 1,\n /** Maximum number of tiers */\n MAX_TIERS: 10,\n /** Minimum tier amount (10 USDC in lamports) */\n MIN_TIER_AMOUNT: 10_000_000n,\n /** Minimum max_lots per tier */\n MIN_TIER_MAX_LOTS: 1,\n /** Minimum token ratio */\n MIN_TIER_TOKEN_RATIO: 1n,\n /** Minimum vote multiplier (100 = 1.0x) */\n MIN_TIER_VOTE_MULTIPLIER: 100,\n} as const;\n\n// =============================================================================\n// Progressive Pricing Constants (add-linear-progressive-pricing)\n// =============================================================================\n\nexport const PROGRESSIVE_PRICING = {\n /** Base price multiplier (10000 BPS = 1.0x) */\n PRICE_MULTIPLIER_BASE: 10000,\n /** Maximum price multiplier (20000 BPS = 2.0x) */\n MAX_MULTIPLIER_BPS: 20000,\n /** Percentage of ZEMYTH increment allocated to time-based component */\n TIME_ALLOCATION_PERCENT: 50,\n /** Percentage of ZEMYTH increment allocated to milestone spike component */\n MILESTONE_ALLOCATION_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// Investment Tiers (Legacy - kept for backwards compatibility)\n// =============================================================================\n\nexport enum InvestmentTier {\n Bronze = 'Bronze',\n Silver = 'Silver',\n Gold = 'Gold',\n Platinum = 'Platinum',\n Diamond = 'Diamond',\n}\n\n/** Investment tier minimum amounts in USDC lamports (6 decimals) - LEGACY */\nexport const TIER_MINIMUMS = {\n [InvestmentTier.Bronze]: 100_000_000n, // 100 USDC\n [InvestmentTier.Silver]: 500_000_000n, // 500 USDC\n [InvestmentTier.Gold]: 1_000_000_000n, // 1,000 USDC\n [InvestmentTier.Platinum]: 5_000_000_000n, // 5,000 USDC\n [InvestmentTier.Diamond]: 10_000_000_000n, // 10,000 USDC\n} as const;\n\n/** Vote weight multipliers (scaled by 100) - LEGACY */\nexport const TIER_VOTE_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100, // 1.0x\n [InvestmentTier.Silver]: 120, // 1.2x\n [InvestmentTier.Gold]: 150, // 1.5x\n [InvestmentTier.Platinum]: 200, // 2.0x\n [InvestmentTier.Diamond]: 300, // 3.0x\n} as const;\n\n/** Token allocation multipliers (same as vote multipliers) - LEGACY */\nexport const TIER_TOKEN_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100,\n [InvestmentTier.Silver]: 120,\n [InvestmentTier.Gold]: 150,\n [InvestmentTier.Platinum]: 200,\n [InvestmentTier.Diamond]: 300,\n} as const;\n\n/** Get tier from investment amount (in lamports) - LEGACY, use project.tiers instead */\nexport function getTierFromAmount(amount: bigint): InvestmentTier {\n if (amount >= TIER_MINIMUMS[InvestmentTier.Diamond]) return InvestmentTier.Diamond;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Platinum]) return InvestmentTier.Platinum;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Gold]) return InvestmentTier.Gold;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Silver]) return InvestmentTier.Silver;\n return InvestmentTier.Bronze;\n}\n\n/** Get vote multiplier for an investment amount - LEGACY */\nexport function getVoteMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_VOTE_MULTIPLIERS[tier] / 100;\n}\n\n/** Get token multiplier for an investment amount - LEGACY */\nexport function getTokenMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_TOKEN_MULTIPLIERS[tier] / 100;\n}\n\n/**\n * Find matching tier index for an investment amount (threshold-based)\n * Returns the highest tier where amount >= tier.amount\n */\nexport function findTierIndex(tiers: Array<{ amount: bigint }>, amount: bigint): number | null {\n for (let i = tiers.length - 1; i >= 0; i--) {\n if (amount >= tiers[i].amount) {\n return i;\n }\n }\n return null;\n}\n\n// =============================================================================\n// Voting and Governance\n// =============================================================================\n\nexport const GOVERNANCE = {\n /** Scam report threshold (30%) */\n SCAM_THRESHOLD_PERCENT: 30,\n /** Consecutive milestone failures before exit window eligible */\n CONSECUTIVE_FAILURES_THRESHOLD: 3,\n /** Milestone approval threshold (>50% weighted approval per whitepaper voting.md:100-101) */\n MILESTONE_APPROVAL_THRESHOLD_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// NFT Constants\n// =============================================================================\n\nexport const NFT = {\n /** NFT symbol */\n SYMBOL: 'ZRI',\n /** NFT name prefix */\n NAME_PREFIX: 'Zemyth Raise Investment #',\n /** Royalty basis points (2%) */\n ROYALTY_BASIS_POINTS: 200,\n} as const;\n\n// =============================================================================\n// USDC Constants\n// =============================================================================\n\nexport const USDC = {\n /** USDC decimals */\n DECIMALS: 6,\n /** Convert USDC to lamports */\n toAmount: (usdc: number): bigint => BigInt(Math.floor(usdc * 10 ** 6)),\n /** Convert lamports to USDC */\n fromAmount: (lamports: bigint): number => Number(lamports) / 10 ** 6,\n} as const;\n\n// =============================================================================\n// Tokenomics Allocation Constants\n// =============================================================================\n\nexport const TOKENOMICS = {\n /** Minimum investor allocation (20%) */\n MIN_INVESTOR_ALLOCATION_BPS: 2000,\n /** Minimum founder allocation (5%) if > 0 */\n MIN_FOUNDER_ALLOCATION_BPS: 500,\n /** Minimum LP token allocation (5%) */\n MIN_LP_TOKEN_ALLOCATION_BPS: 500,\n /** Minimum LP USDC allocation (5%) */\n MIN_LP_USDC_BPS: 500,\n /** Minimum Zemyth allocation (1%) */\n MIN_ZEMYTH_ALLOCATION_BPS: 100,\n /** Default Zemyth allocation (1%) */\n DEFAULT_ZEMYTH_ALLOCATION_BPS: 100,\n /** Minimum future round allocation (10%) if > 0 */\n MIN_FUTURE_ROUND_ALLOCATION_BPS: 1000,\n /** Maximum token symbol length */\n MAX_TOKEN_SYMBOL_LEN: 8,\n /** Total allocation must sum to this (100% = 10000 bps) */\n TOTAL_ALLOCATION_BPS: 10000,\n} as const;\n"]}
@@ -10,6 +10,7 @@ declare const SEEDS: {
10
10
  readonly INVESTMENT: "investment";
11
11
  readonly VOTE: "vote";
12
12
  readonly ESCROW: "escrow";
13
+ readonly ESCROW_TOKEN: "escrow_token";
13
14
  readonly PIVOT: "pivot";
14
15
  readonly PIVOT_PROPOSAL: "pivot_proposal";
15
16
  readonly TGE_ESCROW: "tge_escrow";
@@ -42,10 +43,120 @@ declare const VALIDATION: {
42
43
  /** Maximum pivot justification length */
43
44
  readonly MAX_PIVOT_JUSTIFICATION_LEN: 512;
44
45
  };
46
+ /** Production timing constants (mainnet) */
47
+ declare const TIMING_PRODUCTION: {
48
+ /** Voting period (14 days) */
49
+ readonly VOTING_PERIOD_SECONDS: 1209600;
50
+ /** Hold period (7 days) */
51
+ readonly HOLD_PERIOD_SECONDS: 604800;
52
+ /** Inactivity timeout (90 days) */
53
+ readonly INACTIVITY_TIMEOUT_SECONDS: 7776000;
54
+ /** Abandonment timeout (90 days) */
55
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 7776000;
56
+ /** Refund window (14 days) */
57
+ readonly REFUND_WINDOW_SECONDS: 1209600;
58
+ /** Pivot withdrawal window (7 days) */
59
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604800;
60
+ /** Early token cooling period (24 hours) */
61
+ readonly EARLY_TOKEN_COOLING_PERIOD: 86400;
62
+ /** Exit window period (7 days) */
63
+ readonly EXIT_WINDOW_PERIOD: 604800;
64
+ /** Wallet update timelock (7 days) */
65
+ readonly WALLET_UPDATE_TIMELOCK: 604800;
66
+ /** Minimum deadline duration (7 days) */
67
+ readonly MIN_DEADLINE_DURATION_SECONDS: 604800;
68
+ /** Maximum deadline duration (90 days) */
69
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
70
+ /** Deadline grace period (90 days) */
71
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 7776000;
72
+ };
73
+ /** Dev timing constants (localnet/devnet) - matches Solana program dev mode */
74
+ declare const TIMING_DEV: {
75
+ /** Voting period (60 seconds) */
76
+ readonly VOTING_PERIOD_SECONDS: 60;
77
+ /** Hold period (1 second) */
78
+ readonly HOLD_PERIOD_SECONDS: 1;
79
+ /** Inactivity timeout (10 seconds) */
80
+ readonly INACTIVITY_TIMEOUT_SECONDS: 10;
81
+ /** Abandonment timeout (60 seconds) */
82
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 60;
83
+ /** Refund window (2 minutes) */
84
+ readonly REFUND_WINDOW_SECONDS: 120;
85
+ /** Pivot withdrawal window (10 seconds) */
86
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 10;
87
+ /** Early token cooling period (10 seconds) */
88
+ readonly EARLY_TOKEN_COOLING_PERIOD: 10;
89
+ /** Exit window period (20 seconds) */
90
+ readonly EXIT_WINDOW_PERIOD: 20;
91
+ /** Wallet update timelock (60 seconds) */
92
+ readonly WALLET_UPDATE_TIMELOCK: 60;
93
+ /** Minimum deadline duration (60 seconds) */
94
+ readonly MIN_DEADLINE_DURATION_SECONDS: 60;
95
+ /** Maximum deadline duration (90 days) */
96
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
97
+ /** Deadline grace period (5 seconds) */
98
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 5;
99
+ };
100
+ /**
101
+ * Get timing constants based on environment
102
+ * @param isDev - Whether to use dev mode constants (localnet/devnet)
103
+ */
104
+ declare function getTimingConstants(isDev?: boolean): {
105
+ /** Voting period (14 days) */
106
+ readonly VOTING_PERIOD_SECONDS: 1209600;
107
+ /** Hold period (7 days) */
108
+ readonly HOLD_PERIOD_SECONDS: 604800;
109
+ /** Inactivity timeout (90 days) */
110
+ readonly INACTIVITY_TIMEOUT_SECONDS: 7776000;
111
+ /** Abandonment timeout (90 days) */
112
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 7776000;
113
+ /** Refund window (14 days) */
114
+ readonly REFUND_WINDOW_SECONDS: 1209600;
115
+ /** Pivot withdrawal window (7 days) */
116
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604800;
117
+ /** Early token cooling period (24 hours) */
118
+ readonly EARLY_TOKEN_COOLING_PERIOD: 86400;
119
+ /** Exit window period (7 days) */
120
+ readonly EXIT_WINDOW_PERIOD: 604800;
121
+ /** Wallet update timelock (7 days) */
122
+ readonly WALLET_UPDATE_TIMELOCK: 604800;
123
+ /** Minimum deadline duration (7 days) */
124
+ readonly MIN_DEADLINE_DURATION_SECONDS: 604800;
125
+ /** Maximum deadline duration (90 days) */
126
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
127
+ /** Deadline grace period (90 days) */
128
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 7776000;
129
+ } | {
130
+ /** Voting period (60 seconds) */
131
+ readonly VOTING_PERIOD_SECONDS: 60;
132
+ /** Hold period (1 second) */
133
+ readonly HOLD_PERIOD_SECONDS: 1;
134
+ /** Inactivity timeout (10 seconds) */
135
+ readonly INACTIVITY_TIMEOUT_SECONDS: 10;
136
+ /** Abandonment timeout (60 seconds) */
137
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 60;
138
+ /** Refund window (2 minutes) */
139
+ readonly REFUND_WINDOW_SECONDS: 120;
140
+ /** Pivot withdrawal window (10 seconds) */
141
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 10;
142
+ /** Early token cooling period (10 seconds) */
143
+ readonly EARLY_TOKEN_COOLING_PERIOD: 10;
144
+ /** Exit window period (20 seconds) */
145
+ readonly EXIT_WINDOW_PERIOD: 20;
146
+ /** Wallet update timelock (60 seconds) */
147
+ readonly WALLET_UPDATE_TIMELOCK: 60;
148
+ /** Minimum deadline duration (60 seconds) */
149
+ readonly MIN_DEADLINE_DURATION_SECONDS: 60;
150
+ /** Maximum deadline duration (90 days) */
151
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
152
+ /** Deadline grace period (5 seconds) */
153
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 5;
154
+ };
155
+ /** @deprecated Use TIMING_PRODUCTION or TIMING_DEV instead */
45
156
  declare const TIMING: {
46
- /** Production voting period (14 days) */
157
+ /** Voting period (14 days) */
47
158
  readonly VOTING_PERIOD_SECONDS: 1209600;
48
- /** Production hold period (7 days) */
159
+ /** Hold period (7 days) */
49
160
  readonly HOLD_PERIOD_SECONDS: 604800;
50
161
  /** Inactivity timeout (90 days) */
51
162
  readonly INACTIVITY_TIMEOUT_SECONDS: 7776000;
@@ -55,12 +166,18 @@ declare const TIMING: {
55
166
  readonly REFUND_WINDOW_SECONDS: 1209600;
56
167
  /** Pivot withdrawal window (7 days) */
57
168
  readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604800;
58
- /** Minimum TGE date (15 days from now) */
59
- readonly TGE_MIN_DAYS: 1296000;
60
- /** Maximum TGE date (90 days from now) */
61
- readonly TGE_MAX_DAYS: 7776000;
62
- /** Post-TGE holdback period (30 days) */
63
- readonly POST_TGE_HOLDBACK_DAYS: 2592000;
169
+ /** Early token cooling period (24 hours) */
170
+ readonly EARLY_TOKEN_COOLING_PERIOD: 86400;
171
+ /** Exit window period (7 days) */
172
+ readonly EXIT_WINDOW_PERIOD: 604800;
173
+ /** Wallet update timelock (7 days) */
174
+ readonly WALLET_UPDATE_TIMELOCK: 604800;
175
+ /** Minimum deadline duration (7 days) */
176
+ readonly MIN_DEADLINE_DURATION_SECONDS: 604800;
177
+ /** Maximum deadline duration (90 days) */
178
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
179
+ /** Deadline grace period (90 days) */
180
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 7776000;
64
181
  };
65
182
  declare const TIER_CONSTRAINTS: {
66
183
  /** Minimum number of tiers */
@@ -175,4 +292,4 @@ declare const TOKENOMICS: {
175
292
  readonly TOTAL_ALLOCATION_BPS: 10000;
176
293
  };
177
294
 
178
- export { GOVERNANCE, InvestmentTier, NFT, PROGRESSIVE_PRICING, SEEDS, TIER_CONSTRAINTS, TIER_MINIMUMS, TIER_TOKEN_MULTIPLIERS, TIER_VOTE_MULTIPLIERS, TIMING, TOKENOMICS, USDC, VALIDATION, findTierIndex, getTierFromAmount, getTokenMultiplier, getVoteMultiplier };
295
+ export { GOVERNANCE, InvestmentTier, NFT, PROGRESSIVE_PRICING, SEEDS, TIER_CONSTRAINTS, TIER_MINIMUMS, TIER_TOKEN_MULTIPLIERS, TIER_VOTE_MULTIPLIERS, TIMING, TIMING_DEV, TIMING_PRODUCTION, TOKENOMICS, USDC, VALIDATION, findTierIndex, getTierFromAmount, getTimingConstants, getTokenMultiplier, getVoteMultiplier };
@@ -10,6 +10,7 @@ declare const SEEDS: {
10
10
  readonly INVESTMENT: "investment";
11
11
  readonly VOTE: "vote";
12
12
  readonly ESCROW: "escrow";
13
+ readonly ESCROW_TOKEN: "escrow_token";
13
14
  readonly PIVOT: "pivot";
14
15
  readonly PIVOT_PROPOSAL: "pivot_proposal";
15
16
  readonly TGE_ESCROW: "tge_escrow";
@@ -42,10 +43,120 @@ declare const VALIDATION: {
42
43
  /** Maximum pivot justification length */
43
44
  readonly MAX_PIVOT_JUSTIFICATION_LEN: 512;
44
45
  };
46
+ /** Production timing constants (mainnet) */
47
+ declare const TIMING_PRODUCTION: {
48
+ /** Voting period (14 days) */
49
+ readonly VOTING_PERIOD_SECONDS: 1209600;
50
+ /** Hold period (7 days) */
51
+ readonly HOLD_PERIOD_SECONDS: 604800;
52
+ /** Inactivity timeout (90 days) */
53
+ readonly INACTIVITY_TIMEOUT_SECONDS: 7776000;
54
+ /** Abandonment timeout (90 days) */
55
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 7776000;
56
+ /** Refund window (14 days) */
57
+ readonly REFUND_WINDOW_SECONDS: 1209600;
58
+ /** Pivot withdrawal window (7 days) */
59
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604800;
60
+ /** Early token cooling period (24 hours) */
61
+ readonly EARLY_TOKEN_COOLING_PERIOD: 86400;
62
+ /** Exit window period (7 days) */
63
+ readonly EXIT_WINDOW_PERIOD: 604800;
64
+ /** Wallet update timelock (7 days) */
65
+ readonly WALLET_UPDATE_TIMELOCK: 604800;
66
+ /** Minimum deadline duration (7 days) */
67
+ readonly MIN_DEADLINE_DURATION_SECONDS: 604800;
68
+ /** Maximum deadline duration (90 days) */
69
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
70
+ /** Deadline grace period (90 days) */
71
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 7776000;
72
+ };
73
+ /** Dev timing constants (localnet/devnet) - matches Solana program dev mode */
74
+ declare const TIMING_DEV: {
75
+ /** Voting period (60 seconds) */
76
+ readonly VOTING_PERIOD_SECONDS: 60;
77
+ /** Hold period (1 second) */
78
+ readonly HOLD_PERIOD_SECONDS: 1;
79
+ /** Inactivity timeout (10 seconds) */
80
+ readonly INACTIVITY_TIMEOUT_SECONDS: 10;
81
+ /** Abandonment timeout (60 seconds) */
82
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 60;
83
+ /** Refund window (2 minutes) */
84
+ readonly REFUND_WINDOW_SECONDS: 120;
85
+ /** Pivot withdrawal window (10 seconds) */
86
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 10;
87
+ /** Early token cooling period (10 seconds) */
88
+ readonly EARLY_TOKEN_COOLING_PERIOD: 10;
89
+ /** Exit window period (20 seconds) */
90
+ readonly EXIT_WINDOW_PERIOD: 20;
91
+ /** Wallet update timelock (60 seconds) */
92
+ readonly WALLET_UPDATE_TIMELOCK: 60;
93
+ /** Minimum deadline duration (60 seconds) */
94
+ readonly MIN_DEADLINE_DURATION_SECONDS: 60;
95
+ /** Maximum deadline duration (90 days) */
96
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
97
+ /** Deadline grace period (5 seconds) */
98
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 5;
99
+ };
100
+ /**
101
+ * Get timing constants based on environment
102
+ * @param isDev - Whether to use dev mode constants (localnet/devnet)
103
+ */
104
+ declare function getTimingConstants(isDev?: boolean): {
105
+ /** Voting period (14 days) */
106
+ readonly VOTING_PERIOD_SECONDS: 1209600;
107
+ /** Hold period (7 days) */
108
+ readonly HOLD_PERIOD_SECONDS: 604800;
109
+ /** Inactivity timeout (90 days) */
110
+ readonly INACTIVITY_TIMEOUT_SECONDS: 7776000;
111
+ /** Abandonment timeout (90 days) */
112
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 7776000;
113
+ /** Refund window (14 days) */
114
+ readonly REFUND_WINDOW_SECONDS: 1209600;
115
+ /** Pivot withdrawal window (7 days) */
116
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604800;
117
+ /** Early token cooling period (24 hours) */
118
+ readonly EARLY_TOKEN_COOLING_PERIOD: 86400;
119
+ /** Exit window period (7 days) */
120
+ readonly EXIT_WINDOW_PERIOD: 604800;
121
+ /** Wallet update timelock (7 days) */
122
+ readonly WALLET_UPDATE_TIMELOCK: 604800;
123
+ /** Minimum deadline duration (7 days) */
124
+ readonly MIN_DEADLINE_DURATION_SECONDS: 604800;
125
+ /** Maximum deadline duration (90 days) */
126
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
127
+ /** Deadline grace period (90 days) */
128
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 7776000;
129
+ } | {
130
+ /** Voting period (60 seconds) */
131
+ readonly VOTING_PERIOD_SECONDS: 60;
132
+ /** Hold period (1 second) */
133
+ readonly HOLD_PERIOD_SECONDS: 1;
134
+ /** Inactivity timeout (10 seconds) */
135
+ readonly INACTIVITY_TIMEOUT_SECONDS: 10;
136
+ /** Abandonment timeout (60 seconds) */
137
+ readonly ABANDONMENT_TIMEOUT_SECONDS: 60;
138
+ /** Refund window (2 minutes) */
139
+ readonly REFUND_WINDOW_SECONDS: 120;
140
+ /** Pivot withdrawal window (10 seconds) */
141
+ readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 10;
142
+ /** Early token cooling period (10 seconds) */
143
+ readonly EARLY_TOKEN_COOLING_PERIOD: 10;
144
+ /** Exit window period (20 seconds) */
145
+ readonly EXIT_WINDOW_PERIOD: 20;
146
+ /** Wallet update timelock (60 seconds) */
147
+ readonly WALLET_UPDATE_TIMELOCK: 60;
148
+ /** Minimum deadline duration (60 seconds) */
149
+ readonly MIN_DEADLINE_DURATION_SECONDS: 60;
150
+ /** Maximum deadline duration (90 days) */
151
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
152
+ /** Deadline grace period (5 seconds) */
153
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 5;
154
+ };
155
+ /** @deprecated Use TIMING_PRODUCTION or TIMING_DEV instead */
45
156
  declare const TIMING: {
46
- /** Production voting period (14 days) */
157
+ /** Voting period (14 days) */
47
158
  readonly VOTING_PERIOD_SECONDS: 1209600;
48
- /** Production hold period (7 days) */
159
+ /** Hold period (7 days) */
49
160
  readonly HOLD_PERIOD_SECONDS: 604800;
50
161
  /** Inactivity timeout (90 days) */
51
162
  readonly INACTIVITY_TIMEOUT_SECONDS: 7776000;
@@ -55,12 +166,18 @@ declare const TIMING: {
55
166
  readonly REFUND_WINDOW_SECONDS: 1209600;
56
167
  /** Pivot withdrawal window (7 days) */
57
168
  readonly PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604800;
58
- /** Minimum TGE date (15 days from now) */
59
- readonly TGE_MIN_DAYS: 1296000;
60
- /** Maximum TGE date (90 days from now) */
61
- readonly TGE_MAX_DAYS: 7776000;
62
- /** Post-TGE holdback period (30 days) */
63
- readonly POST_TGE_HOLDBACK_DAYS: 2592000;
169
+ /** Early token cooling period (24 hours) */
170
+ readonly EARLY_TOKEN_COOLING_PERIOD: 86400;
171
+ /** Exit window period (7 days) */
172
+ readonly EXIT_WINDOW_PERIOD: 604800;
173
+ /** Wallet update timelock (7 days) */
174
+ readonly WALLET_UPDATE_TIMELOCK: 604800;
175
+ /** Minimum deadline duration (7 days) */
176
+ readonly MIN_DEADLINE_DURATION_SECONDS: 604800;
177
+ /** Maximum deadline duration (90 days) */
178
+ readonly MAX_DEADLINE_DURATION_SECONDS: number;
179
+ /** Deadline grace period (90 days) */
180
+ readonly DEADLINE_GRACE_PERIOD_SECONDS: 7776000;
64
181
  };
65
182
  declare const TIER_CONSTRAINTS: {
66
183
  /** Minimum number of tiers */
@@ -175,4 +292,4 @@ declare const TOKENOMICS: {
175
292
  readonly TOTAL_ALLOCATION_BPS: 10000;
176
293
  };
177
294
 
178
- export { GOVERNANCE, InvestmentTier, NFT, PROGRESSIVE_PRICING, SEEDS, TIER_CONSTRAINTS, TIER_MINIMUMS, TIER_TOKEN_MULTIPLIERS, TIER_VOTE_MULTIPLIERS, TIMING, TOKENOMICS, USDC, VALIDATION, findTierIndex, getTierFromAmount, getTokenMultiplier, getVoteMultiplier };
295
+ export { GOVERNANCE, InvestmentTier, NFT, PROGRESSIVE_PRICING, SEEDS, TIER_CONSTRAINTS, TIER_MINIMUMS, TIER_TOKEN_MULTIPLIERS, TIER_VOTE_MULTIPLIERS, TIMING, TIMING_DEV, TIMING_PRODUCTION, TOKENOMICS, USDC, VALIDATION, findTierIndex, getTierFromAmount, getTimingConstants, getTokenMultiplier, getVoteMultiplier };
@@ -5,6 +5,7 @@ var SEEDS = {
5
5
  INVESTMENT: "investment",
6
6
  VOTE: "vote",
7
7
  ESCROW: "escrow",
8
+ ESCROW_TOKEN: "escrow_token",
8
9
  PIVOT: "pivot",
9
10
  PIVOT_PROPOSAL: "pivot_proposal",
10
11
  TGE_ESCROW: "tge_escrow",
@@ -38,10 +39,10 @@ var VALIDATION = {
38
39
  /** Maximum pivot justification length */
39
40
  MAX_PIVOT_JUSTIFICATION_LEN: 512
40
41
  };
41
- var TIMING = {
42
- /** Production voting period (14 days) */
42
+ var TIMING_PRODUCTION = {
43
+ /** Voting period (14 days) */
43
44
  VOTING_PERIOD_SECONDS: 1209600,
44
- /** Production hold period (7 days) */
45
+ /** Hold period (7 days) */
45
46
  HOLD_PERIOD_SECONDS: 604800,
46
47
  /** Inactivity timeout (90 days) */
47
48
  INACTIVITY_TIMEOUT_SECONDS: 7776e3,
@@ -51,13 +52,49 @@ var TIMING = {
51
52
  REFUND_WINDOW_SECONDS: 1209600,
52
53
  /** Pivot withdrawal window (7 days) */
53
54
  PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604800,
54
- /** Minimum TGE date (15 days from now) */
55
- TGE_MIN_DAYS: 1296e3,
56
- /** Maximum TGE date (90 days from now) */
57
- TGE_MAX_DAYS: 7776e3,
58
- /** Post-TGE holdback period (30 days) */
59
- POST_TGE_HOLDBACK_DAYS: 2592e3
55
+ /** Early token cooling period (24 hours) */
56
+ EARLY_TOKEN_COOLING_PERIOD: 86400,
57
+ /** Exit window period (7 days) */
58
+ EXIT_WINDOW_PERIOD: 604800,
59
+ /** Wallet update timelock (7 days) */
60
+ WALLET_UPDATE_TIMELOCK: 604800,
61
+ /** Minimum deadline duration (7 days) */
62
+ MIN_DEADLINE_DURATION_SECONDS: 604800,
63
+ /** Maximum deadline duration (90 days) */
64
+ MAX_DEADLINE_DURATION_SECONDS: 90 * 24 * 60 * 60,
65
+ /** Deadline grace period (90 days) */
66
+ DEADLINE_GRACE_PERIOD_SECONDS: 7776e3
60
67
  };
68
+ var TIMING_DEV = {
69
+ /** Voting period (60 seconds) */
70
+ VOTING_PERIOD_SECONDS: 60,
71
+ /** Hold period (1 second) */
72
+ HOLD_PERIOD_SECONDS: 1,
73
+ /** Inactivity timeout (10 seconds) */
74
+ INACTIVITY_TIMEOUT_SECONDS: 10,
75
+ /** Abandonment timeout (60 seconds) */
76
+ ABANDONMENT_TIMEOUT_SECONDS: 60,
77
+ /** Refund window (2 minutes) */
78
+ REFUND_WINDOW_SECONDS: 120,
79
+ /** Pivot withdrawal window (10 seconds) */
80
+ PIVOT_WITHDRAWAL_WINDOW_SECONDS: 10,
81
+ /** Early token cooling period (10 seconds) */
82
+ EARLY_TOKEN_COOLING_PERIOD: 10,
83
+ /** Exit window period (20 seconds) */
84
+ EXIT_WINDOW_PERIOD: 20,
85
+ /** Wallet update timelock (60 seconds) */
86
+ WALLET_UPDATE_TIMELOCK: 60,
87
+ /** Minimum deadline duration (60 seconds) */
88
+ MIN_DEADLINE_DURATION_SECONDS: 60,
89
+ /** Maximum deadline duration (90 days) */
90
+ MAX_DEADLINE_DURATION_SECONDS: 90 * 24 * 60 * 60,
91
+ /** Deadline grace period (5 seconds) */
92
+ DEADLINE_GRACE_PERIOD_SECONDS: 5
93
+ };
94
+ function getTimingConstants(isDev = false) {
95
+ return isDev ? TIMING_DEV : TIMING_PRODUCTION;
96
+ }
97
+ var TIMING = TIMING_PRODUCTION;
61
98
  var TIER_CONSTRAINTS = {
62
99
  /** Minimum number of tiers */
63
100
  MIN_TIERS: 1,
@@ -189,6 +226,6 @@ var TOKENOMICS = {
189
226
  TOTAL_ALLOCATION_BPS: 1e4
190
227
  };
191
228
 
192
- export { GOVERNANCE, InvestmentTier, NFT, PROGRESSIVE_PRICING, SEEDS, TIER_CONSTRAINTS, TIER_MINIMUMS, TIER_TOKEN_MULTIPLIERS, TIER_VOTE_MULTIPLIERS, TIMING, TOKENOMICS, USDC, VALIDATION, findTierIndex, getTierFromAmount, getTokenMultiplier, getVoteMultiplier };
229
+ export { GOVERNANCE, InvestmentTier, NFT, PROGRESSIVE_PRICING, SEEDS, TIER_CONSTRAINTS, TIER_MINIMUMS, TIER_TOKEN_MULTIPLIERS, TIER_VOTE_MULTIPLIERS, TIMING, TIMING_DEV, TIMING_PRODUCTION, TOKENOMICS, USDC, VALIDATION, findTierIndex, getTierFromAmount, getTimingConstants, getTokenMultiplier, getVoteMultiplier };
193
230
  //# sourceMappingURL=index.js.map
194
231
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/constants/index.ts"],"names":["InvestmentTier"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Raise Constants\n *\n * Mirrors the on-chain program constants for client-side validation\n * and display purposes.\n */\n\n// =============================================================================\n// PDA Seeds\n// =============================================================================\n\nexport const SEEDS = {\n PROJECT: 'project',\n MILESTONE: 'milestone',\n INVESTMENT: 'investment',\n VOTE: 'vote',\n ESCROW: 'escrow',\n PIVOT: 'pivot',\n PIVOT_PROPOSAL: 'pivot_proposal',\n TGE_ESCROW: 'tge_escrow',\n TGE_ESCROW_VAULT: 'tge_escrow_vault',\n SCAM_REPORT: 'scam_report',\n ADMIN_CONFIG: 'admin-config',\n NFT_MINT: 'nft_mint',\n AUTHORITY: 'authority',\n FUTURE_ROUND_VAULT: 'future_round_vault',\n FUTURE_ROUND_STATE: 'future_round_state',\n // Multi-Round Fundraising seeds\n FUNDING_ROUND: 'funding_round',\n ROUND_ESCROW: 'round_escrow',\n INVESTOR_MS_VESTING: 'investor_ms_vesting',\n} as const;\n\n// =============================================================================\n// Validation Constants\n// =============================================================================\n\nexport const VALIDATION = {\n /** Minimum number of milestones per project */\n MIN_MILESTONES: 2,\n /** Maximum number of milestones per project */\n MAX_MILESTONES: 10,\n /** Milestone percentages must sum to this value */\n MILESTONE_PERCENTAGE_SUM: 100,\n /** Maximum funding buffer (110% of goal) */\n MAX_FUNDING_BUFFER_PERCENT: 110,\n /** Maximum metadata URI length */\n MAX_METADATA_URI_LENGTH: 200,\n /** Maximum pivot description length */\n MAX_PIVOT_DESCRIPTION_LEN: 256,\n /** Maximum pivot vision length */\n MAX_PIVOT_VISION_LEN: 512,\n /** Maximum pivot justification length */\n MAX_PIVOT_JUSTIFICATION_LEN: 512,\n} as const;\n\n// =============================================================================\n// Timing Constants (in seconds)\n// =============================================================================\n\nexport const TIMING = {\n /** Production voting period (14 days) */\n VOTING_PERIOD_SECONDS: 1_209_600,\n /** Production hold period (7 days) */\n HOLD_PERIOD_SECONDS: 604_800,\n /** Inactivity timeout (90 days) */\n INACTIVITY_TIMEOUT_SECONDS: 7_776_000,\n /** Abandonment timeout (90 days) */\n ABANDONMENT_TIMEOUT_SECONDS: 7_776_000,\n /** Refund window (14 days) */\n REFUND_WINDOW_SECONDS: 1_209_600,\n /** Pivot withdrawal window (7 days) */\n PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604_800,\n /** Minimum TGE date (15 days from now) */\n TGE_MIN_DAYS: 1_296_000,\n /** Maximum TGE date (90 days from now) */\n TGE_MAX_DAYS: 7_776_000,\n /** Post-TGE holdback period (30 days) */\n POST_TGE_HOLDBACK_DAYS: 2_592_000,\n} as const;\n\n// =============================================================================\n// Tier Configuration Constraints\n// =============================================================================\n\nexport const TIER_CONSTRAINTS = {\n /** Minimum number of tiers */\n MIN_TIERS: 1,\n /** Maximum number of tiers */\n MAX_TIERS: 10,\n /** Minimum tier amount (10 USDC in lamports) */\n MIN_TIER_AMOUNT: 10_000_000n,\n /** Minimum max_lots per tier */\n MIN_TIER_MAX_LOTS: 1,\n /** Minimum token ratio */\n MIN_TIER_TOKEN_RATIO: 1n,\n /** Minimum vote multiplier (100 = 1.0x) */\n MIN_TIER_VOTE_MULTIPLIER: 100,\n} as const;\n\n// =============================================================================\n// Progressive Pricing Constants (add-linear-progressive-pricing)\n// =============================================================================\n\nexport const PROGRESSIVE_PRICING = {\n /** Base price multiplier (10000 BPS = 1.0x) */\n PRICE_MULTIPLIER_BASE: 10000,\n /** Maximum price multiplier (20000 BPS = 2.0x) */\n MAX_MULTIPLIER_BPS: 20000,\n /** Percentage of ZEMYTH increment allocated to time-based component */\n TIME_ALLOCATION_PERCENT: 50,\n /** Percentage of ZEMYTH increment allocated to milestone spike component */\n MILESTONE_ALLOCATION_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// Investment Tiers (Legacy - kept for backwards compatibility)\n// =============================================================================\n\nexport enum InvestmentTier {\n Bronze = 'Bronze',\n Silver = 'Silver',\n Gold = 'Gold',\n Platinum = 'Platinum',\n Diamond = 'Diamond',\n}\n\n/** Investment tier minimum amounts in USDC lamports (6 decimals) - LEGACY */\nexport const TIER_MINIMUMS = {\n [InvestmentTier.Bronze]: 100_000_000n, // 100 USDC\n [InvestmentTier.Silver]: 500_000_000n, // 500 USDC\n [InvestmentTier.Gold]: 1_000_000_000n, // 1,000 USDC\n [InvestmentTier.Platinum]: 5_000_000_000n, // 5,000 USDC\n [InvestmentTier.Diamond]: 10_000_000_000n, // 10,000 USDC\n} as const;\n\n/** Vote weight multipliers (scaled by 100) - LEGACY */\nexport const TIER_VOTE_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100, // 1.0x\n [InvestmentTier.Silver]: 120, // 1.2x\n [InvestmentTier.Gold]: 150, // 1.5x\n [InvestmentTier.Platinum]: 200, // 2.0x\n [InvestmentTier.Diamond]: 300, // 3.0x\n} as const;\n\n/** Token allocation multipliers (same as vote multipliers) - LEGACY */\nexport const TIER_TOKEN_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100,\n [InvestmentTier.Silver]: 120,\n [InvestmentTier.Gold]: 150,\n [InvestmentTier.Platinum]: 200,\n [InvestmentTier.Diamond]: 300,\n} as const;\n\n/** Get tier from investment amount (in lamports) - LEGACY, use project.tiers instead */\nexport function getTierFromAmount(amount: bigint): InvestmentTier {\n if (amount >= TIER_MINIMUMS[InvestmentTier.Diamond]) return InvestmentTier.Diamond;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Platinum]) return InvestmentTier.Platinum;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Gold]) return InvestmentTier.Gold;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Silver]) return InvestmentTier.Silver;\n return InvestmentTier.Bronze;\n}\n\n/** Get vote multiplier for an investment amount - LEGACY */\nexport function getVoteMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_VOTE_MULTIPLIERS[tier] / 100;\n}\n\n/** Get token multiplier for an investment amount - LEGACY */\nexport function getTokenMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_TOKEN_MULTIPLIERS[tier] / 100;\n}\n\n/**\n * Find matching tier index for an investment amount (threshold-based)\n * Returns the highest tier where amount >= tier.amount\n */\nexport function findTierIndex(tiers: Array<{ amount: bigint }>, amount: bigint): number | null {\n for (let i = tiers.length - 1; i >= 0; i--) {\n if (amount >= tiers[i].amount) {\n return i;\n }\n }\n return null;\n}\n\n// =============================================================================\n// Voting and Governance\n// =============================================================================\n\nexport const GOVERNANCE = {\n /** Scam report threshold (30%) */\n SCAM_THRESHOLD_PERCENT: 30,\n /** Consecutive milestone failures before exit window eligible */\n CONSECUTIVE_FAILURES_THRESHOLD: 3,\n /** Milestone approval threshold (>50% weighted approval per whitepaper voting.md:100-101) */\n MILESTONE_APPROVAL_THRESHOLD_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// NFT Constants\n// =============================================================================\n\nexport const NFT = {\n /** NFT symbol */\n SYMBOL: 'ZRI',\n /** NFT name prefix */\n NAME_PREFIX: 'Zemyth Raise Investment #',\n /** Royalty basis points (2%) */\n ROYALTY_BASIS_POINTS: 200,\n} as const;\n\n// =============================================================================\n// USDC Constants\n// =============================================================================\n\nexport const USDC = {\n /** USDC decimals */\n DECIMALS: 6,\n /** Convert USDC to lamports */\n toAmount: (usdc: number): bigint => BigInt(Math.floor(usdc * 10 ** 6)),\n /** Convert lamports to USDC */\n fromAmount: (lamports: bigint): number => Number(lamports) / 10 ** 6,\n} as const;\n\n// =============================================================================\n// Tokenomics Allocation Constants\n// =============================================================================\n\nexport const TOKENOMICS = {\n /** Minimum investor allocation (20%) */\n MIN_INVESTOR_ALLOCATION_BPS: 2000,\n /** Minimum founder allocation (5%) if > 0 */\n MIN_FOUNDER_ALLOCATION_BPS: 500,\n /** Minimum LP token allocation (5%) */\n MIN_LP_TOKEN_ALLOCATION_BPS: 500,\n /** Minimum LP USDC allocation (5%) */\n MIN_LP_USDC_BPS: 500,\n /** Minimum Zemyth allocation (1%) */\n MIN_ZEMYTH_ALLOCATION_BPS: 100,\n /** Default Zemyth allocation (1%) */\n DEFAULT_ZEMYTH_ALLOCATION_BPS: 100,\n /** Minimum future round allocation (10%) if > 0 */\n MIN_FUTURE_ROUND_ALLOCATION_BPS: 1000,\n /** Maximum token symbol length */\n MAX_TOKEN_SYMBOL_LEN: 8,\n /** Total allocation must sum to this (100% = 10000 bps) */\n TOTAL_ALLOCATION_BPS: 10000,\n} as const;\n"]}
1
+ {"version":3,"sources":["../../src/constants/index.ts"],"names":["InvestmentTier"],"mappings":"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","file":"index.js","sourcesContent":["/**\n * Raise Constants\n *\n * Mirrors the on-chain program constants for client-side validation\n * and display purposes.\n */\n\n// =============================================================================\n// PDA Seeds\n// =============================================================================\n\nexport const SEEDS = {\n PROJECT: 'project',\n MILESTONE: 'milestone',\n INVESTMENT: 'investment',\n VOTE: 'vote',\n ESCROW: 'escrow',\n ESCROW_TOKEN: 'escrow_token',\n PIVOT: 'pivot',\n PIVOT_PROPOSAL: 'pivot_proposal',\n TGE_ESCROW: 'tge_escrow',\n TGE_ESCROW_VAULT: 'tge_escrow_vault',\n SCAM_REPORT: 'scam_report',\n ADMIN_CONFIG: 'admin-config',\n NFT_MINT: 'nft_mint',\n AUTHORITY: 'authority',\n FUTURE_ROUND_VAULT: 'future_round_vault',\n FUTURE_ROUND_STATE: 'future_round_state',\n // Multi-Round Fundraising seeds\n FUNDING_ROUND: 'funding_round',\n ROUND_ESCROW: 'round_escrow',\n INVESTOR_MS_VESTING: 'investor_ms_vesting',\n} as const;\n\n// =============================================================================\n// Validation Constants\n// =============================================================================\n\nexport const VALIDATION = {\n /** Minimum number of milestones per project */\n MIN_MILESTONES: 2,\n /** Maximum number of milestones per project */\n MAX_MILESTONES: 10,\n /** Milestone percentages must sum to this value */\n MILESTONE_PERCENTAGE_SUM: 100,\n /** Maximum funding buffer (110% of goal) */\n MAX_FUNDING_BUFFER_PERCENT: 110,\n /** Maximum metadata URI length */\n MAX_METADATA_URI_LENGTH: 200,\n /** Maximum pivot description length */\n MAX_PIVOT_DESCRIPTION_LEN: 256,\n /** Maximum pivot vision length */\n MAX_PIVOT_VISION_LEN: 512,\n /** Maximum pivot justification length */\n MAX_PIVOT_JUSTIFICATION_LEN: 512,\n} as const;\n\n// =============================================================================\n// Timing Constants (in seconds)\n// =============================================================================\n\n/** Production timing constants (mainnet) */\nexport const TIMING_PRODUCTION = {\n /** Voting period (14 days) */\n VOTING_PERIOD_SECONDS: 1_209_600,\n /** Hold period (7 days) */\n HOLD_PERIOD_SECONDS: 604_800,\n /** Inactivity timeout (90 days) */\n INACTIVITY_TIMEOUT_SECONDS: 7_776_000,\n /** Abandonment timeout (90 days) */\n ABANDONMENT_TIMEOUT_SECONDS: 7_776_000,\n /** Refund window (14 days) */\n REFUND_WINDOW_SECONDS: 1_209_600,\n /** Pivot withdrawal window (7 days) */\n PIVOT_WITHDRAWAL_WINDOW_SECONDS: 604_800,\n /** Early token cooling period (24 hours) */\n EARLY_TOKEN_COOLING_PERIOD: 86_400,\n /** Exit window period (7 days) */\n EXIT_WINDOW_PERIOD: 604_800,\n /** Wallet update timelock (7 days) */\n WALLET_UPDATE_TIMELOCK: 604_800,\n /** Minimum deadline duration (7 days) */\n MIN_DEADLINE_DURATION_SECONDS: 604_800,\n /** Maximum deadline duration (90 days) */\n MAX_DEADLINE_DURATION_SECONDS: 90 * 24 * 60 * 60,\n /** Deadline grace period (90 days) */\n DEADLINE_GRACE_PERIOD_SECONDS: 7_776_000,\n} as const;\n\n/** Dev timing constants (localnet/devnet) - matches Solana program dev mode */\nexport const TIMING_DEV = {\n /** Voting period (60 seconds) */\n VOTING_PERIOD_SECONDS: 60,\n /** Hold period (1 second) */\n HOLD_PERIOD_SECONDS: 1,\n /** Inactivity timeout (10 seconds) */\n INACTIVITY_TIMEOUT_SECONDS: 10,\n /** Abandonment timeout (60 seconds) */\n ABANDONMENT_TIMEOUT_SECONDS: 60,\n /** Refund window (2 minutes) */\n REFUND_WINDOW_SECONDS: 120,\n /** Pivot withdrawal window (10 seconds) */\n PIVOT_WITHDRAWAL_WINDOW_SECONDS: 10,\n /** Early token cooling period (10 seconds) */\n EARLY_TOKEN_COOLING_PERIOD: 10,\n /** Exit window period (20 seconds) */\n EXIT_WINDOW_PERIOD: 20,\n /** Wallet update timelock (60 seconds) */\n WALLET_UPDATE_TIMELOCK: 60,\n /** Minimum deadline duration (60 seconds) */\n MIN_DEADLINE_DURATION_SECONDS: 60,\n /** Maximum deadline duration (90 days) */\n MAX_DEADLINE_DURATION_SECONDS: 90 * 24 * 60 * 60,\n /** Deadline grace period (5 seconds) */\n DEADLINE_GRACE_PERIOD_SECONDS: 5,\n} as const;\n\n/**\n * Get timing constants based on environment\n * @param isDev - Whether to use dev mode constants (localnet/devnet)\n */\nexport function getTimingConstants(isDev: boolean = false) {\n return isDev ? TIMING_DEV : TIMING_PRODUCTION;\n}\n\n/** @deprecated Use TIMING_PRODUCTION or TIMING_DEV instead */\nexport const TIMING = TIMING_PRODUCTION;\n\n// =============================================================================\n// Tier Configuration Constraints\n// =============================================================================\n\nexport const TIER_CONSTRAINTS = {\n /** Minimum number of tiers */\n MIN_TIERS: 1,\n /** Maximum number of tiers */\n MAX_TIERS: 10,\n /** Minimum tier amount (10 USDC in lamports) */\n MIN_TIER_AMOUNT: 10_000_000n,\n /** Minimum max_lots per tier */\n MIN_TIER_MAX_LOTS: 1,\n /** Minimum token ratio */\n MIN_TIER_TOKEN_RATIO: 1n,\n /** Minimum vote multiplier (100 = 1.0x) */\n MIN_TIER_VOTE_MULTIPLIER: 100,\n} as const;\n\n// =============================================================================\n// Progressive Pricing Constants (add-linear-progressive-pricing)\n// =============================================================================\n\nexport const PROGRESSIVE_PRICING = {\n /** Base price multiplier (10000 BPS = 1.0x) */\n PRICE_MULTIPLIER_BASE: 10000,\n /** Maximum price multiplier (20000 BPS = 2.0x) */\n MAX_MULTIPLIER_BPS: 20000,\n /** Percentage of ZEMYTH increment allocated to time-based component */\n TIME_ALLOCATION_PERCENT: 50,\n /** Percentage of ZEMYTH increment allocated to milestone spike component */\n MILESTONE_ALLOCATION_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// Investment Tiers (Legacy - kept for backwards compatibility)\n// =============================================================================\n\nexport enum InvestmentTier {\n Bronze = 'Bronze',\n Silver = 'Silver',\n Gold = 'Gold',\n Platinum = 'Platinum',\n Diamond = 'Diamond',\n}\n\n/** Investment tier minimum amounts in USDC lamports (6 decimals) - LEGACY */\nexport const TIER_MINIMUMS = {\n [InvestmentTier.Bronze]: 100_000_000n, // 100 USDC\n [InvestmentTier.Silver]: 500_000_000n, // 500 USDC\n [InvestmentTier.Gold]: 1_000_000_000n, // 1,000 USDC\n [InvestmentTier.Platinum]: 5_000_000_000n, // 5,000 USDC\n [InvestmentTier.Diamond]: 10_000_000_000n, // 10,000 USDC\n} as const;\n\n/** Vote weight multipliers (scaled by 100) - LEGACY */\nexport const TIER_VOTE_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100, // 1.0x\n [InvestmentTier.Silver]: 120, // 1.2x\n [InvestmentTier.Gold]: 150, // 1.5x\n [InvestmentTier.Platinum]: 200, // 2.0x\n [InvestmentTier.Diamond]: 300, // 3.0x\n} as const;\n\n/** Token allocation multipliers (same as vote multipliers) - LEGACY */\nexport const TIER_TOKEN_MULTIPLIERS = {\n [InvestmentTier.Bronze]: 100,\n [InvestmentTier.Silver]: 120,\n [InvestmentTier.Gold]: 150,\n [InvestmentTier.Platinum]: 200,\n [InvestmentTier.Diamond]: 300,\n} as const;\n\n/** Get tier from investment amount (in lamports) - LEGACY, use project.tiers instead */\nexport function getTierFromAmount(amount: bigint): InvestmentTier {\n if (amount >= TIER_MINIMUMS[InvestmentTier.Diamond]) return InvestmentTier.Diamond;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Platinum]) return InvestmentTier.Platinum;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Gold]) return InvestmentTier.Gold;\n if (amount >= TIER_MINIMUMS[InvestmentTier.Silver]) return InvestmentTier.Silver;\n return InvestmentTier.Bronze;\n}\n\n/** Get vote multiplier for an investment amount - LEGACY */\nexport function getVoteMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_VOTE_MULTIPLIERS[tier] / 100;\n}\n\n/** Get token multiplier for an investment amount - LEGACY */\nexport function getTokenMultiplier(amount: bigint): number {\n const tier = getTierFromAmount(amount);\n return TIER_TOKEN_MULTIPLIERS[tier] / 100;\n}\n\n/**\n * Find matching tier index for an investment amount (threshold-based)\n * Returns the highest tier where amount >= tier.amount\n */\nexport function findTierIndex(tiers: Array<{ amount: bigint }>, amount: bigint): number | null {\n for (let i = tiers.length - 1; i >= 0; i--) {\n if (amount >= tiers[i].amount) {\n return i;\n }\n }\n return null;\n}\n\n// =============================================================================\n// Voting and Governance\n// =============================================================================\n\nexport const GOVERNANCE = {\n /** Scam report threshold (30%) */\n SCAM_THRESHOLD_PERCENT: 30,\n /** Consecutive milestone failures before exit window eligible */\n CONSECUTIVE_FAILURES_THRESHOLD: 3,\n /** Milestone approval threshold (>50% weighted approval per whitepaper voting.md:100-101) */\n MILESTONE_APPROVAL_THRESHOLD_PERCENT: 50,\n} as const;\n\n// =============================================================================\n// NFT Constants\n// =============================================================================\n\nexport const NFT = {\n /** NFT symbol */\n SYMBOL: 'ZRI',\n /** NFT name prefix */\n NAME_PREFIX: 'Zemyth Raise Investment #',\n /** Royalty basis points (2%) */\n ROYALTY_BASIS_POINTS: 200,\n} as const;\n\n// =============================================================================\n// USDC Constants\n// =============================================================================\n\nexport const USDC = {\n /** USDC decimals */\n DECIMALS: 6,\n /** Convert USDC to lamports */\n toAmount: (usdc: number): bigint => BigInt(Math.floor(usdc * 10 ** 6)),\n /** Convert lamports to USDC */\n fromAmount: (lamports: bigint): number => Number(lamports) / 10 ** 6,\n} as const;\n\n// =============================================================================\n// Tokenomics Allocation Constants\n// =============================================================================\n\nexport const TOKENOMICS = {\n /** Minimum investor allocation (20%) */\n MIN_INVESTOR_ALLOCATION_BPS: 2000,\n /** Minimum founder allocation (5%) if > 0 */\n MIN_FOUNDER_ALLOCATION_BPS: 500,\n /** Minimum LP token allocation (5%) */\n MIN_LP_TOKEN_ALLOCATION_BPS: 500,\n /** Minimum LP USDC allocation (5%) */\n MIN_LP_USDC_BPS: 500,\n /** Minimum Zemyth allocation (1%) */\n MIN_ZEMYTH_ALLOCATION_BPS: 100,\n /** Default Zemyth allocation (1%) */\n DEFAULT_ZEMYTH_ALLOCATION_BPS: 100,\n /** Minimum future round allocation (10%) if > 0 */\n MIN_FUTURE_ROUND_ALLOCATION_BPS: 1000,\n /** Maximum token symbol length */\n MAX_TOKEN_SYMBOL_LEN: 8,\n /** Total allocation must sum to this (100% = 10000 bps) */\n TOTAL_ALLOCATION_BPS: 10000,\n} as const;\n"]}