ILIAS  trunk Revision v11.0_alpha-1689-g66c127b4ae8
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilDclBaseRecordModel.php
Go to the documentation of this file.
1 <?php
2 
19 declare(strict_types=1);
20 
22 
24 {
25  protected \ILIAS\UI\Factory $ui_factory;
26  protected \ILIAS\UI\Renderer $renderer;
27  protected Service $notes;
28 
32  protected ?array $recordfields = null;
33  protected int $id = 0;
34  protected int $table_id;
35  protected ?ilDclTable $table = null;
36  protected ?int $last_edit_by = null;
37  protected int $owner = 0;
40  protected ?int $nr_of_comments = null;
43  protected ilDBInterface $db;
45  private ilObjUser $user;
46 
47  public function __construct(?int $a_id = 0)
48  {
49  global $DIC;
50  $this->db = $DIC->database();
51  $this->event = $DIC->event();
52  $this->user = $DIC->user();
53  $this->ui_factory = $DIC->ui()->factory();
54  $this->renderer = $DIC->ui()->renderer();
55 
56  if ($a_id && $a_id != 0) {
57  $this->id = $a_id;
58  $this->doRead();
59  }
60 
61  $this->notes = $DIC->notes();
62  $this->http = $DIC->http();
63  $this->refinery = $DIC->refinery();
64  }
65 
66  public function doUpdate(bool $omit_notification = false): void
67  {
68  $values = [
69  "table_id" => [
70  "integer",
71  $this->getTableId(),
72  ],
73  "last_update" => [
74  "date",
75  $this->getLastUpdate()->get(IL_CAL_DATETIME),
76  ],
77  "owner" => [
78  "integer",
79  $this->getOwner(),
80  ],
81  "last_edit_by" => [
82  "integer",
83  $this->getLastEditBy(),
84  ],
85  ];
86  $this->db->update(
87  "il_dcl_record",
88  $values,
89  [
90  "id" => [
91  "integer",
92  $this->id,
93  ],
94  ]
95  );
96 
97  foreach ($this->getRecordFields() as $recordfield) {
98  $recordfield->doUpdate();
99  }
100 
101  //TODO: add event raise
102  if (!$omit_notification) {
103  $ref_id = $this->http->wrapper()->query()->retrieve('ref_id', $this->refinery->kindlyTo()->int());
104  $objDataCollection = new ilObjDataCollection($ref_id);
105  $objDataCollection->sendNotification("update_record", $this->getTableId(), $this->id);
106  }
107  }
108 
109  public function doRead(): void
110  {
111  //build query
112  $query = "Select * From il_dcl_record WHERE id = " . $this->db->quote($this->getId(), "integer") . " ORDER BY id";
113 
114  $set = $this->db->query($query);
115  $rec = $this->db->fetchAssoc($set);
116 
117  if (!$rec) {
118  $this->id = 0;
119  return;
120  }
121 
122  $this->setTableId((int) $rec["table_id"]);
123  $this->loadTable();
124  if (null !== $rec["create_date"]) {
125  $this->setCreateDate(new ilDateTime($rec["create_date"], IL_CAL_DATETIME));
126  }
127  if (null !== $rec["last_update"]) {
128  $this->setLastUpdate(new ilDateTime($rec["last_update"], IL_CAL_DATETIME));
129  } else {
130  $this->setLastUpdate(new ilDateTime($rec["create_date"], IL_CAL_DATETIME));
131  }
132  $this->setOwner((int) $rec["owner"]);
133  if (null !== $rec["last_edit_by"]) {
134  $this->setLastEditBy((int) $rec["last_edit_by"]);
135  }
136  }
137 
141  public function doCreate(): void
142  {
143  if (!ilDclTable::_tableExists($this->getTableId())) {
144  throw new ilException("The field does not have a related table!");
145  }
146 
147  $id = $this->db->nextId("il_dcl_record");
148  $this->setId($id);
149  $query
150  = "INSERT INTO il_dcl_record (
151  id,
152  table_id,
153  create_date,
154  Last_update,
155  owner,
156  last_edit_by
157  ) VALUES (" . $this->db->quote($this->getId(), "integer") . "," . $this->db->quote(
158  $this->getTableId(),
159  "integer"
160  ) . ","
161  . $this->db->quote($this->getCreateDate()->get(IL_CAL_DATETIME), "timestamp") . "," . $this->db->quote(
162  $this->getLastUpdate()->get(IL_CAL_DATETIME),
163  "timestamp"
164  ) . ","
165  . $this->db->quote($this->getOwner(), "integer") . "," . $this->db->quote($this->getLastEditBy(), "integer") . "
166  )";
167  $this->db->manipulate($query);
168 
169  $this->loadRecordFields();
170  foreach ($this->getRecordFields() as $recordField) {
171  $recordField->doCreate();
172  }
173 
174  $this->getTable()->loadRecords();
175  }
176 
177  public function deleteField(int $field_id): void
178  {
179  $this->loadRecordFields();
180  $this->recordfields[$field_id]->delete();
181  if (count($this->recordfields) == 1) {
182  $this->doDelete();
183  }
184  }
185 
186  public function setId(int $a_id): void
187  {
188  $this->id = $a_id;
189  }
190 
191  public function getId(): ?int
192  {
193  return $this->id;
194  }
195 
196  public function setTableId(int $a_id): void
197  {
198  $this->table_id = $a_id;
199  }
200 
201  public function getTableId(): int
202  {
203  return $this->table_id;
204  }
205 
206  public function setCreateDate(ilDateTime $a_datetime): void
207  {
208  $this->create_date = $a_datetime;
209  }
210 
211  public function getCreateDate(): ilDateTime
212  {
213  return $this->create_date;
214  }
215 
216  public function setLastUpdate(ilDateTime $a_datetime): void
217  {
218  $this->last_update = $a_datetime;
219  }
220 
221  public function getLastUpdate(): ilDateTime
222  {
223  return $this->last_update;
224  }
225 
226  public function setOwner(int $a_id): void
227  {
228  $this->owner = $a_id;
229  }
230 
231  public function getOwner(): int
232  {
233  return $this->owner;
234  }
235 
236  public function getLastEditBy(): ?int
237  {
238  return $this->last_edit_by;
239  }
240 
241  public function setLastEditBy(?int $last_edit_by): void
242  {
243  $this->last_edit_by = $last_edit_by;
244  }
245 
251  public function setRecordFieldValue($field_id, $value): void
252  {
253  $this->loadRecordFields();
254  if (ilDclStandardField::_isStandardField($field_id)) {
255  $this->setStandardField($field_id, $value);
256  } else {
257  $this->loadTable();
258  $this->recordfields[$field_id]->setValue($value);
259  }
260  }
261 
266  public function setRecordFieldValueFromForm(int $field_id, ilPropertyFormGUI $form): void
267  {
268  $this->loadRecordFields();
269  if (ilDclStandardField::_isStandardField($field_id)) {
270  $this->setStandardFieldFromForm($field_id, $form);
271  } else {
272  $this->loadTable();
273  $this->recordfields[$field_id]->setValueFromForm($form);
274  }
275  }
276 
280  public function getRecordFieldValueFromExcel(ilExcel $excel, int $row, int $col, ilDclBaseFieldModel $field)
281  {
282  $this->loadRecordFields();
283 
284  return $this->recordfields[$field->getId()]->getValueFromExcel($excel, $row, $col);
285  }
286 
288  ilExcel $excel,
289  int $row,
290  int $col,
291  ilDclBaseFieldModel $field
292  ): void {
293  $value = $field->getValueFromExcel($excel, $row, $col);
294  if ($value) {
295  $this->{$field->getId()} = $value;
296  }
297  }
298 
299  public function getRecordFieldValues(): array
300  {
301  $this->loadRecordFields();
302  $return = [];
303  foreach ($this->recordfields as $id => $record_field) {
304  $return[$id] = $record_field->getValue();
305  }
306 
307  return $return;
308  }
309 
314  public function getRecordFieldValue(?string $field_id)
315  {
316  if ($field_id === null) {
317  return null;
318  }
319  $this->loadRecordFields();
320  if (ilDclStandardField::_isStandardField($field_id)) {
321  return $this->getStandardField($field_id);
322  } else {
323  return $this->recordfields[$field_id]->getValue();
324  }
325  }
326 
332  public function getRecordFieldRepresentationValue($field_id)
333  {
334  if ($field_id === null) {
335  return null;
336  }
337  $this->loadRecordFields();
338  if (ilDclStandardField::_isStandardField($field_id)) {
339  return $this->getStandardField($field_id);
340  } else {
341  return $this->recordfields[$field_id]->getValueForRepresentation();
342  }
343  }
344 
350  public function getRecordFieldExportValue($field_id)
351  {
352  $this->loadRecordFields();
353  if (ilDclStandardField::_isStandardField($field_id)) {
354  return $this->getStandardFieldHTML($field_id);
355  } else {
356  return $this->recordfields[$field_id]->getExportValue();
357  }
358  }
359 
365  public function getRecordFieldPlainText($field_id)
366  {
367  $this->loadRecordFields();
368  if (ilDclStandardField::_isStandardField($field_id)) {
369  return $this->getStandardFieldHTML($field_id);
370  } else {
371  return $this->recordfields[$field_id]->getPlainText();
372  }
373  }
374 
378  public function fillRecordFieldExcelExport(ilExcel $worksheet, int &$row, int &$col, $field_id): void
379  {
380  $this->loadRecordFields();
381  if (ilDclStandardField::_isStandardField($field_id)) {
382  if ($field_id === 'owner') {
383  $worksheet->setCell($row, $col, ilObjUser::_lookupLogin($this->getOwner()));
384  $col++;
385  $name_array = ilObjUser::_lookupName($this->getOwner());
386  $worksheet->setCell($row, $col, $name_array['lastname'] . ', ' . $name_array['firstname']);
387  } elseif ($field_id === 'last_update') {
388  $date_time = $this->getLastUpdate()->get(IL_CAL_DATETIME, '', $this->user->getTimeZone());
389  $worksheet->setCell($row, $col, $date_time);
390  } elseif ($field_id === 'create_date') {
391  $date_time = $this->getCreateDate()->get(IL_CAL_DATETIME, '', $this->user->getTimeZone());
392  $worksheet->setCell($row, $col, $date_time);
393  } else {
394  $worksheet->setCell($row, $col, $this->getStandardFieldHTML($field_id));
395  }
396  $col++;
397  } else {
398  $this->recordfields[$field_id]->fillExcelExport($worksheet, $row, $col);
399  }
400  }
401 
405  public function getRecordFieldFormulaValue($field_id): string
406  {
407  $this->loadRecordFields();
408  if (ilDclStandardField::_isStandardField($field_id)) {
409  $value = $this->getStandardFieldFormulaValue($field_id);
410  } else {
411  if (is_object($this->recordfields[$field_id])) {
412  $value = $this->recordfields[$field_id]->getFormulaValue();
413  } else {
414  $value = '';
415  }
416  }
417 
418  return $value;
419  }
420 
424  public function getRecordFieldHTML($field_id, array $options = []): string
425  {
426  $this->loadRecordFields();
427  if (ilDclStandardField::_isStandardField($field_id)) {
428  $html = $this->getStandardFieldHTML($field_id, $options);
429  } else {
430  if (array_key_exists($field_id, $this->recordfields) && is_object($this->recordfields[$field_id])) {
431  $html = $this->recordfields[$field_id]->getRecordRepresentation()->getHTML(true, $options);
432  } else {
433  $html = '';
434  }
435  }
436 
437  return $html;
438  }
439 
443  public function getRecordFieldSortingValue($field_id, array $options = []): string
444  {
445  $this->loadRecordFields();
446  if (ilDclStandardField::_isStandardField($field_id)) {
447  $html = $this->getStandardFieldHTML($field_id, $options);
448  } else {
449  if (is_object($this->recordfields[$field_id])) {
450  $html = $this->recordfields[$field_id]->getSortingValue();
451  } else {
452  $html = '';
453  }
454  }
455 
456  return $html;
457  }
458 
462  public function getRecordFieldSingleHTML($field_id, array $options = []): string
463  {
464  $this->loadRecordFields();
465 
466  if (ilDclStandardField::_isStandardField($field_id)) {
467  $html = $this->getStandardFieldHTML($field_id);
468  } else {
469  $field = $this->recordfields[$field_id];
474  $html = $field->getRecordRepresentation()->getSingleHTML($options, false);
475  }
476 
477  return $html;
478  }
479 
483  public function fillRecordFieldFormInput($field_id, ilPropertyFormGUI $form): void
484  {
485  $this->loadRecordFields();
486  if (ilDclStandardField::_isStandardField($field_id)) {
487  $this->fillStandardFieldFormInput($field_id, $form);
488  } else {
489  $this->recordfields[$field_id]->getRecordRepresentation()->fillFormInput($form);
490  }
491  }
492 
496  protected function setStandardFieldFromForm($field_id, ilPropertyFormGUI $form): void
497  {
498  if ($item = $form->getItemByPostVar("field_" . $field_id)) {
499  $this->setStandardField($field_id, $item->getValue());
500  }
501  }
502 
507  protected function setStandardField($field_id, $value)
508  {
509  if ($field_id == "last_edit_by") {
510  $this->setLastEditBy($value);
511  return;
512  }
513  $this->{$field_id} = $value;
514  }
515 
519  protected function fillStandardFieldFormInput($field_id, ilPropertyFormGUI $form): void
520  {
521  if ($item = $form->getItemByPostVar('field_' . $field_id)) {
522  $item->setValue($this->getStandardField($field_id));
523  }
524  }
525 
529  protected function getStandardField($field_id): string
530  {
531  switch ($field_id) {
532  case "last_edit_by":
533  return ilObjUser::_lookupName($this->getLastEditBy())['login'];
534  case 'owner':
535  return ilObjUser::_lookupName($this->getOwner())['login'];
536  }
537 
538  return $this->{$field_id};
539  }
540 
544  public function getStandardFieldFormulaValue($field_id): string
545  {
546  return $this->getStandardFieldHTML($field_id);
547  }
548 
549  public function getStandardFieldHTML(string $field_id, array $options = []): string
550  {
551  switch ($field_id) {
552  case 'id':
553  return (string) $this->getId();
554  case 'owner':
555  return ilUserUtil::getNamePresentation($this->getOwner());
556  case 'last_edit_by':
558  case 'last_update':
560  case 'create_date':
562  case 'comments':
563 
564  $ref_id = $this->http->wrapper()->query()->retrieve('ref_id', $this->refinery->kindlyTo()->int());
565 
567  1,
568  $ref_id,
569  'dcl',
570  $this->table->getCollectionObject()
571  ->getId(),
572  'dcl',
573  $this->getId()
574  );
575  $update_code = "il.UI.counter.getCounterObject($(\".ilc_page_Page\")).incrementStatusCount(1);";
576  $ajax_link = ilNoteGUI::getListCommentsJSCall($ajax_hash, $update_code);
577  $nr_comments = $this->getNrOfComments();
578 
579  $comment_glyph = $this->ui_factory->symbol()->glyph()->comment()->withCounter(
580  $this->ui_factory->counter()->status($nr_comments)
581  )->withAdditionalOnLoadCode(function ($id) use ($ajax_link): string {
582  return "document.getElementById('$id').onclick = function (event) { $ajax_link; };";
583  });
584  return $this->renderer->render($comment_glyph);
585  }
586 
587  return "";
588  }
589 
594  public function getStandardFieldPlainText(string $field_id)
595  {
596  switch ($field_id) {
597  case 'comments':
598  return $this->getNrOfComments();
599  default:
600  return strip_tags($this->getStandardFieldHTML($field_id));
601  }
602  }
603 
604  private function loadRecordFields(): void
605  {
606  if ($this->recordfields == null) {
607  $this->loadTable();
608  $recordfields = [];
609  foreach ($this->table->getRecordFields() as $field) {
610  if (($recordfields[$field->getId()] ?? null) === null) {
611  $recordfields[$field->getId()] = ilDclCache::getRecordFieldCache($this, $field);
612  }
613  }
614 
615  $this->recordfields = $recordfields;
616  }
617  }
618 
619  private function loadTable(): void
620  {
621  if ($this->table === null) {
622  $this->table = ilDclCache::getTableCache($this->getTableId());
623  }
624  }
625 
626  public function getRecordField(int $field_id): ilDclBaseRecordFieldModel
627  {
628  $this->loadRecordFields();
629 
630  return $this->recordfields[$field_id];
631  }
632 
633  public function doDelete(bool $omit_notification = false): void
634  {
635  $this->loadRecordFields();
636  foreach ($this->recordfields as $recordfield) {
637  if ($recordfield->getField()->getDatatypeId() == ilDclDatatype::INPUTFORMAT_MOB) {
638  $this->deleteMob((int) $recordfield->getValue());
639  }
640 
641  $recordfield->delete();
642  }
643 
644  $query = "DELETE FROM il_dcl_record WHERE id = " . $this->db->quote($this->getId(), "integer");
645  $this->db->manipulate($query);
646 
647  $this->table->loadRecords();
648 
649  if (!$omit_notification) {
650  $ref_id = $this->http->wrapper()->query()->retrieve('ref_id', $this->refinery->kindlyTo()->int());
651  $objDataCollection = new ilObjDataCollection($ref_id);
652  $objDataCollection->sendNotification("delete_record", $this->getTableId(), $this->getId());
653 
654  $this->event->raise(
655  'components/ILIAS/DataCollection',
656  'deleteRecord',
657  [
658  'dcl' => ilDclCache::getTableCache($this->getTableId())->getCollectionObject(),
659  'table_id' => $this->table_id,
660  'record_id' => $this->getId(),
661  'record' => $this,
662  ]
663  );
664  }
665  }
666 
667  // TODO: Find better way to copy data (including all references)
668  public function cloneStructure(int $original_id, array $new_fields): void
669  {
670  $original = ilDclCache::getRecordCache($original_id);
671  $this->setCreateDate($original->getCreateDate());
672  $this->setLastEditBy($original->getLastEditBy());
673  $this->setLastUpdate($original->getLastUpdate());
674  $this->setOwner($original->getOwner());
675  $this->doCreate();
676  foreach ($new_fields as $old => $new) {
677  $old_rec_field = $original->getRecordField($old);
678  $new_rec_field = ilDclCache::getRecordFieldCache($this, $new);
679  $new_rec_field->cloneStructure($old_rec_field);
680  $this->recordfields[] = $new_rec_field;
681  }
682 
683  // mandatory for all cloning functions
684  ilDclCache::setCloneOf($original_id, $this->getId(), ilDclCache::TYPE_RECORD);
685  }
686 
687  public function deleteFile(int $obj_id): void
688  {
689  if (ilObject2::_exists($obj_id, false)) {
690  $file = new ilObjFile($obj_id, false);
691  $file->delete();
692  }
693  }
694 
695  public function deleteMob(int $obj_id): void
696  {
697  if (ilObject2::_lookupObjId($obj_id)) {
698  $mob = new ilObjMediaObject($obj_id);
699  $mob->delete();
700  }
701  }
702 
703  public function hasPermissionToEdit(int $ref_id): bool
704  {
705  return $this->getTable()->hasPermissionToEditRecord($ref_id, $this);
706  }
707 
708  public function hasPermissionToDelete(int $ref_id): bool
709  {
710  return $this->getTable()->hasPermissionToDeleteRecord($ref_id, $this);
711  }
712 
713  public function hasPermissionToView(int $ref_id): bool
714  {
715  return $this->getTable()->hasPermissionToViewRecord($ref_id, $this);
716  }
717 
721  public function getRecordFields(): array
722  {
723  $this->loadRecordFields();
724 
725  return $this->recordfields;
726  }
727 
728  public function getTable(): ilDclTable
729  {
730  $this->loadTable();
731 
732  return $this->table;
733  }
734 
738  public function getNrOfComments(): int
739  {
740  if ($this->nr_of_comments === null) {
741  $context = $this->notes
742  ->data()
743  ->context(
744  $this->table->getCollectionObject()->getId(),
745  $this->getId(),
746  'dcl'
747  );
748  $this->nr_of_comments = $this->notes
749  ->domain()
750  ->getNrOfCommentsForContext($context);
751  }
752 
753  return $this->nr_of_comments;
754  }
755 }
getRecordFieldHTML($field_id, array $options=[])
Global event handler.
$context
Definition: webdav.php:31
const IL_CAL_DATETIME
getRecordFieldExportValue($field_id)
Get Field Export Value.
getItemByPostVar(string $a_post_var)
setStandardFieldFromForm($field_id, ilPropertyFormGUI $form)
doUpdate(bool $omit_notification=false)
getRecordFieldValue(?string $field_id)
Get Field Value.
renderer()
setStandardFieldValueFromExcel(ilExcel $excel, int $row, int $col, ilDclBaseFieldModel $field)
static _lookupName(int $a_user_id)
lookup user name
getStandardFieldHTML(string $field_id, array $options=[])
setRecordFieldValue($field_id, $value)
static _lookupObjId(int $ref_id)
setRecordFieldValueFromForm(int $field_id, ilPropertyFormGUI $form)
Set a field value.
static buildAjaxHash(int $node_type, ?int $node_id, string $obj_type, int $obj_id, ?string $sub_type=null, ?int $sub_id=null, int $news_id=0)
Build ajax hash.
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
static _exists(int $id, bool $reference=false, ?string $type=null)
checks if an object exists in object_data
setCell(int $a_row, int $col, $value, ?string $datatype=null, bool $disable_strip_tags_for_strings=false)
Set cell value.
$ref_id
Definition: ltiauth.php:65
static http()
Fetches the global http state from ILIAS.
static getNamePresentation( $a_user_id, bool $a_user_image=false, bool $a_profile_link=false, string $a_profile_back_link='', bool $a_force_first_lastname=false, bool $a_omit_login=false, bool $a_sortable=true, bool $a_return_data_array=false, $a_ctrl_path='ilpublicuserprofilegui')
Default behaviour is:
ILIAS Refinery Factory $refinery
getRecordFieldSortingValue($field_id, array $options=[])
getNrOfComments()
Get nr of comments of this record.
getStandardFieldPlainText(string $field_id)
Class ilObjFile.
global $DIC
Definition: shib_login.php:22
static getTableCache(?int $table_id=null)
static setCloneOf(int $old, int $new, string $type)
getRecordFieldValueFromExcel(ilExcel $excel, int $row, int $col, ilDclBaseFieldModel $field)
static _isStandardField($field_id)
static getListCommentsJSCall(string $a_hash, ?string $a_update_code=null)
Get list comments js call.
fillRecordFieldExcelExport(ilExcel $worksheet, int &$row, int &$col, $field_id)
getRecordFieldPlainText($field_id)
Get Field Export Value.
static getRecordCache(?int $record_id)
setCreateDate(ilDateTime $a_datetime)
getRecordFieldRepresentationValue($field_id)
Get Field Value for Representation in a Form.
static formatDate(ilDateTime $date, bool $a_skip_day=false, bool $a_include_wd=false, bool $include_seconds=false, ?ilObjUser $user=null,)
setLastUpdate(ilDateTime $a_datetime)
static getRecordFieldCache(object $record, object $field)
cloneStructure(int $original_id, array $new_fields)
doDelete(bool $omit_notification=false)
fillRecordFieldFormInput($field_id, ilPropertyFormGUI $form)
static _tableExists(int $table_id)
fillStandardFieldFormInput($field_id, ilPropertyFormGUI $form)
static _lookupLogin(int $a_user_id)