Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/molly/annotate
Annotate text and publish it on the web
https://github.com/molly/annotate
annotations website
Last synced: 13 days ago
JSON representation
Annotate text and publish it on the web
- Host: GitHub
- URL: https://github.com/molly/annotate
- Owner: molly
- License: mit
- Created: 2022-10-02T23:37:56.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2023-01-26T00:37:39.000Z (about 2 years ago)
- Last Synced: 2024-11-26T02:17:19.153Z (2 months ago)
- Topics: annotations, website
- Language: HTML
- Homepage:
- Size: 6.76 MB
- Stars: 294
- Watchers: 5
- Forks: 9
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Annotate
Annotate and publish text on the web! This project was created for ["The (Edited) Latecomer's Guide to Crypto"](https://www.mollywhite.net/annotations/latecomers-guide-to-crypto), but can be used to annotate any text document.
View a live demo at https://molly.github.io/annotate/.
![](./screenshots/latecomers-desktop.png)
## How to use
Copy the `index.html`, `styles.css`, and `annotate.js` files to your project. You should only need to edit the `index.html` file, unless you want to change the styling or JavaScript behavior. This project does not *require* the JavaScript, so if you want to leave it out, just omit the `annotate.js` file and remove the `` tag from the HTML file. The `screenshots` folder has full-size screenshots of the index page in both desktop ([`index-desktop.png`](https://github.com/molly/annotate/blob/main/screenshots/index-desktop.png)) and mobile ([`index-mobile.png`](https://github.com/molly/annotate/blob/main/screenshots/index-mobile.png)) views, so you can see what the HTML produces.Each section of the document follows this basic structure:
```html
Text that's being annotated.
Commenter name
Comment text.
```
and produces:
![](./screenshots/small-example.png)
## Details
Each section of text is captured in a row with left- and right-hand sections. The `` element represents this row. Each side then has a div with the `content` class and either the `quote` or `note` classes. `quote` is the text being annotated, `note` is for the annotations.
Each portion of highlighted text in the original source (left-hand side) is marked with `` tags. These must have a unique `aria-details` attribute that will correspond to the `id` of the annotation, which will enable visual focus highlighting on click. It can also optionally have a `data-annotation-id` to number the annotation, to help distinguish annotations when there are multiple in a section.
Corresponding to the `` tag will be a div with either the `annotation` or `annotation-group` class on the right-hand side (the former for single annotations, the latter for grouped annotations). These must have `role="comment"` and an `id` that exactly matches the unique `aria-details` value of the highlighted text to which it corresponds. As with the highlighted text, it can have a `data-annotation-id` to number the annotation.
### Grouped annotations
Within an annotation group, there will be one or more divs with the `annotation` class. These can contain a div with the class `commenter` to identify the writer, if there are multiple annotators working on the document. These do *not* need `role="comment`, `data-annotation-id`, or `id` since they're nested within an `annotation-group` with those attributes.In the case of multiple annotations within an annotation group, they can appear directly stacked, or threaded (rendering with increasing levels of indentation, to indicate that they are replies to one another). To thread comments, include the `thread` class on the second comment (the first reply). Any subsequent replies should be marked with the `thread-x` class, where `x` is the level of indentation from 2–10: `thread-2`, `thread-3`, ..., `thread-10`. Omit the `thread` classes to render multiple annotations in a stack without indentation.
```html
Text that's being annotated.
A comment with indented responses.
A reply
A second reply
```
![](./screenshots/small-example-thread.png)
## Other source formats
The original Latecomer's Guide project was created using [Pug](https://pugjs.org/) and [Sass](https://sass-lang.com). If you'd rather work with those, that source code lives over with my [website source](https://github.com/molly/website-v2):
* [Pug](https://github.com/molly/website-v2/blob/master/src/pug/pages/annotations/latecomers-guide-to-crypto.pug) file
* [Sass](https://github.com/molly/website-v2/blob/master/src/sass/reviews.sass) file## Mobile display
This is how the annotations display on mobile: