Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ethereum/esp-website
Website for the Ethereum Foundation's Ecosystem Support Program (ESP):
https://github.com/ethereum/esp-website
blockchain ethereum gatsby react
Last synced: 3 days ago
JSON representation
Website for the Ethereum Foundation's Ecosystem Support Program (ESP):
- Host: GitHub
- URL: https://github.com/ethereum/esp-website
- Owner: ethereum
- License: mit
- Created: 2019-11-19T06:07:58.000Z (about 5 years ago)
- Default Branch: master
- Last Pushed: 2024-12-27T15:41:07.000Z (27 days ago)
- Last Synced: 2025-01-06T10:04:48.946Z (17 days ago)
- Topics: blockchain, ethereum, gatsby, react
- Language: TypeScript
- Homepage: https://esp.ethereum.foundation/
- Size: 60.2 MB
- Stars: 50
- Watchers: 8
- Forks: 36
- Open Issues: 11
-
Metadata Files:
- Readme: README.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
[![Netlify Status](https://api.netlify.com/api/v1/badges/dc4a526c-394c-4001-8452-b63ce3c1c77b/deploy-status)](https://app.netlify.com/sites/ecosystem-support/deploys)
Ethereum Ecosystem Support ProgramThe Ethereum Ecosystem Support Program exists to provide both financial and non-financial support to projects and entities within the greater Ethereum community, in order to accelerate the growth of the ecosystem. The Ecosystem Support Program is an expansion of the original Ethereum Grants Program which mainly focused on financial support. Our focus is on deploying our resources where they will have the biggest impact.
This repository holds the codebase to our website, [esp.ethereum.foundation](https://esp.ethereum.foundation)
## Stack
The main stack used in the project includes:
- [Next.js](https://nextjs.org/).
- [TypeScript](https://www.typescriptlang.org/).
- [ChakraUI](https://chakra-ui.com/) as component library.
- [react-hook-form](https://react-hook-form.com/) to validate forms.
- [Framer Motion](https://www.framer.com/motion/) to animate buttons.
- [ESLint](https://eslint.org/) and [Prettier](https://prettier.io/) for linting and code formatting.## Local development
The project is bootstrapped with [`create-next-app`](https://github.com/vercel/next.js/tree/canary/packages/create-next-app), with a custom scaffolding.
### Getting Started
First, run the development server:
```bash
npm run dev
# or
yarn dev
```Open [http://localhost:3000](http://localhost:3000) with your browser to see the result.
You can start editing the page by modifying `pages/index.tsx`. The page auto-updates as you edit the file.
[API routes](https://nextjs.org/docs/api-routes/introduction) can be accessed on [http://localhost:3000/api/hello](http://localhost:3000/api/hello). This endpoint can be edited in `pages/api/hello.ts`.
The `pages/api` directory is mapped to `/api/*`. Files in this directory are treated as [API routes](https://nextjs.org/docs/api-routes/introduction) instead of React pages.
### testing w/hCaptcha locally
We can use [hCaptcha testing keys](https://docs.hcaptcha.com/#test-key-set-publisher-account) (already defined on `.env.local.example`) to be able to test forms locally.
## Project Structure
The following list describes the main elements of the project structure:
- `public`: contains static assets like fonts and images.
- `src`: contains the source code.
- `components`: React components.
- components with state are directly located inside `/components`.
- `forms`: components used in forms.
- `api.ts`: this file contains the api fetching logic details used when submitting the forms data.
- `layout`: components used to contain and apply different layouts to different pages.
- `UI`: stateless (functional) components.
- `hooks`: custom hooks.
- `middlewares`: custom middlewares (required for captcha input validation).
- `pages`: includes components that renders to pages and [NextJS API Routes](https://nextjs.org/docs/api-routes/introduction).
- `theme`: contains the [Chakra UI custom theme](https://chakra-ui.com/docs/styled-system/theming/customize-theme), organized in `foundations` and `components` for better scaling.
- `utils`
- `constants.ts`: this is the _global_ constants file (we have another one for specific _form constants_), containing URLs and lists of elements we use across the site.
- `global.css`: global stylesheet.
- `types.ts`: contains the custom defined TypeScript types and interfaces.## Salesforce Integration
For the custom integration with the Salesforce API, we rely on the [JSforce](https://jsforce.github.io/) library. Some operations are not documented and were the result of lots of googling, SO and [Github issues scanning](https://github.com/jsforce/jsforce/issues).
The Salesforce API field names (listed on `types.ts`) are defined in Salesforce for each corresponding object (Lead, Contract, etc).
### Connected App
To enable a custom API integration with Salesforce, you need to create a [Connected App](https://help.salesforce.com/s/articleView?id=sf.connected_app_overview.htm&type=5). You'll need an account with admin permissions. Go to `Setup > App Manager > New connected app` to create a new one.
#### Configuration
Check that your Connected App is configured with the following parameters
- **Callback URL:** https://salesforce.com
- **Selected OAuth Scopes:**
- Manage user data via APIs (api)
- Manage user data via Web browsers (web)
- Perform requests at any time (refresh_token, offline_access)
- **Connected App policies:**
- IP Relaxation: Relax IP Restrictions
- Permitted Users: All users may self-authorized
- Refresh Token Policy: Refresh token is valid until revoked### Common issues
Some common issues regarding Salesforce data types
- `Picklist`: if you get the error
```
Error 'bad value for restricted picklist field' appears when a record is created
```when creating a new record, try disabling the _'Restrict picklist to the values defined in the value set'_ option for the corresponding field.
- `Checkbox`: besides how you're handling this input on the UI (e.g.: a radio button), Salesforce expects the value to be a boolean (`true`, `false`), so remember to convert the string before submitting the data.
#### When adding new Grants
Check that the hardwired string value of `Proactive_Community_Grants_Round__c` is defined on Salesforce, otherwise submission will fail.
## Grantees List data source
The data published in the [Latest Grantees](https://esp.ethereum.foundation/about/who-we-support#latest-grantees) list is being pulled from a Google Spreadsheet maintained by the ESP Team. This document uses Markdown syntax as it's also being used as source for other pages.
To accomplish that, we [publish the content of the document as CSV](https://support.google.com/a/users/answer/9308870?hl=en) and then render it in the `LatestGranteesList` component. This includes some parsing work, from CSV to JSON and then rendering the Markdown. This process happens server-side only, [on build time](https://nextjs.org/docs/basic-features/data-fetching/get-static-props), so the [resulting page](https://esp.ethereum.foundation/about/who-we-support) is completely static.
## Tutorials
### Learning NextJS
To learn more about Next.js, take a look at the following resources:
- [Next.js Documentation](https://nextjs.org/docs) - learn about Next.js features and API.
- [Learn Next.js](https://nextjs.org/learn) - an interactive Next.js tutorial.### Adding ChakraUI to a NextJS project
[This](https://chakra-ui.com/guides/getting-started/nextjs-guide) is a very clear and step-by-step guide on it.
### Learning ChakraUI
We recommend checking the [official docs](https://chakra-ui.com/docs/getting-started).