diff --git a/Modules/DataCollection/classes/Fields/Formula/class.ilDclFormulaFieldModel.php b/Modules/DataCollection/classes/Fields/Formula/class.ilDclFormulaFieldModel.php index e1cc42456da9..9c646f694e3d 100644 --- a/Modules/DataCollection/classes/Fields/Formula/class.ilDclFormulaFieldModel.php +++ b/Modules/DataCollection/classes/Fields/Formula/class.ilDclFormulaFieldModel.php @@ -20,6 +20,13 @@ class ilDclFormulaFieldModel extends ilDclBaseFieldModel { + public const SUPPORTED_FIELDS = [ + ilDclDatatype::INPUTFORMAT_NUMBER, + ilDclDatatype::INPUTFORMAT_TEXT, + ilDclDatatype::INPUTFORMAT_BOOLEAN, + ilDclDatatype::INPUTFORMAT_DATETIME, + ]; + /** * Returns a query-object for building the record-loader-sql-query */ diff --git a/Modules/DataCollection/classes/Fields/Text/class.ilDclTextRecordRepresentation.php b/Modules/DataCollection/classes/Fields/Text/class.ilDclTextRecordRepresentation.php index b69fb00a6da8..20c32d919eab 100644 --- a/Modules/DataCollection/classes/Fields/Text/class.ilDclTextRecordRepresentation.php +++ b/Modules/DataCollection/classes/Fields/Text/class.ilDclTextRecordRepresentation.php @@ -86,10 +86,6 @@ public function getHTML(bool $link = true, array $options = []): string $html = (is_array($value) && isset($value['link'])) ? $value['link'] : nl2br((string) $value); } - if (!$html) { - $html = ""; - } - return $html; } diff --git a/Modules/DataCollection/classes/Table/class.ilDclTable.php b/Modules/DataCollection/classes/Table/class.ilDclTable.php index 66834b998912..fff19ffa5b83 100644 --- a/Modules/DataCollection/classes/Table/class.ilDclTable.php +++ b/Modules/DataCollection/classes/Table/class.ilDclTable.php @@ -18,6 +18,8 @@ declare(strict_types=1); +use ILIAS\Modules\DataCollection\Fields\Formula\FormulaParser\Token\Tokenizer; + class ilDclTable { protected int $id = 0; @@ -528,23 +530,14 @@ public function getFirstTableViewId(int $ref_id, int $user_id = 0, bool $with_de */ public function getFieldsForFormula(): array { - $unsupported = [ - ilDclDatatype::INPUTFORMAT_ILIAS_REF, - ilDclDatatype::INPUTFORMAT_FORMULA, - ilDclDatatype::INPUTFORMAT_MOB, - ilDclDatatype::INPUTFORMAT_REFERENCELIST, - ilDclDatatype::INPUTFORMAT_REFERENCE, - ilDclDatatype::INPUTFORMAT_FILEUPLOAD, - ilDclDatatype::INPUTFORMAT_RATING, - ]; - - $this->loadCustomFields(); - $return = $this->getStandardFields(); - /** - * @var $field ilDclBaseFieldModel - */ - foreach ($this->fields as $field) { - if (!in_array($field->getDatatypeId(), $unsupported)) { + $syntax_chars = array_merge(Tokenizer::$operators, Tokenizer::$functions, ['(', ')', ',']); + foreach ($this->getFields() as $field) { + if (in_array($field->getDatatypeId(), ilDclFormulaFieldModel::SUPPORTED_FIELDS)) { + foreach ($syntax_chars as $element) { + if (str_contains($field->getTitle(), $element)) { + continue 2; + } + } $return[] = $field; } } diff --git a/Modules/DataCollection/classes/class.ilObjDataCollection.php b/Modules/DataCollection/classes/class.ilObjDataCollection.php index 55bdb4af6e67..0e66e4a30c9a 100644 --- a/Modules/DataCollection/classes/class.ilObjDataCollection.php +++ b/Modules/DataCollection/classes/class.ilObjDataCollection.php @@ -191,7 +191,7 @@ public function sendNotification($a_action, $a_table_id, $a_record_id = null): v $message .= $this->prepareMessageText($t); } $message .= "------------------------------------\n"; - $message .= $ulng->txt('dcl_changed_by') . ": " . $user->getFullname() . " " . ilUserUtil::getNamePresentation($user->getId()) + $message .= $ulng->txt('dcl_changed_by') . ": " . ilUserUtil::getNamePresentation($user->getId()) . "\n\n"; $message .= $ulng->txt('dcl_change_notification_link') . ": " . $link . "\n\n"; diff --git a/Modules/DataCollection/templates/default/tpl.tableview_create_view.html b/Modules/DataCollection/templates/default/tpl.tableview_create_view.html index 08e734743795..4d3f5a27e584 100644 --- a/Modules/DataCollection/templates/default/tpl.tableview_create_view.html +++ b/Modules/DataCollection/templates/default/tpl.tableview_create_view.html @@ -1,18 +1,22 @@