ILIAS  trunk Revision v11.0_alpha-3011-gc6b235a2e85
QuestionsTable.php
Go to the documentation of this file.
1<?php
2
19declare(strict_types=1);
20
22
24use ILIAS\Test\Questions\Properties\Repository as TestQuestionsRepository;
25use ILIAS\Test\Questions\Properties\Properties as TestQuestionProperties;
26use ILIAS\Refinery\Factory as Refinery;
27use ILIAS\UI\Factory as UIFactory;
32use Psr\Http\Message\ServerRequestInterface;
33
35{
39 public function __construct(
40 private readonly UIFactory $ui_factory,
41 private readonly Refinery $refinery,
42 private readonly ServerRequestInterface $request,
43 private readonly QuestionsTableActions $table_actions,
44 private readonly Language $lng,
45 private readonly \ilObjTest $test_obj,
46 private readonly TestQuestionsRepository $questionrepository,
47 private readonly TitleColumnsBuilder $title_builder,
48 ) {
49 }
50
51 public function getTableComponent(): Ordering
52 {
53 $table = $this->ui_factory->table()->ordering(
54 $this,
55 $this->table_actions->getOrderActionUrl(),
56 $this->lng->txt('list_of_questions'),
57 $this->getColumns(),
58 )
59 ->withId((string) $this->test_obj->getId())
60 ->withActions($this->table_actions->getActions())
61 ->withRequest($this->request);
62
63 if ($this->test_obj->isRandomTest()) {
64 return $table->withOrderingDisabled(true);
65 }
66
67 return $table;
68 }
69
70 public function getRows(
71 OrderingRowBuilder $row_builder,
72 array $visible_column_ids
73 ): \Generator {
74 foreach ($this->getRecords() as $record) {
75 $row = $record->getAsQuestionsTableRow(
76 $this->lng,
77 $this->ui_factory,
78 $this->refinery,
79 $this->table_actions->getQuestionTargetLinkBuilder(),
80 $row_builder,
81 $this->title_builder
82 );
83 yield $this->table_actions->setDisabledActions($row, $record);
84 }
85 }
86
87 private function getColumns(): array
88 {
89 $f = $this->ui_factory;
90 $columns = [
91 'question_id' => $f->table()->column()->text($this->lng->txt('question_id'))
92 ->withIsOptional(true, false),
93 'title' => $f->table()->column()->link($this->lng->txt('tst_question_title')),
94 'description' => $f->table()->column()->text($this->lng->txt('description'))
95 ->withIsOptional(true, false),
96 'complete' => $f->table()->column()->boolean(
97 $this->lng->txt('question_complete_title'),
98 $f->symbol()->icon()->custom('assets/images/standard/icon_checked.svg', '', 'small'),
99 $f->symbol()->icon()->custom('assets/images/standard/icon_alert.svg', '', 'small')
100 ),
101 'type_tag' => $f->table()->column()->text($this->lng->txt('tst_question_type')),
102 'points' => $f->table()->column()->text($this->lng->txt('points')),
103 'author' => $f->table()->column()->text($this->lng->txt('author'))
104 ->withIsOptional(true, false),
105 'lifecycle' => $f->table()->column()->text($this->lng->txt('qst_lifecycle'))
106 ->withIsOptional(true, false),
107 'qpl' => $f->table()->column()->link($this->lng->txt('qpl')),
108 'nr_of_answers' => $f->table()->column()->number($this->lng->txt('number_of_answers'))
109 ->withIsOptional(true, false),
110 'average_points' => $f->table()->column()->number($this->lng->txt('average_reached_points'))
111 ->withIsOptional(true, false),
112 'percentage_points_achieved' => $f->table()->column()->text($this->lng->txt('percentage_points_achieved'))
113 ->withIsOptional(true, false),
114 ];
115
116 return $columns;
117 }
118
119 private function getActions(): array
120 {
121 $this->table_actions->getActions();
122 }
123
124 private function getRecords(): \Generator
125 {
126 $records = $this->questionrepository
127 ->getQuestionPropertiesWithAggregatedResultsForTest($this->test_obj);
128 usort(
129 $records,
130 static fn(TestQuestionProperties $a, TestQuestionProperties $b): int =>
131 $a->getSequenceInformation()?->getPlaceInSequence() <=> $b->getSequenceInformation()?->getPlaceInSequence()
132 );
133 yield from $records;
134 }
135}
Builds a Color from either hex- or rgb values.
Definition: Factory.php:31
Builds data types.
Definition: Factory.php:36
getRows(OrderingRowBuilder $row_builder, array $visible_column_ids)
This is called by the (ordering-)table to retrieve rows; map data-records to rows using the $row_buil...
__construct(private readonly UIFactory $ui_factory, private readonly Refinery $refinery, private readonly ServerRequestInterface $request, private readonly QuestionsTableActions $table_actions, private readonly Language $lng, private readonly \ilObjTest $test_obj, private readonly TestQuestionsRepository $questionrepository, private readonly TitleColumnsBuilder $title_builder,)
This describes a Table to specify the order of its data (rows).
Definition: Ordering.php:29
withId(string $id)
The DataTable comes with a storage to keep e.g.
$a
thx to https://mlocati.github.io/php-cs-fixer-configurator for the examples
global $lng
Definition: privfeed.php:31