ILIAS  trunk Revision v12.0_alpha-377-g3641b37b9db
CertificateOverviewTable.php
Go to the documentation of this file.
1<?php
2
19declare(strict_types=1);
20
22
23use DateInterval;
24use DateTimeImmutable;
25use Generator;
28use ilCtrl;
39use ilLanguage;
40use ilLink;
42use ilObject;
43use ilObjUser;
44use ilUIService;
47use Psr\Http\Message\RequestInterface;
48use Psr\Http\Message\ServerRequestInterface;
50use Throwable;
51
53{
55 private readonly ilUIService $ui_service;
56 private readonly Factory $ui_factory;
57 private readonly ilLanguage $lng;
58 private readonly ServerRequestInterface $request;
59 private readonly \ILIAS\Data\Factory $data_factory;
60 private readonly ilCtrl|ilCtrlInterface $ctrl;
61 private readonly \ILIAS\UI\Component\Input\Container\Filter\Standard $filter;
62 private readonly Data $table;
63 private readonly Renderer $ui_renderer;
64 private readonly ilAccessHandler $access;
65 private readonly ilObjUser $user;
66 private readonly \DateTimeZone $user_timezone;
67
68 public function __construct(
69 ?Factory $ui_factory = null,
72 ?ilLanguage $lng = null,
73 ServerRequestInterface|RequestInterface|null $request = null,
75 ?ilCtrl $ctrl = null,
76 ?Renderer $ui_renderer = null,
78 ?ilObjUser $user = null
79 ) {
80 global $DIC;
81 $this->ui_factory = $ui_factory ?: $DIC->ui()->factory();
82 $this->repo = $repo ?: new ilUserCertificateRepository();
83 $this->ui_service = $ui_service ?: $DIC->uiService();
84 $this->lng = $lng ?: $DIC->language();
85 $this->request = $request ?: $DIC->http()->request();
86 $this->data_factory = $data_factory ?: new \ILIAS\Data\Factory();
87 $this->ctrl = $ctrl ?: $DIC->ctrl();
88 $this->ui_renderer = $ui_renderer ?: $DIC->ui()->renderer();
89 $this->access = $access ?: $DIC->access();
90 $this->user = $user ?: $DIC->user();
91 $this->user_timezone = new \DateTimeZone($this->user->getTimeZone());
92
93 $this->filter = $this->buildFilter();
94 $this->table = $this->buildTable();
95 }
96
97 public function getRows(
98 DataRowBuilder $row_builder,
99 array $visible_column_ids,
101 Order $order,
102 mixed $additional_viewcontrol_data,
103 mixed $filter_data,
104 mixed $additional_parameters
105 ): Generator {
109 [$order_field, $order_direction] = $order->join([], fn($ret, $key, $value) => [$key, $value]);
110
111 $ui_filter_data = $this->mapUiFilterData($this->ui_service->filter()->getData($this->filter));
112
113 $table_rows = $this->buildTableRows($this->repo->fetchCertificatesForOverview(
114 $this->user->getLanguage(),
115 $ui_filter_data,
116 $range,
117 $order_field,
118 $order_direction
119 ));
120
121 foreach ($table_rows as $row) {
122 $row['issue_date'] = (new DateTimeImmutable())
123 ->setTimestamp($row['issue_date'])
124 ->setTimezone($this->user_timezone);
125 yield $row_builder->buildDataRow((string) $row['id'], $row);
126 }
127 }
128
133 private function mapUiFilterData(array $filter_data): array
134 {
135 if (isset($filter_data['issue_date']) && $filter_data['issue_date'] !== '') {
136 try {
137 $from = new DateTimeImmutable($filter_data['issue_date'][0], $this->user_timezone);
138 } catch (Throwable) {
139 $from = null;
140 }
141
142 try {
143 $to = new DateTimeImmutable($filter_data['issue_date'][1], $this->user_timezone);
144 $seconds_to_add = 59 - (int) $to->format('s');
145 $to = $to->modify("+$seconds_to_add seconds");
146 } catch (Throwable) {
147 $to = null;
148 }
149
150 $filter_data['issue_date'] = [
151 'from' => $from,
152 'to' => $to
153 ];
154 } else {
155 $filter_data['issue_date'] = [
156 'from' => null,
157 'to' => null
158 ];
159 }
160
161 return $filter_data;
162 }
163
164 public function getTotalRowCount(
165 mixed $additional_viewcontrol_data,
166 mixed $filter_data,
167 mixed $additional_parameters
168 ): ?int {
169 $ui_filter_data = $this->mapUiFilterData($this->ui_service->filter()->getData($this->filter));
170
171 return $this->repo->fetchCertificatesForOverviewCount($ui_filter_data);
172 }
173
174
175 private function buildFilter(): \ILIAS\UI\Component\Input\Container\Filter\Standard
176 {
177 return $this->ui_service->filter()->standard(
178 'certificates_overview_filter',
179 $this->ctrl->getLinkTargetByClass(
180 ilObjCertificateSettingsGUI::class,
182 ),
183 [
184 'certificate_id' => $this->ui_factory->input()->field()->text($this->lng->txt('certificate_id')),
185 'issue_date' => $this->ui_factory->input()->field()
186 ->duration($this->lng->txt('certificate_issue_date'))
187 ->withFormat($this->user->getDateTimeFormat())
188 ->withUseTime(true),
189 'object' => $this->ui_factory->input()->field()->text($this->lng->txt('obj')),
190 'obj_id' => $this->ui_factory->input()->field()->text($this->lng->txt('object_id')),
191 'owner' => $this->ui_factory->input()->field()->text($this->lng->txt('owner')),
192 ],
193 [true, true, true, true, true],
194 true,
195 true
196 );
197 }
198
199 private function buildTable(): Data
200 {
201 $ui_table = $this->ui_factory->table();
202
203 return $ui_table->data(
204 $this,
205 $this->lng->txt('certificates'),
206 [
207 'certificate_id' => $ui_table->column()->text($this->lng->txt('certificate_id')),
208 'issue_date' => $ui_table->column()->date($this->lng->txt('certificate_issue_date'), $this->user->getDateTimeFormat()),
209 'object' => $ui_table->column()->text($this->lng->txt('obj')),
210 'obj_id' => $ui_table->column()->text($this->lng->txt('object_id')),
211 'owner' => $ui_table->column()->text($this->lng->txt('owner'))
212 ],
213 )
214 ->withOrder(new Order('issue_date', Order::DESC))
215 ->withId('certificateOverviewTable')
216 ->withRequest($this->request)
217 ->withActions($this->buildTableActions());
218 }
219
223 private function buildTableActions(): array
224 {
225 $uri_download = $this->data_factory->uri(
226 ILIAS_HTTP_PATH . '/' . $this->ctrl->getLinkTargetByClass(
227 ilObjCertificateSettingsGUI::class,
229 )
230 );
231
237 [
238 $url_builder_download,
239 $action_parameter_token_download,
240 $row_id_token_download
241 ] =
242 (new URLBuilder($uri_download))->acquireParameters(
243 ['cert_overview'],
244 'action',
245 'id'
246 );
247
248 return [
249 'download' => $this->ui_factory->table()->action()->single(
250 $this->lng->txt('download'),
251 $url_builder_download->withParameter($action_parameter_token_download, 'download'),
252 $row_id_token_download
253 )
254 ];
255 }
256
261 private function buildTableRows(array $certificates): array
262 {
263 $table_rows = [];
264
265 $ref_id_cache = [];
266 $owner_cache = [];
267 $object_title_cache = [];
268
269 foreach ($certificates as $certificate) {
270 if (!isset($ref_id_cache[$certificate->getObjId()])) {
271 $ref_id_cache[$certificate->getObjId()] = ilObject::_getAllReferences($certificate->getObjId());
272 }
273 $ref_ids = $ref_id_cache[$certificate->getObjId()];
274
275 if (!isset($object_title_cache[$certificate->getObjId()])) {
276 $object_title = ilObject::_lookupTitle($certificate->getObjId());
277 foreach ($ref_ids as $refId) {
278 if ($this->access->checkAccess('read', '', $refId)) {
279 $object_title = $this->ui_renderer->render(
280 $this->ui_factory->link()->standard($object_title, ilLink::_getLink($refId))
281 );
282 break;
283 }
284 }
285
286 $object_title_cache[$certificate->getObjId()] = $object_title;
287 }
288
289
290
291 if (!isset($owner_cache[$certificate->getUserId()])) {
292 $owner_cache[$certificate->getUserId()] = ilObjUser::_lookupLogin($certificate->getUserId());
293 }
294
295 $table_rows[] = [
296 'id' => $certificate->getId(),
297 'certificate_id' => $certificate->getCertificateId()->asString(),
298 'issue_date' => $certificate->getAcquiredTimestamp(),
299 'object' => $object_title_cache[$certificate->getObjId()],
300 'obj_id' => (string) $certificate->getObjId(),
301 'owner' => $owner_cache[$certificate->getUserId()],
302 ];
303 }
304
305 return $table_rows;
306 }
307
308 public function render(): string
309 {
310 return $this->ui_renderer->render([$this->filter, $this->table]);
311 }
312}
readonly ILIAS UI Component Input Container Filter Standard $filter
__construct(?Factory $ui_factory=null, ?ilUserCertificateRepository $repo=null, ?ilUIService $ui_service=null, ?ilLanguage $lng=null, ServerRequestInterface|RequestInterface|null $request=null, ?\ILIAS\Data\Factory $data_factory=null, ?ilCtrl $ctrl=null, ?Renderer $ui_renderer=null, ?ilAccessHandler $access=null, ?ilObjUser $user=null)
getTotalRowCount(mixed $additional_viewcontrol_data, mixed $filter_data, mixed $additional_parameters)
Mainly for the purpose of pagination-support, it is important to know about the total number of recor...
Builds a Color from either hex- or rgb values.
Definition: Factory.php:31
Both the subject and the direction need to be specified when expressing an order.
Definition: Order.php:29
A simple class to express a naive range of whole positive numbers.
Definition: Range.php:29
Definition: UI.php:24
Stores all calendar relevant settings.
Class ilCtrl provides processing control methods.
language handling
User class.
static _lookupLogin(int $a_user_id)
Class ilObject Basic functions for all objects.
static _getAllReferences(int $id)
get all reference ids for object ID
static _lookupTitle(int $obj_id)
Filter service.
getRows(DataRowBuilder $row_builder, array $visible_column_ids, Range $range, Order $order, mixed $additional_viewcontrol_data, mixed $filter_data, mixed $additional_parameters)
This is called by the table to retrieve rows; map data-records to rows using the $row_builder e....
buildDataRow(string $id, array $record)
This describes a Data Table.
Definition: Data.php:33
This is how the factory for UI elements looks.
Definition: Factory.php:38
An entity that renders components to a string output.
Definition: Renderer.php:31
Interface ilAccessHandler This interface combines all available interfaces which can be called via gl...
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
filter(string $filter_id, array $class_path, string $cmd, bool $activated=true, bool $expanded=true)
Interface Observer \BackgroundTasks Contains several chained tasks and infos about them.
global $DIC
Definition: shib_login.php:26
$refId
Definition: xapitoken.php:56