Area Chart
An area chart is a visual representation that shows quantitative data as a series of points connected by straight line segments, filled below with color.
Source
@saas-ui/charts
- 2.10.0 (latest)
Import
import { AreaChart } from '@saas-ui/charts'
Usage
Basic
Basic composition with Card
and Heading
components. AreaChart
requires a fixed height (eg height="300px"
) to render properly.
import { Card, CardBody, CardHeader, Heading } from '@chakra-ui/react'import { AreaChart } from '@saas-ui/charts'const valueFormatter = (value) => {return new Intl.NumberFormat('en-US', {style: 'currency',currency: 'USD',}).format(value)}export default function Page() {return (<Card><CardHeader pb="0"><Heading as="h4" fontWeight="medium" size="md">Revenue over time</Heading></CardHeader><CardBody><AreaChartdata={data}categories={['Revenue']}valueFormatter={valueFormatter}yAxisWidth={80}height="300px"/></CardBody></Card>)}const data = [{date: 'Jan 1',Revenue: 1475,},{date: 'Jan 8',Revenue: 1936,},{date: 'Jan 15',Revenue: 1555,},{date: 'Jan 22',Revenue: 1557,},{date: 'Jan 29',Revenue: 1977,},{date: 'Feb 5',Revenue: 2315,},{date: 'Feb 12',Revenue: 1736,},{date: 'Feb 19',Revenue: 1981,},{date: 'Feb 26',Revenue: 2581,},{date: 'Mar 5',Revenue: 2592,},{date: 'Mar 12',Revenue: 2635,},{date: 'Mar 19',Revenue: 2074,},{date: 'Mar 26',Revenue: 2984,},{date: 'Apr 2',Revenue: 2254,},{date: 'Apr 9',Revenue: 3159,},{date: 'Apr 16',Revenue: 2804,},{date: 'Apr 23',Revenue: 2602,},{date: 'Apr 30',Revenue: 2840,},{date: 'May 7',Revenue: 3299,},{date: 'May 14',Revenue: 3487,},{date: 'May 21',Revenue: 3439,},{date: 'May 28',Revenue: 3095,},{date: 'Jun 4',Revenue: 3252,},{date: 'Jun 11',Revenue: 4096,},{date: 'Jun 18',Revenue: 4193,},{date: 'Jun 25',Revenue: 4759,},]
Multiple categories
Multiple categories can be displayed in the same chart. Categories map to the data
object keys.
import { Card, CardBody, CardHeader, Heading } from '@chakra-ui/react'import { AreaChart } from '@saas-ui/charts'export default function Page() {return (<Card><CardHeader pb="0"><Heading as="h4" fontWeight="medium" size="md">Developers</Heading></CardHeader><CardBody><AreaChartdata={data}categories={['Backend', 'Frontend']}height="300px"/></CardBody></Card>)}const data = [{date: 'Dec 1',Backend: 40,Frontend: 21,},{date: 'Dec 2',Backend: 38,Frontend: 22,},{date: 'Dec 3',Backend: 49,Frontend: 22,},{date: 'Dec 4',Backend: 48,Frontend: 29,},{date: 'Dec 5',Backend: 50,Frontend: 22,},{date: 'Dec 6',Backend: 42,Frontend: 30,},{date: 'Dec 7',Backend: 41,Frontend: 28,},{date: 'Dec 8',Backend: 44,Frontend: 23,},{date: 'Dec 9',Backend: 44,Frontend: 24,},{date: 'Dec 10',Backend: 44,Frontend: 30,},{date: 'Dec 11',Backend: 46,Frontend: 25,},{date: 'Dec 12',Backend: 48,Frontend: 25,},{date: 'Dec 13',Backend: 46,Frontend: 25,},{date: 'Dec 14',Backend: 50,Frontend: 28,},{date: 'Dec 15',Backend: 42,Frontend: 34,},{date: 'Dec 16',Backend: 58,Frontend: 33,},{date: 'Dec 17',Backend: 49,Frontend: 35,},{date: 'Dec 18',Backend: 44,Frontend: 33,},{date: 'Dec 19',Backend: 46,Frontend: 35,},{date: 'Dec 20',Backend: 44,Frontend: 35,},{date: 'Dec 21',Backend: 51,Frontend: 30,},{date: 'Dec 22',Backend: 58,Frontend: 36,},{date: 'Dec 23',Backend: 46,Frontend: 30,},{date: 'Dec 24',Backend: 61,Frontend: 30,},{date: 'Dec 25',Backend: 56,Frontend: 33,},{date: 'Dec 26',Backend: 55,Frontend: 33,},{date: 'Dec 27',Backend: 47,Frontend: 32,},{date: 'Dec 28',Backend: 55,Frontend: 33,},{date: 'Dec 29',Backend: 61,Frontend: 32,},{date: 'Dec 30',Backend: 62,Frontend: 29,},{date: 'Dec 31',Backend: 52,Frontend: 37,},]
Customize colors
Use the colors
prop to customize the chart colors. Supported formats are primary
, purple
, purple.400
, or #4FD1C5
.
import { Card, CardBody, CardHeader, Heading } from '@chakra-ui/react'import { AreaChart } from '@saas-ui/charts'export default function Page() {return (<Card><CardHeader pb="0"><Heading as="h4" fontWeight="medium" size="md">Developers</Heading></CardHeader><CardBody><AreaChartdata={data}categories={['Backend', 'Frontend']}colors={['orange', 'yellow']}height="300px"/></CardBody></Card>)}const data = [{date: 'Dec 1',Backend: 40,Frontend: 21,},{date: 'Dec 2',Backend: 38,Frontend: 22,},{date: 'Dec 3',Backend: 49,Frontend: 22,},{date: 'Dec 4',Backend: 48,Frontend: 29,},{date: 'Dec 5',Backend: 50,Frontend: 22,},{date: 'Dec 6',Backend: 42,Frontend: 30,},{date: 'Dec 7',Backend: 41,Frontend: 28,},{date: 'Dec 8',Backend: 44,Frontend: 23,},{date: 'Dec 9',Backend: 44,Frontend: 24,},{date: 'Dec 10',Backend: 44,Frontend: 30,},{date: 'Dec 11',Backend: 46,Frontend: 25,},{date: 'Dec 12',Backend: 48,Frontend: 25,},{date: 'Dec 13',Backend: 46,Frontend: 25,},{date: 'Dec 14',Backend: 50,Frontend: 28,},{date: 'Dec 15',Backend: 42,Frontend: 34,},{date: 'Dec 16',Backend: 58,Frontend: 33,},{date: 'Dec 17',Backend: 49,Frontend: 35,},{date: 'Dec 18',Backend: 44,Frontend: 33,},{date: 'Dec 19',Backend: 46,Frontend: 35,},{date: 'Dec 20',Backend: 44,Frontend: 35,},{date: 'Dec 21',Backend: 51,Frontend: 30,},{date: 'Dec 22',Backend: 58,Frontend: 36,},{date: 'Dec 23',Backend: 46,Frontend: 30,},{date: 'Dec 24',Backend: 61,Frontend: 30,},{date: 'Dec 25',Backend: 56,Frontend: 33,},{date: 'Dec 26',Backend: 55,Frontend: 33,},{date: 'Dec 27',Backend: 47,Frontend: 32,},{date: 'Dec 28',Backend: 55,Frontend: 33,},{date: 'Dec 29',Backend: 61,Frontend: 32,},{date: 'Dec 30',Backend: 62,Frontend: 29,},{date: 'Dec 31',Backend: 52,Frontend: 37,},]
Stacked
Categories can be stacked using the stack
prop. Stacked charts are useful for displaying cumulative data of multiple categories over time.
import { Card, CardBody, CardHeader, Heading } from '@chakra-ui/react'import { AreaChart } from '@saas-ui/charts'export default function Page() {return (<Card><CardHeader pb="0"><Heading as="h4" fontWeight="medium" size="md">Customer types</Heading></CardHeader><CardBody><AreaChartdata={data}categories={['New', 'Active', 'Churned']}colors={['green', 'blue', 'red']}variant="solid"height="300px"stack/></CardBody></Card>)}const data = [{date: 'Dec 1',New: 46,Active: 26,Churned: 2,},{date: 'Dec 2',New: 47,Active: 23,Churned: 2,},{date: 'Dec 3',New: 40,Active: 25,Churned: 2,},{date: 'Dec 4',New: 50,Active: 28,Churned: 2,},{date: 'Dec 5',New: 53,Active: 31,Churned: 2,},{date: 'Dec 6',New: 61,Active: 34,Churned: 2,},{date: 'Dec 7',New: 65,Active: 37,Churned: 2,},{date: 'Dec 8',New: 54,Active: 39,Churned: 3,},{date: 'Dec 9',New: 55,Active: 43,Churned: 3,},{date: 'Dec 10',New: 64,Active: 40,Churned: 2,},{date: 'Dec 11',New: 65,Active: 46,Churned: 2,},{date: 'Dec 12',New: 68,Active: 42,Churned: 3,},{date: 'Dec 13',New: 88,Active: 51,Churned: 4,},{date: 'Dec 14',New: 81,Active: 44,Churned: 3,},{date: 'Dec 15',New: 83,Active: 51,Churned: 3,},{date: 'Dec 16',New: 97,Active: 52,Churned: 4,},{date: 'Dec 17',New: 106,Active: 51,Churned: 4,},{date: 'Dec 18',New: 106,Active: 58,Churned: 5,},{date: 'Dec 19',New: 112,Active: 51,Churned: 4,},{date: 'Dec 20',New: 121,Active: 60,Churned: 4,},{date: 'Dec 21',New: 100,Active: 73,Churned: 5,},{date: 'Dec 22',New: 135,Active: 63,Churned: 5,},{date: 'Dec 23',New: 109,Active: 79,Churned: 4,},{date: 'Dec 24',New: 130,Active: 84,Churned: 5,},{date: 'Dec 25',New: 126,Active: 88,Churned: 6,},{date: 'Dec 26',New: 163,Active: 98,Churned: 5,},{date: 'Dec 27',New: 133,Active: 106,Churned: 7,},{date: 'Dec 28',New: 180,Active: 97,Churned: 7,},{date: 'Dec 29',New: 138,Active: 89,Churned: 7,},{date: 'Dec 30',New: 147,Active: 108,Churned: 6,},{date: 'Dec 31',New: 168,Active: 115,Churned: 8,},]
Was this helpful?