From dd56821f919495ae44a8c45b205b0b8a7d943bc1 Mon Sep 17 00:00:00 2001 From: Guille Date: Thu, 16 Jan 2025 14:55:47 +0100 Subject: [PATCH] feat: consolidate frontend docs (#2427) Co-authored-by: Guillermo Alejandro Gallardo Diez --- docs/2.build/4.web3-apps/frontend.md | 67 ------------------- .../4.web3-apps/integrate-contracts.md | 32 ++++++++- website/sidebars.js | 5 +- 3 files changed, 32 insertions(+), 72 deletions(-) delete mode 100644 docs/2.build/4.web3-apps/frontend.md diff --git a/docs/2.build/4.web3-apps/frontend.md b/docs/2.build/4.web3-apps/frontend.md deleted file mode 100644 index 2fae10c11c..0000000000 --- a/docs/2.build/4.web3-apps/frontend.md +++ /dev/null @@ -1,67 +0,0 @@ ---- -id: frontend -title: Frontends for Web3 dApps -sidebar_label: Frontends ---- - -When building decentralized web applications (dApps), developers have two primary options for connecting a front-end user interface (UI) to a smart contract backend. Each option offers distinct advantages and disadvantages, tailored to different project requirements and goals. - -- [Standard Web2 Frontend](#standard-web-2-frontend) -- [Decentralized Frontend](#decentralized-frontend-solutions) - -## Standard Web 2 Frontend - -While your user interface layer will remain centralized, the backend layer—including business logic and stored data—will be decentralized through smart contracts. This approach offers optimal convenience for most applications as it eliminates technical constraints and does not impact performance. However, if your requirement is for full decentralization across the entire stack, this configuration may not be suitable. - -**Pros:** - -- Develop a standard web application without any technical restrictions. -- Compatible with any framework and library combination. -- Supports server-side rendering with platforms like Next.js or SvelteKit. -- Delivers the best overall performance. - -**Cons:** - -- Requires hosting through a traditional Web 2 provider (e.g., Vercel, AWS). -- The user interface layer will not be decentralized. - -**How to Build:** - -When building a frontend that can connect with the NEAR blockchain using standard web2 tooling will require you to import two dependencies: - -- [NEAR API JS](../../4.tools/near-api.md) - A JavaScript API tool that allows frontend clients the ability to view and retrieve data directly from the blockchain. -- [Wallet Selector](../../4.tools/wallet-selector.md) - Wallet integration tool allowing developers to choose which wallets are supported and allows users to choose which wallet they would like to connect with. - -:::tip - -[Checkout this article](integrate-contracts.md) to learn how to integrate smart contracts to your frontend, using [Wallet Selector](../../4.tools/wallet-selector.md) and [NEAR API JS](../../4.tools/near-api.md). - -::: - -## Decentralized Frontend Solutions - -If you need full decentralization of your entire stack, this option is ideal. However, consider the possible technical constraints, such as the absence of server-side rendering or meta frameworks like Next.js. - -Although the ecosystem for developing decentralized frontends is still maturing, here are some notable projects for you to evaluate and consider: - -|Name|
Description
| -|--------|------| -| [**IPFS**](https://docs.ipfs.tech/how-to/websites-on-ipfs/single-page-website/)| A peer-to-peer hypermedia protocol designed to preserve and grow humanity's knowledge by making the web upgradeable, resilient, and more open. | -| [**Fleek**](https://docs.fleek.co/tutorials/hosting/)| Hosts websites on IPFS with a user-friendly interface and continuous deployment from popular repositories. | -| [**Arweave**](https://www.arweave.org/build) | Arweave lets you build quickly and simply with permanent storage. You can store anything from files to fully decentralized web applications. | -| [**Web4**](https://web4.near.page/) | Web4 is a new way to distribute decentralized apps on NEAR Protocol. Deploy single WASM smart contract to deploy an entire web application.| -| [**NEAR Social** ***(aka B.O.S. Components)***](https://near.social) | An experimental platform that allows users to build and deploy multi-chain decentralized UI experiences. | - -**Pros:** - -- Decentralized frontends are less susceptible to single points of failure, making them more resistant to attacks and server downtimes -- By decentralizing the hosting of your frontend, you minimize the risk of content being censored or blocked by centralized authorities. -- Users might trust a decentralized application more, knowing that it operates on a transparent and immutable blockchain. -- Data displayed on the frontend is more likely to be accurate and tamper-proof since it's typically fetched directly from the blockchain. - -**Cons:** - -- Implementing a decentralized frontend can be more complex than traditional web development, requiring knowledge of specific technologies like IPFS, Arweave, or blockchain interactions. -- Decentralized networks can face issues such as latency or lower speeds compared to traditional centralized servers, potentially affecting user experience. -- The ecosystem for developing decentralized frontends is still maturing, which means there might be fewer tools and libraries available compared to traditional web development. -- While decentralized storage costs have been decreasing, they can still be higher than traditional hosting, especially if the dApp generates a lot of data transactions. diff --git a/docs/2.build/4.web3-apps/integrate-contracts.md b/docs/2.build/4.web3-apps/integrate-contracts.md index 4fcda9f50f..38ecd34dcd 100644 --- a/docs/2.build/4.web3-apps/integrate-contracts.md +++ b/docs/2.build/4.web3-apps/integrate-contracts.md @@ -18,12 +18,42 @@ Using those tools you will implement the following flow: 2. Ask the user to **sign-in** using a NEAR wallet. 2. **Call methods** in the contract. -### Naxios + +:::warning NEAR BOS + + The project known as NEAR Blockchain Operating System (NEAR BOS) has been deprecated, but you can find its documentation on [this link](https://deprecated-near.github.io/legacy-docs/components/what-is) + +::: + +
+ + Alternatives to `near-api-js` You can optionally use [Naxios](https://wpdas.gitbook.io/naxios). A promise-based NEAR Contract and NEAR Wallet Client for browser. Naxios was designed to facilitate the React / Next.js integration with NEAR Blockchain and avoid the boilerplate of setting up a wallet and contract. +
+ + +
+ + Decentralized Frontend Solutions + +If you need full decentralization of your entire stack, this option is ideal. However, consider the possible technical constraints, such as the absence of server-side rendering or meta frameworks like Next.js. + +Although the ecosystem for developing decentralized frontends is still maturing, here are some notable projects for you to evaluate and consider: + +| Name |
Description
| +|-------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------| +| [**IPFS**](https://docs.ipfs.tech/how-to/websites-on-ipfs/single-page-website/) | A peer-to-peer hypermedia protocol designed to preserve and grow humanity's knowledge by making the web upgradeable, resilient, and more open. | +| [**Fleek**](https://docs.fleek.co/tutorials/hosting/) | Hosts websites on IPFS with a user-friendly interface and continuous deployment from popular repositories. | +| [**Arweave**](https://www.arweave.org/build) | Arweave lets you build quickly and simply with permanent storage. You can store anything from files to fully decentralized web applications. | +| [**Web4**](https://web4.near.page/) | Web4 is a new way to distribute decentralized apps on NEAR Protocol. Deploy single WASM smart contract to deploy an entire web application. | +| [**B.O.S. Components**](https://deprecated-near.github.io/legacy-docs/components/what-is) | An experimental platform that allows users to build and deploy multi-chain decentralized UI experiences. | + +
+ --- ## Adding NEAR API JS and Wallet Selector diff --git a/website/sidebars.js b/website/sidebars.js index 023eb02c25..715815de63 100644 --- a/website/sidebars.js +++ b/website/sidebars.js @@ -194,10 +194,7 @@ const sidebar = { "Building Web3 Applications": [ "build/web3-apps/quickstart", { - type: 'category', - label: 'Frontends', - link: { type: 'doc', id: 'build/web3-apps/frontend' }, - items: [ + "Frontends": [ "build/web3-apps/integrate-contracts", ] },