content.inc in Feeds 6
On behalf implementation of Feeds mapping API for content.module (CCK).
File
mappers/content.incView source
<?php
/**
* @file
* On behalf implementation of Feeds mapping API for content.module (CCK).
*/
/**
* Implementation of hook_feeds_node_processor_targets_alter().
*
* @see FeedsNodeProcessor::getMappingTargets().
*/
function content_feeds_node_processor_targets_alter(&$targets, $content_type) {
$info = content_types($content_type);
$fields = array();
if (isset($info['fields']) && count($info['fields'])) {
foreach ($info['fields'] as $field_name => $field) {
if (in_array($field['type'], array(
'text',
'number_integer',
'number_decimal',
'number_float',
))) {
$fields[$field_name] = isset($field['widget']['label']) ? $field['widget']['label'] : $field_name;
}
}
}
foreach ($fields as $k => $name) {
$targets[$k] = array(
'name' => check_plain($name),
'callback' => 'content_feeds_set_target',
'description' => t('The CCK @name field of the node.', array(
'@name' => $name,
)),
);
}
}
/**
* Callback for mapping. Here is where the actual mapping happens.
*
* When the callback is invoked, $target contains the name of the field the
* user has decided to map to and $value contains the value of the feed item
* element the user has picked as a source.
*/
function content_feeds_set_target($node, $target, $value) {
$field = isset($node->{$target}) ? $node->{$target} : array();
// Handle multiple value fields.
if (is_array($value)) {
$i = 0;
foreach ($value as $v) {
if (!is_array($v) && !is_object($v)) {
$field[$i]['value'] = $v;
}
$i++;
}
}
else {
$field[0]['value'] = $value;
}
$node->{$target} = $field;
}
Functions
Name![]() |
Description |
---|---|
content_feeds_node_processor_targets_alter | Implementation of hook_feeds_node_processor_targets_alter(). |
content_feeds_set_target | Callback for mapping. Here is where the actual mapping happens. |