Skip to content

Commit

Permalink
- configuration of the minimum, maximum, tick amount of the y-axis
Browse files Browse the repository at this point in the history
  • Loading branch information
marineusde committed Jan 31, 2024
1 parent 585e17b commit cf2b21d
Show file tree
Hide file tree
Showing 2 changed files with 88 additions and 47 deletions.
60 changes: 50 additions & 10 deletions src/LarapexChart.php
Original file line number Diff line number Diff line change
Expand Up @@ -40,6 +40,10 @@ class LarapexChart
protected string $dataLabels;
protected string $theme = 'light';
protected string $sparkline;
protected bool $yAxisShow = false;
protected ?int $yAxisMin = null;
protected ?int $yAxisMax = null;
protected ?int $yAxisTickAmount = null;
private string $chartLetters = 'abcdefghijklmnopqrstuvwxyz';

/*
Expand Down Expand Up @@ -133,11 +137,11 @@ public function setType($type = null) :LarapexChart
return $this;
}

public function setFontFamily($fontFamily) :LarapexChart
{
$this->fontFamily = $fontFamily;
return $this;
}
public function setFontFamily($fontFamily) :LarapexChart
{
$this->fontFamily = $fontFamily;
return $this;
}

public function setFontColor($fontColor) :LarapexChart
{
Expand Down Expand Up @@ -200,6 +204,16 @@ public function setXAxis(array $categories) :LarapexChart
return $this;
}

public function setYAxis(int $min, int $max, ?int $tickAmount = null, bool $show = true) :self
{
$this->yAxisMin = $min;
$this->yAxisMax = $max;
$this->yAxisTickAmount = $tickAmount ?? $max;
$this->yAxisShow = $show;

return $this;
}

public function setGrid($color = '#e5e5e5', $opacity = 0.1) :LarapexChart
{
$this->grid = json_encode([
Expand Down Expand Up @@ -263,9 +277,9 @@ public function setDataLabels(bool $enabled = true) :LarapexChart
public function setTheme(string $theme) :LarapexChart
{
$this->theme = $theme;
return $this;
return $this;
}

public function setSparkline(bool $enabled = true): LarapexChart
{
$this->sparkline = json_encode(['enabled' => $enabled]);
Expand Down Expand Up @@ -332,10 +346,10 @@ public function type(): string
return $this->type;
}

public function fontFamily(): string
public function fontFamily(): string
{
return $this->fontFamily;
}
return $this->fontFamily;
}

public function foreColor(): string
{
Expand Down Expand Up @@ -417,6 +431,24 @@ public function stacked(): bool
return $this->stacked;
}

public function yAxis(): ?array
{
if (
$this->yAxisMin === null ||
$this->yAxisMax === null ||
$this->yAxisTickAmount === null
) {
return null;
}

return [
'show' => $this->yAxisShow ? 'true' : 'false',
'min' => $this->yAxisMin,
'max' => $this->yAxisMax,
'tickAmount' => $this->yAxisTickAmount
];
}

/*
|--------------------------------------------------------------------------
| JSON Options Builder
Expand Down Expand Up @@ -468,6 +500,10 @@ public function toJson(): \Illuminate\Http\JsonResponse
$options['stroke'] = json_decode($this->stroke());
}

if($this->yAxis() !== null) {
$options['yaxis'] = $this->yAxis();
}

return response()->json([
'id' => $this->id(),
'options' => $options,
Expand Down Expand Up @@ -522,6 +558,10 @@ public function toVue() :array
$options['stroke'] = json_decode($this->stroke());
}

if($this->yAxis() !== null) {
$options['yaxis'] = $this->yAxis();
}

return [
'height' => $this->height(),
'width' => $this->width(),
Expand Down
75 changes: 38 additions & 37 deletions stubs/resources/views/chart/script.blade.php
Original file line number Diff line number Diff line change
@@ -1,44 +1,45 @@
<script>
var options =
{
chart: {
type: '{!! $chart->type() !!}',
height: {!! $chart->height() !!},
width: '{!! $chart->width() !!}',
toolbar: {!! $chart->toolbar() !!},
zoom: {!! $chart->zoom() !!},
fontFamily: '{!! $chart->fontFamily() !!}',
foreColor: '{!! $chart->foreColor() !!}',
sparkline: {!! $chart->sparkline() !!},
@if($chart->stacked())
stacked: {!! $chart->stacked() !!},
@endif
},
plotOptions: {
bar: {!! $chart->horizontal() !!}
},
colors: {!! $chart->colors() !!},
series: {!! $chart->dataset() !!},
dataLabels: {!! $chart->dataLabels() !!},
@if($chart->labels())
{
chart: {
type: '{!! $chart->type() !!}',
height: {!! $chart->height() !!},
width: '{!! $chart->width() !!}',
toolbar: {!! $chart->toolbar() !!},
zoom: {!! $chart->zoom() !!},
fontFamily: '{!! $chart->fontFamily() !!}',
foreColor: '{!! $chart->foreColor() !!}',
sparkline: {!! $chart->sparkline() !!},
@if($chart->stacked())
stacked: {!! $chart->stacked() !!},
@endif
},
plotOptions: {
bar: {!! $chart->horizontal() !!}
},
colors: {!! $chart->colors() !!},
series: {!! $chart->dataset() !!},
dataLabels: {!! $chart->dataLabels() !!},
@if($chart->labels())
labels: {!! json_encode($chart->labels(), true) !!},
@endif
title: {
text: "{!! $chart->title() !!}"
},
subtitle: {
text: '{!! $chart->subtitle() !!}',
align: '{!! $chart->subtitlePosition() !!}'
},
xaxis: {
categories: {!! $chart->xAxis() !!}
},
grid: {!! $chart->grid() !!},
markers: {!! $chart->markers() !!},
@if($chart->stroke())
@endif
title: {
text: "{!! $chart->title() !!}"
},
subtitle: {
text: '{!! $chart->subtitle() !!}',
align: '{!! $chart->subtitlePosition() !!}'
},
xaxis: {
categories: {!! $chart->xAxis() !!}
},
yaxis: {!! json_encode($chart->yAxis(), true) !!},
grid: {!! $chart->grid() !!},
markers: {!! $chart->markers() !!},
@if($chart->stroke())
stroke: {!! $chart->stroke() !!},
@endif
}
@endif
}
var chart = new ApexCharts(document.querySelector("#{!! $chart->id() !!}"), options);
chart.render();
Expand Down

0 comments on commit cf2b21d

Please sign in to comment.