| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172 | 
							- <?php
 
- /**
 
-  * @file
 
-  * Base integration with the Migrate API class.
 
-  */
 
- /**
 
-  * Implements hook_migrate_api().
 
-  */
 
- function addressfield_migrate_api() {
 
-   $api = array(
 
-     'api' => 2,
 
-     'field handlers' => array('MigrateAddressFieldHandler'),
 
-   );
 
-   return $api;
 
- }
 
- /**
 
-  * Primary value passed to this field must be the two letter ISO country code of
 
-  * the address.
 
-  *
 
-  * Arguments are used to specify all the other values:
 
-  *   'administrative_area' - The administrative area of this address. (i.e. State/Province)
 
-  *   'sub_administrative_area' - The sub administrative area of this address.
 
-  *   'locality' - The locality of this address. (i.e. City)
 
-  *   'dependent_locality' - The dependent locality of this address.
 
-  *   'postal_code' - The postal code of this address.
 
-  *   'thoroughfare' - The thoroughfare of this address. (i.e. Street address)
 
-  *   'premise' - The premise of this address. (i.e. Apartment / Suite number)
 
-  *   'sub_premise' - The sub_premise of this address.
 
-  *   'organisation_name' - Contents of a primary OrganisationName element in the xNL XML.
 
-  *   'name_line' - Contents of a primary NameLine element in the xNL XML.
 
-  *   'first_name' - Contents of the FirstName element of a primary PersonName element in the xNL XML.
 
-  *   'last_name' - Contents of the LastName element of a primary PersonName element in the xNL XML.
 
-  *   'data' - Additional data for this address.
 
-  *
 
-  * Add the source field mappings to the argument array then add null mappings to
 
-  * avoid having fields flagged as as unmapped:
 
-  * @code
 
-  *   // The country should be passed in as the primary value.
 
-  *   $this->addFieldMapping('field_address', 'profile_country');
 
-  *   $this->addFieldMapping('field_address:thoroughfare', 'profile_address');
 
-  *   $this->addFieldMapping('field_address:locality', 'profile_city');
 
-  *   $this->addFieldMapping('field_address:administrative_area', 'profile_state');
 
-  * @endcode
 
-  */
 
- class MigrateAddressFieldHandler extends MigrateFieldHandler {
 
-   public function __construct() {
 
-     $this->registerTypes(array('addressfield'));
 
-   }
 
-   /**
 
-    * Provide subfields for the addressfield columns.
 
-    */
 
-   public function fields() {
 
-     // Declare our arguments to also be available as subfields.
 
-     $fields = array(
 
-       'administrative_area' => t('<a href="@doc">The administrative area of ' .
 
-           'this address (i.e. State/Province)</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#administrative_area')),
 
-       'sub_administrative_area' => t('<a href="@doc">The sub administrative ' .
 
-           'area of this address</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#sub_administrative_area')),
 
-       'locality' => t('<a href="@doc">The locality of this address (i.e. ' .
 
-           'City)</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#locality')),
 
-       'dependent_locality' => t('<a href="@doc">The dependent locality of ' .
 
-           'this address</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#dependent_locality')),
 
-       'postal_code' => t('<a href="@doc">The postal code of this address</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#postal_code')),
 
-       'thoroughfare' => t('<a href="@doc">The thoroughfare of this address ' .
 
-           '(i.e. Street address)</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#thoroughfare')),
 
-       'premise' => t('<a href="@doc">The premise of this address (i.e. Apartment / Suite number)</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#premise')),
 
-       'sub_premise' => t('<a href="@doc">The sub_premise of this address</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#sub_premise')),
 
-       'organisation_name' => t('<a href="@doc">Contents of a primary ' .
 
-           'OrganisationName element in the xNL XML</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#organisation_name')),
 
-       'name_line' => t('<a href="@doc">Contents of a primary NameLine element ' .
 
-           'in the xNL XML</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#name_line')),
 
-       'first_name' => t('<a href="@doc">Contents of the FirstName element of ' .
 
-           'a primary PersonName element in the xNL XML</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#first_name')),
 
-       'last_name' => t('<a href="@doc">Contents of the LastName element of a ' .
 
-           'primary PersonName element in the xNL XML</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#last_name')),
 
-       'data' => t('<a href="@doc">Additional data for this address</a>',
 
-         array('@doc' => 'http://drupal.org/node/1996546#data')),
 
-     );
 
-     return $fields;
 
-   }
 
-   /**
 
-    * Implements MigrateFieldHandler::prepare().
 
-    *
 
-    * @param $entity
 
-    * @param array $field_info
 
-    * @param array $instance
 
-    * @param array $values
 
-    *
 
-    * @return null
 
-    */
 
-   public function prepare($entity, array $field_info, array $instance,
 
-                           array $values) {
 
-     $arguments = array();
 
-     if (isset($values['arguments'])) {
 
-       $arguments = array_filter($values['arguments']);
 
-       unset($values['arguments']);
 
-     }
 
-     $language = $this->getFieldLanguage($entity, $field_info, $arguments);
 
-     // Setup the standard Field API array for saving.
 
-     $delta = 0;
 
-     foreach ($values as $value) {
 
-       $return[$language][$delta] = array('country' => $value)
 
-         + $this->prepareArguments($arguments, $field_info, $delta);
 
-       $delta++;
 
-     }
 
-     return isset($return) ? $return : NULL;
 
-   }
 
-   /**
 
-    * Builds an array with additional data for the current $delta.
 
-    *
 
-    * @param  array $arguments
 
-    * @param  array $field_info
 
-    * @param  $delta
 
-    *
 
-    * @return array
 
-    */
 
-   protected function prepareArguments(array $arguments, array $field_info, $delta) {
 
-     $result = array();
 
-     $data = array();
 
-     foreach ($arguments as $column_key => $column_value) {
 
-       $value = NULL;
 
-       if (is_array($arguments[$column_key])) {
 
-         if (!empty($arguments[$column_key][$delta])) {
 
-           $value = $arguments[$column_key][$delta];
 
-         }
 
-       }
 
-       else {
 
-         $value = $arguments[$column_key];
 
-       }
 
-       if ($value) {
 
-         if (isset($field_info['columns'][$column_key])) {
 
-           // Store the data in a seperate column.
 
-           $result[$column_key] = $value;
 
-         }
 
-         else {
 
-           // Add the data to the 'data' column.
 
-           $data[$column_key] = $value;
 
-         }
 
-       }
 
-     }
 
-     // Store all the other data as a serialized array in the data field.
 
-     if (!empty($data)) {
 
-       $result['data'] = serialize($data);
 
-     }
 
-     return $result;
 
-   }
 
- }
 
 
  |