Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jaydenseric/device-agnostic-ui
Device agnostic styles, components & hooks for React apps.
https://github.com/jaydenseric/device-agnostic-ui
css deno esm maintained mjs node npm react typescript
Last synced: 2 months ago
JSON representation
Device agnostic styles, components & hooks for React apps.
- Host: GitHub
- URL: https://github.com/jaydenseric/device-agnostic-ui
- Owner: jaydenseric
- License: mit
- Created: 2019-09-13T04:12:48.000Z (over 5 years ago)
- Default Branch: master
- Last Pushed: 2022-09-02T00:36:32.000Z (over 2 years ago)
- Last Synced: 2024-10-04T13:33:10.229Z (4 months ago)
- Topics: css, deno, esm, maintained, mjs, node, npm, react, typescript
- Language: JavaScript
- Homepage: https://deviceagnosticui.com
- Size: 267 KB
- Stars: 19
- Watchers: 7
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: readme.md
- Changelog: changelog.md
- Funding: .github/funding.yml
- License: license.md
Awesome Lists containing this project
README
![Device Agnostic UI logo](https://cdn.jsdelivr.net/gh/jaydenseric/device-agnostic-ui/device-agnostic-ui-logo.svg)
# Device Agnostic UI
**Device agnostic** styles, components and hooks for [React](https://reactjs.org) apps β [deviceagnosticui.com](https://deviceagnosticui.com). One design for any viewport (size, orientation, resolution), input method (touch, mouse) or network speed. Simple to build, test and use.
- π¦ **Tiny bundle size.** The minified and gzipped bundle size of individual modules are tested.
- π± **Mobile first.** Intuitive layouts suitable for any screen size, _without media queries_.
- β¨οΈ **Keyboard ok.** Interactive components have clearly discernable [`:focus`](https://developer.mozilla.org/en-US/docs/Web/CSS/:focus) styles.
- π¨ **Native UI.** Lightweight, pretty and accessible [form field validation](https://developer.mozilla.org/en-US/docs/Web/API/Constraint_validation) messages.
- π **Dark mode.** The color scheme [adapts](https://developer.mozilla.org/en-US/docs/Web/CSS/@media/prefers-color-scheme) to the operating systemβs light or dark mode.
- π¨ **CSS variables.** Easily tweak the theme globally or in your components.
- π **Few global styles.** No intrusive normalization or resets; just the [`:root`](https://developer.mozilla.org/en-US/docs/Web/CSS/:root) essentials.
- π **Style raw HTML.** Special [``](./Html.mjs) component to style rendered Markdown.
- π§ **Semantic markup.** Lean use of semantically appropriate HTML elements.
- βοΈ **Modern React.** Elegant use of [React](https://reactjs.org) [hooks](https://reactjs.org/docs/react-api.html#hooks), [refs](https://reactjs.org/docs/react-api.html#refs) and [fragments](https://reactjs.org/docs/react-api.html#fragments) makes for a great DX.
- β **Type safety.** Modules are typed via [TypeScript](https://typescriptlang.org) JSDoc comments.## Installation
For [Node.js](https://nodejs.org), to install [`device-agnostic-ui`](https://npm.im/device-agnostic-ui) and its [`react`](https://npm.im/react) peer dependency with [npm](https://npmjs.com/get-npm), run:
```sh
npm install device-agnostic-ui react
```For [Deno](https://deno.land) and browsers, an example import map:
```json
{
"imports": {
"class-name-prop": "https://unpkg.com/[email protected]/classNameProp.mjs",
"device-agnostic-ui/": "https://unpkg.com/[email protected]/",
"react": "https://esm.sh/[email protected]"
}
}
```These dependencies might not need to be in the import map, depending on what [`device-agnostic-ui`](https://npm.im/device-agnostic-ui) modules the project imports from:
- [`class-name-prop`](https://npm.im/class-name-prop)
Theme, global, component, and syntax highlighting styles are [exported](#exports) in vanilla CSS files that must be manually loaded in your app, as necessary.
## Requirements
Supported runtime environments:
- [Node.js](https://nodejs.org) versions `^14.17.0 || ^16.0.0 || >= 18.0.0`.
- [Deno](https://deno.land).
- Browsers matching the [Browserslist](https://browsersl.ist) query [`> 0.5%, not OperaMini all, not dead`](https://browsersl.ist/?q=%3E+0.5%25%2C+not+OperaMini+all%2C+not+dead).Non [Deno](https://deno.land) projects must configure [TypeScript](https://typescriptlang.org) to use types from the ECMAScript modules that have a `// @ts-check` comment:
- [`compilerOptions.allowJs`](https://typescriptlang.org/tsconfig#allowJs) should be `true`.
- [`compilerOptions.maxNodeModuleJsDepth`](https://typescriptlang.org/tsconfig#maxNodeModuleJsDepth) should be reasonably large, e.g. `10`.
- [`compilerOptions.module`](https://typescriptlang.org/tsconfig#module) should be `"node16"` or `"nodenext"`.## Exports
The [npm](https://npmjs.com) package [`device-agnostic-ui`](https://npm.im/device-agnostic-ui) features [optimal JavaScript module design](https://jaydenseric.com/blog/optimal-javascript-module-design). It doesnβt have a main index module, so use deep imports from the ECMAScript modules that are exported. These ECMAScript modules and CSS files are exported via the [`package.json`](./package.json) field [`exports`](https://nodejs.org/api/packages.html#exports):
- [`Blockquote.css`](./Blockquote.css)
- [`Blockquote.mjs`](./Blockquote.mjs)
- [`Button.css`](./Button.css)
- [`Button.mjs`](./Button.mjs)
- [`ButtonSubmit.css`](./ButtonSubmit.css)
- [`ButtonSubmit.mjs`](./ButtonSubmit.mjs)
- [`Code.css`](./Code.css)
- [`Code.mjs`](./Code.mjs)
- [`Fieldset.css`](./Fieldset.css)
- [`Fieldset.mjs`](./Fieldset.mjs)
- [`global.css`](./global.css)
- [`Heading.css`](./Heading.css)
- [`Heading.mjs`](./Heading.mjs)
- [`Html.css`](./Html.css)
- [`Html.mjs`](./Html.mjs)
- [`Icon.css`](./Icon.css)
- [`Icon.mjs`](./Icon.mjs)
- [`IconTick.mjs`](./IconTick.mjs)
- [`LinkCard.css`](./LinkCard.css)
- [`LinkCard.mjs`](./LinkCard.mjs)
- [`LinkNav.css`](./LinkNav.css)
- [`LinkNav.mjs`](./LinkNav.mjs)
- [`LinkText.css`](./LinkText.css)
- [`LinkText.mjs`](./LinkText.mjs)
- [`ListOrdered.css`](./ListOrdered.css)
- [`ListOrdered.mjs`](./ListOrdered.mjs)
- [`ListUnordered.css`](./ListUnordered.css)
- [`ListUnordered.mjs`](./ListUnordered.mjs)
- [`Loading.css`](./Loading.css)
- [`Loading.mjs`](./Loading.mjs)
- [`Margin.css`](./Margin.css)
- [`Margin.mjs`](./Margin.mjs)
- [`Nav.css`](./Nav.css)
- [`Nav.mjs`](./Nav.mjs)
- [`package.json`](./package.json)
- [`Para.css`](./Para.css)
- [`Para.mjs`](./Para.mjs)
- [`Picture.css`](./Picture.css)
- [`Picture.mjs`](./Picture.mjs)
- [`Pre.css`](./Pre.css)
- [`Pre.mjs`](./Pre.mjs)
- [`Scroll.css`](./Scroll.css)
- [`Scroll.mjs`](./Scroll.mjs)
- [`Select.css`](./Select.css)
- [`Select.mjs`](./Select.mjs)
- [`splitWordBreaks.mjs`](./splitWordBreaks.mjs)
- [`syntax-highlighting-prism.css`](./syntax-highlighting-prism.css)
- [`Table.css`](./Table.css)
- [`Table.mjs`](./Table.mjs)
- [`Textbox.css`](./Textbox.css)
- [`Textbox.mjs`](./Textbox.mjs)
- [`theme.css`](./theme.css)
- [`Toggle.css`](./Toggle.css)
- [`Toggle.mjs`](./Toggle.mjs)
- [`useCustomValidity.mjs`](./useCustomValidity.mjs)
- [`useMergedRef.mjs`](./useMergedRef.mjs)
- [`useOnFocusReportValidity.mjs`](./useOnFocusReportValidity.mjs)
- [`WordBreaks.mjs`](./WordBreaks.mjs)