ILIAS  release_6 Revision v6.24-5-g0c8bfefb3b8
ilDclFieldFactory Class Reference

Class ilDclFieldFactory This Class handles the creation of all field-classes. More...

+ Collaboration diagram for ilDclFieldFactory:

Static Public Member Functions

static getRecordFieldInstance (ilDclBaseFieldModel $field, ilDclBaseRecordModel $record)
 Creates a RecordField instance and loads the field and record representation. More...
 
static getFieldClass ($datatype, $class_pattern)
 Concatenates Classname from datatype and pattern. More...
 
static getFieldClassFile ($datatype, $class_pattern)
 Get Filename from datatype and pattern. More...
 
static getFieldRepresentationInstance (ilDclBaseFieldModel $field)
 Returns FieldRepresentation from BaseFieldModel. More...
 
static getRecordRepresentationInstance (ilDclBaseRecordFieldModel $record_field)
 Get RecordRepresentation from RecordFieldModel. More...
 
static getFieldModelInstance ($field_id, $datatype=null)
 Get FieldModel from field-id and datatype. More...
 
static getFieldModelInstanceByClass (ilDclBaseFieldModel $field, $field_id=null)
 Gets the correct instance of a fieldModel class Checks if a field is a plugin a replaces the fieldModel with the necessary class. More...
 
static getFieldTypeByInstance (ilDclBaseFieldModel $field)
 
static getClassByInstance (ilDclBaseFieldModel $field, $class_pattern)
 
static getClassPathByInstance (ilDclBaseFieldModel $field, $class_pattern)
 
static parseDatatypeTitle ($title)
 Parse string to FieldClass format Replaces _ with camelcase-notation. More...
 
static getRecordModelInstance ($record_id)
 Creates a RecordModel instance. More...
 
static getPluginNameFromFieldModel (ilDclBaseFieldModel $object)
 Get plugin-name from FieldModel. More...
 

Static Public Attributes

static $field_base_path_patter = "./Modules/DataCollection/classes/Fields/%s/"
 
static $default_prefix = "ilDcl"
 
static $record_field_class_patter = "%sRecordFieldModel"
 
static $field_class_patter = "%sFieldModel"
 
static $record_class_patter = "%sRecordModel"
 
static $record_representation_class_pattern = "%sRecordRepresentation"
 
static $field_representation_class_pattern = "%sFieldRepresentation"
 

Static Protected Attributes

static $record_field_cache = array()
 
static $field_class_cache = array()
 
static $field_representation_cache = array()
 
static $record_representation_cache = array()
 
static $field_model_cache = array()
 
static $field_type_cache = array()
 
static $class_path_cache = array()
 

Detailed Description

Class ilDclFieldFactory This Class handles the creation of all field-classes.

Author
Michael Herren mh@st.nosp@m.uder.nosp@m.-raim.nosp@m.ann..nosp@m.ch
Version
1.0.0

Definition at line 10 of file class.ilDclFieldFactory.php.

Member Function Documentation

◆ getClassByInstance()

static ilDclFieldFactory::getClassByInstance ( ilDclBaseFieldModel  $field,
  $class_pattern 
)
static
Parameters
ilDclBaseFieldModel$field
$class_pattern
Returns
string

Definition at line 332 of file class.ilDclFieldFactory.php.

333 {
334 $fieldtype = self::getFieldTypeByInstance($field);
335
336 return self::getFieldClass($fieldtype, $class_pattern);
337 }
static getFieldClass($datatype, $class_pattern)
Concatenates Classname from datatype and pattern.
static getFieldTypeByInstance(ilDclBaseFieldModel $field)

References getFieldClass(), and getFieldTypeByInstance().

Referenced by getFieldModelInstanceByClass(), getFieldRepresentationInstance(), getRecordFieldInstance(), and getRecordRepresentationInstance().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getClassPathByInstance()

static ilDclFieldFactory::getClassPathByInstance ( ilDclBaseFieldModel  $field,
  $class_pattern 
)
static
Parameters
ilDclBaseFieldModel$field
$class_pattern
Returns
string
Exceptions
ilDclException

Definition at line 353 of file class.ilDclFieldFactory.php.

354 {
355 $datatype = $field->getDatatype();
356
357 if ($field->getId() != null && !empty(self::$class_path_cache[$field->getId()][$class_pattern])) {
358 return self::$class_path_cache[$field->getId()][$class_pattern];
359 }
360
361 if ($datatype->getId() == ilDclDatatype::INPUTFORMAT_PLUGIN) {
363 $plugin_data
365 if ($plugin_data == null) {
366 throw new ilDclException(
367 "Something went wrong by initializing the FieldHook-Plugin '"
368 . $field->getProperty(ilDclBaseFieldModel::PROP_PLUGIN_HOOK_NAME) . "' on Component '"
369 . ilDclFieldTypePlugin::COMPONENT_NAME . "' with slot '" . ilDclFieldTypePlugin::SLOT_ID . "' on field: "
370 . $field->getTitle()
371 );
372 }
373
374 $class_path = $plugin_data->getDirectory() . "/classes/";
375 } else {
376 $class_path = sprintf(self::$field_base_path_patter, ucfirst(self::parseDatatypeTitle($datatype->getTitle())));
377 }
378 } else {
379 $class_path = sprintf(self::$field_base_path_patter, ucfirst(self::parseDatatypeTitle($datatype->getTitle())));
380 }
381
382 $return = $class_path . self::getFieldClassFile(self::getFieldTypeByInstance($field), $class_pattern);
383
384 if ($field->getId() != null) {
385 self::$class_path_cache[$field->getId()][$class_pattern] = $return;
386 }
387
388 return $return;
389 }
const IL_COMP_MODULE
hasProperty($key)
Checks if a certain property for a field is set.
getProperty($key)
Returns a certain property of a field.
Class ilDclException.
static getFieldClassFile($datatype, $class_pattern)
Get Filename from datatype and pattern.
static getPluginObject(string $a_ctype, string $a_cname, string $a_slot_id, string $a_pname)

References ilDclFieldTypePlugin\COMPONENT_NAME, ilDclBaseFieldModel\getDatatype(), getFieldClassFile(), ilDclBaseFieldModel\getId(), ilPlugin\getPluginObject(), ilDclBaseFieldModel\getProperty(), ilDclBaseFieldModel\getTitle(), ilDclBaseFieldModel\hasProperty(), IL_COMP_MODULE, ilDclDatatype\INPUTFORMAT_PLUGIN, ilDclBaseFieldModel\PROP_PLUGIN_HOOK_NAME, and ilDclFieldTypePlugin\SLOT_ID.

Referenced by getFieldModelInstanceByClass(), getFieldRepresentationInstance(), getRecordFieldInstance(), and getRecordRepresentationInstance().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getFieldClass()

static ilDclFieldFactory::getFieldClass (   $datatype,
  $class_pattern 
)
static

Concatenates Classname from datatype and pattern.

Parameters
$datatype
$class_pattern
Returns
string

Definition at line 96 of file class.ilDclFieldFactory.php.

97 {
98 if (!empty(self::$field_class_cache[$datatype . $class_pattern])) {
99 return self::$field_class_cache[$datatype . $class_pattern];
100 }
101
102 $fieldtype = $datatype;
103
104 $class = sprintf($class_pattern, $fieldtype);
105 self::$field_class_cache[$datatype . $class_pattern] = $class;
106
107 return $class;
108 }

Referenced by getClassByInstance(), getFieldClassFile(), getFieldModelInstanceByClass(), and getRecordRepresentationInstance().

+ Here is the caller graph for this function:

◆ getFieldClassFile()

static ilDclFieldFactory::getFieldClassFile (   $datatype,
  $class_pattern 
)
static

Get Filename from datatype and pattern.

Parameters
$datatype
$class_pattern
Returns
string

Definition at line 119 of file class.ilDclFieldFactory.php.

120 {
121 return "class." . self::getFieldClass($datatype, $class_pattern) . ".php";
122 }

References getFieldClass().

Referenced by getClassPathByInstance().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getFieldModelInstance()

static ilDclFieldFactory::getFieldModelInstance (   $field_id,
  $datatype = null 
)
static

Get FieldModel from field-id and datatype.

Parameters
$field_id
null$datatype
Returns
mixed
Exceptions
ilDclException

Definition at line 221 of file class.ilDclFieldFactory.php.

222 {
223 $base = new ilDclBaseFieldModel($field_id);
224 if ($datatype != null) {
225 $base->setDatatypeId($datatype);
226 }
227
228 $ilDclBaseFieldModel = self::getFieldModelInstanceByClass($base, $field_id);
229
230 return $ilDclBaseFieldModel;
231 }
Class ilDclBaseFieldModel.
static getFieldModelInstanceByClass(ilDclBaseFieldModel $field, $field_id=null)
Gets the correct instance of a fieldModel class Checks if a field is a plugin a replaces the fieldMod...
$base
Definition: index.php:4

References $base, and getFieldModelInstanceByClass().

Referenced by ilDclFieldEditGUI\__construct(), and ilDclCache\getFieldCache().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getFieldModelInstanceByClass()

static ilDclFieldFactory::getFieldModelInstanceByClass ( ilDclBaseFieldModel  $field,
  $field_id = null 
)
static

Gets the correct instance of a fieldModel class Checks if a field is a plugin a replaces the fieldModel with the necessary class.

Parameters
ilDclBaseFieldModel$field
null$field_id
Returns
ilDclBaseFieldModel
Exceptions
ilDclException

Definition at line 250 of file class.ilDclFieldFactory.php.

251 {
252 if ($field->getId() != null && !empty(self::$field_model_cache[$field->getId()])) {
253 return self::$field_model_cache[$field->getId()];
254 }
255
256 $path_type = self::getClassPathByInstance($field, self::$field_class_patter);
257
258 if (file_exists($path_type)) {
259 $class = self::getClassByInstance($field, self::$field_class_patter);
260 } else {
261 $class = self::getFieldClass(self::$default_prefix . "Base", self::$field_class_patter);
262 }
263
264 if ($field_id) {
265 $instance = new $class($field_id);
266 } else {
267 $instance = new $class();
268 }
269
270 if ($instance == null) {
271 throw new ilDclException("Could not create FieldModel of " . $class);
272 }
273
274 if ($field->getId() != null) {
275 self::$field_model_cache[$field->getId()] = $instance;
276 }
277
278 return $instance;
279 }
static getClassByInstance(ilDclBaseFieldModel $field, $class_pattern)
static getClassPathByInstance(ilDclBaseFieldModel $field, $class_pattern)

References getClassByInstance(), getClassPathByInstance(), getFieldClass(), and ilDclBaseFieldModel\getId().

Referenced by ilDclCache\buildFieldFromRecord(), ilDclFieldEditGUI\checkInput(), and getFieldModelInstance().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getFieldRepresentationInstance()

static ilDclFieldFactory::getFieldRepresentationInstance ( ilDclBaseFieldModel  $field)
static

Returns FieldRepresentation from BaseFieldModel.

Parameters
ilDclBaseFieldModel$field
Returns
ilDclBaseFieldRepresentation
Exceptions
ilDclException

Definition at line 139 of file class.ilDclFieldFactory.php.

140 {
141 // when the datatype overview is generated no field-models are available, so an empty instance is used => no caching there
142 if ($field->getId() != null && !empty(self::$field_representation_cache[$field->getId()])) {
143 return self::$field_representation_cache[$field->getId()];
144 }
145
146 $class_path = self::getClassPathByInstance($field, self::$field_representation_class_pattern);
147
148 $instance = null;
149 if (file_exists($class_path)) {
150 $class = self::getClassByInstance($field, self::$field_representation_class_pattern);
151 $instance = new $class($field);
152 } else {
153 throw new ilDclException("Path for FieldRepresentation with file " . $class_path . " does not exists!");
154 }
155
156 if ($instance == null) {
157 throw new ilDclException("Could not create FieldRepresentation of " . $class . " with file " . $class_path);
158 }
159
160 if ($field->getId() != null) {
161 self::$field_representation_cache[$field->getId()] = $instance;
162 }
163
164 return $instance;
165 }

References getClassByInstance(), getClassPathByInstance(), and ilDclBaseFieldModel\getId().

Referenced by ilDclSelectionFieldModel\getConfirmationGUI(), ilDclCache\getFieldRepresentation(), ilDclTableViewEditFieldsTableGUI\getStandardFilterHTML(), ilDclFieldEditGUI\initForm(), ilDclBaseFieldModel\storePropertiesFromForm(), and ilDclSelectionFieldModel\storePropertiesFromForm().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getFieldTypeByInstance()

static ilDclFieldFactory::getFieldTypeByInstance ( ilDclBaseFieldModel  $field)
static
Parameters
ilDclBaseFieldModel$field
Returns
string

Definition at line 294 of file class.ilDclFieldFactory.php.

295 {
296 $datatype = $field->getDatatype();
297
298 if (!empty(self::$field_type_cache[$datatype->getId()])) {
299 if ($datatype->getId() == ilDclDatatype::INPUTFORMAT_PLUGIN) {
300 if (!empty(self::$field_type_cache[$datatype->getId()][$field->getId()])) {
301 return self::$field_type_cache[$datatype->getId()][$field->getId()];
302 }
303 } else {
304 return self::$field_type_cache[$datatype->getId()];
305 }
306 }
307
308 if ($datatype->getId() == ilDclDatatype::INPUTFORMAT_PLUGIN) {
310 $plugin_data
312 $fieldtype = $plugin_data->getPluginClassPrefix() . ucfirst($plugin_data->getPluginName());
313 } else {
314 $fieldtype = self::$default_prefix . ucfirst(self::parseDatatypeTitle($datatype->getTitle()));
315 }
316 self::$field_type_cache[$datatype->getId()][$field->getId()] = $fieldtype;
317 } else {
318 $fieldtype = self::$default_prefix . ucfirst(self::parseDatatypeTitle($datatype->getTitle()));
319 self::$field_type_cache[$datatype->getId()] = $fieldtype;
320 }
321
322 return $fieldtype;
323 }

References ilDclFieldTypePlugin\COMPONENT_NAME, ilDclBaseFieldModel\getDatatype(), ilDclBaseFieldModel\getId(), ilPlugin\getPluginObject(), ilDclBaseFieldModel\getProperty(), ilDclBaseFieldModel\hasProperty(), IL_COMP_MODULE, ilDclDatatype\INPUTFORMAT_PLUGIN, ilDclBaseFieldModel\PROP_PLUGIN_HOOK_NAME, and ilDclFieldTypePlugin\SLOT_ID.

Referenced by getClassByInstance().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getPluginNameFromFieldModel()

static ilDclFieldFactory::getPluginNameFromFieldModel ( ilDclBaseFieldModel  $object)
static

Get plugin-name from FieldModel.

Parameters
ilDclBaseFieldModel$object
Returns
string

Definition at line 434 of file class.ilDclFieldFactory.php.

435 {
436 $class_name = get_class($object);
437 $class_name = substr($class_name, 2, -(strlen(self::$field_class_patter) - 2));
438
439 return $class_name;
440 }

Referenced by ilDclBaseFieldRepresentation\addFieldCreationForm().

+ Here is the caller graph for this function:

◆ getRecordFieldInstance()

static ilDclFieldFactory::getRecordFieldInstance ( ilDclBaseFieldModel  $field,
ilDclBaseRecordModel  $record 
)
static

Creates a RecordField instance and loads the field and record representation.

Parameters
ilDclBaseFieldModel$field
ilDclBaseRecordModel$record
Returns
mixed
Exceptions
ilDclException

Definition at line 56 of file class.ilDclFieldFactory.php.

57 {
58 if (!empty(self::$record_field_cache[$field->getId()][$record->getId()])) {
59 return self::$record_field_cache[$field->getId()][$record->getId()];
60 }
61
62 $path = self::getClassPathByInstance($field, self::$record_field_class_patter);
63 if (file_exists($path)) {
64 $class = self::getClassByInstance($field, self::$record_field_class_patter);
65 $instance = new $class($record, $field);
66 if ($instance instanceof ilDclBaseRecordFieldModel) {
67 if (!$instance->getFieldRepresentation()) {
68 $instance->setFieldRepresentation(self::getFieldRepresentationInstance($field));
69 }
70
71 if (!$instance->getRecordRepresentation()) {
72 $instance->setRecordRepresentation(self::getRecordRepresentationInstance($instance));
73 }
74 self::$record_field_cache[$field->getId()][$record->getId()] = $instance;
75
76 return $instance;
77 }
78 }
79 }

References getClassByInstance(), getClassPathByInstance(), ilDclBaseFieldModel\getId(), and ilDclBaseRecordModel\getId().

Referenced by ilDclCache\getRecordFieldCache().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ getRecordModelInstance()

static ilDclFieldFactory::getRecordModelInstance (   $record_id)
static

Creates a RecordModel instance.

Parameters
$record_id
Returns
ilDclBaseRecordModel

Definition at line 421 of file class.ilDclFieldFactory.php.

422 {
423 return new ilDclBaseRecordModel($record_id);
424 }
Class ilDclBaseRecordModel.

Referenced by ilDclCache\getRecordCache().

+ Here is the caller graph for this function:

◆ getRecordRepresentationInstance()

static ilDclFieldFactory::getRecordRepresentationInstance ( ilDclBaseRecordFieldModel  $record_field)
static

Get RecordRepresentation from RecordFieldModel.

Parameters
ilDclBaseRecordFieldModel$record_field
Returns
ilDclBaseRecordRepresentation
Exceptions
ilDclException

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

183 {
184 // there are some field types which have no recordFieldModel object (e.g rating) => no caching
185 if ($record_field->getId() != null && !empty(self::$record_representation_cache[$record_field->getId()])) {
186 return self::$record_representation_cache[$record_field->getId()];
187 }
188
189 $class_path = self::getClassPathByInstance($record_field->getField(), self::$record_representation_class_pattern);
190 $instance = null;
191
192 if (file_exists($class_path)) {
193 $class = self::getClassByInstance($record_field->getField(), self::$record_representation_class_pattern);
194 } else {
195 $class = self::getFieldClass(self::$default_prefix . "Base", self::$record_representation_class_pattern);
196 }
197
198 $instance = new $class($record_field);
199
200 if ($instance == null) {
201 throw new ilDclException("Could not create RecordRepresentation of " . $class_path . " " . $record_field->getField()->getDatatype()->getTitle());
202 }
203
204 if ($record_field->getId() != null) {
205 self::$record_representation_cache[$record_field->getId()] = $instance;
206 }
207
208 return $instance;
209 }

References getClassByInstance(), getClassPathByInstance(), ilDclBaseRecordFieldModel\getField(), getFieldClass(), and ilDclBaseRecordFieldModel\getId().

Referenced by ilDclCache\getRecordRepresentation().

+ Here is the call graph for this function:
+ Here is the caller graph for this function:

◆ parseDatatypeTitle()

static ilDclFieldFactory::parseDatatypeTitle (   $title)
static

Parse string to FieldClass format Replaces _ with camelcase-notation.

Parameters
$title
Returns
string

Definition at line 400 of file class.ilDclFieldFactory.php.

401 {
402 $parts = explode("_", $title);
403 $func = function ($value) {
404 return ucfirst($value);
405 };
406
407 $parts = array_map($func, $parts);
408 $title = implode("", $parts);
409
410 return $title;
411 }

Field Documentation

◆ $class_path_cache

ilDclFieldFactory::$class_path_cache = array()
staticprotected

Definition at line 343 of file class.ilDclFieldFactory.php.

◆ $default_prefix

ilDclFieldFactory::$default_prefix = "ilDcl"
static

Definition at line 20 of file class.ilDclFieldFactory.php.

◆ $field_base_path_patter

ilDclFieldFactory::$field_base_path_patter = "./Modules/DataCollection/classes/Fields/%s/"
static

Definition at line 16 of file class.ilDclFieldFactory.php.

◆ $field_class_cache

ilDclFieldFactory::$field_class_cache = array()
staticprotected

Definition at line 85 of file class.ilDclFieldFactory.php.

◆ $field_class_patter

ilDclFieldFactory::$field_class_patter = "%sFieldModel"
static

Definition at line 28 of file class.ilDclFieldFactory.php.

◆ $field_model_cache

ilDclFieldFactory::$field_model_cache = array()
staticprotected

Definition at line 237 of file class.ilDclFieldFactory.php.

◆ $field_representation_cache

ilDclFieldFactory::$field_representation_cache = array()
staticprotected

Definition at line 128 of file class.ilDclFieldFactory.php.

◆ $field_representation_class_pattern

ilDclFieldFactory::$field_representation_class_pattern = "%sFieldRepresentation"
static

Definition at line 40 of file class.ilDclFieldFactory.php.

◆ $field_type_cache

ilDclFieldFactory::$field_type_cache = array()
staticprotected

Definition at line 285 of file class.ilDclFieldFactory.php.

◆ $record_class_patter

ilDclFieldFactory::$record_class_patter = "%sRecordModel"
static

Definition at line 32 of file class.ilDclFieldFactory.php.

◆ $record_field_cache

ilDclFieldFactory::$record_field_cache = array()
staticprotected

Definition at line 44 of file class.ilDclFieldFactory.php.

◆ $record_field_class_patter

ilDclFieldFactory::$record_field_class_patter = "%sRecordFieldModel"
static

Definition at line 24 of file class.ilDclFieldFactory.php.

◆ $record_representation_cache

ilDclFieldFactory::$record_representation_cache = array()
staticprotected

Definition at line 171 of file class.ilDclFieldFactory.php.

◆ $record_representation_class_pattern

ilDclFieldFactory::$record_representation_class_pattern = "%sRecordRepresentation"
static

Definition at line 36 of file class.ilDclFieldFactory.php.


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