Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/techeng322/radium-starter
The minimum viable layer on top of HTML/CSS (using React and Radium)
https://github.com/techeng322/radium-starter
Last synced: 18 days ago
JSON representation
The minimum viable layer on top of HTML/CSS (using React and Radium)
- Host: GitHub
- URL: https://github.com/techeng322/radium-starter
- Owner: techeng322
- Created: 2023-11-08T19:54:09.000Z (about 1 year ago)
- Default Branch: master
- Last Pushed: 2023-12-03T22:21:22.000Z (about 1 year ago)
- Last Synced: 2024-01-15T10:34:58.429Z (about 1 year ago)
- Language: JavaScript
- Homepage: https://mvila.github.io/radium-starter/
- Size: 2.18 MB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Radium Starter [![npm version](https://img.shields.io/npm/v/radium-starter.svg)](https://www.npmjs.com/package/radium-starter)
The minimum viable layer on top of HTML/CSS (using React and Radium).
## Introduction
Nope, this is not another CSS framework! This package provides the bare minimum to make HTML/CSS a better world:
* Normalization (use [Normalize.css](https://necolas.github.io/normalize.css/)).
* Basic styling of HTML elements.
* Useful polyfills like [Form validation](https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Forms/Data_form_validation) in Safari.
* Theme variables (i.e. variables for defining colors, font sizes, etc.)
* [Radium](http://stack.formidable.com/radium/) for flexible customization and high composability.## Compatibility
Modern browsers (including IE11).
## Demo
Have a look to the [demo here](http://mvila.github.io/radium-starter/demo/index.html).
## Installation
```bash
npm install --save radium-starter
```## Usage
At the root of your application, define a `theme` and use `RadiumStarterRoot` to wrap your main component:
```javascript
import {RadiumStarterRoot} from 'radium-starter';ReactDOM.render(
,
document.getElementById('root')
);
```Then, use the `RadiumStarter` component:
```javascript
import React from 'react';
import RadiumStarter from 'radium-starter';export class Main extends React.Component {
render() {
return (
{() => {
returnHello, World!
;
}}
);
}
}
```Once a component is wrapped with `RadiumStarter`, you can use all the power of [Radium](http://stack.formidable.com/radium/):
```javascript
{() => {
returnHover me
;
}}```
... and Radium Starter features, such as theme variables:
```javascript
{theme => {
returnAn error occurred;
}}```
And built-in styles:
```javascript
{(theme, styles) => {
returnHello, World!;
}}```
## Theme variables
Radium Starter provides theme variables with sensible defaults for font sizes, colors, spacing, etc. You can pass a `theme` attribute to the `RadiumStarterRoot` component to customize any variable. For example, if you want to change the primary color, you would do something like that:
```javascript
```
But you can do even better, instead of passing a POJO object to `RadiumStarterRoot`, you can pass an instance of the `Theme` class. The advantage of using the `Theme` class is that if you change some theme variables later, all your React components will be automatically re-rendered to reflect the changes. For example:
```javascript
import {RadiumStarterRoot, Theme} from 'radium-starter';const theme = new Theme({primaryColor: '#2196F3'});
ReactDOM.render(
,
document.getElementById('root')
);
```Later, changing the primary color:
```javascript
theme.primaryColor = '#FF5252';
```... will automatically re-render everything with the new primary color.
One last thing, when you create a `Theme` instance, if you need to set a variable based on the value of another variable, you can specify a function:
```javascript
const theme = new Theme({linkColor: theme => theme.accentColor});
```Components wrapped with `RadiumStarter` can use the current `theme` instance:
```javascript
import React from 'react';
import RadiumStarter from 'radium-starter';export class Main extends React.Component {
render() {
return (
{theme => {
returnSpecial title;
}}
);
}
}
```Here is a few useful theme variables:
* Base colors: `primaryColor`, `accentColor`, `textColor`, `backgroundColor`, `inverseBackgroundColor`, `borderColor`, `inverseBorderColor`, `errorColor`, `warningColor`.
* Font families: `sansSerifFontFamily`, `serifFontFamily`, `monospaceFontFamily`.
* Font sizes: `baseFontSize`, `smallFontSize`, `largeFontSize`, `h1FontSize`, `h2FontSize`,...
* Line heights: `baseLineHeight`, `smallLineHeight`, `headingsLineHeight`.
* Breakpoints: `smallBreakpoint`, `mediumBreakpoint`, `largeBreakpoint`.Many other variables are available, please check the [theme.js](https://github.com/mvila/radium-starter/blob/master/src/theme.js) file.
## Built-in styles
Components wrapped with `RadiumStarter` can get the `styles` object which contains many convenient styles usable with the `style` attribute of HTML elements.
Example :
```javascript
{(theme, styles) => {
return Hello, World!>;
}}
;
```Thanks to [Radium](http://stack.formidable.com/radium/) goodness, you can combine several styles with an array:
Example :
```javascript
Hi
```### Text colors
Convenient styles to define text color (CSS `color` property): `primaryColor`, `darkPrimaryColor`, `lightPrimaryColor`, `accentColor`, `darkAccentColor`, `backgroundColor`, `altBackgroundColor`, `borderColor`, `altBorderColor`, `textColor`, `altTextColor`, `mutedTextColor`, `inverseTextColor`, `inverseAltTextColor`, `inverseMutedTextColor`, `errorColor`, `warningColor`.
Example :
```javascript
Notice
```### Background colors
Convenient styles to define background color (CSS `background-color` property): `backgroundPrimaryColor`, `backgroundDarkPrimaryColor`, `backgroundLightPrimaryColor`, `backgroundAccentColor`, `backgroundDarkAccentColor`, `backgroundBackgroundColor`, `backgroundAltBackgroundColor`, `backgroundErrorColor`, `backgroundWarningColor`.
Example :
```javascript
Bonjour
```### Text styling
* `regular`: set `font-weight` to `normal`.
* `bold`: set `font-weight` to `bold`.
* `italic`: set `font-style` to `italic`.
* `mutedText`: set `color` to `mutedTextColor` theme variable.### Block styling
* `border`: add top, right, bottom and left borders.
* `topBorder`, `rightBorder`, `bottomBorder`, `leftBorder`: add only the corresponding border.
* `rounded`: set `borderRadius` CSS property to `borderRadius` theme variable.### List styling
* `unstyledList`: remove default HTML list (`ul`, `ol`) styling.
### Responsive tools
* `showIfSmall`/`hideIfSmall`: show/hide an HTML element if the viewport width is less/greater than the `smallBreakpoint` theme variable (_default:_ `640px`).
* `showIfMedium`/`hideIfMedium`: show/hide an HTML element if the viewport width is less/greater than the `mediumBreakpoint` theme variable (_default:_ `1024px`).
* `showIfLarge`/`hideIfLarge`: show/hide an HTML element if the viewport width is less/greater than the `largeBreakpoint` theme variable (_default:_ `1440px`).### Utilities
* `showIf(condition)`: convenient function to hide an HTML element if `condition` is `false`.
* `hideIf(condition)`: convenient function to hide an HTML element if `condition` is `true`.### More
Check [styles.js](https://github.com/mvila/radium-starter/blob/master/src/styles.js) for the full set of styles.
### Customization
Pass the `styles` attribute to the `RadiumStarterRoot` component to add new styles or customize the existing ones.
```javascript
```
## Enhanced HTML elements
Radium Starter is not a full-featured framework like [Bootstrap](http://getbootstrap.com/) or [Foundation](http://foundation.zurb.com/). It doesn't provide any fancy component like modals or carousels. What Radium Starter does is just enhancing standard HTML elements (`
`, ``, `
`, etc.).
Most of the enhancements consist only in CSS styling and you don't have to do anything special to benefit from that, just use regular HTML tags. But sometimes we needed more power control because we wanted to add new attributes to HTML elements or we needed to polyfill inconsistent or missing behaviors in certain browsers (e.g. [Form validation](https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Forms/Data_form_validation) in Safari). This is why we created some custom React components that you can use in replacement of the standard HTML elements.
### ``
Like the HTML `` element but with some useful added attributes:
* `rsSmall`, `rsLarge`: smaller/larger sizes for your controls.
* `rsPrimary`, `rsAccent`, `rsInverse`: colorize your buttons.Example:
```javascript
Sign up
```
### ``
Use this component in replacement of the HTML `` element to enjoy [Form validation](https://developer.mozilla.org/en-US/docs/Web/Guide/HTML/Forms/Data_form_validation) in any modern browser (including Safari!).
### ``, ``, ``
Augment the corresponding HTML elements with the following attributes:
* `rsSmall`, `rsLarge`: smaller/larger sizes for your input fields.
* `rsInverse`: inverse styling.
* `rsAutoSelect`: similar to the `autofocus` HTML attribute but select the content of an input in addition to focusing it.
* `rsCustomValidity`: provide `setCustomValidity()` in a declarative way.## License
MIT