forked from mirror/Part-DB.Part-DB-server
Color a part row if the part is favorite or needs review.
This commit is contained in:
parent
6be863d356
commit
1135bfcbef
4 changed files with 74 additions and 8 deletions
|
@ -24,6 +24,7 @@ namespace App\DataTables;
|
||||||
|
|
||||||
use App\DataTables\Column\LocaleDateTimeColumn;
|
use App\DataTables\Column\LocaleDateTimeColumn;
|
||||||
use App\DataTables\Column\PrettyBoolColumn;
|
use App\DataTables\Column\PrettyBoolColumn;
|
||||||
|
use App\DataTables\Column\RowClassColumn;
|
||||||
use App\DataTables\Filters\AttachmentFilter;
|
use App\DataTables\Filters\AttachmentFilter;
|
||||||
use App\Entity\Attachments\Attachment;
|
use App\Entity\Attachments\Attachment;
|
||||||
use App\Entity\LogSystem\AbstractLogEntry;
|
use App\Entity\LogSystem\AbstractLogEntry;
|
||||||
|
@ -60,10 +61,7 @@ final class AttachmentDataTable implements DataTableTypeInterface
|
||||||
|
|
||||||
public function configure(DataTable $dataTable, array $options): void
|
public function configure(DataTable $dataTable, array $options): void
|
||||||
{
|
{
|
||||||
$dataTable->add('$$rowClass', TextColumn::class, [
|
$dataTable->add('dont_matter', RowClassColumn::class, [
|
||||||
'label' => '',
|
|
||||||
'className' => 'no-colvis',
|
|
||||||
'visible' => false,
|
|
||||||
'render' => function ($value, Attachment $context) {
|
'render' => function ($value, Attachment $context) {
|
||||||
//Mark attachments with missing files yellow
|
//Mark attachments with missing files yellow
|
||||||
if(!$this->attachmentHelper->isFileExisting($context)){
|
if(!$this->attachmentHelper->isFileExisting($context)){
|
||||||
|
|
55
src/DataTables/Column/RowClassColumn.php
Normal file
55
src/DataTables/Column/RowClassColumn.php
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
<?php
|
||||||
|
/*
|
||||||
|
* This file is part of Part-DB (https://github.com/Part-DB/Part-DB-symfony).
|
||||||
|
*
|
||||||
|
* Copyright (C) 2019 - 2022 Jan Böhmer (https://github.com/jbtronics)
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as published
|
||||||
|
* by the Free Software Foundation, either version 3 of the License, or
|
||||||
|
* (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace App\DataTables\Column;
|
||||||
|
|
||||||
|
use Omines\DataTablesBundle\Column\AbstractColumn;
|
||||||
|
use Omines\DataTablesBundle\DataTable;
|
||||||
|
use Symfony\Component\OptionsResolver\OptionsResolver;
|
||||||
|
|
||||||
|
class RowClassColumn extends AbstractColumn
|
||||||
|
{
|
||||||
|
|
||||||
|
public function configureOptions(OptionsResolver $resolver)
|
||||||
|
{
|
||||||
|
parent::configureOptions($resolver);
|
||||||
|
|
||||||
|
$resolver->setDefaults([
|
||||||
|
'label' => '',
|
||||||
|
'orderable' => false,
|
||||||
|
'searchable' => false,
|
||||||
|
'className' => 'no-colvis',
|
||||||
|
'visible' => false,
|
||||||
|
]);
|
||||||
|
|
||||||
|
return $this;
|
||||||
|
}
|
||||||
|
|
||||||
|
public function initialize(string $name, int $index, array $options, DataTable $dataTable)
|
||||||
|
{
|
||||||
|
//The field name is always "$$rowClass" as this is the name the frontend controller expects
|
||||||
|
parent::initialize('$$rowClass', $index, $options, $dataTable); // TODO: Change the autogenerated stub
|
||||||
|
}
|
||||||
|
|
||||||
|
public function normalize($value)
|
||||||
|
{
|
||||||
|
return $value;
|
||||||
|
}
|
||||||
|
}
|
|
@ -27,6 +27,7 @@ use App\DataTables\Column\LocaleDateTimeColumn;
|
||||||
use App\DataTables\Column\LogEntryExtraColumn;
|
use App\DataTables\Column\LogEntryExtraColumn;
|
||||||
use App\DataTables\Column\LogEntryTargetColumn;
|
use App\DataTables\Column\LogEntryTargetColumn;
|
||||||
use App\DataTables\Column\RevertLogColumn;
|
use App\DataTables\Column\RevertLogColumn;
|
||||||
|
use App\DataTables\Column\RowClassColumn;
|
||||||
use App\DataTables\Filters\AttachmentFilter;
|
use App\DataTables\Filters\AttachmentFilter;
|
||||||
use App\DataTables\Filters\LogFilter;
|
use App\DataTables\Filters\LogFilter;
|
||||||
use App\Entity\Base\AbstractDBElement;
|
use App\Entity\Base\AbstractDBElement;
|
||||||
|
@ -106,10 +107,7 @@ class LogDataTable implements DataTableTypeInterface
|
||||||
$options = $resolver->resolve($options);
|
$options = $resolver->resolve($options);
|
||||||
|
|
||||||
//This special $$rowClass column is used to set the row class depending on the log level. The class gets set by the frontend controller
|
//This special $$rowClass column is used to set the row class depending on the log level. The class gets set by the frontend controller
|
||||||
$dataTable->add('$$rowClass', TextColumn::class, [
|
$dataTable->add('dont_matter', RowClassColumn::class, [
|
||||||
'label' => '',
|
|
||||||
'className' => 'no-colvis',
|
|
||||||
'visible' => false,
|
|
||||||
'render' => static function ($value, AbstractLogEntry $context) {
|
'render' => static function ($value, AbstractLogEntry $context) {
|
||||||
switch ($context->getLevel()) {
|
switch ($context->getLevel()) {
|
||||||
case AbstractLogEntry::LEVEL_EMERGENCY:
|
case AbstractLogEntry::LEVEL_EMERGENCY:
|
||||||
|
|
|
@ -28,6 +28,7 @@ use App\DataTables\Column\LocaleDateTimeColumn;
|
||||||
use App\DataTables\Column\MarkdownColumn;
|
use App\DataTables\Column\MarkdownColumn;
|
||||||
use App\DataTables\Column\PartAttachmentsColumn;
|
use App\DataTables\Column\PartAttachmentsColumn;
|
||||||
use App\DataTables\Column\PrettyBoolColumn;
|
use App\DataTables\Column\PrettyBoolColumn;
|
||||||
|
use App\DataTables\Column\RowClassColumn;
|
||||||
use App\DataTables\Column\SelectColumn;
|
use App\DataTables\Column\SelectColumn;
|
||||||
use App\DataTables\Column\SIUnitNumberColumn;
|
use App\DataTables\Column\SIUnitNumberColumn;
|
||||||
use App\DataTables\Column\TagsColumn;
|
use App\DataTables\Column\TagsColumn;
|
||||||
|
@ -102,6 +103,20 @@ final class PartsDataTable implements DataTableTypeInterface
|
||||||
$options = $resolver->resolve($options);
|
$options = $resolver->resolve($options);
|
||||||
|
|
||||||
$dataTable
|
$dataTable
|
||||||
|
//Color the table rows depending on the review and favorite status
|
||||||
|
->add('dont_matter', RowClassColumn::class, [
|
||||||
|
'render' => function ($value, Part $context) {
|
||||||
|
if ($context->isNeedsReview()) {
|
||||||
|
return 'table-secondary';
|
||||||
|
}
|
||||||
|
if ($context->isFavorite()) {
|
||||||
|
return 'table-info';
|
||||||
|
}
|
||||||
|
|
||||||
|
return ''; //Default coloring otherwise
|
||||||
|
},
|
||||||
|
])
|
||||||
|
|
||||||
->add('select', SelectColumn::class)
|
->add('select', SelectColumn::class)
|
||||||
->add('picture', TextColumn::class, [
|
->add('picture', TextColumn::class, [
|
||||||
'label' => '',
|
'label' => '',
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue