@djammadev/react-lib
v2.0.2
Published
Djamma Dev React Library
Downloads
26
Readme
@djammadev/react-lib
Djamma Dev React Library
Install
npm install --save @djammadev/react-lib
Usage
import React, {useEffect, useState} from 'react'
import {DDAlert, DDChart, DDDataGrid, ExampleComponent, sendInfoAlert, sendSuccessAlert} from '@djammadev/react-lib'
import {Button, Container} from '@material-ui/core'
import {createMuiTheme, makeStyles, ThemeProvider} from '@material-ui/core/styles';
import {blue, green} from '@material-ui/core/colors';
import '@djammadev/react-lib/dist/index.css'
const useStyles = makeStyles((theme) => ({
margin: {
margin: theme.spacing(1),
},
}));
const App = () => {
const columns = [
{field: 'col1', headerName: 'Column 1', width: 250},
{field: 'col2', headerName: 'Column 2', width: 150, resizable: true},
];
const rows = [
{id: 1, col1: 'Hello', col2: 'World'},
{id: 2, col1: 'XGrid', col2: 'is Awesome'},
{id: 3, col1: 'Material-UI', col2: 'is Amazing'},
];
const [gridApi, setGridApi] = useState(null);
const [data, setData] = useState([]);
const onGridReady = (params) => {
setGridApi(params.api);
params.api.setRowData(rows)
params.api.setColumnDefs(columns);
}
useEffect(() => {
sendInfoAlert({
title: 'This is an info',
message: "I'm the best for ever...",
timeout: 1000
});
fetch('/users.json')
.then(res => res.json())
.then(response => setData(response.entities))
}, [gridApi]);
const columnMapper = (column) => {
let mapping = {
"String": "text",
"Integer": "number",
"Short": "number",
"Long": "number",
"Double": "number",
"Date": "date",
"List": "array"
}
let myColumn = Object.assign({}, column);
myColumn.type = mapping[myColumn.type] || myColumn.type;
return myColumn;
}
const theme = createMuiTheme({
palette: {
primary: green,
secondary: blue,
},
});
const getLabels = (data) => {
return ['Red', 'Blue', 'Yellow', 'Green', 'Purple', 'Orange'];
}
const getData = (data) => {
return [12, 19, 3, 5, 2, 3];
}
const getLabelColor = (data) => {
return [
{r: 255, g: 99, b: 132, a: 0.2},
{r: 54, g: 162, b: 235, a: 0.2},
{r: 255, g: 206, b: 86, a: 0.2},
{r: 75, g: 192, b: 192, a: 0.2},
{r: 153, g: 102, b: 255, a: 0.2},
{r: 255, g: 159, b: 64, a: 0.2}
]
}
const classes = useStyles();
return <Container>
<DDAlert show={true}/>
<ExampleComponent text="Djamma Dev React Library Example 😄"/>
<ThemeProvider theme={theme}>
<Button variant="contained" color="secondary" className={classes.margin} onClick={(e) => {
console.log('----');
sendInfoAlert({
title: 'This is an info notification',
message: "I'm the best for ever...",
timeout: 5000
});
}}>Alert Info</Button>
</ThemeProvider>
<ThemeProvider theme={theme}>
<Button variant="contained" color="primary" className={classes.margin} onClick={(e) => {
sendSuccessAlert({
title: 'This is a success notification',
message: "I'm the best for ever...",
timeout: 5000
});
}}>Alert Success</Button>
</ThemeProvider>
<h2>Auto load data</h2>
<DDDataGrid
rowModelType={"infinite"}
columnsPath={"descriptions/user.json"}
dataPath={"users.json"}
columns={columns}
rows={rows}
columnMapper={columnMapper}
style={{height: 300, width: '100%', marginBottom: 20}}/>
<h2>Passing data from parent</h2>
<DDDataGrid
onGridReady={onGridReady}
columns={columns}
rows={rows}
style={{height: 300, width: '100%', marginBottom: 20}}/>
<h2>Chart Js</h2>
<DDChart getLabels={getLabels} getData={getData} getLabelColor={getLabelColor} height={100} width={400}/>
<h2>Chart With Data</h2>
<DDChart type={"doughnut"} labelKey={"promotion"} data={data} height={100} width={400}/>
</Container>
}
export default App;
License
MIT © mcicheick