From 8f2a2048764f60b66afc45d0b373de3dc2bdd442 Mon Sep 17 00:00:00 2001 From: Dhaiwat Date: Wed, 28 Aug 2024 23:32:08 +0530 Subject: [PATCH] feat: make vite the default `create-fuels` template --- .changeset/odd-coats-tease.md | 5 + apps/create-fuels-counter-guide/.env.example | 4 +- apps/create-fuels-counter-guide/.eslintignore | 1 - .../create-fuels-counter-guide/.eslintrc.json | 4 - apps/create-fuels-counter-guide/.gitignore | 52 +- apps/create-fuels-counter-guide/README.md | 2 +- .../eslint.config.js | 26 + .../fuels.config.ts | 6 +- apps/create-fuels-counter-guide/index.html | 16 + .../create-fuels-counter-guide/next.config.js | 6 - apps/create-fuels-counter-guide/package.json | 27 +- .../postcss.config.js | 4 +- .../src/app/layout.tsx | 85 -- .../src/components/Layout.tsx | 15 +- .../src/components/Link.tsx | 8 +- .../src/components/WalletDisplay.tsx | 2 +- .../src/hooks/useActiveWallet.tsx | 4 +- .../src/hooks/useBrowserWallet.tsx | 2 +- .../src/hooks/useBurnerWallet.tsx | 2 +- .../src/hooks/useFaucet.tsx | 2 +- .../src/{styles/globals.css => index.css} | 0 apps/create-fuels-counter-guide/src/lib.ts | 8 +- apps/create-fuels-counter-guide/src/main.tsx | 29 + .../src/routeTree.gen.ts | 118 +++ .../src/routes/__root.tsx | 76 ++ .../page.tsx => routes/faucet.lazy.tsx} | 17 +- .../{app/page.tsx => routes/index.lazy.tsx} | 42 +- .../page.tsx => routes/predicate.lazy.tsx} | 31 +- .../page.tsx => routes/script.lazy.tsx} | 27 +- .../src/sway-api/contract-ids.json | 2 +- .../src/vite-env.d.ts | 1 + .../sway-programs/Forc.toml | 2 +- .../sway-programs/fuel-toolchain.toml | 4 +- ...{tailwind.config.ts => tailwind.config.js} | 8 +- .../test/contract.test.ts | 60 ++ .../test/predicate.test.ts | 69 ++ .../test/script.test.ts | 42 + .../tsconfig.app.json | 25 + apps/create-fuels-counter-guide/tsconfig.json | 30 +- .../tsconfig.node.json | 22 + apps/create-fuels-counter-guide/vercel.json | 3 + .../create-fuels-counter-guide/vite.config.ts | 14 + .../vitest.config.mts | 5 + .../deploying-a-dapp-to-testnet.md | 20 +- .../src/guide/creating-a-fuel-dapp/index.md | 32 +- .../src/guide/creating-a-fuel-dapp/options.md | 2 +- .../working-with-predicates.md | 4 +- packages/create-fuels/src/lib/setupProgram.ts | 2 +- playwright-tests/create-fuels.test.ts | 2 +- pnpm-lock.yaml | 824 ++++++++++++++---- scripts/tests-ui.sh | 2 +- 51 files changed, 1347 insertions(+), 449 deletions(-) create mode 100644 .changeset/odd-coats-tease.md delete mode 100644 apps/create-fuels-counter-guide/.eslintignore delete mode 100644 apps/create-fuels-counter-guide/.eslintrc.json create mode 100644 apps/create-fuels-counter-guide/eslint.config.js create mode 100644 apps/create-fuels-counter-guide/index.html delete mode 100644 apps/create-fuels-counter-guide/next.config.js delete mode 100644 apps/create-fuels-counter-guide/src/app/layout.tsx rename apps/create-fuels-counter-guide/src/{styles/globals.css => index.css} (100%) create mode 100644 apps/create-fuels-counter-guide/src/main.tsx create mode 100644 apps/create-fuels-counter-guide/src/routeTree.gen.ts create mode 100644 apps/create-fuels-counter-guide/src/routes/__root.tsx rename apps/create-fuels-counter-guide/src/{app/faucet/page.tsx => routes/faucet.lazy.tsx} (85%) rename apps/create-fuels-counter-guide/src/{app/page.tsx => routes/index.lazy.tsx} (82%) rename apps/create-fuels-counter-guide/src/{app/predicate/page.tsx => routes/predicate.lazy.tsx} (89%) rename apps/create-fuels-counter-guide/src/{app/script/page.tsx => routes/script.lazy.tsx} (76%) create mode 100644 apps/create-fuels-counter-guide/src/vite-env.d.ts rename apps/create-fuels-counter-guide/{tailwind.config.ts => tailwind.config.js} (62%) create mode 100644 apps/create-fuels-counter-guide/test/contract.test.ts create mode 100644 apps/create-fuels-counter-guide/test/predicate.test.ts create mode 100644 apps/create-fuels-counter-guide/test/script.test.ts create mode 100644 apps/create-fuels-counter-guide/tsconfig.app.json create mode 100644 apps/create-fuels-counter-guide/tsconfig.node.json create mode 100644 apps/create-fuels-counter-guide/vercel.json create mode 100644 apps/create-fuels-counter-guide/vite.config.ts create mode 100644 apps/create-fuels-counter-guide/vitest.config.mts diff --git a/.changeset/odd-coats-tease.md b/.changeset/odd-coats-tease.md new file mode 100644 index 00000000000..0a8f92ff407 --- /dev/null +++ b/.changeset/odd-coats-tease.md @@ -0,0 +1,5 @@ +--- +"create-fuels": patch +--- + +feat: make vite the default `create-fuels` template diff --git a/apps/create-fuels-counter-guide/.env.example b/apps/create-fuels-counter-guide/.env.example index 2c6ac505fa1..e9a1ac1f1de 100644 --- a/apps/create-fuels-counter-guide/.env.example +++ b/apps/create-fuels-counter-guide/.env.example @@ -1,2 +1,2 @@ -NEXT_PUBLIC_FUEL_NODE_PORT=4000 -NEXT_PUBLIC_DAPP_ENVIRONMENT=local \ No newline at end of file +VITE_FUEL_NODE_PORT=4000 +VITE_DAPP_ENVIRONMENT=local \ No newline at end of file diff --git a/apps/create-fuels-counter-guide/.eslintignore b/apps/create-fuels-counter-guide/.eslintignore deleted file mode 100644 index 3cf1c8470fb..00000000000 --- a/apps/create-fuels-counter-guide/.eslintignore +++ /dev/null @@ -1 +0,0 @@ -src/sway-api diff --git a/apps/create-fuels-counter-guide/.eslintrc.json b/apps/create-fuels-counter-guide/.eslintrc.json deleted file mode 100644 index 297609cdfb6..00000000000 --- a/apps/create-fuels-counter-guide/.eslintrc.json +++ /dev/null @@ -1,4 +0,0 @@ -{ - "extends": "next/core-web-vitals", - "ignoreDuringBuilds": true -} diff --git a/apps/create-fuels-counter-guide/.gitignore b/apps/create-fuels-counter-guide/.gitignore index 9e82727fa10..aff61832060 100644 --- a/apps/create-fuels-counter-guide/.gitignore +++ b/apps/create-fuels-counter-guide/.gitignore @@ -1,37 +1,27 @@ -# dependencies -/node_modules -/.pnp -.pnp.js -.yarn/install-state.gz - -# testing -/coverage - -# next.js -/.next/ -/out/ - -# production -/build - -# misc -.DS_Store -*.pem - -# debug +# Logs +logs +*.log npm-debug.log* yarn-debug.log* yarn-error.log* - -# local env files -.env*.local - -# vercel -.vercel - -# typescript -*.tsbuildinfo -next-env.d.ts +pnpm-debug.log* +lerna-debug.log* + +node_modules +dist +dist-ssr +*.local + +# Editor directories and files +.vscode/* +!.vscode/extensions.json +.idea +.DS_Store +*.suo +*.ntvs* +*.njsproj +*.sln +*.sw? .fuels diff --git a/apps/create-fuels-counter-guide/README.md b/apps/create-fuels-counter-guide/README.md index 6232b0ce71d..1177ed9b02b 100644 --- a/apps/create-fuels-counter-guide/README.md +++ b/apps/create-fuels-counter-guide/README.md @@ -1,4 +1,4 @@ -This is a [Next.js](https://nextjs.org/) project bootstrapped with [`create-fuels`](https://github.com/FuelLabs/fuels-ts/tree/master/packages/create-fuels). +This is a [Vite](https://vitejs.dev/) project bootstrapped with [`create-fuels`](https://github.com/FuelLabs/fuels-ts/tree/master/packages/create-fuels). ## Getting Started diff --git a/apps/create-fuels-counter-guide/eslint.config.js b/apps/create-fuels-counter-guide/eslint.config.js new file mode 100644 index 00000000000..c4bc8f33c0b --- /dev/null +++ b/apps/create-fuels-counter-guide/eslint.config.js @@ -0,0 +1,26 @@ +import js from '@eslint/js' +import globals from 'globals' +import reactHooks from 'eslint-plugin-react-hooks' +import reactRefresh from 'eslint-plugin-react-refresh' +import tseslint from 'typescript-eslint' + +export default tseslint.config({ + extends: [js.configs.recommended, ...tseslint.configs.recommended], + files: ['**/*.{ts,tsx}'], + ignores: ['dist'], + languageOptions: { + ecmaVersion: 2020, + globals: globals.browser, + }, + plugins: { + 'react-hooks': reactHooks, + 'react-refresh': reactRefresh, + }, + rules: { + ...reactHooks.configs.recommended.rules, + 'react-refresh/only-export-components': [ + 'warn', + { allowConstantExport: true }, + ], + }, +}) diff --git a/apps/create-fuels-counter-guide/fuels.config.ts b/apps/create-fuels-counter-guide/fuels.config.ts index 6d73104e54a..1c0ea70a379 100644 --- a/apps/create-fuels-counter-guide/fuels.config.ts +++ b/apps/create-fuels-counter-guide/fuels.config.ts @@ -1,19 +1,21 @@ // #region fuels-config-file-env import { createConfig } from 'fuels'; import dotenv from 'dotenv'; -import { NODE_URL } from '@/lib'; +import { NODE_URL } from './src/lib'; dotenv.config({ path: ['.env.local', '.env'], }); // If your node is running on a port other than 4000, you can set it here -const fuelCorePort = +(process.env.NEXT_PUBLIC_FUEL_NODE_PORT as string) || 4000; +const fuelCorePort = +(process.env.VITE_FUEL_NODE_PORT as string) || 4000; export default createConfig({ workspace: './sway-programs', // Path to your Sway workspace output: './src/sway-api', // Where your generated types will be saved fuelCorePort, providerUrl: NODE_URL, + fuelCorePath: 'fuels-core', + forcPath: 'fuels-forc', }); // #endregion fuels-config-file-env \ No newline at end of file diff --git a/apps/create-fuels-counter-guide/index.html b/apps/create-fuels-counter-guide/index.html new file mode 100644 index 00000000000..999540e98ed --- /dev/null +++ b/apps/create-fuels-counter-guide/index.html @@ -0,0 +1,16 @@ + + + + + + + + Fuel dApp + + + +
+ + + + \ No newline at end of file diff --git a/apps/create-fuels-counter-guide/next.config.js b/apps/create-fuels-counter-guide/next.config.js deleted file mode 100644 index 91ef62f0db5..00000000000 --- a/apps/create-fuels-counter-guide/next.config.js +++ /dev/null @@ -1,6 +0,0 @@ -/** @type {import('next').NextConfig} */ -const nextConfig = { - reactStrictMode: true, -}; - -module.exports = nextConfig; diff --git a/apps/create-fuels-counter-guide/package.json b/apps/create-fuels-counter-guide/package.json index 78726acec3b..ba8a787343a 100644 --- a/apps/create-fuels-counter-guide/package.json +++ b/apps/create-fuels-counter-guide/package.json @@ -1,12 +1,14 @@ { "name": "create-fuels-counter-guide", - "version": "0.1.0", "private": true, + "version": "0.1.0", + "type": "module", "scripts": { - "original:dev": "next dev", - "original:build": "next build", + "test": "vitest", + "original:dev": "vite", + "original:build": "tsc -b && vite build", "original:start": "next start", - "original:lint": "next lint", + "original:lint": "eslint .", "fuels:build": "fuels build", "fuels:dev": "fuels dev", "postbuild": "run-s fuels:build original:build" @@ -14,26 +16,33 @@ "dependencies": { "@fuels/connectors": "^0.26.0", "@fuels/react": "^0.26.0", - "fuels": "workspace:*", "@tanstack/react-query": "^5.52.1", + "@tanstack/react-router": "^1.48.1", "@wagmi/connectors": "^5.1.7", "@wagmi/core": "^2.13.4", "dotenv": "^16.4.5", - "next": "14.2.6", + "fuels": "workspace:*", "react": "^18.3.1", "react-dom": "^18.3.1", "react-hot-toast": "^2.4.1", "react-use": "^17.5.1" }, "devDependencies": { - "@types/node": "^22.2.0", + "@eslint/js": "^9.9.1", + "@tanstack/router-plugin": "^1.47.0", "@types/react": "^18.3.4", "@types/react-dom": "^18.3", + "@vitejs/plugin-react-swc": "^3.5.0", "autoprefixer": "^10.4.20", "eslint": "^8.57.0", - "eslint-config-next": "14.2.6", + "eslint-plugin-react-hooks": "^4.6.2", + "eslint-plugin-react-refresh": "^0.4.11", + "globals": "^15.9.0", "postcss": "^8", "tailwindcss": "^3.4.10", - "typescript": "~5.4.5" + "typescript": "~5.4.5", + "typescript-eslint": "^8.0.0", + "vite": "^5.4.2", + "vitest": "^1.6.0" } } diff --git a/apps/create-fuels-counter-guide/postcss.config.js b/apps/create-fuels-counter-guide/postcss.config.js index 12a703d900d..2e7af2b7f1a 100644 --- a/apps/create-fuels-counter-guide/postcss.config.js +++ b/apps/create-fuels-counter-guide/postcss.config.js @@ -1,6 +1,6 @@ -module.exports = { +export default { plugins: { tailwindcss: {}, autoprefixer: {}, }, -}; +} diff --git a/apps/create-fuels-counter-guide/src/app/layout.tsx b/apps/create-fuels-counter-guide/src/app/layout.tsx deleted file mode 100644 index 74d0a2f1be4..00000000000 --- a/apps/create-fuels-counter-guide/src/app/layout.tsx +++ /dev/null @@ -1,85 +0,0 @@ -"use client"; - -import { Layout } from "@/components/Layout"; -import "@/styles/globals.css"; -import { FuelProvider } from "@fuels/react"; -import React, { ReactNode, useEffect, useMemo, useState } from "react"; -import { QueryClient, QueryClientProvider } from "@tanstack/react-query"; -import { Provider } from "fuels"; -import { - BakoSafeConnector, - BurnerWalletConnector, - FuelWalletConnector, - FuelWalletDevelopmentConnector, - FueletWalletConnector, - WalletConnectConnector, -} from "@fuels/connectors"; -import { NODE_URL } from "@/lib"; -import { ActiveWalletProvider } from "@/hooks/useActiveWallet"; - -/** - * react-query is a peer dependency of @fuels/react, so we set it up here. - * See https://docs.fuel.network/docs/wallet/dev/getting-started/#installation-1 - */ -const queryClient = new QueryClient(); - -interface RootLayoutProps { - children: ReactNode; -} - -export default function RootLayout({ children }: RootLayoutProps) { - const [isMounted, setIsMounted] = useState(false); - - /** - * Create a Provider instance. - * We memoize it to avoid creating a new instance on every render. - */ - const providerToUse = useMemo(() => Provider.create(NODE_URL), [NODE_URL]); - - useEffect(() => { - setIsMounted(true); - }, []); - - // Only render the component if the page has been mounted. - if (!isMounted) return null; - - return ( - - - - Fuel dApp - - - - - - - {children} - - - - - - - ); -} diff --git a/apps/create-fuels-counter-guide/src/components/Layout.tsx b/apps/create-fuels-counter-guide/src/components/Layout.tsx index 5af8341e045..9874fc97d34 100644 --- a/apps/create-fuels-counter-guide/src/components/Layout.tsx +++ b/apps/create-fuels-counter-guide/src/components/Layout.tsx @@ -1,13 +1,12 @@ import toast, { Toaster } from "react-hot-toast"; import { Link } from "./Link"; import { Button } from "./Button"; -import { CURRENT_ENVIRONMENT, NODE_URL, TESTNET_FAUCET_LINK } from "@/lib"; +import { CURRENT_ENVIRONMENT, NODE_URL, TESTNET_FAUCET_LINK } from "../lib"; import { useConnectUI, useDisconnect } from "@fuels/react"; import { WalletDisplay } from "./WalletDisplay"; -import { useBrowserWallet } from "@/hooks/useBrowserWallet"; -import { useActiveWallet } from "@/hooks/useActiveWallet"; -import { useFaucet } from "@/hooks/useFaucet"; -import Head from "next/head"; +import { useBrowserWallet } from "../hooks/useBrowserWallet"; +import { useActiveWallet } from "../hooks/useActiveWallet"; +import { useFaucet } from "../hooks/useFaucet"; import { bn } from "fuels"; export const Layout = ({ children }: { children: React.ReactNode }) => { @@ -73,12 +72,8 @@ export const Layout = ({ children }: { children: React.ReactNode }) => { return ( <> - - Fuel App - - -
+