ILIAS  release_5-4 Revision v5.4.26-12-gabc799a52e6
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 336 of file class.ilDclFieldFactory.php.

337  {
338  $fieldtype = self::getFieldTypeByInstance($field);
339 
340  return self::getFieldClass($fieldtype, $class_pattern);
341  }

◆ getClassPathByInstance()

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

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

References ilDclFieldTypePlugin\COMPONENT_NAME, ilDclBaseFieldModel\getDatatype(), 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.

358  {
359  $datatype = $field->getDatatype();
360 
361  if ($field->getId() != null && !empty(self::$class_path_cache[$field->getId()][$class_pattern])) {
362  return self::$class_path_cache[$field->getId()][$class_pattern];
363  }
364 
365  if ($datatype->getId() == ilDclDatatype::INPUTFORMAT_PLUGIN) {
367  $plugin_data
369  if ($plugin_data == null) {
370  throw new ilDclException(
371  "Something went wrong by initializing the FieldHook-Plugin '"
372  . $field->getProperty(ilDclBaseFieldModel::PROP_PLUGIN_HOOK_NAME) . "' on Component '"
373  . ilDclFieldTypePlugin::COMPONENT_NAME . "' with slot '" . ilDclFieldTypePlugin::SLOT_ID . "' on field: "
374  . $field->getTitle()
375  );
376  }
377 
378  $class_path = $plugin_data->getDirectory() . "/classes/";
379  } else {
380  $class_path = sprintf(self::$field_base_path_patter, ucfirst(self::parseDatatypeTitle($datatype->getTitle())));
381  }
382  } else {
383  $class_path = sprintf(self::$field_base_path_patter, ucfirst(self::parseDatatypeTitle($datatype->getTitle())));
384  }
385 
386  $return = $class_path . self::getFieldClassFile(self::getFieldTypeByInstance($field), $class_pattern);
387 
388  if ($field->getId() != null) {
389  self::$class_path_cache[$field->getId()][$class_pattern] = $return;
390  }
391 
392  return $return;
393  }
static getPluginObject(string $a_ctype, string $a_cname, string $a_slot_id, string $a_pname)
hasProperty($key)
Checks if a certain property for a field is set.
const IL_COMP_MODULE
getProperty($key)
Returns a certain property of a field.
Class ilDclException.
+ Here is the call 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 97 of file class.ilDclFieldFactory.php.

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

◆ getFieldClassFile()

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

Get Filename from datatype and pattern.

Parameters
$datatype
$class_pattern
Returns
string

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

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

◆ 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 224 of file class.ilDclFieldFactory.php.

References $base.

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

225  {
226  $base = new ilDclBaseFieldModel($field_id);
227  if ($datatype != null) {
228  $base->setDatatypeId($datatype);
229  }
230 
231  $ilDclBaseFieldModel = self::getFieldModelInstanceByClass($base, $field_id);
232 
233  return $ilDclBaseFieldModel;
234  }
Class ilDclBaseFieldModel.
$base
Definition: index.php:4
+ 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 253 of file class.ilDclFieldFactory.php.

References ilDclBaseFieldModel\getId().

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

254  {
255  if ($field->getId() != null && !empty(self::$field_model_cache[$field->getId()])) {
256  return self::$field_model_cache[$field->getId()];
257  }
258 
259  $path_type = self::getClassPathByInstance($field, self::$field_class_patter);
260 
261  if (file_exists($path_type)) {
262  require_once($path_type);
263  $class = self::getClassByInstance($field, self::$field_class_patter);
264  } else {
265  $class = self::getFieldClass(self::$default_prefix . "Base", self::$field_class_patter);
266  }
267 
268  if ($field_id) {
269  $instance = new $class($field_id);
270  } else {
271  $instance = new $class();
272  }
273 
274  if ($instance == null) {
275  throw new ilDclException("Could not create FieldModel of " . $class);
276  }
277 
278  if ($field->getId() != null) {
279  self::$field_model_cache[$field->getId()] = $instance;
280  }
281 
282  return $instance;
283  }
Class ilDclException.
+ 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 140 of file class.ilDclFieldFactory.php.

References ilDclBaseFieldModel\getId().

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

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

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.

299  {
300  $datatype = $field->getDatatype();
301 
302  if (!empty(self::$field_type_cache[$datatype->getId()])) {
303  if ($datatype->getId() == ilDclDatatype::INPUTFORMAT_PLUGIN) {
304  if (!empty(self::$field_type_cache[$datatype->getId()][$field->getId()])) {
305  return self::$field_type_cache[$datatype->getId()][$field->getId()];
306  }
307  } else {
308  return self::$field_type_cache[$datatype->getId()];
309  }
310  }
311 
312  if ($datatype->getId() == ilDclDatatype::INPUTFORMAT_PLUGIN) {
314  $plugin_data
316  $fieldtype = $plugin_data->getPluginClassPrefix() . ucfirst($plugin_data->getPluginName());
317  } else {
318  $fieldtype = self::$default_prefix . ucfirst(self::parseDatatypeTitle($datatype->getTitle()));
319  }
320  self::$field_type_cache[$datatype->getId()][$field->getId()] = $fieldtype;
321  } else {
322  $fieldtype = self::$default_prefix . ucfirst(self::parseDatatypeTitle($datatype->getTitle()));
323  self::$field_type_cache[$datatype->getId()] = $fieldtype;
324  }
325 
326  return $fieldtype;
327  }
static getPluginObject(string $a_ctype, string $a_cname, string $a_slot_id, string $a_pname)
hasProperty($key)
Checks if a certain property for a field is set.
const IL_COMP_MODULE
getProperty($key)
Returns a certain property of a field.
+ Here is the call graph for this function:

◆ getPluginNameFromFieldModel()

static ilDclFieldFactory::getPluginNameFromFieldModel ( ilDclBaseFieldModel  $object)
static

Get plugin-name from FieldModel.

Parameters
ilDclBaseFieldModel$object
Returns
string

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

Referenced by ilDclBaseFieldRepresentation\addFieldCreationForm().

439  {
440  $class_name = get_class($object);
441  $class_name = substr($class_name, 2, -(strlen(self::$field_class_patter) - 2));
442 
443  return $class_name;
444  }
+ 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.

References $path, ilDclBaseFieldModel\getId(), and ilDclBaseRecordModel\getId().

Referenced by ilDclCache\getRecordFieldCache().

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  require_once($path);
65  $class = self::getClassByInstance($field, self::$record_field_class_patter);
66  $instance = new $class($record, $field);
67  if ($instance instanceof ilDclBaseRecordFieldModel) {
68  if (!$instance->getFieldRepresentation()) {
69  $instance->setFieldRepresentation(self::getFieldRepresentationInstance($field));
70  }
71 
72  if (!$instance->getRecordRepresentation()) {
73  $instance->setRecordRepresentation(self::getRecordRepresentationInstance($instance));
74  }
75  self::$record_field_cache[$field->getId()][$record->getId()] = $instance;
76 
77  return $instance;
78  }
79  }
80  }
$path
Definition: aliased.php:25
+ 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 425 of file class.ilDclFieldFactory.php.

Referenced by ilDclCache\getRecordCache().

426  {
427  return new ilDclBaseRecordModel($record_id);
428  }
Class ilDclBaseRecordModel.
+ 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 184 of file class.ilDclFieldFactory.php.

References ilDclBaseRecordFieldModel\getField(), and ilDclBaseRecordFieldModel\getId().

Referenced by ilDclRecordEditGUI\cancelSave(), and ilDclCache\getRecordRepresentation().

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

References $title.

405  {
406  $parts = explode("_", $title);
407  $func = function ($value) {
408  return ucfirst($value);
409  };
410 
411  $parts = array_map($func, $parts);
412  $title = implode("", $parts);
413 
414  return $title;
415  }

Field Documentation

◆ $class_path_cache

ilDclFieldFactory::$class_path_cache = array()
staticprotected

Definition at line 347 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 86 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 240 of file class.ilDclFieldFactory.php.

◆ $field_representation_cache

ilDclFieldFactory::$field_representation_cache = array()
staticprotected

Definition at line 129 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 289 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 173 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: