| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139 | <?php/** * @file * Support for migrate module. * * With Migrate 2.4 or later, you can use the subfield syntax to set the title * and attributes: * * @code * $this->addFieldMapping('field_my_link', 'source_url'); * $this->addFieldMapping('field_my_link:title', 'source_title'); * $this->addFieldMapping('field_my_link:attributes', 'source_attributes'); * * # With earlier versions of Migrate, you must pass an arguments array: * * $link_args = array( *   'title' => array('source_field' => 'source_title'), *   'attributes' => array('source_field' => 'source_attributes'), * ); * $this->addFieldMapping('field_my_link', 'source_url') *      ->arguments($link_args); * @endcode */if (!class_exists('MigrateFieldHandler')) {  return;}/** * Implements hook_migrate_api(). */function link_migrate_api() {  return array(    'api' => 2,    'field handlers' => array('MigrateLinkFieldHandler'),  );}// @codingStandardsIgnoreLineclass MigrateLinkFieldHandler extends MigrateFieldHandler {  /**   * Construct.   */  public function __construct() {    $this->registerTypes(array('link_field'));  }  /**   * Arguments.   */  public static function arguments($title = NULL, $attributes = NULL, $language = NULL) {    $arguments = array();    if (!is_null($title)) {      $arguments['title'] = $title;    }    if (!is_null($attributes)) {      $arguments['attributes'] = $attributes;    }    if (!is_null($language)) {      $arguments['language'] = $language;    }    return $arguments;  }  /**   * Implementation of MigrateFieldHandler::fields().   *   * @param array $type   *   The field type.   * @param array $instance   *   Instance info for the field.   * @param Migration $migration   *   The migration context for the parent field. We can look at the mappings   *   and determine which subfields are relevant.   *   * @return array   *   Array with values.   *   * @codingStandardsIgnoreStart   */  public function fields($type, $instance, $migration = NULL) {    // @codingStandardsIgnoreEnd    return array(      'title' => t('Subfield: The link title attribute'),      'attributes' => t('Subfield: The attributes for this link'),      'language' => t('Subfield: The language for the field'),    );  }  /**   * Prepare.   */  public function prepare($entity, array $field_info, array $instance, array $values) {    if (isset($values['arguments'])) {      $arguments = $values['arguments'];      unset($values['arguments']);    }    else {      $arguments = array();    }    $language = $this->getFieldLanguage($entity, $field_info, $arguments);    $values = array_filter($values);    foreach ($values as $delta => $value) {      $item = array();      if (isset($arguments['title'])) {        if (!is_array($arguments['title'])) {          $item['title'] = $arguments['title'];        }        elseif (isset($arguments['title'][$delta])) {          $item['title'] = $arguments['title'][$delta];        }      }      if (isset($arguments['attributes'])) {        if (is_array($arguments['attributes']) && isset($arguments['attributes'][$delta])) {          $item['attributes'] = $arguments['attributes'][$delta];        }        else {          $item['attributes'] = $arguments['attributes'];        }      }      $item['url'] = $value;      if (is_array($language)) {        $current_language = $language[$delta];      }      else {        $current_language = $language;      }      $return[$current_language][$delta] = $item;    }    return isset($return) ? $return : NULL;  }}
 |