Synopsis
This governance proposal outlines funding the integration of the V4 Juicebox (omnichain) contracts on juicebox.money (JBM).
Motivation
For an overview of the project plan and technical details, see Rationale section.
Since being funded in Oct 2023, the #protocol team has been hard at work on Bananapus, a.k.a "The Juicebox V4 Contracts".
There are currently two web applications being built on the new contracts: Bannyverse and Revnet. But JBM remains the primary gateway into Juicebox, and thanks to Strath and Wraeth’s recent work, the UX continues to improve.
But sooner or later, JBM will need to migrate to V4. We propose that the time is now.
V4 contracts will be a huge win for juicebox.money. It will eventually allow projects to be launched and operated across multiple chains, allowing users to pay projects on gas-efficient chains and use the tokens they gain across all other chains the project is launched on. See more. L2/Multichain Juicebox has been a (if not, the most) heavily requested feature by the Juicebox community (see Appendix section at the end of this document).
Aeolian and Johnny D, as the developers behind the V2/V3 Juicebox contracts integration on juicebox.money, understand the depth of the task.
Specification
US$12k per cycle for 7 cycles to @v4-frontend-developers Juicebox project.
Rationale
Integrating V4 into JBM is no small feat. We propose a 3-phase implementation plan.
This proposal doesn't make guarantees about timelines or completion of specific milestones. We'll endeavor to complete work as quickly and effectively as possible, but the complexity and uncertainty inherent in this implementation means that milestones are hard to define and timelines are inaccurate. We commit to providing weekly status updates in Discord. If JBDAO is unhappy with the progress, anyone is free to submit a cancellation to this proposal.
Phase 1: V4 mainnet support Goal: get V4 working on JBM, on mainnet. The initial phase aims to support V4 projects launched on mainnet, close-to feature parity with the existing JBM. This allows us to set a technical foundation for Phase 2, and usher incoming JB projects to V4 as soon as possible.
JBM V4 mainnet projects will be indicated as "beta".
Phase 2: L2 Goal: allow projects to launch on L2, and have an L2 project page. This phase brings JBM into the world of L2s. Projects will be able to launch on a single L2, and collect payments and manage their treasuries on a single L2.
This is possible on Revnet.app today, built by Aeolian. See these links for an example: https://revnet.app/sepolia/net/2, https://revnet.app/opsepolia/net/2).
It does not enable full cross-chain/omnichain functionality; we'll support projects with a single treasury on a single chain, not projects with multiple treasuries across multiple chains. This will come in Phase 3.
Phase 3: Omnichain Goal: expose the full power of V4, with omnichain support. While we’ve teased out some of the technical details and UX with the Revnet project, there’s still much to investigate and solidify. If we make it to this phase, we're committed to working with UX specialists alongside #protocol team to find the best path forward.
Given the complexities and unknowns at hand, it’s difficult to commit to accurate timelines. This proposal commits to fulfilling Phase 1, and spending any remaining time on Phase 2.
Phase 1 technical implementation plan
In recent weeks, we have devised a plan to deliver Phase 1, outlined as follows:
- Remove underused/legacy features from JBM (Done)
- Reduce reliance on database in favor of subgraph (Done)
- Complete Ethers V5 -> V6 upgrade (In review, credits Wraeth)
- Reorganise codebase to be version-first (in progress)
- Prepare codebase for wagmi and V4
- Scope all existing React providers to existing pages
- Remove providers from global scope (e.g. Supabase)
- Remove all uses of the database, besides Project Search. Then purge unused data.
- Create proof-of-concept V4 project page, at juicebox.money/v4/mainnet/:projectId
- Using wagmi library, juice-sdk-v4, making any upgrades to juice-sdk-v4 as necessary.
- Flesh out core V4 project page features
- Rewrite all v2v3 components to be v4-compatible
- Implement V4 project settings
- Implement project creation in V4
Note that the UI will remain roughly the same as v2/v3, with accommodations made for V4 as necessary.
Phase 2 technical implementation plan
- Upgrade Juice SDK to use latest wagmi/viem (Done)
- Support L2 in Juice SDK (Done)
- Subgraph deployments to all supported chains (outside this proposal's scope)
- Create 'aggregator' API endpoints to aggregate subgraph queries across chains (e.g. build one endpoint to get all JB projects across chains)
- Add ability to 'hotswap' subgraph URLs based on the given chain
- Add support to L2 routing (/base/p/2, /arbitrum/p/69)
- Add "switch network" to all transaction buttons
- Add UI to indicate a project's chain.
Risks
- We may discover the feasibility to be more complicated than anticipated - Changes in contracts may result in drawn out frontend development times
Timeline
ASAP, ending in 7 cycles.
Appendix
--- nance-actions
- type: Payout
uuid: a95c56a36102471bac6ebe2dcec92c42
payload:
type: project
count: "7"
amountUSD: "12000"
project: 689
address: "0xAF28bcB48C40dBC86f52D459A6562F658fc94B1e"