From 8e6f8deaf633fd9988f87a825777585ea2eed451 Mon Sep 17 00:00:00 2001
From: Bram Vanroy
Date: Mon, 6 May 2019 21:08:01 +0200
Subject: [PATCH] Re-added Universe readme (#3688) (closes #3680)
---
website/UNIVERSE.md | 95 +++++++++++++++++++++++++++++++
website/src/templates/universe.js | 2 +-
2 files changed, 96 insertions(+), 1 deletion(-)
create mode 100644 website/UNIVERSE.md
diff --git a/website/UNIVERSE.md b/website/UNIVERSE.md
new file mode 100644
index 000000000..c26c0fce4
--- /dev/null
+++ b/website/UNIVERSE.md
@@ -0,0 +1,95 @@
+
+
+# spaCy Universe
+
+The [spaCy Universe](https://spacy.io/universe) collects the many great resources developed with or for spaCy. It
+includes standalone packages, plugins, extensions, educational materials,
+operational utilities and bindings for other languages.
+
+If you have a project that you want the spaCy community to make use of, you can
+suggest it by submitting a pull request to this repository. The Universe
+database is open-source and collected in a simple JSON file.
+
+Looking for inspiration for your own spaCy plugin or extension? Check out the
+[`project idea`](https://github.com/explosion/spaCy/labels/project%20idea) label
+on the issue tracker.
+
+## Checklist
+
+### Projects
+
+✅ Libraries and packages should be **open-source** (with a user-friendly license) and at least somewhat **documented** (e.g. a simple `README` with usage instructions).
+
+✅ We're happy to include work in progress and prereleases, but we'd like to keep the emphasis on projects that should be useful to the community **right away**.
+
+✅ Demos and visualizers should be available via a **public URL**.
+
+### Educational Materials
+
+✅ Books should be **available for purchase or download** (not just pre-order). Ebooks and self-published books are fine, too, if they include enough substantial content.
+
+✅ The `"url"` of book entries should either point to the publisher's website or a reseller of your choice (ideally one that ships worldwide or as close as possible).
+
+✅ If an online course is only available behind a paywall, it should at least have a **free excerpt** or chapter available, so users know what to expect.
+
+## JSON format
+
+To add a project, fork this repository, edit the [`universe.json`](universe.json)
+and add an object of the following format to the list of `"resources"`. Before
+you submit your pull request, make sure to use a linter to verify that your
+markup is correct. We'll also be adding linting for the `universe.json` to our
+automated GitHub checks soon.
+
+```json
+{
+ "id": "unique-project-id",
+ "title": "Project title",
+ "slogan": "A short summary",
+ "description": "A longer description – *Mardown allowed!*",
+ "github": "user/repo",
+ "pip": "package-name",
+ "code_example": [
+ "import spacy",
+ "import package_name",
+ "",
+ "nlp = spacy.load('en')",
+ "nlp.add_pipe(package_name)"
+ ],
+ "code_language": "python",
+ "url": "https://example.com",
+ "thumb": "https://example.com/thumb.jpg",
+ "image": "https://example.com/image.jpg",
+ "author": "Your Name",
+ "author_links": {
+ "twitter": "username",
+ "github": "username",
+ "website": "https://example.com"
+ },
+ "category": ["pipeline", "standalone"],
+ "tags": ["some-tag", "etc"]
+}
+```
+
+| Field | Type | Description |
+| --- | --- | --- |
+| `id` | string | Unique ID of the project. |
+| `title` | string | Project title. If not set, the `id` will be used as the display title. |
+| `slogan` | string | A short description of the project. Displayed in the overview and under the title. |
+| `description` | string | A longer description of the project. Markdown is allowed, but should be limited to basic formatting like bold, italics, code or links. |
+| `github` | string | Associated GitHub repo in the format `user/repo`. Will be displayed as a link and used for release, license and star badges. |
+| `pip` | string | Package name on pip. If available, the installation command will be displayed. |
+| `cran` | string | For R packages: package name on CRAN. If available, the installation command will be displayed. |
+| `code_example` | array | Short example that shows how to use the project. Formatted as an array with one string per line. |
+| `code_language` | string | Defaults to `'python'`. Optional code language used for syntax highlighting with [Prism](http://prismjs.com/). |
+| `url` | string | Optional project link to display as button. |
+| `thumb` | string | Optional URL to project thumbnail to display in overview and project header. Recommended size is 100x100px. |
+| `image` | string | Optional URL to project image to display with description. |
+| `author` | string | Name(s) of project author(s). |
+| `author_links` | object | Usernames and links to display as icons to author info. Currently supports `twitter` and `github` usernames, as well as `website` link. |
+| `category` | list | One or more categories to assign to project. Must be one of the available options. |
+| `tags` | list | Still experimental and not used for filtering: one or more tags to assign to project. |
+
+To separate them from the projects, educational materials also specify
+`"type": "education`. Books can also set a `"cover"` field containing a URL
+to a cover image. If available, it's used in the overview and displayed on
+the individual book page.
\ No newline at end of file
diff --git a/website/src/templates/universe.js b/website/src/templates/universe.js
index 644a2de17..379b1a541 100644
--- a/website/src/templates/universe.js
+++ b/website/src/templates/universe.js
@@ -125,7 +125,7 @@ const UniverseContent = ({ content = [], categories, pageContext, location, mdxC