109 lines
3.4 KiB
Vue
109 lines
3.4 KiB
Vue
|
<template>
|
||
|
<DocSectionText v-bind="$attrs">
|
||
|
<p>
|
||
|
A chart is configured with 3 properties; <i>type</i>, <i>data</i> and <i>options</i>. Chart type is defined using the <i>type</i> property that accepts <i>pie</i>, <i>doughtnut</i>, <i>line</i>, <i>bar</i>, <i>radar</i> and
|
||
|
<i>polarArea</i> as a value. The <i>data</i> defines datasets represented with the chart and the <i>options</i> provide numerous customization options to customize the presentation.
|
||
|
</p>
|
||
|
</DocSectionText>
|
||
|
<div class="card">
|
||
|
<Chart type="bar" :data="chartData" :options="chartOptions" />
|
||
|
</div>
|
||
|
<DocSectionCode :code="code" :dependencies="{ 'chart.js': '3.3.2' }" component="Chart" />
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
export default {
|
||
|
data() {
|
||
|
return {
|
||
|
chartData: {
|
||
|
labels: ['Q1', 'Q2', 'Q3', 'Q4'],
|
||
|
datasets: [
|
||
|
{
|
||
|
label: 'Sales',
|
||
|
data: [540, 325, 702, 620],
|
||
|
backgroundColor: ['rgba(255, 159, 64, 0.2)', 'rgba(75, 192, 192, 0.2)', 'rgba(54, 162, 235, 0.2)', 'rgba(153, 102, 255, 0.2)'],
|
||
|
borderColor: ['rgb(255, 159, 64)', 'rgb(75, 192, 192)', 'rgb(54, 162, 235)', 'rgb(153, 102, 255)'],
|
||
|
borderWidth: 1
|
||
|
}
|
||
|
]
|
||
|
},
|
||
|
chartOptions: {
|
||
|
scales: {
|
||
|
y: {
|
||
|
beginAtZero: true
|
||
|
}
|
||
|
}
|
||
|
},
|
||
|
code: {
|
||
|
basic: `
|
||
|
<Chart type="bar" :data="chartData" :options="chartOptions" />`,
|
||
|
options: `
|
||
|
<template>
|
||
|
<div class="card">
|
||
|
<Chart type="bar" :data="chartData" :options="chartOptions" />
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script>
|
||
|
export default {
|
||
|
data() {
|
||
|
return {
|
||
|
chartData: {
|
||
|
labels: ['Q1', 'Q2', 'Q3', 'Q4'],
|
||
|
datasets: [
|
||
|
{
|
||
|
label: 'Sales',
|
||
|
data: [540, 325, 702, 620],
|
||
|
backgroundColor: ['rgba(255, 159, 64, 0.2)', 'rgba(75, 192, 192, 0.2)', 'rgba(54, 162, 235, 0.2)', 'rgba(153, 102, 255, 0.2)'],
|
||
|
borderColor: ['rgb(255, 159, 64)', 'rgb(75, 192, 192)', 'rgb(54, 162, 235)', 'rgb(153, 102, 255)'],
|
||
|
borderWidth: 1
|
||
|
}
|
||
|
]
|
||
|
},
|
||
|
chartOptions: {
|
||
|
scales: {
|
||
|
y: {
|
||
|
beginAtZero: true
|
||
|
}
|
||
|
}
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
};
|
||
|
<\/script>`,
|
||
|
composition: `
|
||
|
<template>
|
||
|
<div class="card">
|
||
|
<Chart type="bar" :data="chartData" :options="chartOptions" />
|
||
|
</div>
|
||
|
</template>
|
||
|
|
||
|
<script setup>
|
||
|
import { ref } from "vue";
|
||
|
|
||
|
const chartData = ref({
|
||
|
labels: ['Q1', 'Q2', 'Q3', 'Q4'],
|
||
|
datasets: [
|
||
|
{
|
||
|
label: 'Sales',
|
||
|
data: [540, 325, 702, 620],
|
||
|
backgroundColor: ['rgba(255, 159, 64, 0.2)', 'rgba(75, 192, 192, 0.2)', 'rgba(54, 162, 235, 0.2)', 'rgba(153, 102, 255, 0.2)'],
|
||
|
borderColor: ['rgb(255, 159, 64)', 'rgb(75, 192, 192)', 'rgb(54, 162, 235)', 'rgb(153, 102, 255)'],
|
||
|
borderWidth: 1
|
||
|
}
|
||
|
]
|
||
|
});
|
||
|
const chartOptions = ref({
|
||
|
scales: {
|
||
|
y: {
|
||
|
beginAtZero: true
|
||
|
}
|
||
|
}
|
||
|
});
|
||
|
<\/script>`
|
||
|
}
|
||
|
};
|
||
|
}
|
||
|
};
|
||
|
</script>
|