mirror of
https://github.com/explosion/spaCy.git
synced 2025-01-19 14:04:12 +03:00
668ec989ad
* Update Dockerfile to work with Next.js - Update to Node 18 - Do not run as root, this also works better with Node privilege-dropping. - Update README with new run instructions and adding the `--rm` flag to avoid leaving a bunch of unused Docker containers. - Also change README to recommend building the image locally. Image builds are pretty fast and the uploaded images get outdated pretty quickly. * Add .dockerignore to avoid sending large build contexts * Typo
101 lines
3.7 KiB
Markdown
101 lines
3.7 KiB
Markdown
# spacy.io website and docs
|
|
|
|
![Netlify Status](https://api.netlify.com/api/v1/badges/d65fe97d-99ab-47f8-a339-1d8987251da0/deploy-status)
|
|
|
|
The styleguide for the spaCy website is available at
|
|
[spacy.io/styleguide](https://spacy.io/styleguide).
|
|
|
|
## Setup and installation
|
|
|
|
```bash
|
|
# Clone the repository
|
|
git clone https://github.com/explosion/spaCy
|
|
cd spaCy/website
|
|
|
|
# Switch to the correct Node version
|
|
#
|
|
# If you don't have NVM and don't want to use it, you can manually switch to the Node version
|
|
# stated in /.nvmrc and skip this step
|
|
nvm use
|
|
|
|
# Install the dependencies
|
|
npm install
|
|
|
|
# Start the development server
|
|
npm run dev
|
|
```
|
|
|
|
If you are planning on making edits to the site, you should also set up the
|
|
[Prettier](https://prettier.io/) code formatter. It takes care of formatting
|
|
Markdown and other files automatically.
|
|
[See here](https://prettier.io/docs/en/editors.html) for the available
|
|
extensions for your code editor. The
|
|
[`.prettierrc`](https://github.com/explosion/spaCy/tree/master/website/.prettierrc)
|
|
file in the root defines the settings used in this codebase.
|
|
|
|
## Building & developing the site with Docker
|
|
|
|
While it shouldn't be necessary and is not recommended you can run this site in a Docker container.
|
|
|
|
If you'd like to do this, **be sure you do _not_ include your local
|
|
`node_modules` folder**, since there are some dependencies that need to be built
|
|
for the image system. Rename it before using.
|
|
|
|
First build the Docker image. This only needs to be done on the first run
|
|
or when changes are made to `Dockerfile` or the website dependencies:
|
|
|
|
```bash
|
|
docker build -t spacy-io .
|
|
```
|
|
|
|
You can then build and run the website with:
|
|
|
|
```bash
|
|
docker run -it \
|
|
--rm \
|
|
-v $(pwd):/home/node/website \
|
|
-p 3000:3000 \
|
|
spacy-io \
|
|
npm run dev -- -H 0.0.0.0
|
|
```
|
|
|
|
This will allow you to access the built website at http://0.0.0.0:3000/ in your
|
|
browser, and still edit code in your editor while having the site reflect those
|
|
changes.
|
|
|
|
## Project structure
|
|
|
|
```yaml
|
|
├── docs # the actual markdown content
|
|
├── meta # JSON-formatted site metadata
|
|
| ├── dynamicMeta.js # At build time generated meta data
|
|
| ├── languages.json # supported languages and statistical models
|
|
| ├── sidebars.json # sidebar navigations for different sections
|
|
| ├── site.json # general site metadata
|
|
| ├── type-annotations.json # Type annotations
|
|
| └── universe.json # data for the spaCy universe section
|
|
├── pages # Next router pages
|
|
├── public # static images and other assets
|
|
├── setup # Jinja setup
|
|
├── src # source
|
|
| ├── components # React components
|
|
| ├── fonts # webfonts
|
|
| ├── images # images used in the layout
|
|
| ├── plugins # custom plugins to transform Markdown
|
|
| ├── styles # CSS modules and global styles
|
|
| ├── templates # page layouts
|
|
| | ├── docs.js # layout template for documentation pages
|
|
| | ├── index.js # global layout template
|
|
| | ├── models.js # layout template for model pages
|
|
| | └── universe.js # layout templates for universe
|
|
| └── widgets # non-reusable components with content, e.g. changelog
|
|
├── .eslintrc.json # ESLint config file
|
|
├── .nvmrc # NVM config file
|
|
| # (to support "nvm use" to switch to correct Node version)
|
|
|
|
|
├── .prettierrc # Prettier config file
|
|
├── next.config.mjs # Next config file
|
|
├── package.json # package settings and dependencies
|
|
└── tsconfig.json # TypeScript config file
|
|
```
|