3 declare(strict_types=1);
28 protected \ILIAS\Style\Content\InternalRepoService
$repo;
41 public static array
$num_unit = array(
"px",
"em",
"ex",
"%",
"pt",
"pc",
"in",
"mm",
"cm");
42 public static array
$num_unit_no_perc = array(
"px",
"em",
"ex",
"pt",
"pc",
"in",
"mm",
"cm");
47 "values" => array(
"xx-small",
"x-small",
"small",
"medium",
"large",
"x-large",
"xx-large",
"smaller",
"larger"),
48 "input" =>
"fontsize",
50 "font-family" => array(
54 "font-style" => array(
55 "values" => array(
"italic",
"oblique",
"normal"),
58 "font-weight" => array(
59 "values" => array(
"bold",
"normal",
"bolder",
"lighter"),
62 "font-variant" => array(
63 "values" => array(
"small-caps",
"normal"),
66 "word-spacing" => array(
68 "input" =>
"numeric_no_perc",
70 "letter-spacing" => array(
72 "input" =>
"numeric_no_perc",
74 "text-decoration" => array(
75 "values" => array(
"underline",
"overline",
"line-through",
"blink",
"none"),
78 "text-transform" => array(
79 "values" => array(
"capitalize",
"uppercase",
"lowercase",
"none"),
86 "text-indent" => array(
90 "line-height" => array(
94 "vertical-align" => array(
95 "values" => array(
"top",
"middle",
"bottom",
"baseline",
"sub",
"super",
96 "text-top",
"text-bottom"),
99 "text-align" => array(
100 "values" => array(
"left",
"center",
"right",
"justify"),
103 "white-space" => array(
104 "values" => array(
"normal",
"pre",
"nowrap"),
109 "input" =>
"trbl_numeric",
110 "subpar" => array(
"margin",
"margin-top",
"margin-right",
111 "margin-bottom",
"margin-left"),
112 "group" =>
"margin_and_padding"),
115 "input" =>
"trbl_numeric",
116 "subpar" => array(
"padding",
"padding-top",
"padding-right",
117 "padding-bottom",
"padding-left"),
118 "group" =>
"margin_and_padding"),
119 "border-width" => array(
120 "values" => array(
"thin",
"medium",
"thick"),
121 "input" =>
"border_width",
122 "subpar" => array(
"border-width",
"border-top-width",
"border-right-width",
123 "border-bottom-width",
"border-left-width"),
124 "group" =>
"border"),
125 "border-color" => array(
127 "input" =>
"trbl_color",
128 "subpar" => array(
"border-color",
"border-top-color",
"border-right-color",
129 "border-bottom-color",
"border-left-color"),
130 "group" =>
"border"),
131 "border-style" => array(
132 "values" => array(
"none",
"hidden",
"dotted",
"dashed",
"solid",
"double",
133 "groove",
"ridge",
"inset",
"outset"),
134 "input" =>
"border_style",
135 "subpar" => array(
"border-style",
"border-top-style",
"border-right-style",
136 "border-bottom-style",
"border-left-style"),
137 "group" =>
"border"),
139 "background-color" => array(
142 "group" =>
"background"),
143 "background-image" => array(
145 "input" =>
"background_image",
146 "group" =>
"background"),
147 "background-repeat" => array(
148 "values" => array(
"repeat",
"repeat-x",
"repeat-y",
"no-repeat"),
150 "group" =>
"background"),
151 "background-attachment" => array(
152 "values" => array(
"fixed",
"scroll"),
154 "group" =>
"background"),
155 "background-position" => array(
156 "values" => array(
"horizontal" => array(
"left",
"center",
"right"),
157 "vertical" => array(
"top",
"center",
"bottom")),
158 "input" =>
"background_position",
159 "group" =>
"background"),
162 "values" => array(
"absolute",
"fixed",
"relative",
"static"),
164 "group" =>
"positioning"),
167 "input" =>
"numeric",
168 "group" =>
"positioning"),
171 "input" =>
"numeric",
172 "group" =>
"positioning"),
175 "input" =>
"numeric",
176 "group" =>
"positioning"),
179 "input" =>
"numeric",
180 "group" =>
"positioning"),
183 "input" =>
"numeric",
184 "group" =>
"positioning"),
187 "input" =>
"numeric",
188 "group" =>
"positioning"),
189 "min-height" => array(
191 "input" =>
"numeric",
192 "group" =>
"positioning"),
194 "values" => array(
"left",
"right",
"none"),
196 "group" =>
"positioning"),
198 "values" => array(
"visible",
"hidden",
"scroll",
"auto"),
200 "group" =>
"positioning"),
203 "input" =>
"percentage",
204 "group" =>
"special"),
205 "transform" => array(
206 "values" => array(
"rotate(90deg)",
"rotate(180deg)",
"rotate(270deg)"),
208 "group" =>
"special"),
209 "transform-origin" => array(
210 "values" => array(
"horizontal" => array(
"left",
"center",
"right"),
211 "vertical" => array(
"top",
"center",
"bottom")),
212 "input" =>
"background_position",
213 "group" =>
"special"),
215 "values" => array(
"auto",
"default",
"crosshair",
"pointer",
"move",
216 "n-resize",
"ne-resize",
"e-resize",
"se-resize",
"s-resize",
"sw-resize",
217 "w-resize",
"nw-resize",
"text",
"wait",
"help"),
219 "group" =>
"special"),
221 "values" => array(
"both",
"left",
"right",
"none"),
223 "group" =>
"special"),
225 "list-style-type.ol" => array(
226 "values" => array(
"decimal",
"lower-roman",
"upper-roman",
227 "lower-alpha",
"upper-alpha",
"lower-greek",
"hebrew",
228 "decimal-leading-zero",
"cjk-ideographic",
"hiragana",
229 "katakana",
"hiragana-iroha",
"katakana-iroha",
"none"),
232 "list-style-type.ul" => array(
233 "values" => array(
"disc",
"circle",
"square",
237 "list-style-image.ul" => array(
239 "input" =>
"background_image",
241 "list-style-position.ol" => array(
242 "values" => array(
"inside",
"outside"),
245 "list-style-position.ul" => array(
246 "values" => array(
"inside",
"outside"),
250 "border-collapse" => array(
251 "values" => array(
"collapse",
"separate"),
255 "caption-side" => array(
256 "values" => array(
"top",
"bottom",
"left",
"right"),
265 array(
"ol" => array(
"ol"),
"ul" => array(
"ul"),
266 "table" => array(
"table"),
"positioning" => array(
"h1",
"h2",
"h3",
"div",
"img",
"table",
"a",
"figure"));
270 "text_block" => array(
"text_block",
"heading1",
"heading2",
"heading3",
"code_block"),
271 "text_inline" => array(
"text_inline",
"sub",
"sup",
"code_inline"),
272 "section" => array(
"section"),
273 "link" => array(
"link"),
274 "table" => array(
"table",
"table_cell",
"table_caption"),
275 "list" => array(
"list_o",
"list_u",
"list_item"),
276 "flist" => array(
"flist_cont",
"flist_head",
"flist",
"flist_li",
"flist_a"),
277 "media" => array(
"media_cont",
"media_caption",
"iim",
"marker"),
278 "tabs" => array(
"va_cntr",
"va_icntr",
"va_ihead",
"va_iheada",
"va_ihcap",
"va_icont",
279 "ha_cntr",
"ha_icntr",
"ha_ihead",
"ha_iheada",
"ha_ihcap",
"ha_icont",
"ca_cntr",
"ca_icntr",
"ca_ihead",
"ca_icont"),
280 "question" => array(
"question",
"qtitle",
"qanswer",
"qinput",
"qlinput",
"qsubmit",
"qfeedr",
"qfeedw",
281 "qimg",
"qordul",
"qordli",
"qimgd",
"qetitem",
"qetcorr",
"qover"),
282 "page" => array(
"page_frame",
"page_cont",
"page_title",
"page_fn",
283 "page_tnav",
"page_bnav",
"page_lnav",
"page_rnav",
"page_lnavlink",
"page_rnavlink",
284 "page_lnavimage",
"page_rnavimage")
290 "text_inline",
"section",
"media_cont",
"media_caption",
"table",
"table_cell",
"flist_li",
"table_caption",
292 "va_cntr",
"va_icntr",
"va_ihead",
"va_iheada",
"va_ihcap",
"va_icont",
293 "ha_cntr",
"ha_icntr",
"ha_ihead",
"ha_iheada",
"ha_ihcap",
"ha_icont",
294 "ca_cntr",
"ca_icntr",
"ca_ihead",
"ca_icont" 299 "table",
"table_cell" 304 "text_block" =>
"div",
308 "code_block" =>
"pre",
309 "text_inline" =>
"span",
310 "code_inline" =>
"code",
316 "table_cell" =>
"td",
317 "table_caption" =>
"caption",
318 "media_cont" =>
"figure",
319 "media_caption" =>
"div",
325 "flist_cont" =>
"div",
326 "flist_head" =>
"div",
340 "qlinput" =>
"textarea",
341 "qsubmit" =>
"input",
345 "page_frame" =>
"div",
346 "page_cont" =>
"div",
349 "page_tnav" =>
"div",
350 "page_bnav" =>
"div",
351 "page_lnav" =>
"div",
352 "page_rnav" =>
"div",
353 "page_lnavlink" =>
"a",
354 "page_rnavlink" =>
"a",
355 "page_lnavimage" =>
"img",
356 "page_rnavimage" =>
"img",
357 "page_title" =>
"h1",
362 "va_iheada" =>
"div",
367 "ha_iheada" =>
"div",
378 array(
"a" => array(
"hover"),
"div" => array(
"hover"),
"img" => array(
"hover"));
382 array(
"type" =>
"text_block",
"class" =>
"Standard"),
383 array(
"type" =>
"text_block",
"class" =>
"List"),
384 array(
"type" =>
"text_block",
"class" =>
"TableContent"),
385 array(
"type" =>
"code_block",
"class" =>
"Code"),
386 array(
"type" =>
"heading1",
"class" =>
"Headline1"),
387 array(
"type" =>
"heading2",
"class" =>
"Headline2"),
388 array(
"type" =>
"heading3",
"class" =>
"Headline3"),
389 array(
"type" =>
"text_inline",
"class" =>
"Comment"),
390 array(
"type" =>
"text_inline",
"class" =>
"Emph"),
391 array(
"type" =>
"text_inline",
"class" =>
"Quotation"),
392 array(
"type" =>
"text_inline",
"class" =>
"Strong"),
393 array(
"type" =>
"text_inline",
"class" =>
"Accent"),
394 array(
"type" =>
"text_inline",
"class" =>
"Important"),
395 array(
"type" =>
"code_inline",
"class" =>
"CodeInline"),
396 array(
"type" =>
"sup",
"class" =>
"Sup"),
397 array(
"type" =>
"sub",
"class" =>
"Sub"),
398 array(
"type" =>
"link",
"class" =>
"IntLink"),
399 array(
"type" =>
"link",
"class" =>
"ExtLink"),
400 array(
"type" =>
"link",
"class" =>
"FootnoteLink"),
401 array(
"type" =>
"link",
"class" =>
"FileLink"),
402 array(
"type" =>
"link",
"class" =>
"GlossaryLink"),
403 array(
"type" =>
"media_cont",
"class" =>
"MediaContainer"),
404 array(
"type" =>
"media_cont",
"class" =>
"MediaContainerMax50"),
405 array(
"type" =>
"media_cont",
"class" =>
"MediaContainerFull100"),
406 array(
"type" =>
"table",
"class" =>
"StandardTable"),
407 array(
"type" =>
"media_caption",
"class" =>
"MediaCaption"),
408 array(
"type" =>
"iim",
"class" =>
"ContentPopup"),
409 array(
"type" =>
"marker",
"class" =>
"Marker"),
410 array(
"type" =>
"page_frame",
"class" =>
"PageFrame"),
411 array(
"type" =>
"page_cont",
"class" =>
"PageContainer"),
412 array(
"type" =>
"page",
"class" =>
"Page"),
413 array(
"type" =>
"page_tnav",
"class" =>
"TopNavigation"),
414 array(
"type" =>
"page_bnav",
"class" =>
"BottomNavigation"),
415 array(
"type" =>
"page_lnav",
"class" =>
"LeftNavigation"),
416 array(
"type" =>
"page_rnav",
"class" =>
"RightNavigation"),
417 array(
"type" =>
"page_lnavlink",
"class" =>
"LeftNavigationLink"),
418 array(
"type" =>
"page_rnavlink",
"class" =>
"RightNavigationLink"),
419 array(
"type" =>
"page_lnavimage",
"class" =>
"LeftNavigationImage"),
420 array(
"type" =>
"page_rnavimage",
"class" =>
"RightNavigationImage"),
421 array(
"type" =>
"page_fn",
"class" =>
"Footnote"),
422 array(
"type" =>
"page_title",
"class" =>
"PageTitle"),
423 array(
"type" =>
"list_o",
"class" =>
"NumberedList"),
424 array(
"type" =>
"list_u",
"class" =>
"BulletedList"),
425 array(
"type" =>
"list_item",
"class" =>
"StandardListItem"),
426 array(
"type" =>
"question",
"class" =>
"Standard"),
427 array(
"type" =>
"question",
"class" =>
"SingleChoice"),
428 array(
"type" =>
"question",
"class" =>
"MultipleChoice"),
429 array(
"type" =>
"question",
"class" =>
"TextQuestion"),
430 array(
"type" =>
"question",
"class" =>
"OrderingQuestion"),
431 array(
"type" =>
"question",
"class" =>
"MatchingQuestion"),
432 array(
"type" =>
"question",
"class" =>
"ImagemapQuestion"),
433 array(
"type" =>
"question",
"class" =>
"ErrorText"),
434 array(
"type" =>
"question",
"class" =>
"TextSubset"),
435 array(
"type" =>
"question",
"class" =>
"ClozeTest"),
436 array(
"type" =>
"qtitle",
"class" =>
"Title"),
437 array(
"type" =>
"qanswer",
"class" =>
"Answer"),
438 array(
"type" =>
"qimg",
"class" =>
"QuestionImage"),
439 array(
"type" =>
"qimgd",
"class" =>
"ImageDetailsLink"),
440 array(
"type" =>
"qordul",
"class" =>
"OrderList"),
441 array(
"type" =>
"qordli",
"class" =>
"OrderListItem"),
442 array(
"type" =>
"qordul",
"class" =>
"OrderListHorizontal"),
443 array(
"type" =>
"qordli",
"class" =>
"OrderListItemHorizontal"),
444 array(
"type" =>
"qetitem",
"class" =>
"ErrorTextItem"),
445 array(
"type" =>
"qetitem",
"class" =>
"ErrorTextSelected"),
446 array(
"type" =>
"qetcorr",
"class" =>
"ErrorTextCorrected"),
447 array(
"type" =>
"qinput",
"class" =>
"TextInput"),
448 array(
"type" =>
"qlinput",
"class" =>
"LongTextInput"),
449 array(
"type" =>
"qsubmit",
"class" =>
"Submit"),
450 array(
"type" =>
"qfeedr",
"class" =>
"FeedbackRight"),
451 array(
"type" =>
"qfeedw",
"class" =>
"FeedbackWrong"),
452 array(
"type" =>
"qover",
"class" =>
"Correct"),
453 array(
"type" =>
"qover",
"class" =>
"Inorrect"),
454 array(
"type" =>
"qover",
"class" =>
"StatusMessage"),
455 array(
"type" =>
"qover",
"class" =>
"WrongAnswersMessage"),
456 array(
"type" =>
"flist_cont",
"class" =>
"FileListContainer"),
457 array(
"type" =>
"flist_head",
"class" =>
"FileListHeading"),
458 array(
"type" =>
"flist",
"class" =>
"FileList"),
459 array(
"type" =>
"flist_li",
"class" =>
"FileListItem"),
460 array(
"type" =>
"flist_a",
"class" =>
"FileListItemLink")
466 "caption" =>
"table_caption",
467 "row_head" =>
"table_cell",
468 "row_foot" =>
"table_cell",
469 "col_head" =>
"table_cell",
470 "col_foot" =>
"table_cell",
471 "odd_row" =>
"table_cell",
472 "even_row" =>
"table_cell",
473 "odd_col" =>
"table_cell",
474 "even_col" =>
"table_cell"),
475 "vaccordion" => array(
476 "va_cntr" =>
"va_cntr",
477 "va_icntr" =>
"va_icntr",
478 "va_ihead" =>
"va_ihead",
479 "va_iheada" =>
"va_iheada",
480 "va_ihcap" =>
"va_ihcap",
481 "va_icont" =>
"va_icont" 483 "haccordion" => array(
484 "ha_cntr" =>
"ha_cntr",
485 "ha_icntr" =>
"ha_icntr",
486 "ha_ihead" =>
"ha_ihead",
487 "ha_iheada" =>
"ha_iheada",
488 "ha_ihcap" =>
"ha_ihcap",
489 "ha_icont" =>
"ha_icont" 492 "ca_cntr" =>
"ca_cntr",
493 "ca_icntr" =>
"ca_icntr",
494 "ca_ihead" =>
"ca_ihead",
495 "ca_icont" =>
"ca_icont" 507 bool $a_call_by_reference =
false 511 $this->db = $DIC->database();
512 $this->
lng = $DIC->language();
514 $this->style = array();
515 $this->
ilias = $DIC[
"ilias"];
517 if ($a_call_by_reference) {
518 $this->
ilias->raiseError(
"Can't instantiate style object via reference id.", $this->
ilias->error_obj->FATAL);
521 $this->repo = $DIC->contentStyle()->internal()->repo();
526 return self::$basic_style_zip;
534 $this->up_to_date = $a_up_to_date;
544 $this->scope = $a_scope;
558 $ilDB = $DIC->database();
560 $q =
"UPDATE style_data SET uptodate = " .
561 $ilDB->quote((
int) $a_up_to_date,
"integer") .
562 " WHERE id = " .
$ilDB->quote($a_id,
"integer");
563 $ilDB->manipulate($q);
569 $ilDB = $DIC->database();
571 $q =
"UPDATE style_data SET owner_obj = " .
572 $ilDB->quote((
int) $obj_id,
"integer") .
573 " WHERE id = " .
$ilDB->quote($style_id,
"integer");
574 $ilDB->manipulate($q);
581 $ilDB = $DIC->database();
583 $q =
"SELECT uptodate FROM style_data " .
584 " WHERE id = " .
$ilDB->quote($a_id,
"integer");
588 return (
bool) $sty[
"uptodate"];
600 $ilDB = $DIC->database();
602 $q =
"UPDATE style_data SET standard = " .
603 $ilDB->quote((
int) $a_std,
"integer") .
604 " WHERE id = " .
$ilDB->quote($a_id,
"integer");
605 $ilDB->manipulate($q);
612 $ilDB = $DIC->database();
614 $q =
"UPDATE style_data SET category = " .
615 $ilDB->quote($a_scope,
"integer") .
616 " WHERE id = " .
$ilDB->quote($a_id,
"integer");
617 $ilDB->manipulate($q);
627 $ilDB = $DIC->database();
629 $q =
"SELECT * FROM style_data " .
630 " WHERE id = " .
$ilDB->quote($a_id,
"integer");
634 return (
bool) ($sty[
"standard"] ??
false);
641 $ilDB = $DIC->database();
643 $q =
"UPDATE style_data SET active = " .
644 $ilDB->quote((
int) $a_active,
"integer") .
645 " WHERE id = " .
$ilDB->quote($a_id,
"integer");
646 $ilDB->manipulate($q);
656 $ilDB = $DIC->database();
658 $q =
"SELECT * FROM style_data " .
659 " WHERE id = " .
$ilDB->quote($a_id,
"integer");
663 return (
bool) $sty[
"active"];
671 bool $a_exclude_default_style =
false,
672 bool $a_include_deactivated =
false,
677 $ilDB = $DIC->database();
679 $tree = $DIC->repositoryTree();
681 $default_style =
$ilSetting->get(
"default_content_style_id");
684 if (!$a_include_deactivated) {
685 $and_str =
" AND active = 1";
688 $q =
"SELECT * FROM style_data " .
689 " WHERE standard = 1" . $and_str;
693 if (!$a_exclude_default_style || $default_style != $sty[
"id"]) {
695 if ($a_scope > 0 && $sty[
"category"] > 0) {
699 if (!in_array((
int) $sty[
"category"],
$path)) {
721 $ilAccess = $DIC->access();
722 $ilDB = $DIC->database();
724 $clonable_styles = array();
726 $q =
"SELECT * FROM style_data";
727 $style_set =
$ilDB->query($q);
728 while ($style_rec =
$ilDB->fetchAssoc($style_set)) {
730 if ($style_rec[
"standard"] == 1) {
731 if ($style_rec[
"active"] == 1) {
736 if (count($obj_ids) == 0) {
737 $obj_ids = self::lookupObjectForStyle((
int) $style_rec[
"id"]);
739 foreach ($obj_ids as
$id) {
742 if ($ilAccess->checkAccess(
"write",
"", $ref_id)) {
749 $clonable_styles[(
int) $style_rec[
"id"]] =
754 asort($clonable_styles);
756 return $clonable_styles;
761 if (!is_object(self::$basic_style_dom)) {
763 self::$basic_style_dom->load(self::$basic_style_file);
766 return self::$basic_style_dom;
771 return self::$basic_style_image_dir;
779 int $a_from_style = 0,
780 bool $a_import_mode =
false 786 $id = parent::create();
790 $access_manager =
$service->domain()->access(
792 $DIC->user()->getId()
794 $access_manager->enableWrite(
true);
795 $color_manager =
$service->domain()->color($this->
getId(), $access_manager);
797 if ($a_from_style == 0) {
798 if (!$a_import_mode) {
807 self::$basic_style_image_dir,
812 $q =
"INSERT INTO style_data (id, uptodate, category) VALUES " .
813 "(" .
$ilDB->quote($this->
getId(),
"integer") .
", 0," .
815 $ilDB->manipulate($q);
821 $q =
"SELECT * FROM style_parameter WHERE style_id = " .
822 $ilDB->quote($a_from_style,
"integer");
823 $par_set =
$ilDB->query($q);
824 while ($par_rec =
$ilDB->fetchAssoc($par_set)) {
825 $def[] = array(
"tag" => $par_rec[
"tag"],
"class" => $par_rec[
"class"],
826 "parameter" => $par_rec[
"parameter"],
"value" => $par_rec[
"value"],
827 "type" => $par_rec[
"type"],
"mq_id" => $par_rec[
"mq_id"],
"custom" => $par_rec[
"custom"]);
830 $char_repo = $this->repo->characteristic();
831 $char_repo->cloneAllFromStyle($a_from_style, $this->
getId());
836 $mqs = $from_style->getMediaQueries();
837 $mq_mapping = array();
838 foreach ($mqs as $mq) {
840 $mq_mapping[$mq[
"id"]] = $nid;
844 foreach ($def as $sty) {
845 $id =
$ilDB->nextId(
"style_parameter");
846 $q =
"INSERT INTO style_parameter (id, style_id, tag, class, parameter, value, type, mq_id, custom) VALUES " .
848 $ilDB->quote(
$id,
"integer") .
"," .
849 $ilDB->quote($this->
getId(),
"integer") .
"," .
850 $ilDB->quote($sty[
"tag"],
"text") .
"," .
851 $ilDB->quote($sty[
"class"],
"text") .
"," .
852 $ilDB->quote($sty[
"parameter"],
"text") .
"," .
853 $ilDB->quote($sty[
"value"],
"text") .
"," .
854 $ilDB->quote($sty[
"type"],
"text") .
"," .
855 $ilDB->quote((
int) ($mq_mapping[$sty[
"mq_id"]] ?? 0),
"integer") .
"," .
856 $ilDB->quote($sty[
"custom"],
"integer") .
858 $ilDB->manipulate($q);
862 $q =
"INSERT INTO style_data (id, uptodate, category) VALUES " .
863 "(" .
$ilDB->quote($this->
getId(),
"integer") .
", 0," .
865 $ilDB->manipulate($q);
870 $from_style->getImagesDirectory(),
875 $colors = $from_style->getColors();
876 foreach ($colors as
$c) {
877 $color_manager->addColor($c[
"name"], $c[
"code"]);
882 foreach ($tcts as $tct => $v) {
883 $templates = $from_style->getTemplates($tct);
884 foreach ($templates as $t) {
885 $this->
addTemplate($tct, $t[
"name"], $t[
"classes"]);
891 if (!$a_import_mode) {
907 $set =
$ilDB->queryF(
908 "SELECT style_id FROM style_char WHERE style_id = %s AND characteristic = %s AND type = %s",
909 array(
"integer",
"text",
"text"),
910 array($this->
getId(), $a_char, $a_style_type)
912 if (
$ilDB->fetchAssoc($set)) {
921 bool $a_hidden =
false,
923 bool $outdated =
false 928 $ilDB->insert(
"style_char", [
929 "style_id" => [
"integer", $this->
getId()],
930 "type" => [
"text", $a_type],
931 "characteristic" => [
"text", $a_char],
932 "hide" => [
"integer", (
int) $a_hidden],
933 "outdated" => [
"integer", (
int) $outdated],
934 "order_nr" => [
"integer", $order_nr]
946 bool $a_no_hidden =
false,
947 bool $a_include_core =
true 954 if (isset($this->chars_by_type[$a_type])) {
955 foreach ($this->chars_by_type[$a_type] as
$c) {
956 if ($a_include_core || !self::isCoreStyle($a_type, $c)) {
963 foreach ($chars as $k => $char) {
964 if ($a_type ==
"" && $this->hidden_chars[$char[
"type"] .
":" . $char[
"class"]]) {
966 } elseif ($this->hidden_chars[$a_type .
":" . $char] ??
false) {
977 $this->chars = $a_chars;
991 "UPDATE style_char SET " .
992 " hide = " .
$ilDB->quote((
int) $a_hide,
"integer") .
993 " WHERE style_id = " .
$ilDB->quote($this->
getId(),
"integer") .
" AND " .
994 " type = " .
$ilDB->quote($a_type,
"text") .
" AND " .
995 " characteristic = " .
$ilDB->quote($a_char,
"text")
1008 $set =
$ilDB->query(
1009 "SELECT hide FROM style_char " .
1010 " WHERE style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" AND " .
1011 " type = " .
$ilDB->quote($a_type,
"text") .
" AND " .
1012 " characteristic = " .
$ilDB->quote($a_char,
"text")
1014 $rec =
$ilDB->fetchAssoc($set);
1016 return (
bool) ($rec[
"hide"] ??
false);
1029 $new_obj->setTitle($this->
getTitle() .
" (" .
$lng->
txt(
"sty_acopy") .
")");
1030 $new_obj->setType($this->
getType());
1032 $new_obj->create($this->
getId());
1034 $new_obj->writeStyleSetting(
1035 "disable_auto_margins",
1039 return $new_obj->getId();
1064 bool $a_custom =
false 1069 $tag = explode(
".", $a_tag);
1070 $value = $avail_params[$a_par][0];
1071 $id =
$ilDB->nextId(
"style_parameter");
1072 $q =
"INSERT INTO style_parameter (id,style_id, type, tag, class, parameter, value, mq_id, custom) VALUES " .
1074 $ilDB->quote(
$id,
"integer") .
"," .
1075 $ilDB->quote($this->
getId(),
"integer") .
"," .
1076 $ilDB->quote($a_type,
"text") .
"," .
1077 $ilDB->quote($tag[0],
"text") .
"," .
1078 $ilDB->quote($tag[1],
"text") .
"," .
1079 $ilDB->quote($a_par,
"text") .
"," .
1080 $ilDB->quote($value,
"text") .
"," .
1081 $ilDB->quote($a_mq_id,
"integer") .
"," .
1082 $ilDB->quote($a_custom,
"integer") .
1084 $ilDB->manipulate($q);
1110 if (!is_dir($sty_data_dir)) {
1113 if (!is_writable($sty_data_dir)) {
1114 $ilErr->raiseError(
"Style data directory (" . $sty_data_dir
1115 .
") not writeable.",
$ilErr->FATAL);
1118 $style_dir = $sty_data_dir .
"/sty_" . $a_style_id;
1119 if (!is_dir($style_dir)) {
1122 if (!is_dir($style_dir)) {
1123 $ilErr->raiseError(
"Creation of style directory failed (" .
1124 $style_dir .
").",
$ilErr->FATAL);
1128 $im_dir = $style_dir .
"/images";
1129 if (!is_dir($im_dir)) {
1132 if (!is_dir($im_dir)) {
1133 $ilErr->raiseError(
"Creation of Import Directory failed (" .
1134 $im_dir .
").",
$ilErr->FATAL);
1138 $thumb_dir = $style_dir .
"/images/thumbnails";
1140 if (!is_dir($thumb_dir)) {
1141 $ilErr->raiseError(
"Creation of Import Directory failed (" .
1142 $thumb_dir .
").",
$ilErr->FATAL);
1170 $q =
"DELETE FROM style_parameter WHERE id = " .
1171 $ilDB->quote($a_id,
"integer");
1191 $q =
"DELETE FROM style_parameter WHERE " .
1192 " style_id = " .
$ilDB->quote($this->
getId(),
"integer") .
" AND " .
1193 " tag = " .
$ilDB->quote($a_tag,
"text") .
" AND " .
1194 " class = " .
$ilDB->quote($a_class,
"text") .
" AND " .
1195 " mq_id = " .
$ilDB->quote($a_mq_id,
"integer") .
" AND " .
1196 " custom = " .
$ilDB->quote(1,
"integer") .
" AND " .
1197 " " .
$ilDB->equals(
"type", $a_type,
"text",
true);
1199 $ilDB->manipulate($q);
1211 $q =
"DELETE FROM style_parameter WHERE " .
1212 " style_id = " .
$ilDB->quote($this->
getId(),
"integer") .
" AND " .
1213 " class = " .
$ilDB->quote($a_class,
"text") .
" AND " .
1214 " " .
$ilDB->equals(
"type", $a_type,
"text",
true);
1216 $ilDB->manipulate($q);
1220 public function delete():
bool 1228 $def_style = $this->
ilias->getSetting(
"default_content_style_id");
1229 if ($def_style == $this->
getId()) {
1230 $this->
ilias->deleteSetting(
"default_content_style_id");
1234 $fixed_style = $this->
ilias->getSetting(
"fixed_content_style_id");
1235 if ($fixed_style == $this->
getId()) {
1236 $this->
ilias->deleteSetting(
"fixed_content_style_id");
1240 $q =
"DELETE FROM style_parameter WHERE style_id = " .
1242 $ilDB->manipulate($q);
1246 if (is_file($css_file_name)) {
1247 unlink($css_file_name);
1252 "DELETE FROM sty_media_query WHERE " .
1253 " style_id = " .
$ilDB->quote($this->getId(),
"integer")
1260 $q =
"DELETE FROM style_data WHERE id = " .
1262 $ilDB->manipulate($q);
1277 $q =
"SELECT * FROM style_parameter WHERE style_id = " .
1278 $ilDB->quote($this->
getId(),
"integer") .
" ORDER BY tag, class, type, mq_id ";
1279 $style_set =
$ilDB->query($q);
1284 $this->style = array();
1288 $this->end_styles = array();
1290 while ($style_rec =
$ilDB->fetchAssoc($style_set)) {
1291 if ($style_rec[
"tag"] != $ctag || $style_rec[
"class"] != $cclass
1292 || $style_rec[
"type"] != $ctype || $style_rec[
"mq_id"] != $cmq_id) {
1294 if (is_array($tag)) {
1295 if (in_array($ctype, array(
"ha_iheada",
"va_iheada"))) {
1296 $this->end_styles[] = $tag;
1298 $this->style[] = $tag;
1303 $ctag = $style_rec[
"tag"];
1304 $cclass = $style_rec[
"class"];
1305 $ctype = $style_rec[
"type"];
1306 $cmq_id = $style_rec[
"mq_id"];
1307 $tag[] = $style_rec;
1309 $this->style_class[$ctype][$cclass][$cmq_id][$style_rec[
"parameter"]] = $style_rec[
"value"];
1311 if (is_array($tag)) {
1312 $this->style[] = $tag;
1314 foreach ($this->end_styles as $s) {
1315 $this->style[] = $s;
1318 $q =
"SELECT * FROM style_data WHERE id = " .
1323 $this->
setScope((
int) $sty[
"category"]);
1326 $this->chars = array();
1327 $this->chars_by_type = array();
1328 $q =
"SELECT * FROM style_char WHERE style_id = " .
1330 " ORDER BY type ASC, characteristic ASC";
1331 $par_set =
$ilDB->query($q);
1332 while ($par_rec =
$ilDB->fetchAssoc($par_set)) {
1333 $this->chars[] = array(
"type" => $par_rec[
"type"],
"class" => $par_rec[
"characteristic"],
"hide" => $par_rec[
"hide"]);
1334 $this->chars_by_type[$par_rec[
"type"]][] = $par_rec[
"characteristic"];
1335 if ($par_rec[
"hide"]) {
1336 $this->hidden_chars[$par_rec[
"type"] .
":" . $par_rec[
"characteristic"]] =
true;
1346 string $a_target_file =
"",
1347 string $a_image_dir =
"" 1355 if ($a_target_file ==
"") {
1358 $css_file_name = $a_target_file;
1360 $css_file = fopen($css_file_name,
'wb');
1362 $page_background =
"";
1364 $mqs = array(array(
"mquery" =>
"",
"id" => 0));
1370 foreach ($mqs as $mq) {
1371 if ($mq[
"id"] > 0) {
1372 fwrite($css_file,
"@media " . $mq[
"mquery"] .
" {\n");
1375 foreach ($style as $tag) {
1376 if ($tag[0][
"mq_id"] != $mq[
"id"]) {
1379 fwrite($css_file, $tag[0][
"tag"] .
".ilc_" . $tag[0][
"type"] .
"_" . $tag[0][
"class"] .
"\n");
1382 if ($tag[0][
"tag"] ==
"td") {
1383 fwrite($css_file,
",th" .
".ilc_" . $tag[0][
"type"] .
"_" . $tag[0][
"class"] .
"\n");
1385 if (in_array($tag[0][
"tag"], array(
"h1",
"h2",
"h3"))) {
1386 fwrite($css_file,
",div.ilc_text_block_" . $tag[0][
"class"] .
"\n");
1387 fwrite($css_file,
",html.il-no-tiny-bg body#tinymce.ilc_text_block_" . $tag[0][
"class"] .
"\n");
1389 if ($tag[0][
"type"] ==
"section") {
1390 fwrite($css_file,
",div a.ilc_" . $tag[0][
"type"] .
"_" . $tag[0][
"class"] .
"\n");
1392 if ($tag[0][
"type"] ==
"text_block") {
1393 fwrite($css_file,
",html.il-no-tiny-bg body#tinymce.ilc_text_block_" . $tag[0][
"class"] .
"\n");
1395 fwrite($css_file,
"{\n");
1398 $t_border = array();
1400 foreach ($tag as $par) {
1401 $cur_par = $par[
"parameter"];
1402 $cur_val = $par[
"value"];
1405 if (is_int(strpos($cur_par,
"color")) && substr(trim($cur_val), 0, 1) ==
"!") {
1409 if ($tag[0][
"type"] ==
"table" && is_int(strpos($par[
"parameter"],
"border"))) {
1410 $t_border[$cur_par] = $cur_val;
1413 if (in_array($cur_par, array(
"background-image",
"list-style-image"))) {
1414 if (is_int(strpos($cur_val,
"/"))) {
1415 $cur_val =
"url('" . $cur_val .
"')";
1417 if ($a_image_dir ==
"") {
1418 $cur_val =
"url('../sty/sty_" . $this->
getId() .
"/images/" . $cur_val .
"')";
1420 $cur_val =
"url('" . $a_image_dir .
"/" . $cur_val .
"')";
1425 if ($cur_par ==
"opacity") {
1426 $cur_val = ((
int) $cur_val) / 100;
1429 fwrite($css_file,
"\t" . $cur_par .
": " . $cur_val .
";\n");
1439 if ($cur_par ==
"opacity") {
1440 fwrite($css_file,
"\t" .
'-ms-filter:"progid:DXImageTransform.Microsoft.Alpha(Opacity=' . ($cur_val * 100) .
')"' .
";\n");
1441 fwrite($css_file,
"\t" .
'filter: alpha(opacity=' . ($cur_val * 100) .
')' .
";\n");
1442 fwrite($css_file,
"\t" .
'-moz-opacity: ' . $cur_val .
";\n");
1446 if ($cur_par ==
"transform") {
1447 fwrite($css_file,
"\t" .
'-webkit-transform: ' . $cur_val .
";\n");
1448 fwrite($css_file,
"\t" .
'-moz-transform: ' . $cur_val .
";\n");
1449 fwrite($css_file,
"\t" .
'-ms-transform: ' . $cur_val .
";\n");
1453 if ($cur_par ==
"transform-origin") {
1454 fwrite($css_file,
"\t" .
'-webkit-transform-origin: ' . $cur_val .
";\n");
1455 fwrite($css_file,
"\t" .
'-moz-transform-origin: ' . $cur_val .
";\n");
1456 fwrite($css_file,
"\t" .
'-ms-transform-origin: ' . $cur_val .
";\n");
1460 if ($tag[0][
"tag"] ==
"div" && $tag[0][
"class"] ==
"Page" 1461 && $cur_par ==
"background-color") {
1462 $page_background = $cur_val;
1465 fwrite($css_file,
"}\n");
1466 fwrite($css_file,
"\n");
1486 if ($page_background !=
"") {
1487 fwrite($css_file,
"td.ilc_Page\n");
1488 fwrite($css_file,
"{\n");
1489 fwrite($css_file,
"\t" .
"background-color: " . $page_background .
";\n");
1490 fwrite($css_file,
"}\n");
1492 if ($mq[
"id"] > 0) {
1493 fwrite($css_file,
"}\n");
1516 $fixed_style =
$ilSetting->get(
"fixed_content_style_id");
1517 if ($fixed_style > 0) {
1518 $a_style_id = (
int) $fixed_style;
1522 if ($a_style_id <= 0) {
1523 $a_style_id = (
int)
$ilSetting->get(
"default_content_style_id");
1538 if (is_array($this->style_class[$a_type][$a_class][$a_mq_id])) {
1539 return $this->style_class[$a_type][$a_class][$a_mq_id];
1550 bool $add_random =
true,
1551 bool $add_token =
true 1557 $random = new \ilRandom();
1558 $rand = $random->int(1, 999999);
1562 $fixed_style =
$ilSetting->get(
"fixed_content_style_id");
1563 if ($fixed_style > 0) {
1564 $a_style_id = (
int) $fixed_style;
1568 if ($a_style_id <= 0) {
1569 $a_style_id = (
int)
$ilSetting->get(
"default_content_style_id");
1576 $style->writeCSSFile();
1581 $path .=
"?dummy=$rand";
1589 return "./Services/COPage/css/content.css";
1595 return "./Services/COPage/css/print_content.css";
1600 return "./Services/COPage/css/syntaxhighlight.css";
1605 return "./Services/COPage/css/placeholder.css";
1616 $q =
"UPDATE style_data " .
1617 "SET category = " .
$ilDB->quote($this->
getScope(),
"integer") .
1618 " WHERE id = " .
$ilDB->quote($this->
getId(),
"integer");
1619 $ilDB->manipulate($q);
1633 $q =
"UPDATE style_parameter SET VALUE = " .
1634 $ilDB->quote($a_value,
"text") .
" WHERE id = " .
1635 $ilDB->quote($a_id,
"integer");
1636 $style_set =
$ilDB->manipulate($q);
1646 $this->style = $a_style;
1651 return str_replace(
"&",
"&", $a_str);
1660 $xml =
"<StyleSheet>\n";
1667 foreach ($this->chars as $char) {
1669 "\" Type=\"" . $char[
"type"] .
"\" Class=\"" . $char[
"class"] .
"\">\n";
1670 foreach ($this->style as $style) {
1671 if ($style[0][
"type"] == $char[
"type"] && $style[0][
"class"] == $char[
"class"]) {
1672 foreach ($style as $tag) {
1673 $xml .=
"<StyleParameter Name=\"" . $tag[
"parameter"] .
"\" Value=\"" . $tag[
"value"] .
"\" Custom=\"" . $tag[
"custom"] .
"\" />\n";
1677 $xml .=
"</Style>\n";
1681 foreach ($this->
getColors() as $color) {
1682 $xml .=
"<StyleColor Name=\"" . $color[
"name"] .
"\" Code=\"" . $color[
"code"] .
"\"/>\n";
1687 foreach ($tcts as $tct => $v) {
1690 foreach ($ts as $t) {
1691 $xml .=
"<StyleTemplate Type=\"" . $tct .
"\" Name=\"" . $t[
"name"] .
"\">\n";
1692 foreach ($t[
"classes"] as $ct =>
$c) {
1694 $xml .=
"<StyleTemplateClass ClassType=\"" . $ct .
"\" Class=\"" .
$c .
"\"/>\n";
1697 $xml .=
"</StyleTemplate>\n";
1702 $xml .=
"</StyleSheet>";
1711 if (!is_writable($sty_data_dir)) {
1712 $this->
ilias->raiseError(
"Style data directory (" . $sty_data_dir
1713 .
") not writeable.", $this->
ilias->error_obj->FATAL);
1716 $style_dir = $sty_data_dir .
"/sty_" . $this->
getId();
1718 if (!is_dir($style_dir)) {
1719 $this->
ilias->raiseError(
"Creation of style directory failed (" .
1720 $style_dir .
").", $this->
ilias->error_obj->FATAL);
1724 $ex_dir = $style_dir .
"/export";
1726 if (!is_dir($ex_dir)) {
1727 $this->
ilias->raiseError(
"Creation of Import Directory failed (" .
1728 $ex_dir .
").", $this->
ilias->error_obj->FATAL);
1737 $style_dir = $sty_data_dir .
"/sty_" . $this->
getId();
1739 $ex_dir = $style_dir .
"/export";
1741 if (is_dir($ex_dir)) {
1751 if (!is_writable($ex_sub_dir)) {
1752 $this->
ilias->raiseError(
"Style data directory (" . $ex_sub_dir
1753 .
") not writeable.", $this->
ilias->error_obj->FATAL);
1755 $ex_sub_images_dir = $ex_sub_dir .
"/images";
1757 if (!is_writable($ex_sub_images_dir)) {
1758 $this->
ilias->raiseError(
"Style data directory (" . $ex_sub_images_dir
1759 .
") not writeable.", $this->
ilias->error_obj->FATAL);
1768 $this->export_sub_dir = $a_dir;
1776 if ($this->export_sub_dir ==
"") {
1777 return "sty_" . $this->
getId();
1816 $file = $a_dir .
"/style.xml";
1819 if (!($fp = fopen($file,
'wb'))) {
1820 die(
"<b>Error</b>: Could not open \"" . $file .
"\" for writing" .
1821 " in <b>" . __FILE__ .
"</b> on line <b>" . __LINE__ .
"</b><br />");
1828 fwrite($fp, $this->
getXML());
1838 if (!is_writable($sty_data_dir)) {
1839 $this->
ilias->raiseError(
"Style data directory (" . $sty_data_dir
1840 .
") not writeable.", $this->
ilias->error_obj->FATAL);
1843 $style_dir = $sty_data_dir .
"/sty_" . $this->
getId();
1845 if (!is_dir($style_dir)) {
1846 $this->
ilias->raiseError(
"Creation of style directory failed (" .
1847 $style_dir .
").", $this->
ilias->error_obj->FATAL);
1851 $im_dir = $style_dir .
"/import";
1853 if (!is_dir($im_dir)) {
1854 $this->
ilias->raiseError(
"Creation of Import Directory failed (" .
1855 $im_dir .
").", $this->
ilias->error_obj->FATAL);
1868 public function import($a_file):
void 1876 if (is_array($a_file)) {
1878 $a_file[
"tmp_name"],
1880 $im_dir .
"/" . $a_file[
"name"]
1882 $file_name = $a_file[
"name"];
1884 $pi = pathinfo($a_file);
1885 $file_name = $pi[
"basename"];
1886 copy($a_file, $im_dir .
"/" . $file_name);
1888 $file = pathinfo($file_name);
1891 if (strtolower($file[
"extension"]) ==
"zip") {
1893 $subdir = basename($file[
"basename"],
"." . $file[
"extension"]);
1894 if (!is_dir($im_dir .
"/" . $subdir)) {
1897 $xml_file = $im_dir .
"/" . $subdir .
"/style.xml";
1899 $xml_file = $im_dir .
"/" . $file_name;
1908 if (is_dir($im_dir .
"/" . $subdir .
"/images")) {
1910 $im_dir .
"/" . $subdir .
"/images",
1926 bool $a_skip_parent_create =
false 1930 $this->is_3_10_skin =
false;
1932 if (!$a_skip_parent_create) {
1936 $importParser->startParsing();
1939 foreach ($this->style as $style) {
1940 foreach ($style as $tag) {
1941 $id =
$ilDB->nextId(
"style_parameter");
1944 if (in_array($tag[
"class"], array(
"PageFrame",
"PageContainer")) &&
1945 $tag[
"tag"] ==
"table") {
1946 $tag[
"tag"] =
"div";
1947 if ($tag[
"parameter"] ==
"width" && $tag[
"value"] ==
"100%") {
1952 $q =
"INSERT INTO style_parameter (id,style_id, tag, class, parameter, type, value, custom) VALUES " .
1954 $ilDB->quote(
$id,
"integer") .
"," .
1955 $ilDB->quote($this->
getId(),
"integer") .
"," .
1956 $ilDB->quote($tag[
"tag"],
"text") .
"," .
1957 $ilDB->quote($tag[
"class"],
"text") .
"," .
1958 $ilDB->quote($tag[
"parameter"],
"text") .
"," .
1959 $ilDB->quote($tag[
"type"],
"text") .
"," .
1960 $ilDB->quote($tag[
"value"],
"text") .
"," .
1961 $ilDB->quote((
bool) $tag[
"custom"],
"integer") .
1963 $ilDB->manipulate($q);
1968 $this->is_3_10_skin =
true;
1969 foreach ($this->chars as $char) {
1970 if ($char[
"type"] !=
"") {
1971 $s = substr($char[
"class"], strlen($char[
"class"]) - 6);
1972 if ($s !=
":hover") {
1976 "style_id" => array(
"integer", $this->
getId()),
1977 "type" => array(
"text", $char[
"type"]),
1978 "characteristic" => array(
"text",
ilStr::subStr($char[
"class"], 0, 30))),
1979 array(
"hide" => array(
"integer", 0))
1981 $this->is_3_10_skin =
false;
1987 $q =
"INSERT INTO style_data (id, uptodate) VALUES " .
1988 "(" .
$ilDB->quote($this->
getId(),
"integer") .
", 0)";
1989 $ilDB->manipulate($q);
1994 if ($this->is_3_10_skin) {
2007 foreach (self::$parameter as $parameter => $props) {
2015 $input = self::$parameter[$par][
"input"];
2021 $subpar = self::$parameter[$par][
"subpar"];
2029 return self::$parameter;
2032 foreach (self::$parameter as $k => $v) {
2033 if (isset(self::$filtered_groups[$v[
"group"]]) &&
2034 !in_array($a_tag, self::$filtered_groups[$v[
"group"]])) {
2044 return self::$filtered_groups;
2048 bool $a_no_percentage =
false 2050 if ($a_no_percentage) {
2051 return self::$num_unit_no_perc;
2053 return self::$num_unit;
2059 return self::$parameter[$par][
"values"];
2064 return self::$style_super_types;
2069 return in_array($a_type, self::$expandable_types);
2074 return in_array($a_type, self::$hideable_types);
2080 foreach (self::$style_super_types as $s => $t) {
2081 if (in_array($a_type, $t)) {
2084 if ($a_type == $s) {
2093 $c_styles = array();
2094 foreach (self::$core_styles as $cstyle) {
2096 = array(
"type" => $cstyle[
"type"],
2098 "class" => $cstyle[
"class"]);
2107 foreach (self::$core_styles as $s) {
2108 if ($s[
"type"] == $a_type && $s[
"class"] == $a_class) {
2119 string $a_template_type =
"" 2121 if ($a_template_type ==
"") {
2122 return self::$templates;
2125 return self::$templates[$a_template_type];
2130 return self::$pseudo_classes[$tag] ?? [];
2138 return self::$templates[$t][$k];
2143 return self::$assigned_tags[$a_type];
2149 foreach (self::$parameter as $p => $v) {
2150 $pars[$p] = $v[
"values"];
2162 $styles = array(array(
"id" => $a_id));
2171 ?array $a_styles = null
2175 $ilDB = $DIC->database();
2177 if (is_null($a_styles)) {
2180 $styles = $a_styles;
2186 $core_images = array();
2187 $core_dir = self::$basic_style_image_dir;
2188 if (is_dir($core_dir)) {
2189 $dir = opendir($core_dir);
2190 while ($file = readdir($dir)) {
2191 if (substr($file, 0, 1) !=
"." && is_file($core_dir .
"/" . $file)) {
2192 $core_images[] = $file;
2197 foreach ($styles as $style) {
2200 foreach ($core_styles as $cs) {
2202 $set =
$ilDB->queryF(
2203 "SELECT * FROM style_char WHERE style_id = %s " .
2204 "AND type = %s AND characteristic = %s",
2205 array(
"integer",
"text",
"text"),
2206 array(
$id, $cs[
"type"], $cs[
"class"])
2210 if (!($rec =
$ilDB->fetchAssoc($set))) {
2212 "INSERT INTO style_char (style_id, type, characteristic) " .
2213 " VALUES (%s,%s,%s) ",
2214 array(
"integer",
"text",
"text"),
2215 array(
$id, $cs[
"type"], $cs[
"class"])
2219 $par_nodes = $xpath->query(
"/StyleSheet/Style[@Tag = '" . $cs[
"tag"] .
"' and @Type='" .
2220 $cs[
"type"] .
"' and @Class='" . $cs[
"class"] .
"']/StyleParameter");
2221 foreach ($par_nodes as $par_node) {
2223 $set =
$ilDB->queryF(
2224 "SELECT * FROM style_parameter WHERE style_id = %s " .
2225 "AND type = %s AND class = %s AND tag = %s AND parameter = %s",
2226 array(
"integer",
"text",
"text",
"text",
"text"),
2227 array(
$id, $cs[
"type"], $cs[
"class"],
2228 $cs[
"tag"], $par_node->getAttribute(
"Name"))
2232 if (!(
$ilDB->fetchAssoc($set))) {
2233 $spid =
$ilDB->nextId(
"style_parameter");
2234 $st =
$ilDB->manipulateF(
2235 "INSERT INTO style_parameter (id, style_id, type, class, tag, parameter, value) " .
2236 " VALUES (%s,%s,%s,%s,%s,%s,%s)",
2237 array(
"integer",
"integer",
"text",
"text",
"text",
"text",
"text"),
2238 array($spid,
$id, $cs[
"type"], $cs[
"class"], $cs[
"tag"],
2239 $par_node->getAttribute(
"Name"), $par_node->getAttribute(
"Value"))
2249 foreach ($core_images as $cim) {
2250 if (!is_file($imdir .
"/" . $cim)) {
2251 copy($core_dir .
"/" . $cim, $imdir .
"/" . $cim);
2273 $st =
$ilDB->prepareManip(
"UPDATE style_char SET type = ? WHERE characteristic = ?" .
2274 " AND style_id = ? ", array(
"text",
"text",
"integer"));
2275 $ilDB->execute($st, array(
"media_cont",
"Media", $this->
getId()));
2276 $ilDB->execute($st, array(
"media_caption",
"MediaCaption", $this->
getId()));
2277 $ilDB->execute($st, array(
"page_fn",
"Footnote", $this->
getId()));
2278 $ilDB->execute($st, array(
"page_nav",
"LMNavigation", $this->
getId()));
2279 $ilDB->execute($st, array(
"page_title",
"PageTitle", $this->
getId()));
2280 $ilDB->execute($st, array(
"page_cont",
"Page", $this->
getId()));
2283 $st =
$ilDB->prepareManip(
"UPDATE style_parameter SET type = ? WHERE class = ?" .
2284 " AND style_id = ? ", array(
"text",
"text",
"integer"));
2285 $ilDB->execute($st, array(
"media_cont",
"Media", $this->
getId()));
2286 $ilDB->execute($st, array(
"media_caption",
"MediaCaption", $this->
getId()));
2287 $ilDB->execute($st, array(
"page_fn",
"Footnote", $this->
getId()));
2288 $ilDB->execute($st, array(
"page_nav",
"LMNavigation", $this->
getId()));
2289 $ilDB->execute($st, array(
"page_title",
"PageTitle", $this->
getId()));
2290 $ilDB->execute($st, array(
"table",
"Page", $this->
getId()));
2292 $st =
$ilDB->prepareManip(
"UPDATE style_parameter SET tag = ? WHERE class = ?" .
2293 " AND style_id = ? ", array(
"text",
"text",
"integer"));
2294 $ilDB->execute($st, array(
"div",
"MediaCaption", $this->
getId()));
2297 $st =
$ilDB->prepareManip(
"UPDATE style_char SET characteristic = ? WHERE characteristic = ?" .
2298 " AND style_id = ? ", array(
"text",
"text",
"integer"));
2299 $ilDB->execute($st, array(
"MediaContainer",
"Media", $this->
getId()));
2300 $ilDB->execute($st, array(
"PageContainer",
"Page", $this->
getId()));
2303 $st =
$ilDB->prepareManip(
"UPDATE style_parameter SET class = ? WHERE class = ?" .
2304 " AND style_id = ? ", array(
"text",
"text",
"integer"));
2305 $ilDB->execute($st, array(
"MediaContainer",
"Media", $this->
getId()));
2306 $ilDB->execute($st, array(
"PageContainer",
"Page", $this->
getId()));
2309 $st =
$ilDB->prepareManip(
"DELETE FROM style_char WHERE type = ?" .
2310 " AND style_id = ? ", array(
"text",
"integer"));
2311 $ilDB->execute($st, array(
"page_cont", $this->
getId()));
2312 $st =
$ilDB->prepareManip(
"DELETE FROM style_parameter WHERE type = ?" .
2313 " AND style_id = ? ", array(
"text",
"integer"));
2314 $ilDB->execute($st, array(
"page_cont", $this->
getId()));
2328 $add_str =
" AND style_id = " .
$ilDB->quote($a_id,
"integer");
2331 $set =
$ilDB->query($q =
"SELECT DISTINCT style_id, tag, class FROM style_parameter WHERE " .
2332 $ilDB->equals(
"type",
"",
"text",
true) .
" " . $add_str);
2334 while ($rec =
$ilDB->fetchAssoc($set)) {
2337 switch ($rec[
"tag"]) {
2340 if (in_array($rec[
"class"], array(
"Headline3",
"Headline1",
2341 "Headline2",
"TableContent",
"List",
"Standard",
"Remark",
2342 "Additional",
"Mnemonic",
"Citation",
"Example"))) {
2343 $types[] =
"text_block";
2345 if (in_array($rec[
"class"], array(
"Block",
"Remark",
2346 "Additional",
"Mnemonic",
"Example",
"Excursus",
"Special"))) {
2347 $types[] =
"section";
2349 if (in_array($rec[
"class"], array(
"Page",
"Footnote",
"PageTitle",
"LMNavigation"))) {
2355 $types[] =
"table_cell";
2359 if (in_array($rec[
"class"], array(
"ExtLink",
"IntLink",
"FootnoteLink"))) {
2365 $types[] =
"text_inline";
2374 foreach ($types as $t) {
2376 $set4 =
$ilDB->queryF(
2377 "SELECT * FROM style_char " .
2378 " WHERE style_id = %s AND type = %s AND characteristic = %s",
2379 array(
"integer",
"text",
"text"),
2380 array($rec[
"style_id"], $t, $rec[
"class"])
2382 if ($rec4 =
$ilDB->fetchAssoc($set4)) {
2387 "INSERT INTO style_char " .
2388 " (style_id, type, characteristic) VALUES " .
2390 array(
"integer",
"text",
"text"),
2391 array($rec[
"style_id"], $t, $rec[
"class"])
2397 if ($rec[
"type"] ==
"") {
2398 if (count($types) > 0) {
2400 "UPDATE style_parameter SET type = %s " .
2401 " WHERE style_id = %s AND class = %s AND " .
$ilDB->equals(
"type",
"",
"text",
true),
2402 array(
"text",
"integer",
"text"),
2403 array($types[0], $rec[
"style_id"], $rec[
"class"])
2408 if ($types[0] ==
"link") {
2410 "UPDATE style_parameter SET type = %s " .
2411 " WHERE style_id = %s AND (class = %s OR class = %s) AND " .
$ilDB->equals(
"type",
"",
"text",
true),
2412 array(
"text",
"integer",
"text",
"text"),
2413 array($types[0], $rec[
"style_id"], $rec[
"class"] .
":visited",
2414 $rec[
"class"] .
":hover")
2419 if (count($types) == 2) {
2422 $set2 =
$ilDB->queryF(
2423 "SELECT * FROM style_parameter " .
2424 " WHERE style_id = %s AND class = %s AND type = %s",
2425 array(
"integer",
"text",
"text"),
2426 array($rec[
"style_id"], $rec[
"class"], $types[0])
2428 while ($rec2 =
$ilDB->fetchAssoc($set2)) {
2430 $set3 =
$ilDB->queryF(
2431 "SELECT * FROM style_parameter " .
2432 " WHERE style_id = %s AND tag = %s AND class = %s AND type = %s AND parameter = %s",
2433 array(
"integer",
"text",
"text",
"text",
"text"),
2434 array($rec[
"style_id"], $rec[
"tag"], $rec[
"class"], $types[1], $rec[
"parameter"])
2436 if ($rec3 =
$ilDB->fetchAssoc($set3)) {
2439 $nid =
$ilDB->nextId(
"style_parameter");
2441 "INSERT INTO style_parameter " .
2442 " (id, style_id, tag, class, parameter, value, type) VALUES " .
2443 " (%s, %s,%s,%s,%s,%s,%s) ",
2444 array(
"integer",
"integer",
"text",
"text",
"text",
"text",
"text"),
2445 array($nid, $rec2[
"style_id"], $rec2[
"tag"], $rec2[
"class"],
2446 $rec2[
"parameter"], $rec2[
"value"], $types[1])
2462 $classes = array(
"Example",
"Additional",
"Citation",
"Mnemonic",
"Remark");
2463 $pars = array(
"margin-top",
"margin-bottom");
2465 foreach ($classes as $curr_class) {
2466 foreach ($pars as $curr_par) {
2467 $res2 =
$ilDB->queryF(
2468 "SELECT id FROM style_parameter WHERE style_id = %s" .
2469 " AND tag = %s AND class= %s AND parameter = %s",
2470 array(
"integer",
"text",
"text",
"text"),
2471 array($a_id,
"p", $curr_class, $curr_par)
2473 if ($row2 =
$ilDB->fetchAssoc($res2)) {
2475 "UPDATE style_parameter SET value= %s WHERE id = %s",
2476 array(
"text",
"integer"),
2477 array(
"10px", $row2[
"id"])
2480 $nid =
$ilDB->nextId(
"style_parameter");
2482 "INSERT INTO style_parameter " .
2483 "(id, style_id, tag, class, parameter,value) VALUES (%s,%s,%s,%s,%s,%s)",
2484 array(
"integer",
"integer",
"text",
"text",
"text",
"text"),
2485 array($nid, $a_id,
"div", $curr_class, $curr_par,
"10px")
2492 "UPDATE style_parameter SET tag = %s WHERE tag = %s and style_id = %s",
2493 array(
"text",
"text",
"integer"),
2494 array(
"div",
"p", $a_id)
2509 $set =
$ilDB->query(
"SELECT * FROM style_color WHERE " .
2510 "style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" " .
2511 "ORDER BY color_name");
2514 while ($rec =
$ilDB->fetchAssoc($set)) {
2516 "name" => $rec[
"color_name"],
2517 "code" => $rec[
"color_code"]
2531 $ilDB->manipulate(
"DELETE FROM style_color WHERE " .
2532 " style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" AND " .
2533 " color_name = " .
$ilDB->quote($a_name,
"text"));
2540 $pos = strpos($a_name,
"(");
2542 $a_i = substr($a_name, $pos + 1);
2543 $a_i = str_replace(
")",
"", $a_i);
2544 $a_name = substr($a_name, 0, $pos);
2547 $set =
$ilDB->query(
"SELECT color_code FROM style_color WHERE " .
2548 " style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" AND " .
2549 " color_name = " .
$ilDB->quote($a_name,
"text"));
2550 if ($rec =
$ilDB->fetchAssoc($set)) {
2552 return "#" . $rec[
"color_code"];
2574 $hls[
"l"] = $hls[
"l"] + ((255 - $hls[
"l"]) * ($a_i / 100));
2577 $hls[
"l"] = $hls[
"l"] - (($hls[
"l"]) * (-$a_i / 100));
2582 foreach ($rgb as $k => $v) {
2583 $rgb[$k] = str_pad(dechex((
int) $v), 2,
"0", STR_PAD_LEFT);
2586 return $rgb[
"r"] . $rgb[
"g"] . $rgb[
"b"];
2594 bool $as_dec =
false 2596 $r[
"r"] = (string) substr($a_rgb, 0, 2);
2597 $r[
"g"] = (string) substr($a_rgb, 2, 2);
2598 $r[
"b"] = (string) substr($a_rgb, 4, 2);
2600 $r[
"r"] = self::hexdec($r[
"r"]);
2601 $r[
"g"] = self::hexdec($r[
"g"]);
2602 $r[
"b"] = self::hexdec($r[
"b"]);
2610 $hex = preg_replace(
"/[^a-fA-F0-9]+/",
"", $hex);
2614 return (
int)
hexdec($hex);
2622 $r = $a_rgb[
"r"] / 255;
2623 $g = $a_rgb[
"g"] / 255;
2624 $b = $a_rgb[
"b"] / 255;
2628 $max = max($r, $g,
$b);
2629 $min = min($r, $g,
$b);
2632 $l = ($max + $min) / 2;
2638 $s = ($max - $min) / ($max + $min);
2640 $s = ($max - $min) / (2.0 - $max - $min);
2644 $h = ($g -
$b) / ($max - $min);
2645 } elseif ($g == $max) {
2646 $h = 2.0 + (
$b - $r) / ($max - $min);
2647 } elseif (
$b == $max) {
2648 $h = 4.0 + ($r - $g) / ($max - $min);
2652 $hls[
"h"] = round(($h / 6) * 255);
2653 $hls[
"l"] = round($l * 255);
2654 $hls[
"s"] = round($s * 255);
2664 $h = $a_hls[
"h"] / 255;
2665 $l = $a_hls[
"l"] / 255;
2666 $s = $a_hls[
"s"] / 255;
2669 $rgb[
"r"] = $rgb[
"g"] = $rgb[
"b"] = 0;
2673 $rgb[
"r"] = $rgb[
"g"] = $rgb[
"b"] = $l;
2676 $temp2 = $l * (1.0 + $s);
2678 $temp2 = $l + $s - $l * $s;
2681 $temp1 = 2.0 * $l - $temp2;
2684 # For each of R, G, B, compute another temporary value, temp3, as follows: 2685 foreach ($rgb as $k => $v) {
2688 $temp3 = $h + 1.0 / 3.0;
2696 $temp3 = $h - 1.0 / 3.0;
2700 $temp3 = $temp3 + 1.0;
2703 $temp3 = $temp3 - 1.0;
2706 if (6.0 * $temp3 < 1) {
2707 $rgb[$k] = $temp1 + ($temp2 - $temp1) * 6.0 * $temp3;
2708 } elseif (2.0 * $temp3 < 1) {
2710 } elseif (3.0 * $temp3 < 2) {
2711 $rgb[$k] = $temp1 + ($temp2 - $temp1) * ((2.0 / 3.0) - $temp3) * 6.0;
2718 $rgb[
"r"] = round($rgb[
"r"] * 255);
2719 $rgb[
"g"] = round($rgb[
"g"] * 255);
2720 $rgb[
"b"] = round($rgb[
"b"] * 255);
2737 $set =
$ilDB->query(
"SELECT * FROM sty_media_query WHERE " .
2738 "style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" " .
2739 "ORDER BY order_nr");
2742 while ($rec =
$ilDB->fetchAssoc($set)) {
2755 $id =
$ilDB->nextId(
"sty_media_query");
2756 if ($order_nr == 0) {
2760 $ilDB->manipulate(
"INSERT INTO sty_media_query (id, style_id, mquery, order_nr)" .
2762 $ilDB->quote(
$id,
"integer") .
"," .
2763 $ilDB->quote($this->
getId(),
"integer") .
"," .
2764 $ilDB->quote($a_mquery,
"text") .
"," .
2765 $ilDB->quote($order_nr,
"integer") .
2778 $set =
$ilDB->query(
2779 "SELECT max(order_nr) mnr FROM sty_media_query " .
2780 " WHERE style_id = " .
$ilDB->quote($this->getId(),
"integer")
2782 $rec =
$ilDB->fetchAssoc($set);
2784 return (
int) $rec[
"mnr"];
2794 "UPDATE sty_media_query SET " .
2795 " mquery = " .
$ilDB->quote($a_mquery,
"text") .
2796 " WHERE id = " .
$ilDB->quote($a_id,
"integer")
2811 $set =
$ilDB->query(
2812 "SELECT * FROM sty_media_query " .
2813 " WHERE id = " .
$ilDB->quote($a_id,
"integer")
2815 return $ilDB->fetchAssoc($set);
2829 "DELETE FROM sty_media_query WHERE " .
2830 " style_id = " .
$ilDB->quote($this->getId(),
"integer") .
2831 " AND id = " .
$ilDB->quote($a_id,
"integer")
2840 array $a_order_nr = null
2845 if (is_array($a_order_nr)) {
2846 foreach ($mqueries as $k => $mq) {
2847 $mqueries[$k][
"order_nr"] = $a_order_nr[$mq[
"id"]];
2852 foreach ($mqueries as $mq) {
2854 "UPDATE sty_media_query SET " .
2855 " order_nr = " .
$ilDB->quote($cnt,
"integer") .
2856 " WHERE id = " .
$ilDB->quote($mq[
"id"],
"integer")
2875 $set =
$ilDB->query(
"SELECT * FROM style_template WHERE " .
2876 "style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" AND " .
2877 "temp_type = " .
$ilDB->quote($a_type,
"text") .
" " .
2880 $templates = array();
2881 while ($rec =
$ilDB->fetchAssoc($set)) {
2883 $templates[] = $rec;
2896 $set =
$ilDB->query(
"SELECT * FROM style_template_class WHERE " .
2897 "template_id = " .
$ilDB->quote($a_tid,
"integer"));
2900 while ($rec =
$ilDB->fetchAssoc($set)) {
2901 $key = $rec[
"class_type"];
2902 $class[
$key] = $rec[
"class"];
2919 $tid =
$ilDB->nextId(
"style_template");
2920 $ilDB->manipulate(
"INSERT INTO style_template " .
2921 "(id, style_id, name, temp_type)" .
2923 $ilDB->quote($tid,
"integer") .
"," .
2924 $ilDB->quote($this->
getId(),
"integer") .
"," .
2925 $ilDB->quote($a_name,
"text") .
"," .
2926 $ilDB->quote($a_type,
"text") .
2929 foreach ($a_classes as $t =>
$c) {
2930 $ilDB->manipulate(
"INSERT INTO style_template_class " .
2931 "(template_id, class_type, class)" .
2933 $ilDB->quote($tid,
"integer") .
"," .
2934 $ilDB->quote($t,
"text") .
"," .
2957 $ilDB->manipulate(
"UPDATE style_template SET " .
2958 "name = " .
$ilDB->quote($a_name,
"text") .
2959 " WHERE id = " .
$ilDB->quote($a_t_id,
"integer"));
2962 "DELETE FROM style_template_class WHERE " .
2963 "template_id = " .
$ilDB->quote($a_t_id,
"integer")
2965 foreach ($a_classes as $t =>
$c) {
2966 $ilDB->manipulate(
"INSERT INTO style_template_class " .
2967 "(template_id, class_type, class)" .
2969 $ilDB->quote($a_t_id,
"integer") .
"," .
2970 $ilDB->quote($t,
"text") .
"," .
2983 $ilDB->manipulate(
"INSERT INTO style_template_class " .
2984 "(template_id, class_type, class)" .
2986 $ilDB->quote($a_t_id,
"integer") .
"," .
2987 $ilDB->quote($a_type,
"text") .
"," .
2988 $ilDB->quote($a_class,
"text") .
2996 string $a_template_name
3000 $set =
$ilDB->query(
"SELECT * FROM style_template WHERE " .
3001 "style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" AND " .
3002 "name = " .
$ilDB->quote($a_template_name,
"text"));
3003 if (
$ilDB->fetchAssoc($set)) {
3016 $set =
$ilDB->query(
"SELECT * FROM style_template WHERE " .
3017 "style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" " .
3018 " AND id = " .
$ilDB->quote($a_t_id,
"integer"));
3020 if ($rec =
$ilDB->fetchAssoc($set)) {
3034 return self::_lookupTemplateName($a_t_id);
3044 $ilDB = $DIC->database();
3046 $set =
$ilDB->query(
"SELECT name FROM style_template WHERE " .
3047 " id = " .
$ilDB->quote($a_t_id,
"integer"));
3049 if ($rec =
$ilDB->fetchAssoc($set)) {
3050 return $rec[
"name"];
3063 $tag =
"<StyleTemplates>";
3065 $ttypes = array(
"table",
"vaccordion",
"haccordion",
"carousel");
3067 foreach ($ttypes as $ttype) {
3070 foreach ($ts as $t) {
3084 $tag .=
'<StyleTemplate Name="' . $t[
"name"] .
'">';
3086 foreach ($atts as
$type => $t2) {
3087 if ((
$c[
$type] ??
"") !=
"") {
3088 $tag .=
'<StyleClass Type="' . $type .
'" Value="' .
$c[
$type] .
'" />';
3092 $tag .=
"</StyleTemplate>";
3096 $tag .=
"</StyleTemplates>";
3107 string $a_preview_html
3110 $a_preview_html = str_replace(
' width=""',
"", $a_preview_html);
3111 $a_preview_html = str_replace(
' valign="top"',
"", $a_preview_html);
3112 $a_preview_html = str_replace(
'<div class="ilc_text_block_TableContent">',
"<div>", $a_preview_html);
3115 if (strlen($a_preview_html) > 4000) {
3117 $a_preview_html =
"";
3119 $ilDB->manipulate(
"UPDATE style_template SET " .
3120 "preview = " .
$ilDB->quote($a_preview_html,
"text") .
3121 " WHERE id = " .
$ilDB->quote($a_t_id,
"integer"));
3131 $set =
$ilDB->query(
"SELECT preview FROM style_template " .
3132 " WHERE id = " .
$ilDB->quote($a_t_id,
"integer"));
3133 if ($rec =
$ilDB->fetchAssoc($set)) {
3134 return $rec[
"preview"] ??
"";
3149 $ilDB = $DIC->database();
3151 $set =
$ilDB->query(
"SELECT id FROM style_template " .
3152 " WHERE style_id = " .
$ilDB->quote($a_style_id,
"integer") .
3153 " AND name = " .
$ilDB->quote($a_name,
"text"));
3154 if ($rec =
$ilDB->fetchAssoc($set)) {
3155 return (
int) $rec[
"id"];
3168 $ilDB->manipulate(
"DELETE FROM style_template WHERE " .
3169 " style_id = " .
$ilDB->quote($this->getId(),
"integer") .
" AND " .
3170 " id = " .
$ilDB->quote($a_t_id,
"integer"));
3173 "DELETE FROM style_template_class WHERE " .
3174 "template_id = " .
$ilDB->quote($a_t_id,
"integer")
3185 "DELETE FROM style_setting WHERE " .
3186 " style_id = " .
$ilDB->quote($this->getId(),
"integer") .
3187 " AND name = " .
$ilDB->quote($a_name,
"text")
3190 $ilDB->manipulate(
"INSERT INTO style_setting " .
3191 "(style_id, name, value) VALUES (" .
3192 $ilDB->quote($this->getId(),
"integer") .
"," .
3193 $ilDB->quote($a_name,
"text") .
"," .
3194 $ilDB->quote($a_value,
"text") .
3205 $set =
$ilDB->query(
3206 "SELECT value FROM style_setting " .
3207 " WHERE style_id = " .
$ilDB->quote($this->getId(),
"integer") .
3208 " AND name = " .
$ilDB->quote($a_name,
"text")
3210 $rec =
$ilDB->fetchAssoc($set);
3212 return $rec[
"value"] ??
'';
3224 $ilDB = $DIC->database();
3229 "obj_id" => array(
"integer", $a_obj_id)),
3231 "style_id" => array(
"integer", $a_style_id))
3243 $ilDB = $DIC->database();
3245 $set =
$ilDB->query(
3246 "SELECT style_id FROM style_usage " .
3247 " WHERE obj_id = " .
$ilDB->quote($a_obj_id,
"integer")
3249 $rec =
$ilDB->fetchAssoc($set);
3250 if (!is_array($rec)) {
3255 return (
int) $rec[
"style_id"];
3270 $ilDB = $DIC->database();
3274 $set =
$ilDB->query(
3275 "SELECT DISTINCT obj_id FROM style_usage " .
3276 " WHERE style_id = " .
$ilDB->quote($a_style_id,
"integer")
3279 while ($rec =
$ilDB->fetchAssoc($set)) {
3280 $obj_ids[] = (
int) $rec[
"obj_id"];
static getWebspaceDir(string $mode="filesystem")
get webspace directory
templateExists(string $a_template_name)
Check whether template exists.
getXML()
get xml representation of style object todo: add mq_id
static getContentPrintStyle()
static getEffectiveContentStyleId(int $a_style_id)
Get effective Style Id.
static _writeActive(int $a_id, bool $a_active)
static getPlaceHolderStylePath()
updateMediaQuery(int $a_id, string $a_mquery)
static string $basic_style_image_dir
static _explodeRGB(string $a_rgb, bool $as_dec=false)
Explode an RGB string into an array.
static _isExpandable(string $a_type)
do_3_10_Migration()
Migrates 3.10 style to 3.11 style.
static _lookupTemplateIdByName(int $a_style_id, string $a_name)
Lookup table template preview.
txt(string $a_topic, string $a_default_lang_fallback_mod="")
gets the text for a given topic if the topic is not in the list, the topic itself with "-" will be re...
static _getStandardStyles(bool $a_exclude_default_style=false, bool $a_include_deactivated=false, int $a_scope=0)
Get standard styles.
ILIAS Style Content InternalRepoService $repo
static _addMissingStyleClassesToAllStyles(?array $a_styles=null)
Add missing style classes to all styles todo: add mq_id and custom handling.
characteristicExists(string $a_char, string $a_style_type)
Check whether characteristic exists.
getColors()
Get colors of style.
read()
read style properties
static _getImagesDirectory(int $a_style_id)
static _writeScope(int $a_id, int $a_scope)
static _getStyleParameterNumericUnits(bool $a_no_percentage=false)
getMediaQueryForId(int $a_id)
Get media query for id.
exportXML(string $a_dir)
export style xml file to directory
addParameter(string $a_tag, string $a_par, string $a_type, int $a_mq_id=0, bool $a_custom=false)
write style parameter to db
static _getAllReferences(int $id)
get all reference ids for object ID
writeStyleSetting(string $a_name, string $a_value)
static array $pseudo_classes
getTemplateClasses(int $a_tid)
Get template classes.
isInTree(?int $a_node_id)
get all information of a node.
static _lookupContObjIdByStyleId(int $a_style_id)
handleXmlString(string $a_str)
static rCopy(string $a_sdir, string $a_tdir, bool $preserveTimeAttributes=false)
Copies content of a directory $a_sdir recursively to a directory $a_tdir.
setCharacteristics(array $a_chars)
static array $expandable_types
lookupTemplateName(int $a_t_id)
Lookup table template name for template ID.
static _getStyleParameterSubPar(string $par)
static _getObjectsDataForType(string $type, bool $omit_trash=false)
get all objects of a certain type
static _getStyleParameters(string $a_tag="")
loadLanguageModule(string $a_module)
Load language module.
static subStr(string $a_str, int $a_start, ?int $a_length=null)
static _getClonableContentStyles()
Get all clonable styles (active standard styles and individual learning module styles with write perm...
static array $style_super_types
static _getTemplatePreview(ilObjStyleSheet $a_style, string $a_type, int $a_t_id, bool $a_small_mode=false)
Get table template preview.
static _RGBToHLS(array $a_rgb)
RGB to HLS (both arrays, 0..255)
static _getPseudoClasses(string $tag)
static _writeStandard(int $a_id, bool $a_std)
Write standard flag.
static makeDirParents(string $a_dir)
Create a new directory and all parent directories.
static DOMDocument $basic_style_dom
addTemplateClass(int $a_t_id, string $a_type, string $a_class)
addTemplate(string $a_type, string $a_name, array $a_classes)
Add table template.
static _getStyleSuperTypes()
createExportSubDirectory()
removeColor(string $a_name)
Remove a color.
static getBasicImageDir()
setExportSubDir(string $a_dir)
Set local directory, that will be included within the zip file.
static unzip(string $path_to_zip_file, bool $overwrite_existing=false, bool $unpack_flat=false)
static isCoreStyle(string $a_type, string $a_class)
static _getStyleSuperTypeForType(string $a_type)
static writeOwner($obj_id, $style_id)
lookupStyleSetting(string $a_name)
Lookup style setting.
deleteStyleParOfChar(string $a_type, string $a_class)
Delete style parameters of characteristic.
static _exists(int $id, bool $reference=false, ?string $type=null)
checks if an object exists in object_data
static _getBasicStyleDom()
updateTemplate(int $a_t_id, string $a_name, array $a_classes)
Update table template.
static _lookupTitle(int $obj_id)
static _lookupUpToDate(int $a_id)
static _getFilteredGroups()
getHideStatus(string $a_type, string $a_char)
Get characteristic hidden status.
getTemplateXML()
Get table template xml.
static _writeUpToDate(int $a_id, bool $a_up_to_date)
static delDir(string $a_dir, bool $a_clean_only=false)
removes a dir and all its content (subdirs and files) recursively
static _createImagesDirectory(int $a_style_id)
Create images directory <data_dir>/sty/sty_<id>/images.
getTemplates(string $a_type)
Get table templates of style.
static array $core_styles
static _lookupStandard(int $a_id)
Lookup standard flag.
header include for all ilias files.
do_3_9_Migration(int $a_id)
Migrate old 3.9 styles.
deleteParameter(int $a_id)
delete style parameter
static string $basic_style_file
saveHideStatus(string $a_type, string $a_char, bool $a_hide)
Save characteristic hidden status.
writeTemplatePreview(int $a_t_id, string $a_preview_html)
Write table template preview.
static moveUploadedFile(string $a_file, string $a_name, string $a_target, bool $a_raise_errors=true, string $a_mode="move_uploaded")
move uploaded file
static _lookupActive(int $a_id)
Lookup active flag.
static getSyntaxStylePath()
static getDataDir()
get data directory (outside webspace)
static _deleteStyleAssignments(int $a_style_id)
delete all style references to style
copyImagesToDir(string $a_target)
Copy images to directory.
static getContentStylePath(int $a_style_id, bool $add_random=true, bool $add_token=true)
get content style path static (to avoid full reading)
getStyleParameterGroups()
Get grouped parameter.
static _getColorFlavor(string $a_rgb, int $a_i)
Get color flavor.
static array $hideable_types
getColorCodeForName(string $a_name)
writeCSSFile(string $a_target_file="", string $a_image_dir="")
write css file to webspace directory
static _lookupTemplateName(int $a_t_id)
Lookup table template name for template ID.
getMaxMQueryOrderNr()
Get maximum media query order nr.
static array $assigned_tags
getCharacteristics(string $a_type="", bool $a_no_hidden=false, bool $a_include_core=true)
Get characteristics.
getPathId(int $a_endnode_id, int $a_startnode_id=0)
get path from a given startnode to a given endnode if startnode is not given the rootnode is startnod...
static array $num_unit_no_perc
static writeStyleUsage(int $a_obj_id, int $a_style_id)
Write style usage.
static _addMissingStyleClassesToStyle(int $a_id)
Add missing style classes to all styles.
__construct(int $a_id=0, bool $a_call_by_reference=false)
getExportSubDir()
The local directory, that will be included within the zip file.
__construct(Container $dic, ilPlugin $plugin)
static _getStyleParameterValues(string $par)
static lookupObjectStyle(int $a_obj_id)
Lookup object style.
determineTemplateStyleClassType(string $t, string $k)
static zip(string $a_dir, string $a_file, bool $compress_content=false)
zips given directory/file into given zip.file
static signFile(string $path_to_file)
static lookupObjectForStyle(int $a_style_id)
Lookup objects for style.
lookupTemplatePreview(int $a_t_id)
Lookup table template preview.
create(int $a_from_style=0, bool $a_import_mode=false)
Create a new style.
static string $basic_style_zip
static _HLSToRGB(array $a_hls)
HLS to RGB (both arrays, 0..255)
setUpToDate(bool $a_up_to_date=true)
Set style up to date (false + update will trigger css generation next time)
addCharacteristic(string $a_type, string $a_char, bool $a_hidden=false, int $order_nr=0, bool $outdated=false)
static array $filtered_groups
static _isHideable(string $a_type)
saveMediaQueryOrder(array $a_order_nr=null)
Save media query order.
static _determineTag(string $a_type)
static _lookupType(int $id, bool $reference=false)
static _getTemplateClassTypes(string $a_template_type="")
Get template class types.
deleteMediaQuery(int $a_id)
Delete media query.
deleteCustomStylePars(string $a_tag, string $a_class, string $a_type, int $a_mq_id=0)
Delete style parameter by tag/class/parameter.
removeTemplate(int $a_t_id)
Remove table template.
static hexdec(string $hex)
do_3_10_CharMigration(int $a_id=0)
This is more or less a copy of Services/Migration/DBUpdate_1385/classes ilStyleMigration->addMissingS...
createImagesDirectory()
Create images directory <data_dir>/sty/sty_<id>/images.
getParametersOfClass(string $a_type, string $a_class, int $a_mq_id=0)
static makeDir(string $a_dir)
creates a new directory and inherits all filesystem permissions of the parent directory You may pass ...
createFromXMLFile(string $a_file, bool $a_skip_parent_create=false)
create style from xml file todo: add mq_id and custom
ilClone()
clone style sheet (note: styles have no ref ids and return an object id)
static getAvailableParameters()
updateStyleParameter(int $a_id, string $a_value)
update style parameter per id
static _getStyleParameterInputType(string $par)
addMediaQuery(string $a_mquery, int $order_nr=0)
static sortArray(array $array, string $a_array_sortby_key, string $a_array_sortorder="asc", bool $a_numeric=false, bool $a_keep_keys=false)