Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/danieldickison/embedodon
simple web component to render a mastodon account‘s posts
https://github.com/danieldickison/embedodon
client-side embed javascript mastodon typescript vanilla-javascript vanilla-js web-components
Last synced: 8 days ago
JSON representation
simple web component to render a mastodon account‘s posts
- Host: GitHub
- URL: https://github.com/danieldickison/embedodon
- Owner: danieldickison
- License: mit
- Created: 2023-04-01T22:28:51.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2023-08-29T05:21:04.000Z (over 1 year ago)
- Last Synced: 2024-04-14T09:14:21.358Z (9 months ago)
- Topics: client-side, embed, javascript, mastodon, typescript, vanilla-javascript, vanilla-js, web-components
- Language: TypeScript
- Homepage: https://danieldickison.github.io/embedodon/
- Size: 163 KB
- Stars: 0
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# embedodon
Simple js to render a Mastodon user’s public toots.
Live example here: https://danieldickison.github.io/embedodon/
[![npm tests](https://github.com/danieldickison/embedodon/actions/workflows/npm-test.yml/badge.svg)](https://github.com/danieldickison/embedodon/actions/workflows/npm-test.yml)
## simple example ##
```html
import { EmbedodonElement } from 'https://cdn.jsdelivr.net/npm/embedodon@^1.0.6/dist/index.js'
customElements.define('embed-odon', EmbedodonElement)```
Note that custom element names must contain a hyphen. The "standard" class enables a default color scheme.
## customize styles ##
Styles can be customized in several ways. Ordered from simplest to most complex but flexible, you can:
1. Specify a set of [custom CSS properties](#custom-css-properties)
2. Apply styles using [`::part` selectors](#part-selectors)
3. [Override `adoptedStyleSheets`](#override-adoptedstylesheets) to style arbitrary shadowRoot elements
4. [Call `Embedodon#render` directly](#call-embedodonrender-directly) without using the `EmbedodonElement` web component### custom CSS properties ###
[Custom CSS properties](http://developer.mozilla.org/en-US/docs/Web/CSS/--*) can be used to specify some basic colors. Make sure `class="standard"` is _not_ included on the root element or else the standard colors will take precedence. You should specify _all_ of these properties if you are not using `class="standard"`:
| property | standard | definition |
|----------|-------------|---------------------------|
| --fg | black/white | foreground color for text |
| --bg | white/black | background color for toot |
| --link | blue | link text color |
| --border | 1px gray | border for toot |Example:
```css
embed-odon {
--fg: #603;
--bg: #eee;
--link: #b0b;
--border: 2px dashed var(--fg);
}
@media (prefers-color-scheme: dark) {
embed-odon {
--fg: #d9b;
--bg: #222;
--link: #b6e;
}
}
```### `::part` selectors ###
CSS [`::part` selectors](http://developer.mozilla.org/en-US/docs/Web/CSS/::part) can be used to target specific elements within the Embededon-rendered component from your page CSS. Exposed parts are:
| part | element | definition |
|-----------|-------------|-------------------------------------------|
| toot | `` | container for each toot |
| timestamp | `