This repository is home to a suite of internal tools for Pocket curators developed with React and TypeScript. With React, we use functional components and hooks throughout.
We also use:
- Material UI for the UI,
- Apollo Client for connecting to the APIs the tools interact with,
- React Testing Library for unit testing,
- GraphQL Code Generator for generating types and custom Apollo hooks for data that we request from the APIs,
- Formik as a form builder with Yup for schema validation.
The app runs within the Create React App environment. We trade off ability to customize things to our collective heart's content for hassle-free local development.
Check out the repository and install the required packages:
git clone git@github.com:Pocket/curation-admin-tools.git
cd curation-admin-tools
npm ci
Next, to enable SSO auth, create an .env
file in the project root, and add the following:
REACT_APP_OAUTH2_REDIRECT_URI=http://localhost:3000/oauth/callback
REACT_APP_OAUTH2_CLIENT_ID=2jliat5ne5043psrlbhur2unlr
You're almost there! By default, the app will connect to the production Admin API. To point to the Pocket Development or locally spun up API, you will need to override the default endpoint value in your .env
file. Add the following to your .env
file and comment out the endpoint you do not need:
#This is the dev version of the federated graph
REACT_APP_ADMIN_API_ENDPOINT=https://admin-api.getpocket.dev
#A And this is the local version if you need to debug something
# or swap out one of the subgraphs for a locally spun up version.
REACT_APP_ADMIN_API_ENDPOINT=http://localhost:4027
Start the React app:
npm start
The app will open in your default browser at http://localhost:3000.
This is useful for user acceptance testing, live demos of as-yet-not-merged features and code reviews by team members outside of your immediate team who may not have the time to go through all of the setup steps to be able to review a pull request.
The Dev checkout is available at https://curation-admin-tools.getpocket.dev/. Note that this address is accessible only via the Pocket Dev VPN.
To deploy the latest changes merged to main
to Dev, run the following command in your terminal:
git push -f origin main:dev
To push changes from a particular branch to Dev, use the name of the branch instead of main
:
git push -f origin your-branch-name:dev
To run the tests in watch mode, run the following command:
npm run test
-
The
src/_shared
folder houses the basic building blocks of the app, such as any UI components that can be reused across different tools, useful helper functions and React hooks. -
The
src/api
folder contains GraphQL queries and mutations the app needs to execute to retrieve and manipulate data, as well as generated types for these and the Apollo Client connection. -
src/collections
is the home for Collections Admin Tool that lets Pocket curators create, edit and publish collections of stories for Pocket users. -
src/curated-corpus
houses the Curated Corpus Tool.
Within the folder for each tool, the structure is as follows (taking Collections as an example):
collections/
├─ components/
├─ pages/
├─ utils/
The components
folder houses any components specific to that particular tool, for example, CollectionListCard
. The pages
folder is home to page-level components, i.e. AddCollectionPage
.
All components are functional React components. Each component lives in its own folder. Unit tests, styles, validation schemas (for form components) are placed in separate files alongside each component.
Routing within the app is set up with React Router. The entrypoint to the app, App.tsx, sets up all requests to be routed to specific paths within the apps - /collections
for Collections and /prospects
for the Prospecting tool, for example. More detailed routing, for example, individual collection pages, is set up within the landing page - see this example for Collections
If the GraphQL schema of the API changes, or if you add new queries, mutations or fragments to be used on the frontend, you need to re-run the code generation script.
# to update types for Admin API, run
npm run api:generate-types
The generated types and custom hooks are saved in a file named generatedTypes.ts
in the src/api
folder and are automatically formatted with Prettier. Check in the changes to the repository but do not edit this file as the next time the types will be regenerated any updates you make will be lost.
Now that the generated code is ready to use, you can:
- Use the generated types elsewhere in the code to type hint the shape of the returned data or data that is expected by components in the app, for example,
Collection
orCollectionAuthor
. - Use strongly typed custom Apollo hooks to fetch and manipulate data. Apollo Client has generic
useQuery
,useLazyQuery
,useMutation
anduseSubscription
hooks. GraphQL Code Generator builds on that by providing hooks that are specific to the queries and mutations you need to run, for example,useGetCollectionByExternalIdQuery
.
- If you receive an error similar to the following
error:xyz:digital envelope routines
, this means the nvm version you're using doesn't match v16. Here are the steps to install the proper version:# Install nvm using curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.39.3/install.sh | bash # Next start a new terminal window # Ensure nvm was install correctly, nvm -v nvm install v16.19.0 # To set this version as the default, nvm alias default v16.19.0 nvm use v16.19.0`