https://github.com/ipfs-shipyard/ipfs-css
The single-purpose css class names and font-face config to IPFS up your UI.
https://github.com/ipfs-shipyard/ipfs-css
css dweb ipfs ipfs-gui scss theme
Last synced: 20 days ago
JSON representation
The single-purpose css class names and font-face config to IPFS up your UI.
- Host: GitHub
- URL: https://github.com/ipfs-shipyard/ipfs-css
- Owner: ipfs-shipyard
- License: mit
- Created: 2018-01-31T16:56:56.000Z (over 7 years ago)
- Default Branch: main
- Last Pushed: 2024-06-21T04:07:33.000Z (11 months ago)
- Last Synced: 2025-04-13T13:05:54.808Z (20 days ago)
- Topics: css, dweb, ipfs, ipfs-gui, scss, theme
- Language: HTML
- Homepage:
- Size: 90.2 MB
- Stars: 24
- Watchers: 11
- Forks: 14
- Open Issues: 12
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# ipfs-css
The single-purpose CSS class names and @font-face config to IPFS up your UI.
```css
/* ---- font ----- */
.sans-serif { font-family: 'Inter', system-ui, sans-serif; }
.montserrat { font-family: 'Montserrat', 'Verdana', system-ui, sans-serif; }
.monospace { font-family: Consolas, monaco, monospace; }/* ---- color ----- */
.navy { color: #0b3a53; }
.navy-muted { color: #244e66; }
.aqua { color: #69c4cd; }
.aqua-muted { color: #9ad4db; }/* ...and (just a little) more! */
```Pairs well with [tachyons].
## Install
Add `ipfs-css` to your project via npm:
```sh
npm install ipfs-css
```## Usage
Once you've installed ipfs-css from npm, the CSS and SCSS files and the web-fonts are available from your `node_modules/ipfs-css` directory.
If you are set up with a build process that lets you import css files directly from `node_modules`, then you can just add the following to your CSS file.
```css
@import 'tachyons'; /* Optional, jolly good tho */
@import 'ipfs-css';
```The file includes font-face definitions and single purpose CSS class names that you can compose freely, to create your lovely UI.
```html
OH HAI! It's so nice to see you again.
```
### CSS in JS
You can import the `theme.json` file which can be used with a [ThemeProvider] component.
All **the CSS atoms are generated** from that, so you can be sure you're using the same values.
### Less
`ipfs.css` is a regular CSS file, so you can import it normally. Each declaration has a single purpose, so if you prefer to compose your rules outside the DOM, you can safely use them as mixins:
```less
.my-lovely-widget {
.aqua;
.bg-navy;
.montserrat;
}
```### SCSS
While `ipfs.css` contains everything you need, if you prefer variables for fonts, colors and gradients, these are there for you in `theme.scss`.
## Icons
See: https://dweb.link/ipfs/bafybeiebays3i7aem7tptga3kilzux7f5gz6czl4dietazgutcjhozjviu
## Colors
## Releasing
First, clean and build the CSS and the docs.
```console
# Clean then build your local workspace
$ npm run clean
$ npm run build
```Next, with IPFS running locally, add the docs to IPFS, to get the new CID.
```console
# Add the docs to IPFS to get the CID
$ npm run -s deploy:docs
QmQYzfzGKAeBWgarrmTSsG2PJ8AFfFEBprhVBFaudcFTof
```Pin the CID to ipfs-cluster (via #pinbot on IRC or your preferred method). Update the README.md with the new docs link.
Then bump the version, push to GitHub and publish to npm. If you are adding an icon, that's a minor release. Fixing an issue with an existing icon would be a patch. Changing any of the color values would be at least a minor. Changing the naming scheme for the CSS classes would be a major release.
```console
# use npm to bump the version and tag
$ npm version minor# Push the changes back to the repo
$ git push origin master
$ git push --tags# PUBLISH!
$ npm publish
```## Contribute
Contributions are more than welcome! Check out the [currently open issues](https://github.com/ipfs-shipyard/ipfs-css/issues) and start hacking on anything that sounds interesting. Issues are labeled with a variety of tags to help you find a good fit — you may wish to start with the [`help-wanted`](https://github.com/ipfs-shipyard/ipfs-share-files/issues?q=is%3Aissue+is%3Aopen+label%3A%22help+wanted%22) tag.
To contribute to IPFS in general, check out the wide variety of opportunities [here](https://docs.ipfs.io/community/contribute/ways-to-contribute).
The IPFS community believes that our mission is best served in an environment that is friendly, safe, and accepting, and free from intimidation or harassment. To that end, we ask that everyone involved in IPFS read and respect our [code of conduct](https://github.com/ipfs/community/blob/master/code-of-conduct.md).
## License
The [Monserrat font family](https://github.com/JulietaUla/Montserrat) © The Montserrat Project Authors (https://github.com/JulietaUla/Montserrat) is used under the [SIL Open Font License, Version 1.1.](https://github.com/JulietaUla/Montserrat/blob/21047be7ebcae5e71328358fcf20566cb85383ec/OFL.txt)
The [Inter font family](https://github.com/rsms/inter/blob/master/LICENSE.txt) © The Inter Project Authors ([email protected]) is used under the [SIL Open Font License, Version 1.1.](https://github.com/rsms/inter/blob/fa8a99377e8d51d6c0721a4b4c96d91911399dcf/LICENSE.txt)
The home icon © Icons8 is under their [Free License](https://icons8.com/license)
All other documents and icons are [CC-BY-SA 3.0] license © 2018 Protocol Labs Inc.
Code is under the [MIT](./LICENSE) © 2018 Protocol Labs Inc.
[ipfs.io]: https://ipfs.io
[tachyons]: http://tachyons.io
[CC-BY-SA 3.0]: https://ipfs.io/ipfs/QmVreNvKsQmQZ83T86cWSjPu2vR3yZHGPm5jnxFuunEB9u
[ThemeProvider]: https://glamorous.rocks/advanced/#theming