/** * @param Type $type * @param array $metadata * @param FileTypeAdapter $fileTypeAdapter * @param null $itemIndex */ private function writeTypeToFile(Type $type, array &$metadata, FileTypeAdapter $fileTypeAdapter, $itemIndex = null) { $filenameData = [self::FILENAME_DATA_METADATA => $metadata]; if ($type->description()->nativeType() === NativeType::DICTIONARY) { $filenameData[self::FILENAME_DATA_DATA] = $this->dictionaryToArray($type); } elseif ($type instanceof SingleValue) { $filenameData[self::FILENAME_DATA_VALUE] = $type->value(); } if (!is_null($itemIndex)) { $filenameData[self::FILENAME_DATA_ITEM_INDEX] = $itemIndex; } $filename = $this->fileNameRenderer->render($metadata[self::META_FILENAME_TEMPLATE], $filenameData); $fileTypeAdapter->writeDataOfType($metadata[self::META_PATH] . DIRECTORY_SEPARATOR . $filename, $type, $metadata); }
/** * @param Type $type * @return array */ protected function convertToCsvRow(Type $type) { switch ($type->description()->nativeType()) { case NativeType::COLLECTION: case NativeType::DICTIONARY: return array_map(function (Type $item) { return $item->toString(); }, $type->value()); break; default: return [$type->toString()]; } }