spaCy/website
Marcus Blättermann 62b9c9c6d7
Fix images
2022-12-20 23:21:13 +01:00
..
.vscode Add SASS support 2022-12-20 17:46:32 +01:00
docs Fix broken bold markdown 2022-12-20 23:21:09 +01:00
meta Automatically generate "Read Next" link 2022-12-20 23:21:12 +01:00
pages Fix images 2022-12-20 23:21:13 +01:00
plugins Add Smartypants 2022-12-20 23:21:11 +01:00
public Add manifest.webmanifest 2022-12-20 23:21:11 +01:00
setup Add prebuild script 2022-12-20 23:21:07 +01:00
src Fix images 2022-12-20 23:21:13 +01:00
.eslintrc Tidy up website and add eslint config [ci skip] 2019-03-12 15:21:58 +01:00
.eslintrc.json Apply Prettier to all files 2022-12-20 17:46:31 +01:00
.gitignore Add PWA support 2022-12-20 23:21:11 +01:00
.nvmrc Merge branch 'prepare-next' into migrate-to-next-web-17 2022-12-20 17:50:56 +01:00
.prettierignore Add prettier 2022-12-20 17:46:31 +01:00
.prettierrc Add prettier 2022-12-20 17:46:31 +01:00
Dockerfile Docker Image for Website Dev (#10098) 2022-01-20 23:02:13 +01:00
gatsby-browser.js Merge branch 'spacy.io' into develop [ci skip] 2019-02-26 16:51:22 +01:00
gatsby-config.js Minor website fixes (#11974) [ci skip] 2022-12-20 17:41:38 +01:00
gatsby-node.js Minor website fixes (#11974) [ci skip] 2022-12-20 17:41:38 +01:00
netlify.toml Store Netlify settings in file 2022-12-20 23:21:10 +01:00
next-sitemap.config.mjs Add sitemap 2022-12-20 23:21:10 +01:00
next.config.mjs Add PWA support 2022-12-20 23:21:11 +01:00
package-lock.json Use recent DocSearch component and adjust styling 2022-12-20 23:21:12 +01:00
package.json Use recent DocSearch component and adjust styling 2022-12-20 23:21:12 +01:00
README.md Update project structure in README.md 2022-12-20 17:51:55 +01:00
runtime.txt Minor website fixes (#11974) [ci skip] 2022-12-20 17:41:38 +01:00
tsconfig.json Apply Prettier to all files 2022-12-20 17:46:31 +01:00
UNIVERSE.md Apply Prettier (#11996) 2022-12-19 16:18:19 +01:00

spacy.io website and docs

Netlify Status

The styleguide for the spaCy website is available at spacy.io/styleguide.

Setup and installation

# 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 code formatter. It takes care of formatting Markdown and other files automatically. See here for the available extensions for your code editor. The .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.

docker run -it \
  -v $(pwd):/spacy-io/website \
  -p 8000:8000 \
  ghcr.io/explosion/spacy-io \
  gatsby develop -H 0.0.0.0

This will allow you to access the built website at http://0.0.0.0:8000/ in your browser, and still edit code in your editor while having the site reflect those changes.

Note: If you're working on a Mac with an M1 processor, you might see segfault errors from qemu if you use the default image. To fix this use the arm64 tagged image in the docker run command (ghcr.io/explosion/spacy-io:arm64).

Building the Docker image

If you'd like to build the image locally, you can do so like this:

docker build -t spacy-io .

This will take some time, so if you want to use the prebuilt image you'll save a bit of time.

Project structure

├── 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