Skip to content

Commit

Permalink
[docs] Polish the first experience
Browse files Browse the repository at this point in the history
  • Loading branch information
oliviertassinari committed Sep 10, 2020
1 parent cde8cee commit d9b8141
Show file tree
Hide file tree
Showing 31 changed files with 463 additions and 387 deletions.
3 changes: 3 additions & 0 deletions docs/public/_redirects
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
# Proxies
# material-ui-x is configured to be hosted at the root.
/static/* https://material-ui.netlify.app/static/:splat 200
Original file line number Diff line number Diff line change
Expand Up @@ -27,22 +27,22 @@ const rows = [
},
];

const valueFormatter = new Intl.NumberFormat('en-US', {
const currencyFormatter = new Intl.NumberFormat('en-US', {
style: 'currency',
currency: 'USD',
});

const usdPrice = {
type: 'number',
width: 130,
valueFormatter: ({ value }) => valueFormatter.format(Number(value)),
valueFormatter: ({ value }) => currencyFormatter.format(Number(value)),
cellClassName: 'font-tabular-nums',
};

const useStyles = makeStyles({
root: {
'& .font-tabular-nums': {
fontVariantNumeric: 'font-tabular-nums',
fontVariantNumeric: 'tabular-nums',
},
},
});
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -27,22 +27,22 @@ const rows = [
},
];

const valueFormatter = new Intl.NumberFormat('en-US', {
const currencyFormatter = new Intl.NumberFormat('en-US', {
style: 'currency',
currency: 'USD',
});

const usdPrice: ColTypeDef = {
type: 'number',
width: 130,
valueFormatter: ({ value }) => valueFormatter.format(Number(value)),
valueFormatter: ({ value }) => currencyFormatter.format(Number(value)),
cellClassName: 'font-tabular-nums',
};

const useStyles = makeStyles({
root: {
'& .font-tabular-nums': {
fontVariantNumeric: 'font-tabular-nums',
fontVariantNumeric: 'tabular-nums',
},
},
});
Expand Down
15 changes: 8 additions & 7 deletions docs/src/pages/components/data-grid/overview/DataGridDemo.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,21 @@ import * as React from 'react';
import { DataGrid } from '@material-ui/data-grid';

const columns = [
{ field: 'id' },
{ field: 'firstName' },
{ field: 'lastName' },
{ field: 'id', headerName: 'ID', width: 70 },
{ field: 'firstName', headerName: 'First name', width: 130 },
{ field: 'lastName', headerName: 'Last name', width: 130 },
{
field: 'age',
cellClassName: ['age'],
headerClassName: ['age'],
headerName: 'Age',
type: 'number',
width: 90,
},
{
field: 'fullName',
description: 'this column has a value getter and is not sortable',
headerClassName: 'highlight',
headerName: 'Full name',
description: 'This column has a value getter and is not sortable.',
sortable: false,
width: 160,
valueGetter: (params) =>
`${params.getValue('firstName') || ''} ${
params.getValue('lastName') || ''
Expand Down
15 changes: 8 additions & 7 deletions docs/src/pages/components/data-grid/overview/DataGridDemo.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -2,20 +2,21 @@ import * as React from 'react';
import { DataGrid, ColDef } from '@material-ui/data-grid';

const columns: ColDef[] = [
{ field: 'id' },
{ field: 'firstName' },
{ field: 'lastName' },
{ field: 'id', headerName: 'ID', width: 70 },
{ field: 'firstName', headerName: 'First name', width: 130 },
{ field: 'lastName', headerName: 'Last name', width: 130 },
{
field: 'age',
cellClassName: ['age'],
headerClassName: ['age'],
headerName: 'Age',
type: 'number',
width: 90,
},
{
field: 'fullName',
description: 'this column has a value getter and is not sortable',
headerClassName: 'highlight',
headerName: 'Full name',
description: 'This column has a value getter and is not sortable.',
sortable: false,
width: 160,
valueGetter: (params) =>
`${params.getValue('firstName') || ''} ${
params.getValue('lastName') || ''
Expand Down
5 changes: 2 additions & 3 deletions packages/grid/data-grid/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,13 +14,12 @@ npm install @material-ui/data-grid
yarn add @material-ui/data-grid
```

This component has 3 peer dependencies that you will need to install as well.
This component has 2 peer dependencies that you will need to install as well.

```json
"peerDependencies": {
"@material-ui/core": "^4.9.12",
"react": "^16.8.0",
"styled-components": "^5.1.0"
"react": "^16.8.0"
},
```

Expand Down
17 changes: 8 additions & 9 deletions packages/grid/x-grid-data-generator/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,13 @@
"bin": {
"datagen": "./bin/data-gen-script.js"
},
"scripts": {
"precommit": "npm run lint",
"build": "rollup -c",
"start": "rollup -cw",
"lint": "../../../node_modules/.bin/tsc --noEmit && eslint 'src/**/*.{ts,tsx}' --quiet --fix -c ../../../.eslintrc.js && npm run lint:css",
"lint:css": "stylelint 'src/**/*.{ts,tsx}' ../../../.stylelintrc.js"
},
"dependencies": {
"@types/chance": "^1.1.0",
"chance": "^1.1.6",
Expand All @@ -42,15 +49,7 @@
"@material-ui/icons": "^4.9.1",
"@material-ui/lab": "^4.0.0-alpha.54",
"@material-ui/x-grid": "^0.1.35",
"react": "^16.8.0",
"styled-components": "^5.1.0"
},
"scripts": {
"precommit": "npm run lint",
"build": "rollup -c",
"start": "rollup -cw",
"lint": "../../../node_modules/.bin/tsc --noEmit && eslint 'src/**/*.{ts,tsx}' --quiet --fix -c ../../../.eslintrc.js && npm run lint:css",
"lint:css": "stylelint 'src/**/*.{ts,tsx}' ../../../.stylelintrc.js"
"react": "^16.8.0"
},
"setupFiles": [
"<rootDir>/src/setupTests.js"
Expand Down
48 changes: 18 additions & 30 deletions packages/grid/x-grid-data-generator/src/commodities.columns.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -32,20 +32,16 @@ import {
randomTaxCode,
} from './services';
import {
CountryRenderer,
DoneRenderer,
EmailRenderer,
IncotermRenderer,
ProgressRenderer,
StatusRenderer,
renderCountry,
renderDone,
renderEmail,
renderIncoterm,
renderPnl,
renderProgress,
renderStatus,
renderTotalPrice,
} from './renderer';

const totalPriceFormatter = ({ value }) => `$ ${Number(value).toLocaleString()}`;
const pnlFormatter = (params) =>
Number(params.value!) < 0
? `(${Math.abs(Number(params.value!)).toLocaleString()})`
: Number(params.value).toLocaleString();

export const commodityColumns: any[] = [
{
field: 'id',
Expand Down Expand Up @@ -73,7 +69,7 @@ export const commodityColumns: any[] = [
field: 'traderEmail',
headerName: 'Trader Email',
generateData: randomEmail,
renderCell: EmailRenderer,
renderCell: renderEmail,
disableClickEventBubbling: true,
width: 150,
},
Expand All @@ -88,14 +84,14 @@ export const commodityColumns: any[] = [
field: 'filledQuantity',
headerName: 'Filled Quantity',
generateData: generateFilledQuantity,
renderCell: ProgressRenderer,
renderCell: renderProgress,
type: 'number',
width: 120,
},
{
field: 'isFilled',
headerName: 'Is Filled',
renderCell: DoneRenderer,
renderCell: renderDone,
align: 'center',
generateData: generateIsFilled,
width: 80,
Expand All @@ -104,7 +100,7 @@ export const commodityColumns: any[] = [
field: 'status',
headerName: 'Status',
generateData: randomStatusOptions,
renderCell: StatusRenderer,
renderCell: renderStatus,
width: 150,
},
{
Expand Down Expand Up @@ -143,31 +139,23 @@ export const commodityColumns: any[] = [
{
field: 'incoTerm',
generateData: randomIncoterm,
renderCell: IncotermRenderer,
renderCell: renderIncoterm,
},
{
field: 'totalPrice',
headerName: 'Total in USD',
generateData: generateTotalPrice,
valueFormatter: totalPriceFormatter,
cellClassRules: {
good: ({ value }) => Number(value) > 1000000,
bad: ({ value }) => Number(value) < 1000000,
},
renderCell: renderTotalPrice,
type: 'number',
width: 120,
width: 160,
},
{
field: 'pnl',
headerName: 'PnL',
generateData: randomPnL,
valueFormatter: pnlFormatter,
cellClassRules: {
positive: ({ value }) => Number(value) > 0,
negative: ({ value }) => Number(value) < 0,
},
renderCell: renderPnl,
type: 'number',
width: 120,
width: 140,
},
{
field: 'maturityDate',
Expand Down Expand Up @@ -203,7 +191,7 @@ export const commodityColumns: any[] = [
field: 'counterPartyCountry',
headerName: 'Counterparty Country',
generateData: randomCountry,
renderCell: CountryRenderer,
renderCell: renderCountry,
width: 120,
},
{
Expand Down
18 changes: 6 additions & 12 deletions packages/grid/x-grid-data-generator/src/employees.columns.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -15,13 +15,7 @@ import {
randomUrl,
randomUserName,
} from './services';
import {
AvatarRenderer,
CountryRenderer,
EmailRenderer,
LinkRenderer,
RatingRenderer,
} from './renderer';
import { renderAvatar, renderCountry, renderEmail, renderLink, renderRating } from './renderer';

export const employeeColumns: any[] = [
{
Expand All @@ -34,7 +28,7 @@ export const employeeColumns: any[] = [
headerName: '',
sortable: false,
generateData: randomAvatar,
renderCell: AvatarRenderer,
renderCell: renderAvatar,
},
{
field: 'name',
Expand All @@ -49,7 +43,7 @@ export const employeeColumns: any[] = [
field: 'email',
headerName: 'Email',
generateData: randomEmail,
renderCell: EmailRenderer,
renderCell: renderEmail,
disableClickEventBubbling: true,
width: 150,
},
Expand All @@ -69,14 +63,14 @@ export const employeeColumns: any[] = [
field: 'website',
headerName: 'website',
generateData: randomUrl,
renderCell: LinkRenderer,
renderCell: renderLink,
width: 160,
},
{
field: 'rating',
headerName: 'Rating',
generateData: randomRating,
renderCell: RatingRenderer,
renderCell: renderRating,
sortDirection: 'desc',
sortIndex: 0,
width: 180,
Expand All @@ -90,7 +84,7 @@ export const employeeColumns: any[] = [
field: 'country',
headerName: 'Country',
generateData: randomCountry,
renderCell: CountryRenderer,
renderCell: renderCountry,
width: 150,
},
{
Expand Down

This file was deleted.

13 changes: 0 additions & 13 deletions packages/grid/x-grid-data-generator/src/renderer/done-renderer.tsx

This file was deleted.

Loading

0 comments on commit d9b8141

Please sign in to comment.