ILIAS  trunk Revision v11.0_alpha-1689-g66c127b4ae8
All Data Structures Namespaces Files Functions Variables Enumerations Enumerator Modules Pages
class.ilGlossaryTerm.php
Go to the documentation of this file.
1 <?php
2 
24 {
25  protected string $type;
26  protected ilDBInterface $db;
27  public ilLanguage $lng;
29  public int $id = 0;
31  public string $term = "";
32  public string $language = "";
33  public int $glo_id = 0;
34  public string $import_id = "";
35  public string $short_text = "";
36  public int $short_text_dirty = 0;
39 
40  public function __construct(int $a_id = 0)
41  {
42  global $DIC;
43 
44  $this->db = $DIC->database();
45  $lng = $DIC->language();
46  $tpl = $DIC["tpl"];
47 
48  $this->lng = $lng;
49  $this->tpl = $tpl;
50 
51  $this->id = $a_id;
52  $this->type = "term";
53  if ($a_id != 0) {
54  $this->read();
55  }
56  $this->event_handler = $DIC->event();
57  }
58 
59  public function read(): void
60  {
61  $ilDB = $this->db;
62 
63  $q = "SELECT * FROM glossary_term WHERE id = " .
64  $ilDB->quote($this->getId(), "integer");
65  $term_set = $ilDB->query($q);
66  $term_rec = $ilDB->fetchAssoc($term_set);
67 
68  $this->setTerm((string) $term_rec["term"]);
69  $this->setImportId((string) $term_rec["import_id"]);
70  $this->setLanguage((string) $term_rec["language"]);
71  $this->setGlossaryId((int) $term_rec["glo_id"]);
72  $this->setShortText((string) $term_rec["short_text"]);
73  $this->setShortTextDirty((int) $term_rec["short_text_dirty"]);
74 
75  $this->page_object = new ilGlossaryDefPage($this->getId());
76  }
77 
78  public static function _getIdForImportId(
79  string $a_import_id
80  ): int {
81  global $DIC;
82 
83  $ilDB = $DIC->database();
84 
85  if ($a_import_id == "") {
86  return 0;
87  }
88 
89  $q = "SELECT * FROM glossary_term WHERE import_id = " .
90  $ilDB->quote($a_import_id, "text") .
91  " ORDER BY create_date DESC";
92  $term_set = $ilDB->query($q);
93  while ($term_rec = $ilDB->fetchAssoc($term_set)) {
94  $glo_id = self::_lookGlossaryID($term_rec["id"]);
95 
96  $ref_ids = ilObject::_getAllReferences($glo_id); // will be 0 if import of lm is in progress (new import)
97  if (count($ref_ids) == 0 || ilObject::_hasUntrashedReference($glo_id)) {
98  return (int) $term_rec["id"];
99  }
100  }
101 
102  return 0;
103  }
104 
105 
109  public static function _exists(int $a_id): bool
110  {
111  global $DIC;
112 
113  $ilDB = $DIC->database();
114 
115  if (is_int(strpos($a_id, "_"))) {
117  }
118 
119  $q = "SELECT * FROM glossary_term WHERE id = " .
120  $ilDB->quote($a_id, "integer");
121  $obj_set = $ilDB->query($q);
122  if ($obj_rec = $ilDB->fetchAssoc($obj_set)) {
123  return true;
124  } else {
125  return false;
126  }
127  }
128 
129 
133  public function setId(int $a_id): void
134  {
135  $this->id = $a_id;
136  }
137 
138  public function getId(): int
139  {
140  return $this->id;
141  }
142 
143  public function setGlossary(
144  ilObjGlossary $a_glossary
145  ): void {
146  $this->glossary = $a_glossary;
147  $this->setGlossaryId($a_glossary->getId());
148  }
149 
150  public function setGlossaryId(
151  int $a_glo_id
152  ): void {
153  $this->glo_id = $a_glo_id;
154  }
155 
156  public function getGlossaryId(): int
157  {
158  return $this->glo_id;
159  }
160 
161  public function setTerm(string $a_term): void
162  {
163  $this->term = $a_term;
164  }
165 
166  public function getTerm(): string
167  {
168  return $this->term;
169  }
170 
171  public function setLanguage(
172  string $a_language
173  ): void {
174  $this->language = $a_language;
175  }
176 
177  public function getLanguage(): string
178  {
179  return $this->language;
180  }
181 
182  public function setImportId(string $a_import_id): void
183  {
184  $this->import_id = $a_import_id;
185  }
186 
187  public function getImportId(): string
188  {
189  return $this->import_id;
190  }
191 
192  public function setShortText(string $a_text): void
193  {
194  $this->short_text = $this->shortenShortText($a_text);
195  }
196 
197  public function getShortText(): string
198  {
199  return $this->short_text;
200  }
201 
202  public function setShortTextDirty(int $a_val): void
203  {
204  $this->short_text_dirty = $a_val;
205  }
206 
207  public function getShortTextDirty(): int
208  {
210  }
211 
212  public function assignPageObject(ilGlossaryDefPage $a_page_object): void
213  {
214  $this->page_object = $a_page_object;
215  }
216 
217  public function getPageObject(): ilGlossaryDefPage
218  {
219  return $this->page_object;
220  }
221 
222  public function create(bool $a_omit_page_creation = false): void
223  {
224  $ilDB = $this->db;
225 
226  $this->setId($ilDB->nextId("glossary_term"));
227  $ilDB->manipulate("INSERT INTO glossary_term" .
228  " (id, glo_id, term, language, import_id, create_date, last_update, short_text, short_text_dirty)" .
229  " VALUES (" .
230  $ilDB->quote($this->getId(), "integer") . ", " .
231  $ilDB->quote($this->getGlossaryId(), "integer") . ", " .
232  $ilDB->quote($this->getTerm(), "text") . ", " .
233  $ilDB->quote($this->getLanguage(), "text") . ", " .
234  $ilDB->quote($this->getImportId(), "text") . ", " .
235  $ilDB->now() . ", " .
236  $ilDB->now() . ", " .
237  $ilDB->quote($this->getShortText(), "text") . ", " .
238  $ilDB->quote($this->getShortTextDirty(), "integer") . ")");
239 
240  if (!$a_omit_page_creation) {
241  $this->page_object = new ilGlossaryDefPage();
242  $this->page_object->setId($this->getId());
243  $this->page_object->setParentId($this->getGlossaryId());
244  $this->page_object->create(false);
245  }
246  }
247 
251  public function delete(): void
252  {
253  $ilDB = $this->db;
254 
255  // delete term references
257 
258  // delete glossary_term record
259  $ilDB->manipulate("DELETE FROM glossary_term " .
260  " WHERE id = " . $ilDB->quote($this->getId(), "integer"));
261 
262  $this->page_object->delete();
263 
264  // delete flashcard entries
265  $this->event_handler->raise("components/ILIAS/Glossary", "deleteTerm", ["term_id" => $this->getId()]);
266  }
267 
268  public function update(): void
269  {
270  $ilDB = $this->db;
271 
272  $ilDB->manipulate("UPDATE glossary_term SET " .
273  " glo_id = " . $ilDB->quote($this->getGlossaryId(), "integer") . ", " .
274  " term = " . $ilDB->quote($this->getTerm(), "text") . ", " .
275  " import_id = " . $ilDB->quote($this->getImportId(), "text") . ", " .
276  " language = " . $ilDB->quote($this->getLanguage(), "text") . ", " .
277  " last_update = " . $ilDB->now() . ", " .
278  " short_text = " . $ilDB->quote($this->getShortText(), "text") . ", " .
279  " short_text_dirty = " . $ilDB->quote($this->getShortTextDirty(), "integer") . " " .
280  " WHERE id = " . $ilDB->quote($this->getId(), "integer"));
281  }
282 
286  public function shortenShortText(string $text): string
287  {
288  $a_length = 196;
289 
290  if ($this->getId() > 0) {
291  $glo_id = self::_lookGlossaryID($this->getId());
292  $snippet_length = ilObjGlossary::lookupSnippetLength($glo_id);
293  if ($snippet_length > 0) {
294  $a_length = $snippet_length;
295  }
296  }
297 
298  $text = str_replace("<br/>", "<br>", $text);
299  $text = strip_tags($text, "<br>");
300  $offset = 0;
301  if (is_int(strpos(substr($text, $a_length - 16 - 5, 10), "[tex]"))) {
302  $offset = 5;
303  }
304  $short = ilStr::shortenTextExtended($text, $a_length - 16 + $offset, true);
305 
306  // make short text longer, if tex end tag is missing
307  $ltexs = strrpos($short, "[tex]");
308  $ltexe = strrpos($short, "[/tex]");
309  if ($ltexs > $ltexe) {
310  $ltexe = strpos($text, "[/tex]", $ltexs);
311  if ($ltexe > 0) {
312  $text = ilStr::shortenTextExtended($text, $ltexe + 6, true);
313  }
314  }
315 
316  $short = ilStr::shortenTextExtended($text, $a_length, true);
317 
318  return $short;
319  }
320 
321  public function updateShortText(): void
322  {
323  $this->page_object->buildDom();
324  $text = $this->page_object->getFirstParagraphText();
325  $short = $this->shortenShortText($text);
326 
327  $this->setShortText($short);
328  $this->setShortTextDirty(0);
329  $this->update();
330  }
331 
336  public static function setShortTextsDirty(int $a_glo_id): void
337  {
338  global $DIC;
339 
340  $ilDB = $DIC->database();
341 
342  $term_ids = self::getTermsOfGlossary($a_glo_id);
343 
344  foreach ($term_ids as $term_id) {
345  $ilDB->manipulate(
346  "UPDATE glossary_term SET " .
347  " short_text_dirty = " . $ilDB->quote(1, "integer") .
348  " WHERE id = " . $ilDB->quote($term_id, "integer")
349  );
350  }
351  }
352 
356  public static function setShortTextsDirtyGlobally(): void
357  {
358  global $DIC;
359 
360  $ilDB = $DIC->database();
361 
362  $ilDB->manipulate(
363  "UPDATE glossary_term SET " .
364  " short_text_dirty = " . $ilDB->quote(1, "integer")
365  );
366  }
367 
371  public static function _lookGlossaryID(int $term_id): int
372  {
373  global $DIC;
374 
375  $ilDB = $DIC->database();
376 
377  $query = "SELECT * FROM glossary_term WHERE id = " .
378  $ilDB->quote($term_id, "integer");
379  $obj_set = $ilDB->query($query);
380  $obj_rec = $ilDB->fetchAssoc($obj_set);
381 
382  return (int) ($obj_rec["glo_id"] ?? 0);
383  }
384 
388  public static function _lookGlossaryTerm(int $term_id): string
389  {
390  global $DIC;
391 
392  $ilDB = $DIC->database();
393 
394  $query = "SELECT * FROM glossary_term WHERE id = " .
395  $ilDB->quote($term_id, "integer");
396  $obj_set = $ilDB->query($query);
397  $obj_rec = $ilDB->fetchAssoc($obj_set);
398 
399  return $obj_rec["term"] ?? "";
400  }
401 
405  public static function _lookLanguage(int $term_id): string
406  {
407  global $DIC;
408 
409  $ilDB = $DIC->database();
410 
411  $query = "SELECT * FROM glossary_term WHERE id = " .
412  $ilDB->quote($term_id, "integer");
413  $obj_set = $ilDB->query($query);
414  $obj_rec = $ilDB->fetchAssoc($obj_set);
415 
416  return $obj_rec["language"];
417  }
418 
422  public static function _lookShortText(int $term_id): string
423  {
424  global $DIC;
425 
426  $ilDB = $DIC->database();
427 
428  $query = "SELECT * FROM glossary_term WHERE id = " .
429  $ilDB->quote($term_id, "integer");
430  $obj_set = $ilDB->query($query);
431  $obj_rec = $ilDB->fetchAssoc($obj_set);
432 
433  return $obj_rec["short_text"] ?? "";
434  }
435 
439  public static function _lookShortTextDirty(int $term_id): int
440  {
441  global $DIC;
442 
443  $ilDB = $DIC->database();
444 
445  $query = "SELECT * FROM glossary_term WHERE id = " .
446  $ilDB->quote($term_id, "integer");
447  $obj_set = $ilDB->query($query);
448  $obj_rec = $ilDB->fetchAssoc($obj_set);
449 
450  return (int) ($obj_rec["short_text_dirty"] ?? 0);
451  }
452 
456  public static function getTermList(
457  array $a_glo_ref_id,
458  string $searchterm = "",
459  string $a_first_letter = "",
460  string $a_def = "",
461  int $a_tax_node = 0,
462  bool $a_add_amet_fields = false,
463  ?array $a_amet_filter = null,
464  bool $a_include_references = false
465  ): array {
466  global $DIC;
467 
468  if (count($a_glo_ref_id) > 1) {
469  $a_glo_id = array_map(static function ($id): int {
470  return ilObject::_lookupObjectId($id);
471  }, $a_glo_ref_id);
472  } else {
473  $a_glo_id = ilObject::_lookupObjectId(current($a_glo_ref_id));
474  }
475  $ilDB = $DIC->database();
476 
477  $join = $in = "";
478 
479  $terms = array();
480 
481  // get all term ids under taxonomy node (if given)
482  if ($a_tax_node > 1) {
483  $tax_ids = ilObjTaxonomy::getUsageOfObject($a_glo_id);
484  if (count($tax_ids) > 0) {
485  $items = ilObjTaxonomy::getSubTreeItems("glo", $a_glo_id, "term", $tax_ids[0], $a_tax_node);
486  $sub_tree_ids = array();
487  foreach ($items as $i) {
488  $sub_tree_ids[] = $i["item_id"];
489  }
490  $in = " AND " . $ilDB->in("gt.id", $sub_tree_ids, false, "integer");
491  }
492  }
493 
494  if ($a_def != "") {
495  // meta glossary?
496  if (is_array($a_glo_id)) {
497  $glo_where = $ilDB->in("page_object.parent_id", $a_glo_id, false, "integer");
498  } else {
499  $glo_where = " page_object.parent_id = " . $ilDB->quote($a_glo_id, "integer");
500  }
501 
502  $join = " JOIN page_object ON (" .
503  $glo_where .
504  " AND page_object.parent_type = " . $ilDB->quote("term", "text") .
505  " AND page_object.page_id = gt.id" .
506  " AND " . $ilDB->like("page_object.content", "text", "%" . $a_def . "%") .
507  ")";
508  }
509 
510  $searchterm = (!empty($searchterm))
511  ? " AND " . $ilDB->like("term", "text", "%" . $searchterm . "%") . " "
512  : "";
513 
514  if ($a_first_letter != "") {
515  $searchterm .= " AND " . $ilDB->upper($ilDB->substr("term", 1, 1)) . " = " . $ilDB->upper($ilDB->quote($a_first_letter, "text")) . " ";
516  }
517 
518  // include references
519  $where_glo_id_or = "";
520  if ($a_include_references) {
521  $join .= " LEFT JOIN glo_term_reference tr ON (gt.id = tr.term_id) ";
522  if (is_array($a_glo_id)) {
523  $where_glo_id_or = " OR " . $ilDB->in("tr.glo_id", $a_glo_id, false, "integer");
524  } else {
525  $where_glo_id_or = " OR tr.glo_id = " . $ilDB->quote($a_glo_id, "integer");
526  }
527  }
528 
529  // meta glossary
530  if (is_array($a_glo_id)) {
531  $where = "(" . $ilDB->in("gt.glo_id", $a_glo_id, false, "integer") . $where_glo_id_or . ")";
532  } else {
533  $where = "(gt.glo_id = " . $ilDB->quote($a_glo_id, "integer") . $where_glo_id_or . ")";
534  }
535 
536  $where .= $in;
537 
538 
539  $q = "SELECT DISTINCT(gt.term), gt.id, gt.glo_id, gt.language, gt.short_text, gt.short_text_dirty FROM glossary_term gt " .
540  $join . " WHERE " . $where . $searchterm . " ORDER BY gt.term, gt.id";
541 
542  $term_set = $ilDB->query($q);
543  $glo_ids = array();
544  while ($term_rec = $ilDB->fetchAssoc($term_set)) {
545  $terms[] = array("term" => $term_rec["term"],
546  "language" => $term_rec["language"], "id" => $term_rec["id"], "glo_id" => $term_rec["glo_id"],
547  "short_text" => strip_tags((string) $term_rec["short_text"], "<br>"),
548  "short_text_dirty" => $term_rec["short_text_dirty"]);
549  $glo_ids[] = $term_rec["glo_id"];
550  }
551 
552  // add advanced metadata
553  if (($a_add_amet_fields || is_array($a_amet_filter)) && count($a_glo_ref_id) == 1) {
554  $terms = ilAdvancedMDValues::queryForRecords(current($a_glo_ref_id), "glo", "term", $glo_ids, "term", $terms, "glo_id", "id", $a_amet_filter);
555  }
556  return $terms;
557  }
558 
559  public static function getFirstLetters(
560  array $a_glo_id,
561  int $a_tax_node = 0
562  ): array {
563  global $DIC;
564 
565  $ilDB = $DIC->database();
566 
567  // meta glossary
568  if (count($a_glo_id) > 1) {
569  $where = $ilDB->in("glo_id", $a_glo_id, false, "integer");
570  } else {
571  $a_glo_id = current($a_glo_id);
572  $where = " glo_id = " . $ilDB->quote($a_glo_id, "integer") . " ";
573  $in = "";
574  // get all term ids under taxonomy node (if given)
575  if ($a_tax_node > 1) {
576  $tax_ids = ilObjTaxonomy::getUsageOfObject($a_glo_id);
577  if (count($tax_ids) > 0) {
578  $items = ilObjTaxonomy::getSubTreeItems("glo", $a_glo_id, "term", $tax_ids[0], $a_tax_node);
579  $sub_tree_ids = array();
580  foreach ($items as $i) {
581  $sub_tree_ids[] = $i["item_id"];
582  }
583  $in = " AND " . $ilDB->in("id", $sub_tree_ids, false, "integer");
584  }
585  }
586 
587  $where .= $in;
588  }
589 
590  $q = "SELECT DISTINCT " . $ilDB->upper($ilDB->substr("term", 1, 1)) . " let FROM glossary_term WHERE " . $where . " ORDER BY let";
591  $let_set = $ilDB->query($q);
592 
593  $let = array();
594  while ($let_rec = $ilDB->fetchAssoc($let_set)) {
595  $let[$let_rec["let"]] = $let_rec["let"];
596  }
597  return $let;
598  }
599 
600  public function exportXML(
601  ilXmlWriter $a_xml_writer,
602  int $a_inst
603  ): void {
604  $attrs = array();
605  $attrs["Language"] = $this->getLanguage();
606  $attrs["Id"] = "il_" . IL_INST_ID . "_git_" . $this->getId();
607  $a_xml_writer->xmlStartTag("GlossaryItem", $attrs);
608 
609  $attrs = array();
610  $a_xml_writer->xmlElement("GlossaryTerm", $attrs, $this->getTerm());
611 
612  $a_xml_writer->xmlEndTag("GlossaryItem");
613  }
614 
615  public static function getNumberOfUsages(int $a_term_id): int
616  {
617  return count(self::getUsages($a_term_id));
618  }
619 
620  public static function getUsages(int $a_term_id): array
621  {
622  $usages = (ilInternalLink::_getSourcesOfTarget("git", $a_term_id, 0));
623 
625  $usages["glo:termref:" . $glo_id . ":-"] = array(
626  "type" => "glo:termref",
627  "id" => $glo_id,
628  "lang" => "-"
629  );
630  }
631 
632  return $usages;
633  }
634 
639  public static function _copyTerm(
640  int $a_term_id,
641  int $a_glossary_id
642  ): int {
643  $old_term = new ilGlossaryTerm($a_term_id);
644 
645  // copy the term
646  $new_term = new ilGlossaryTerm();
647  $new_term->setTerm($old_term->getTerm());
648  $new_term->setLanguage($old_term->getLanguage());
649  $new_term->setGlossaryId($a_glossary_id);
650  $new_term->setShortText($old_term->getShortText());
651  $new_term->setShortTextDirty($old_term->getShortTextDirty());
652  $new_term->create();
653 
654  $new_page = $new_term->getPageObject();
655  $old_term->getPageObject()->copy($new_page->getId(), $new_page->getParentType(), $new_page->getParentId(), true);
656 
657  // adv metadata
658  $old_recs = ilAdvancedMDRecord::_getSelectedRecordsByObject("glo", $old_term->getGlossaryId(), "term");
659  $new_recs = ilAdvancedMDRecord::_getSelectedRecordsByObject("glo", $a_glossary_id, "term");
660  foreach ($old_recs as $old_record_obj) {
661  reset($new_recs);
662  foreach ($new_recs as $new_record_obj) {
663  if ($old_record_obj->getRecordId() == $new_record_obj->getRecordId()) {
664  foreach (ilAdvancedMDFieldDefinition::getInstancesByRecordId($old_record_obj->getRecordId()) as $def) {
665  // now we need to copy $def->getFieldId() values from old term to new term
666  // how?
667  // clone values
668 
669  $source_primary = array("obj_id" => array("integer", $old_term->getGlossaryId()));
670  $source_primary["sub_type"] = array("text", "term");
671  $source_primary["sub_id"] = array("integer", $old_term->getId());
672  $source_primary["field_id"] = array("integer", $def->getFieldId());
673  $target_primary = array("obj_id" => array("integer", $new_term->getGlossaryId()));
674  $target_primary["sub_type"] = array("text", "term");
675  $target_primary["sub_id"] = array("integer", $new_term->getId());
676 
677  ilADTFactory::getInstance()->initActiveRecordByType();
679  "adv_md_values",
680  array(
681  "obj_id" => "integer",
682  "sub_type" => "text",
683  "sub_id" => "integer",
684  "field_id" => "integer"
685  ),
686  $source_primary,
687  $target_primary,
688  array("disabled" => "integer")
689  );
690  }
691  }
692  }
693  }
694 
695  return $new_term->getId();
696  }
697 
701  public static function getTermsOfGlossary(
702  int $a_glo_id
703  ): array {
704  global $DIC;
705 
706  $ilDB = $DIC->database();
707 
708  $set = $ilDB->query(
709  "SELECT id FROM glossary_term WHERE " .
710  " glo_id = " . $ilDB->quote($a_glo_id, "integer")
711  );
712  $ids = array();
713  while ($rec = $ilDB->fetchAssoc($set)) {
714  $ids[] = (int) $rec["id"];
715  }
716  return $ids;
717  }
718 }
static deleteReferencesOfTerm(int $a_term_id)
Delete all references of a term.
Global event handler.
const IL_INST_ID
Definition: constants.php:40
static getUsages(int $a_term_id)
setShortTextDirty(int $a_val)
ilGlossaryDefPage $page_object
static getSubTreeItems(string $a_comp, int $a_obj_id, string $a_item_type, int $a_tax_id, $a_node)
Get all assigned items under a node.
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
static _exists(int $a_id)
checks whether a glossary term with specified id exists or not
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
assignPageObject(ilGlossaryDefPage $a_page_object)
static _getIdForImportId(string $a_import_id)
static _getAllReferences(int $id)
get all reference ids for object ID
ilAppEventHandler $event_handler
setShortText(string $a_text)
static _hasUntrashedReference(int $obj_id)
checks whether an object has at least one reference that is not in trash
static getUsageOfObject(int $a_obj_id, bool $a_include_titles=false)
static _getSelectedRecordsByObject(string $a_obj_type, int $a_id, string $a_sub_type="", bool $is_ref_id=true)
static getInstancesByRecordId( $a_record_id, $a_only_searchable=false, string $language='')
Get definitions by record id.
static _lookShortTextDirty(int $term_id)
get definition short text dirty
static getTermList(array $a_glo_ref_id, string $searchterm="", string $a_first_letter="", string $a_def="", int $a_tax_node=0, bool $a_add_amet_fields=false, ?array $a_amet_filter=null, bool $a_include_references=false)
Get all terms for given set of glossary ids.
setGlossary(ilObjGlossary $a_glossary)
static _copyTerm(int $a_term_id, int $a_glossary_id)
Copy a term to a glossary.
xmlEndTag(string $tag)
Writes an endtag.
exportXML(ilXmlWriter $a_xml_writer, int $a_inst)
while($session_entry=$r->fetchRow(ilDBConstants::FETCHMODE_ASSOC)) return null
static queryForRecords(int $adv_rec_obj_ref_id, string $adv_rec_obj_type, string $adv_rec_obj_subtype, array $a_obj_id, string $a_subtype, array $a_records, string $a_obj_id_key, string $a_obj_subid_key, ?array $a_amet_filter=null)
setTerm(string $a_term)
static lookupReferencesOfTerm(int $a_term_id)
create(bool $a_omit_page_creation=false)
shortenShortText(string $text)
Shorten short text.
static _lookGlossaryTerm(int $term_id)
get glossary term
global $DIC
Definition: shib_login.php:22
static _lookupObjectId(int $ref_id)
static getTermsOfGlossary(int $a_glo_id)
static _lookShortText(int $term_id)
get definition short text
ilGlobalTemplateInterface $tpl
setId(int $a_id)
set glossary term id (= glossary item id)
static _lookLanguage(int $term_id)
lookup term language
This file is part of ILIAS, a powerful learning management system published by ILIAS open source e-Le...
setLanguage(string $a_language)
ilObjGlossary $glossary
static shortenTextExtended(string $a_str, int $a_len, bool $a_dots=false, bool $a_next_blank=false, bool $a_keep_extension=false)
static lookupSnippetLength(int $a_id)
$q
Definition: shib_logout.php:21
static setShortTextsDirty(int $a_glo_id)
Set all short texts of glossary dirty (e.g.
xmlStartTag(string $tag, ?array $attrs=null, bool $empty=false, bool $encode=true, bool $escape=true)
Writes a starttag.
__construct(int $a_id=0)
xmlElement(string $tag, $attrs=null, $data=null, $encode=true, $escape=true)
Writes a basic element (no children, just textual content)
language()
description: > Example for rendring a language glyph.
Definition: language.php:41
static cloneByPrimary(string $a_table, array $a_primary_def, array $a_source_primary, array $a_target_primary, ?array $a_additional=null)
Clone values by (partial) primary key.
static getNumberOfUsages(int $a_term_id)
setGlossaryId(int $a_glo_id)
static setShortTextsDirtyGlobally()
Set short texts dirty (for all glossaries)
static getFirstLetters(array $a_glo_id, int $a_tax_node=0)
setImportId(string $a_import_id)
static _lookGlossaryID(int $term_id)
get glossary id form term id