diff --git a/inc/condition.class.php b/inc/condition.class.php index 77f7d1097..baaa4d0f1 100644 --- a/inc/condition.class.php +++ b/inc/condition.class.php @@ -94,8 +94,6 @@ public static function import(PluginFormcreatorLinker $linker, $input = [], $con throw new ImportFailureException('UUID or ID is mandatory'); } - //$itemtypeFk = $input['itemtype']::getForeignKeyField(); - //$questionFk = PluginFormcreatorQuestion::getForeignKeyField(); $input['items_id'] = $containerId; $item = new self(); @@ -119,10 +117,16 @@ public static function import(PluginFormcreatorLinker $linker, $input = [], $con } // set ID for linked objects - $linked = $linker->getObject($input['plugin_formcreator_questions_id'], $input['itemtype']); + $linked = $linker->getObject($input['plugin_formcreator_questions_id'], PluginFormcreatorQuestion::class); if ($linked === false) { - $linker->postpone($input[$idKey], $item->getType(), $input, $containerId); - return false; + $linked = new PluginFormcreatorQuestion(); + $linked->getFromDBByCrit([ + $idKey => $input['plugin_formcreator_questions_id'] + ]); + if ($linked->isNewItem()) { + $linker->postpone($input[$idKey], $item->getType(), $input, $containerId); + return false; + } } $input['plugin_formcreator_questions_id'] = $linked->getID(); @@ -170,6 +174,13 @@ public function export($remove_uuid = false) { $question = new PluginFormcreatorQuestion(); $question->getFromDB($condition['plugin_formcreator_questions_id']); $condition['plugin_formcreator_questions_id'] = $question->fields['uuid']; + $containerType = $input['itemtype']; + if (!class_exists($containerType) || !is_subclass_of($containerType, PluginFormcreatorConditionnableInterface::class)) { + return false; + } + $container = new $containerType(); + $container->getFromDB($condition['items_id']); + $condition['items_id'] = $container->fields['uuid']; } unset($condition[$idToRemove]); diff --git a/inc/questiondependency.class.php b/inc/questiondependency.class.php index 0c02327ce..4e65a737d 100644 --- a/inc/questiondependency.class.php +++ b/inc/questiondependency.class.php @@ -171,8 +171,14 @@ public static function import(PluginFormcreatorLinker $linker, $input = [], $con // set ID for linked objects $linked = $linker->getObject($input['plugin_formcreator_questions_id_2'], PluginFormcreatorQuestion::class); if ($linked === false) { - $linker->postpone($input[$idKey], $item->getType(), $input, $containerId); - return false; + $linked = new PluginFormcreatorQuestion(); + $linked->getFromDBByCrit([ + $idKey => $input['plugin_formcreator_questions_id'] + ]); + if ($linked->isNewItem()) { + $linker->postpone($input[$idKey], $item->getType(), $input, $containerId); + return false; + } } $input['plugin_formcreator_questions_id_2'] = $linked->getID(); diff --git a/inc/section.class.php b/inc/section.class.php index 17256e202..f2058724b 100644 --- a/inc/section.class.php +++ b/inc/section.class.php @@ -297,6 +297,7 @@ public static function import(PluginFormcreatorLinker $linker, $input = [], $con // add the section to the linker $linker->addObject($originalId, $item); + // Import the questions if (isset($input['_questions'])) { // sort questions by order usort($input['_questions'], function ($a, $b) { @@ -311,6 +312,13 @@ public static function import(PluginFormcreatorLinker $linker, $input = [], $con } } + // Import conditions + if (isset($input['_conditions'])) { + foreach ($input['_conditions'] as $condition) { + PluginFormcreatorCondition::import($linker, $condition, $itemId); + } + } + return $itemId; } @@ -321,7 +329,7 @@ public function export($remove_uuid = false) { return false; } - $section = $this->fields; + $section = $this->fields; // remove key and fk $formFk = PluginFormcreatorForm::getForeignKeyField(); @@ -343,6 +351,14 @@ public function export($remove_uuid = false) { } } + // get question conditions + $section['_conditions'] = []; + $condition = new PluginFormcreatorCondition(); + $all_conditions = $condition->getConditionsFromItem($this); + foreach ($all_conditions as $condition) { + $section['_conditions'][] = $condition->export($remove_uuid); + } + // remove ID or UUID $idToRemove = 'id'; if ($remove_uuid) { diff --git a/tests/suite-unit/PluginFormcreatorSection.php b/tests/suite-unit/PluginFormcreatorSection.php index f5172df39..4d8ba3566 100644 --- a/tests/suite-unit/PluginFormcreatorSection.php +++ b/tests/suite-unit/PluginFormcreatorSection.php @@ -158,6 +158,7 @@ public function testExport() { ]; $extraFields = [ '_questions', + '_conditions', ]; $this->array($output) ->hasKeys($fieldsWithoutID + $extraFields + ['uuid'])