Merge pull request 'translations' (#1) from translations into 1.0.x

Reviewed-on: #1
This commit is contained in:
megakeegman 2023-11-10 14:20:00 +00:00
commit a8929f9e1c
3 changed files with 39 additions and 26 deletions

View file

@ -1,5 +1,4 @@
name: Agaric Migration Helpers name: Migration Helpers
type: module type: module
description: Provides helpers to migrate data into modern Drupal. description: Provides helpers to migrate data into modern Drupal.
package: Agaric
core_version_requirement: ^9 || ^10 core_version_requirement: ^9 || ^10

View file

@ -1,4 +1,4 @@
services: services:
agaric_migration_helpers.field_transformations: migration_helpers.field_transformations:
class: Drupal\migration_helpers\MigrationHelperFieldTransformations class: Drupal\migration_helpers\MigrationHelperFieldTransformations
arguments: ['@entity_type.manager'] arguments: ['@entity_type.manager']

View file

@ -1,10 +1,10 @@
<?php <?php
namespace Drupal\agaric_migration_helpers; namespace Drupal\migration_helpers;
use Drupal\Core\Entity\EntityTypeManagerInterface; use Drupal\Core\Entity\EntityTypeManagerInterface;
class AgaricMigrationHelperFieldTransformations { class MigrationHelperFieldTransformations {
/** /**
* The entity type manager. * The entity type manager.
@ -14,7 +14,7 @@ class AgaricMigrationHelperFieldTransformations {
protected $entityTypeManager; protected $entityTypeManager;
/** /**
* Constructs an AgaricMigrationHelperFieldTransformations object. * Constructs an MigrationHelperFieldTransformations object.
*/ */
public function __construct( public function __construct(
EntityTypeManagerInterface $entity_type_manager EntityTypeManagerInterface $entity_type_manager
@ -50,29 +50,43 @@ class AgaricMigrationHelperFieldTransformations {
foreach ($entities as $entity) { foreach ($entities as $entity) {
$media_target_ids = []; $media_target_ids = [];
$langcodes = $entity->getTranslationLanguages();
foreach ($source_field_names as $source_field_name) { $translations = [];
foreach ($entity->$source_field_name as $fieldItem) { if ($langcodes > 0) {
$entity_data = [ foreach($langcodes as $langcode) {
'bundle' => $media_entity_bundle, $check_translation = $entity->getTranslation($langcode->getId());
'uid' => $entity->getOwnerId(), if ($check_translation !== NULL) {
'langcode' => $entity->language()->getId(), $translations[] = $entity->getTranslation($langcode->getId());
'status' => 1,
];
foreach (\array_keys($fieldItem->getValue()) as $subfield) {
$entity_data[$media_target_field][$subfield] = $fieldItem->get($subfield)->getValue();
} }
$media_entity = $media_entity_storage->create($entity_data);
$media_entity->save();
$media_target_ids[] = $media_entity->id();
} }
} }
$entity->set($media_field_name, $media_target_ids); foreach ($translations as $translation) {
$entity->save();
}
}
foreach ($source_field_names as $source_field_name) {
foreach ($translation->$source_field_name as $fieldItem) {
$entity_data = [
'bundle' => $media_entity_bundle,
'langcode' => $fieldItem->getLangcode(),
'status' => 1,
];
// Some entities (like taxonomy terms) do not have a an owner id
if(method_exists($entity, 'getOwnerId')) {
$entity_data['uid'] = $entity->getOwnerId();
}
foreach (\array_keys($fieldItem->getValue()) as $subfield) {
$entity_data[$media_target_field][$subfield] = $fieldItem->get($subfield)->getValue();
}
$media_entity = $media_entity_storage->create($entity_data);
$media_entity->save();
$media_target_ids[] = $media_entity->id();
}
}
$translation->set($media_field_name, $media_target_ids);
}
$entity->save();
}
}
} }