The ValueMetric
metric is designed to display a value. For example, how many records are in the table.
You can create a ValueMetric
using the static make()
method.
make(Closure|string $label)
make(Closure|string $label)
make(Closure|string $label)
make(Closure|string $label)
make(Closure|string $label)
The value()
method allows you to specify a value for a metric.
value(int|string|float|Closure $value)
value(int|string|float|Closure $value)
value(int|string|float|Closure $value)
value(int|string|float|Closure $value)
value(int|string|float|Closure $value)
use MoonShine\Metrics\ValueMetric;
public function components(): array
{
return [
ValueMetric::make('Completed orders')
->value(Order::completed()->count())
];
}
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Completed orders')
->value(Order::completed()->count())
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Completed orders')
->value(Order::completed()->count())
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Completed orders')
->value(Order::completed()->count())
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Completed orders')
->value(Order::completed()->count())
];
}
//...
data:image/s3,"s3://crabby-images/e7e92/e7e928dae837a8500be188c1d416bfa617baba19" alt="value_metric_dark"
The progress()
method allows you to display a progress indicator for achieving a goal in a metric.
progress(int|float|Closure $target)
progress(int|float|Closure $target)
progress(int|float|Closure $target)
progress(int|float|Closure $target)
progress(int|float|Closure $target)
use MoonShine\Metrics\ValueMetric;
public function components(): array
{
return [
ValueMetric::make('Open tasks')
->value(Task::opened()->count())
->progress(Task::count())
];
}
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Open tasks')
->value(Task::opened()->count())
->progress(Task::count())
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Open tasks')
->value(Task::opened()->count())
->progress(Task::count())
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Open tasks')
->value(Task::opened()->count())
->progress(Task::count())
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Open tasks')
->value(Task::opened()->count())
->progress(Task::count())
];
}
//...
When using a progress bar, the value()
method must be passed a numeric value or a closure that will return a number.
data:image/s3,"s3://crabby-images/0cf56/0cf5651c744c29ee1c5c4adc3fab7d1754c06c47" alt="value_metric_progress_dark"
The valueFormat()
method allows you to format the metric value and add a prefix and suffix.
valueFormat(string|Closure $value)
valueFormat(string|Closure $value)
valueFormat(string|Closure $value)
valueFormat(string|Closure $value)
valueFormat(string|Closure $value)
use MoonShine\Metrics\ValueMetric;
public function components(): array
{
return [
ValueMetric::make('Profit')
->value(Order::completed()->sum('price'))
->valueFormat(fn($value) => \Illuminate\Support\Number::forHumans($value))
];
}
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Profit')
->value(Order::completed()->sum('price'))
->valueFormat(fn($value) => \Illuminate\Support\Number::forHumans($value))
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Profit')
->value(Order::completed()->sum('price'))
->valueFormat(fn($value) => \Illuminate\Support\Number::forHumans($value))
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Profit')
->value(Order::completed()->sum('price'))
->valueFormat(fn($value) => \Illuminate\Support\Number::forHumans($value))
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Profit')
->value(Order::completed()->sum('price'))
->valueFormat(fn($value) => \Illuminate\Support\Number::forHumans($value))
];
}
//...
data:image/s3,"s3://crabby-images/02ceb/02ceba2bd075d45700f16050db5aa31bdd1f3d16" alt="value_metric_format_dark"
The icon()
method allows you to add an icon to the metric.
use MoonShine\Metrics\ValueMetric;
public function components(): array
{
return [
ValueMetric::make('Orders')
->value(Order::count())
->icon('heroicons.shopping-bag')
];
}
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Orders')
->value(Order::count())
->icon('heroicons.shopping-bag')
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Orders')
->value(Order::count())
->icon('heroicons.shopping-bag')
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Orders')
->value(Order::count())
->icon('heroicons.shopping-bag')
];
}
//...
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
ValueMetric::make('Orders')
->value(Order::count())
->icon('heroicons.shopping-bag')
];
}
//...
For more detailed information, please refer to the section Icons.
data:image/s3,"s3://crabby-images/2aa1d/2aa1d1f57b5a49eb7408b54e1a4a95f5552d9891" alt="value_metric_icon_dark"
Method columnSpan()
allows you to set the block width in the Grid grid.
columnSpan(
int $columnSpan,
int $adaptiveColumnSpan = 12
)
columnSpan(
int $columnSpan,
int $adaptiveColumnSpan = 12
)
columnSpan(
int $columnSpan,
int $adaptiveColumnSpan = 12
)
columnSpan(
int $columnSpan,
int $adaptiveColumnSpan = 12
)
columnSpan(
int $columnSpan,
int $adaptiveColumnSpan = 12
)
$columnSpan
- relevant for desktop
$adaptiveColumnSpan
- relevant for mobile version.
use App\Models\Article;
use MoonShine\Decorations\Grid;
use MoonShine\Metrics\ValueMetric;
public function components(): array
{
return [
Grid::make([
ValueMetric::make('Articles')
->value(Article::count())
->columnSpan(6),
ValueMetric::make('Comments')
->value(Comment::count())
->columnSpan(6)
])
];
}
use App\Models\Article;
use MoonShine\Decorations\Grid;
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
Grid::make([
ValueMetric::make('Articles')
->value(Article::count())
->columnSpan(6),
ValueMetric::make('Comments')
->value(Comment::count())
->columnSpan(6)
])
];
}
//...
use App\Models\Article;
use MoonShine\Decorations\Grid;
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
Grid::make([
ValueMetric::make('Articles')
->value(Article::count())
->columnSpan(6),
ValueMetric::make('Comments')
->value(Comment::count())
->columnSpan(6)
])
];
}
//...
use App\Models\Article;
use MoonShine\Decorations\Grid;
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
Grid::make([
ValueMetric::make('Articles')
->value(Article::count())
->columnSpan(6),
ValueMetric::make('Comments')
->value(Comment::count())
->columnSpan(6)
])
];
}
//...
use App\Models\Article;
use MoonShine\Decorations\Grid;
use MoonShine\Metrics\ValueMetric;
//...
public function components(): array
{
return [
Grid::make([
ValueMetric::make('Articles')
->value(Article::count())
->columnSpan(6),
ValueMetric::make('Comments')
->value(Comment::count())
->columnSpan(6)
])
];
}
//...
data:image/s3,"s3://crabby-images/bd08c/bd08c91e449287ae4d7bc5ee5946e2fa0bb83dd2" alt="value_metric_column_span_dark"