ILIAS  release_5-3 Revision v5.3.23-19-g915713cf615
ilObjCategory Class Reference

Class ilObjCategory. More...

+ Inheritance diagram for ilObjCategory:
+ Collaboration diagram for ilObjCategory:

Public Member Functions

 __construct ($a_id=0, $a_call_by_reference=true)
 Constructor @access public. More...
 
 delete ()
 delete category and all related data More...
 
 getTranslations ()
 get all translations from this category More...
 
 removeTranslations ()
 
 deleteTranslation ($a_lang)
 
 addTranslation ($a_title, $a_desc, $a_lang, $a_lang_default)
 
 updateTranslation ($a_title, $a_desc, $a_lang, $a_lang_default)
 
 cloneObject ($a_target_id, $a_copy_id=0, $a_omit_tree=false)
 Clone course (no member data) More...
 
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies (container sorting) More...
 
 addAdditionalSubItemInformation (&$a_item_data)
 Add additional information to sub item, e.g. More...
 
- Public Member Functions inherited from ilContainer
 __construct ($a_id=0, $a_reference=true)
 Constructor @access public. More...
 
 createContainerDirectory ()
 Create directory for the container. More...
 
 getContainerDirectory ()
 Get the container directory. More...
 
 getBigIconPath ()
 Get path for big icon. More...
 
 getSmallIconPath ()
 Get path for small icon. More...
 
 getTinyIconPath ()
 Get path for tiny icon. More...
 
 getCustomIconPath ()
 Get path for custom icon. More...
 
 setHiddenFilesFound ($a_hiddenfilesfound)
 Set Found hidden files (set by getSubItems). More...
 
 getHiddenFilesFound ()
 Get Found hidden files (set by getSubItems). More...
 
 getStyleSheetId ()
 get ID of assigned style sheet object More...
 
 setStyleSheetId ($a_style_id)
 set ID of assigned style sheet object More...
 
 setNewsTimeline ($a_val)
 Set news timeline. More...
 
 getNewsTimeline ()
 Get news timeline. More...
 
 setNewsTimelineAutoEntries ($a_val)
 Set news timeline auto entries. More...
 
 getNewsTimelineAutoEntries ()
 Get news timeline auto entries. More...
 
 setNewsTimelineLandingPage ($a_val)
 Set news timline is landing page. More...
 
 getNewsTimelineLandingPage ()
 Get news timline is landing page. More...
 
 isNewsTimelineEffective ()
 Is news timeline effective? More...
 
 isNewsTimelineLandingPageEffective ()
 Is news timeline landing page effective? More...
 
 setNewsBlockActivated ($a_val)
 Set news block activated. More...
 
 getNewsBlockActivated ()
 Get news block activated. More...
 
 setUseNews ($a_val)
 Set use news. More...
 
 getUseNews ()
 Get use news. More...
 
 saveIcons ($a_custom_icon)
 save container icons More...
 
 removeCustomIcon ()
 remove small icon More...
 
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies (container sorting) More...
 
 cloneAllObject ($session_id, $client_id, $new_type, $ref_id, $clone_source, $options, $soap_call=false, $a_submode=1)
 clone all objects according to this container More...
 
 getViewMode ()
 Get container view mode. More...
 
 getOrderType ()
 Get order type default implementation. More...
 
 setOrderType ($a_value)
 
 getSubItems ($a_admin_panel_enabled=false, $a_include_side_block=false, $a_get_single=0)
 Get subitems of container. More...
 
 gotItems ()
 Check whether we got any items. More...
 
 addAdditionalSubItemInformation (&$object)
 Add additional information to sub item, e.g. More...
 
 getGroupedObjTypes ()
 Get grouped repository object types. More...
 
 enablePageEditing ()
 Check whether page editing is allowed for container. More...
 
 create ()
 Create. More...
 
 update ()
 Update. More...
 
 read ()
 read More...
 
 readContainerSettings ()
 Read container settings. More...
 
- Public Member Functions inherited from ilObject
 __construct ($a_id=0, $a_reference=true)
 Constructor @access public. More...
 
 withReferences ()
 determines wehter objects are referenced or not (got ref ids or not) More...
 
 read ()
 read object data from db into object More...
 
 getId ()
 get object id @access public More...
 
 setId ($a_id)
 set object id @access public More...
 
 setRefId ($a_id)
 set reference id @access public More...
 
 getRefId ()
 get reference id @access public More...
 
 getType ()
 get object type @access public More...
 
 setType ($a_type)
 set object type @access public More...
 
 getPresentationTitle ()
 get presentation title Normally same as title Overwritten for sessions More...
 
 getTitle ()
 get object title @access public More...
 
 getUntranslatedTitle ()
 get untranslated object title @access public More...
 
 setTitle ($a_title)
 set object title More...
 
 getDescription ()
 get object description More...
 
 setDescription ($a_desc)
 set object description More...
 
 getLongDescription ()
 get object long description (stored in object_description) More...
 
 getImportId ()
 get import id More...
 
 setImportId ($a_import_id)
 set import id More...
 
 getOwner ()
 get object owner More...
 
 getOwnerName ()
 
 setOwner ($a_owner)
 set object owner More...
 
 getCreateDate ()
 get create date @access public More...
 
 getLastUpdateDate ()
 get last update date @access public More...
 
 getDiskUsage ()
 Gets the disk usage of the object in bytes. More...
 
 create ()
 create More...
 
 update ()
 update object in db More...
 
 MDUpdateListener ($a_element)
 Meta data update listener. More...
 
 createMetaData ()
 create meta data entry More...
 
 updateMetaData ()
 update meta data entry More...
 
 deleteMetaData ()
 delete meta data entry More...
 
 updateOwner ()
 update owner of object in db More...
 
 putInTree ($a_parent_ref)
 maybe this method should be in tree object!? More...
 
 setPermissions ($a_parent_ref)
 set permissions of object More...
 
 setParentRolePermissions ($a_parent_ref)
 Initialize the permissions of parent roles (local roles of categories, global roles...) This method is overwritten in e.g courses, groups for building permission intersections with non_member templates. More...
 
 createReference ()
 creates reference for object More...
 
 countReferences ()
 count references of object More...
 
 initDefaultRoles ()
 init default roles settings Purpose of this function is to create a local role folder and local roles, that are needed depending on the object type If you want to setup default local roles you MUST overwrite this method in derived object classes (see ilObjForum for an example) @access public More...
 
 applyDidacticTemplate ($a_tpl_id)
 Apply template. More...
 
 setRegisterMode ($a_bool)
 
 isUserRegistered ($a_user_id=0)
 
 requireRegistration ()
 
 getXMLZip ()
 
 getHTMLDirectory ()
 
 appendCopyInfo ($a_target_id, $a_copy_id)
 Prepend Copy info if object with same name exists in that container. More...
 
 cloneDependencies ($a_target_id, $a_copy_id)
 Clone object dependencies. More...
 
 cloneMetaData ($target_obj)
 Copy meta data. More...
 
 getPossibleSubObjects ($a_filter=true)
 get all possible subobjects of this type the object can decide which types of subobjects are possible jut in time overwrite if the decision distinguish from standard model More...
 

Additional Inherited Members

- Static Public Member Functions inherited from ilContainer
static _getContainerDirectory ($a_id)
 Get the container directory. More...
 
static _lookupContainerSetting ($a_id, $a_keyword, $a_default_value=null)
 Lookup a container setting. More...
 
static _writeContainerSetting ($a_id, $a_keyword, $a_value)
 
static _getContainerSettings ($a_id)
 
static _deleteContainerSettings ($a_id, $a_keyword=null, $a_keyword_like=false)
 
static _exportContainerSettings (ilXmlWriter $a_xml, $a_obj_id)
 
static _lookupIconPath ($a_id, $a_size="big")
 lookup icon path More...
 
static getCompleteDescriptions (array $objects)
 overwrites description fields to long or short description in an assoc array keys needed (obj_id and description) More...
 
- Static Public Member Functions inherited from ilObject
static _lookupObjIdByImportId ($a_import_id)
 
static _lookupImportId ($a_obj_id)
 
static _lookupOwnerName ($a_owner_id)
 lookup owner name for owner id More...
 
static _getIdForImportId ($a_import_id)
 get current object id for import id (static) More...
 
static _getAllReferences ($a_id)
 get all reference ids of object More...
 
static _lookupTitle ($a_id)
 lookup object title More...
 
static _lookupOwner ($a_id)
 lookup object owner More...
 
static _getIdsForTitle ($title, $type='', $partialmatch=false)
 
static _lookupDescription ($a_id)
 lookup object description More...
 
static _lookupLastUpdate ($a_id, $a_as_string=false)
 lookup last update More...
 
static _getLastUpdateOfObjects ($a_objs)
 Get last update for a set of media objects. More...
 
static _lookupObjId ($a_id)
 
static _setDeletedDate ($a_ref_id)
 only called in ilTree::saveSubTree More...
 
static setDeletedDates ($a_ref_ids)
 Set deleted date @global type $ilDB. More...
 
static _resetDeletedDate ($a_ref_id)
 only called in ilObjectGUI::insertSavedNodes More...
 
static _lookupDeletedDate ($a_ref_id)
 only called in ilObjectGUI::insertSavedNodes More...
 
static _writeTitle ($a_obj_id, $a_title)
 write title to db (static) More...
 
static _writeDescription ($a_obj_id, $a_desc)
 write description to db (static) More...
 
static _writeImportId ($a_obj_id, $a_import_id)
 write import id to db (static) More...
 
static _lookupType ($a_id, $a_reference=false)
 lookup object type More...
 
static _isInTrash ($a_ref_id)
 checks wether object is in trash More...
 
static _hasUntrashedReference ($a_obj_id)
 checks wether an object has at least one reference that is not in trash More...
 
static _lookupObjectId ($a_ref_id)
 lookup object id More...
 
static _getObjectsDataForType ($a_type, $a_omit_trash=false)
 get all objects of a certain type More...
 
static _exists ($a_id, $a_reference=false, $a_type=null)
 checks if an object exists in object_data@access public More...
 
static _getObjectsByType ($a_obj_type="", $a_owner="")
 Get objects by type. More...
 
static _prepareCloneSelection ($a_ref_ids, $new_type, $show_path=true)
 Prepare copy wizard object selection. More...
 
static _getIcon ( $a_obj_id="", $a_size="big", $a_type="", $a_offline=false)
 Get icon for repository item. More...
 
static collectDeletionDependencies (&$deps, $a_ref_id, $a_obj_id, $a_type, $a_depth=0)
 Collect deletion dependencies. More...
 
static getDeletionDependencies ($a_obj_id)
 Get deletion dependencies. More...
 
static getLongDescriptions (array $a_obj_ids)
 Get long description data. More...
 
static getAllOwnedRepositoryObjects ($a_user_id)
 Get all ids of objects user owns. More...
 
static fixMissingTitles ($a_type, array &$a_obj_title_map)
 Try to fix missing object titles. More...
 
static _lookupCreationDate ($a_id)
 Lookup creation date. More...
 
static hasAutoRating ($a_type, $a_ref_id)
 Check if auto rating is active for parent group/course. More...
 
- Data Fields inherited from ilContainer
const VIEW_SESSIONS = 0
 
const VIEW_OBJECTIVE = 1
 
const VIEW_TIMING = 2
 
const VIEW_ARCHIVE = 3
 
const VIEW_SIMPLE = 4
 
const VIEW_BY_TYPE = 5
 
const VIEW_INHERIT = 6
 
const VIEW_DEFAULT = self::VIEW_BY_TYPE
 
const SORT_TITLE = 0
 
const SORT_MANUAL = 1
 
const SORT_ACTIVATION = 2
 
const SORT_INHERIT = 3
 
const SORT_CREATION = 4
 
const SORT_DIRECTION_ASC = 0
 
const SORT_DIRECTION_DESC = 1
 
const SORT_NEW_ITEMS_POSITION_TOP = 0
 
const SORT_NEW_ITEMS_POSITION_BOTTOM = 1
 
const SORT_NEW_ITEMS_ORDER_TITLE = 0
 
const SORT_NEW_ITEMS_ORDER_CREATION = 1
 
const SORT_NEW_ITEMS_ORDER_ACTIVATION = 2
 
- Data Fields inherited from ilObject
const TITLE_LENGTH = 255
 max length of object title More...
 
const DESC_LENGTH = 128
 
 $lng
 
 $id
 
 $ref_id
 
 $type
 
 $title
 
 $untranslatedTitle
 
 $desc
 
 $long_desc
 
 $owner
 
 $create_date
 
 $last_update
 
 $import_id
 
 $register = false
 
 $referenced
 
 $objectList
 
 $max_title
 
 $max_desc
 
 $add_dots
 
- Static Public Attributes inherited from ilContainer
static $data_preloaded = false
 
- Protected Attributes inherited from ilContainer
 $db
 
 $log
 
 $access
 
 $error
 
 $rbacsystem
 
 $tree
 
 $user
 
 $obj_definition
 
 $order_type = 0
 
 $hiddenfilesfound = false
 
 $news_timeline = false
 
 $news_timeline_auto_entries = false
 
 $setting
 
- Protected Attributes inherited from ilObject
 $objDefinition
 
 $db
 
 $log
 
 $error
 
 $tree
 
 $app_event_handler
 
 $rbacadmin
 
 $rbacreview
 

Detailed Description

Class ilObjCategory.

Author
Stefan Meyer meyer.nosp@m.@lei.nosp@m.fos.c.nosp@m.om
Version
$Id$

Definition at line 19 of file class.ilObjCategory.php.

Constructor & Destructor Documentation

◆ __construct()

ilObjCategory::__construct (   $a_id = 0,
  $a_call_by_reference = true 
)

Constructor @access public.

Parameters
integerreference_id or object_id
booleantreat the id as reference_id (true) or object_id (false)

Reimplemented from ilContainer.

Definition at line 27 of file class.ilObjCategory.php.

28 {
29 global $DIC;
30
31 $this->db = $DIC->database();
32 $this->app_event_handler = $DIC["ilAppEventHandler"];
33 $this->log = $DIC["ilLog"];
34 $this->user = $DIC->user();
35 $this->type = "cat";
36 parent::__construct($a_id, $a_call_by_reference);
37 }
user()
Definition: user.php:4
global $DIC
Definition: saml.php:7

References $DIC, and user().

+ Here is the call graph for this function:

Member Function Documentation

◆ addAdditionalSubItemInformation()

ilObjCategory::addAdditionalSubItemInformation ( $a_item_data)

Add additional information to sub item, e.g.

used in courses for timings information etc.

Reimplemented from ilContainer.

Definition at line 246 of file class.ilObjCategory.php.

247 {
248 include_once './Services/Object/classes/class.ilObjectActivation.php';
250 }
static addAdditionalSubItemInformation(array &$a_item)
Parse item data for list entries.

References ilObjectActivation\addAdditionalSubItemInformation().

+ Here is the call graph for this function:

◆ addTranslation()

ilObjCategory::addTranslation (   $a_title,
  $a_desc,
  $a_lang,
  $a_lang_default 
)

Definition at line 133 of file class.ilObjCategory.php.

134 {
136
137 if (empty($a_title)) {
138 $a_title = "NO TITLE";
139 }
140
141 $query = "INSERT INTO object_translation " .
142 "(obj_id,title,description,lang_code,lang_default) " .
143 "VALUES " .
144 "(" . $ilDB->quote($this->getId(), 'integer') . "," .
145 $ilDB->quote($a_title, 'text') . "," . $ilDB->quote($a_desc, 'text') . "," .
146 $ilDB->quote($a_lang, 'text') . "," . $ilDB->quote($a_lang_default, 'integer') . ")";
147 $res = $ilDB->manipulate($query);
148
149 return true;
150 }
getId()
get object id @access public
$query
foreach($_POST as $key=> $value) $res
global $ilDB

References ilContainer\$db, $ilDB, $query, $res, and ilObject\getId().

+ Here is the call graph for this function:

◆ cloneDependencies()

ilObjCategory::cloneDependencies (   $a_target_id,
  $a_copy_id 
)

Clone object dependencies (container sorting)

@access public

Parameters
inttarget ref id of new course
intcopy id return bool

Reimplemented from ilContainer.

Definition at line 193 of file class.ilObjCategory.php.

194 {
195 parent::cloneDependencies($a_target_id, $a_copy_id);
196
197
198 // clone taxonomies
199
200 include_once("./Services/Taxonomy/classes/class.ilObjTaxonomy.php");
201 $all_tax = ilObjTaxonomy::getUsageOfObject($this->getId());
202 if (sizeof($all_tax)) {
203 include_once("./Services/Taxonomy/classes/class.ilTaxNodeAssignment.php");
204
205 $cwo = ilCopyWizardOptions::_getInstance($a_copy_id);
206 $mappings = $cwo->getMappings();
207
208 foreach ($all_tax as $old_tax_id) {
209 if ($old_tax_id) {
210 // clone it
211 $old_tax = new ilObjTaxonomy($old_tax_id);
212 $new_tax = $old_tax->cloneObject(0, 0, true);
213 $tax_map = $old_tax->getNodeMapping();
214
215 // assign new taxonomy to new category
216 ilObjTaxonomy::saveUsage($new_tax->getId(), ilObject::_lookupObjId($a_target_id));
217
218 // clone assignments (for all sub-items)
219 foreach ($mappings as $old_ref_id => $new_ref_id) {
220 if ($old_ref_id != $new_ref_id) {
221 $old_obj_id = ilObject::_lookupObjId($old_ref_id);
222 $new_obj_id = ilObject::_lookupObjId($new_ref_id);
223 $obj_type = ilObject::_lookupType($old_obj_id);
224
225 $tax_ass = new ilTaxNodeAssignment($obj_type, $old_obj_id, "obj", $old_tax_id);
226 $assignmts = $tax_ass->getAssignmentsOfItem($old_obj_id);
227 if (sizeof($assignmts)) {
228 $new_tax_ass = new ilTaxNodeAssignment($obj_type, $new_obj_id, "obj", $new_tax->getId());
229 foreach ($assignmts as $a) {
230 if ($tax_map[$a["node_id"]]) {
231 $new_tax_ass->addAssignment($tax_map[$a["node_id"]], $new_obj_id);
232 }
233 }
234 }
235 }
236 }
237 }
238 }
239 }
240 }
static _getInstance($a_copy_id)
Get instance of copy wizard options.
static getUsageOfObject($a_obj_id, $a_include_titles=false)
Get usage of object.
static saveUsage($a_tax_id, $a_obj_id)
Save Usage.
static _lookupObjId($a_id)
static _lookupType($a_id, $a_reference=false)
lookup object type
Taxonomy node <-> item assignment.

References ilCopyWizardOptions\_getInstance(), ilObject\_lookupObjId(), ilObject\_lookupType(), ilObject\getId(), ilObjTaxonomy\getUsageOfObject(), and ilObjTaxonomy\saveUsage().

+ Here is the call graph for this function:

◆ cloneObject()

ilObjCategory::cloneObject (   $a_target_id,
  $a_copy_id = 0,
  $a_omit_tree = false 
)

Clone course (no member data)

@access public

Parameters
inttarget ref_id
intcopy id

Definition at line 182 of file class.ilObjCategory.php.

183 {
184 $new_obj = parent::cloneObject($a_target_id, $a_copy_id, $a_omit_tree);
185
186 include_once("./Services/Object/classes/class.ilObjectTranslation.php");
188 $ot->copy($new_obj->getId());
189
190 return $new_obj;
191 }
static getInstance($a_obj_id)
Get instance.

References ilObject\getId(), and ilObjectTranslation\getInstance().

+ Here is the call graph for this function:

◆ delete()

ilObjCategory::delete ( )

delete category and all related data

@access public

Returns
boolean true if all object data were removed; false if only a references were removed

Definition at line 45 of file class.ilObjCategory.php.

46 {
48 $ilAppEventHandler = $this->app_event_handler;
49
50 // always call parent delete function first!!
51 if (!parent::delete()) {
52 return false;
53 }
54
55 // put here category specific stuff
56 include_once('./Services/User/classes/class.ilObjUserFolder.php');
58
59 $query = "DELETE FROM object_translation WHERE obj_id = " . $ilDB->quote($this->getId(), 'integer');
60 $res = $ilDB->manipulate($query);
61
62 // taxonomies
63 include_once "Services/Taxonomy/classes/class.ilObjTaxonomy.php";
64 foreach (ilObjTaxonomy::getUsageOfObject($this->getId()) as $tax_id) {
65 if ($tax_id) {
66 $tax = new ilObjTaxonomy($tax_id);
67 $tax->delete();
68 }
69 }
70
71 $ilAppEventHandler->raise(
72 'Modules/Category',
73 'delete',
74 array('object' => $this,
75 'obj_id' => $this->getId())
76 );
77
78 return true;
79 }
const USER_FOLDER_ID
Class ilObjUserFolder.
static _updateUserFolderAssignment($a_old_id, $a_new_id)
Update user folder assignment Typically called after deleting a category with local user accounts.

References ilObject\$app_event_handler, ilContainer\$db, $ilDB, $query, $res, ilObjUserFolder\_updateUserFolderAssignment(), ilObject\getId(), ilObjTaxonomy\getUsageOfObject(), and USER_FOLDER_ID.

+ Here is the call graph for this function:

◆ deleteTranslation()

ilObjCategory::deleteTranslation (   $a_lang)

Definition at line 122 of file class.ilObjCategory.php.

123 {
125
126 $query = "DELETE FROM object_translation WHERE obj_id= " .
127 $ilDB->quote($this->getId(), 'integer') . " AND lang_code = " .
128 $ilDB->quote($a_lang, 'text');
129 $res = $ilDB->manipulate($query);
130 }

References ilContainer\$db, $ilDB, $query, $res, and ilObject\getId().

+ Here is the call graph for this function:

◆ getTranslations()

ilObjCategory::getTranslations ( )

get all translations from this category

@access public

Returns
array

Definition at line 87 of file class.ilObjCategory.php.

88 {
90
91 $q = "SELECT * FROM object_translation WHERE obj_id = " .
92 $ilDB->quote($this->getId(), 'integer') . " ORDER BY lang_default DESC";
93 $r = $ilDB->query($q);
94
95 $num = 0;
96
97 while ($row = $r->fetchRow(ilDBConstants::FETCHMODE_OBJECT)) {
98 $data["Fobject"][$num]= array("title" => $row->title,
99 "desc" => $row->description,
100 "lang" => $row->lang_code
101 );
102 $num++;
103 }
104
105 // first entry is always the default language
106 $data["default_language"] = 0;
107
108 return $data ? $data : array();
109 }
$r
Definition: example_031.php:79

References $data, ilContainer\$db, $ilDB, $r, $row, ilDBConstants\FETCHMODE_OBJECT, and ilObject\getId().

+ Here is the call graph for this function:

◆ removeTranslations()

ilObjCategory::removeTranslations ( )

Definition at line 112 of file class.ilObjCategory.php.

113 {
115
116 $query = "DELETE FROM object_translation WHERE obj_id= " .
117 $ilDB->quote($this->getId(), 'integer');
118 $res = $ilDB->manipulate($query);
119 }

References ilContainer\$db, $ilDB, $query, $res, and ilObject\getId().

+ Here is the call graph for this function:

◆ updateTranslation()

ilObjCategory::updateTranslation (   $a_title,
  $a_desc,
  $a_lang,
  $a_lang_default 
)

Definition at line 153 of file class.ilObjCategory.php.

154 {
157
158 if (empty($a_title)) {
159 $a_title = "NO TITLE";
160 }
161
162 $query = "UPDATE object_translation " .
163 "SET title = " . $ilDB->quote($a_title, 'text') . "," .
164 "description = " . $ilDB->quote($a_desc, 'text') . "," .
165 "lang_code = " . $ilDB->quote($a_lang, 'text') . "," .
166 "lang_default = " . $ilDB->quote($a_lang_default, 'integer') . " " .
167 "WHERE " .
168 " obj_id = " . $ilDB->quote($this->getId(), 'integer');
169 $res = $ilDB->manipulate($query);
170
171 return true;
172 }

References ilContainer\$db, $ilDB, $ilLog, ilContainer\$log, $query, $res, and ilObject\getId().

+ Here is the call graph for this function:

The documentation for this class was generated from the following file: