ILIAS  release_6 Revision v6.24-5-g0c8bfefb3b8
All Data Structures Namespaces Files Functions Variables Modules Pages
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  }

◆ 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.

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.

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  }
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 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  }

◆ 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  }

◆ 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.

References $base.

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

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.
$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 250 of file class.ilDclFieldFactory.php.

References ilDclBaseFieldModel\getId().

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

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  }
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 139 of file class.ilDclFieldFactory.php.

References ilDclBaseFieldModel\getId().

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

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  }
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 294 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.

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  }
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 434 of file class.ilDclFieldFactory.php.

Referenced by ilDclBaseFieldRepresentation\addFieldCreationForm().

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  }
+ 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 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  $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  }
+ 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.

Referenced by ilDclCache\getRecordCache().

422  {
423  return new ilDclBaseRecordModel($record_id);
424  }
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 182 of file class.ilDclFieldFactory.php.

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

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

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  }
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 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: