Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/avaya-dux/neo-react-library
A React implementation of the Avaya Neo Design system. Written in TS.
https://github.com/avaya-dux/neo-react-library
avaya neo react typescript vite vitest
Last synced: about 2 months ago
JSON representation
A React implementation of the Avaya Neo Design system. Written in TS.
- Host: GitHub
- URL: https://github.com/avaya-dux/neo-react-library
- Owner: avaya-dux
- License: other
- Created: 2022-08-12T19:55:40.000Z (over 2 years ago)
- Default Branch: main
- Last Pushed: 2024-10-29T20:11:37.000Z (2 months ago)
- Last Synced: 2024-10-29T20:17:30.358Z (2 months ago)
- Topics: avaya, neo, react, typescript, vite, vitest
- Language: TypeScript
- Homepage: https://design.avaya.com/docs/setup
- Size: 4.58 MB
- Stars: 5
- Watchers: 4
- Forks: 2
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- License: LICENSE-3rd-party.html
Awesome Lists containing this project
README
[![Netlify Status](https://api.netlify.com/api/v1/badges/825502d6-02db-45a6-88bc-6aed064eb748/deploy-status)](https://app.netlify.com/sites/neo-react-library-storybook/deploys)
![github workflow status](https://github.com/avaya-dux/neo-react-library/actions/workflows/run-yarn.yml/badge.svg)
[![npm version](https://badge.fury.io/js/@avaya%2Fneo-react.svg)](https://badge.fury.io/js/@avaya%2Fneo-react)
![Coverage](https://img.shields.io/endpoint?url=https://gist.githubusercontent.com/joe-s-avaya/e90dadd4c95bbcf46094100f6591134e/raw/code-coverage.json)# Neo React Component Library
> This is the React version of the shared library called "NEO" buit by Avaya ([storybook site](https://neo-react-library-storybook.netlify.app/))
## Install
```bash
npm i @avaya/neo-react
``````bash
yarn add @avaya/neo-react
``````bash
pnpm add @avaya/neo-react
```## Example Usage
At the root of your application, import the CSS styles via:
```javascript
import "@avaya/neo-react/avaya-neo-react.css";
```Then, simply import the component(s) that you'd like to use, see [the documentation site](https://design.avayacloud.com/components/web) for more examples.
```tsx
import { IconNamesType, NoContent } from "@avaya/neo-react";export const Example = () => {
const agentIconName: IconNamesType = "agent";
return ;
};
```NOTE: if you are using [Astro](https://astro.build/), add the following to your `astro.config.mjs` ([link to Astro docs on "why" to do this](https://docs.astro.build/en/guides/styling/#import-a-stylesheet-from-an-npm-package)):
```javascript
export default defineConfig({
vite: {
ssr: {
noExternal: ["avaya-neo-react"],
},
},
});
```**NOTE**: The Neo CSS Library is included with the Neo React Library. If you install the Neo React Library, you _do not_ need to install or import from the CSS Library.
## Project Recommendations
### [Vite w/ TS](https://vitejs.dev/guide/)
This team has experience building projects (both apps and libraries) using [CRA (create-react-app)](https://create-react-app.dev/), [Vite](https://vitejs.dev/), [Webpack](https://webpack.js.org/), [Parcel](https://parceljs.org/), and [Rollup](https://www.rollupjs.org/guide/en/). Of those, we recommend using Vite to build out brand-new projects. Vite has shown itself to be not only a faster build tool, but also to be a better DX (Developer eXperience) due to its excellent documentation and intelligent defaults. [See this article](https://blog.logrocket.com/vite-3-vs-create-react-app-comparison-migration-guide/) for some further details on those points.
Example app creation with Vite using React+TS: `pnpm create vite my-react-ts-app --template react-ts`
This team also has experience building projects with the package managers NPM, [Yarn (classic)](https://classic.yarnpkg.com/lang/en/docs/install/), and [PNPM](https://pnpm.io/installation). Of the three, we have had good experiences with both Yarn (classic) and PNPM and recommend either of those.
## Adding to this library
If you would like to contribute to this project, you can start in our [how to dev doc](https://github.com/avaya-dux/neo-react-library/blob/main/readmes/how-to-dev.md)
## other readme files
- [accessibility guidelines](https://github.com/avaya-dux/neo-react-library/blob/main/readmes/accessibility-guidelines.md)
- [coding guidelines](https://github.com/avaya-dux/neo-react-library/blob/main/readmes/coding-guidelines.md)
- [how to dev](https://github.com/avaya-dux/neo-react-library/blob/main/readmes/how-to-dev.md)
- [how to publish](https://github.com/avaya-dux/neo-react-library/blob/main/readmes/how-to-publish.md)
- [periphery tech](https://github.com/avaya-dux/neo-react-library/blob/main/readmes/periphery-tech.md)
- [pr best practices](https://github.com/avaya-dux/neo-react-library/blob/main/readmes/pr-best-practices.md)## License
Copyright 2020-2024 Avaya Inc. All Rights Reserved.