array( 'table' => 'node', 'field' => 'vid', ), 'right' => array( 'field' => 'vid', ), ); $module = $field_types[$field['type']]['module']; $formatters = array(); if (is_array($field_types[$field['type']]['formatters'])) { foreach ($field_types[$field['type']]['formatters'] as $name => $info) { $formatters[$name] = $info['label']; } } $columns = $db_info['columns']; $main_column = array_shift($columns); $addlfields = array(); foreach ($columns as $column => $attributes) { $addlfields[] = $attributes['column']; } if ($field['multiple']) { $addlfields[] = 'delta'; } $table['fields'] = array(); $table['fields'][$main_column['column']] = array( 'name' => $field_types[$field['type']]['label'] .': '. $field['widget']['label'] .' ('. $field['field_name'] .')', 'addlfields' => $addlfields, 'sortable' => isset($main_column['sortable']) ? $main_column['sortable'] : FALSE, 'query_handler' => 'content_views_field_query_handler', 'handler' => array( 'content_views_field_handler_group' => t('Group multiple values'), 'content_views_field_handler_ungroup' => t('Do not group multiple values'), 'content_views_field_handler_first' => t('Show first value only'), 'content_views_field_handler_last' => t('Show last value only'), ), 'option' => array('#type' => 'select', '#options' => $formatters), 'content_db_info' => $db_info, 'content_field' => $field, 'content_field_module' => $module, ); if (isset($main_column['sortable']) && $main_column['sortable']) { $table['sorts'] = array(); $table['sorts'][$main_column['column']] = array( 'name' => $field_types[$field['type']]['label'] .': '. $field['widget']['label'] .' ('. $field['field_name'] .')', 'field' => $main_column['column'], 'content_db_info' => $db_info, 'content_field' => $field, 'content_field_module' => $module, ); } $filters = module_invoke($module, 'field_settings', 'filters', $field); if (is_array($filters) && count($filters)) { $table['filters'] = array(); foreach ($filters as $key => $filter) { $filter_name = ''; if (count($filters) > 1) { $filter_name = (!empty($filter['name'])) ? $filter['name'] : $key; $filter_name = ' - '.$filter_name; } $name = $field_types[$field['type']]['label'] .': '. $field['widget']['label'] . $filter_name .' ('. $field['field_name'] .')'; $init = array( 'name' => $name, 'field' => $main_column['column'], 'content_db_info' => $db_info, 'content_field' => $field, 'content_field_module' => $module, ); $table['filters'][$main_column['column'] .'_'. $key] = array_merge($filter, $init); } } // We don't use $db_info['table'] for the key, since that may change during // the lifetime of the field and we don't want to require users to redefine // their views. return array('node_data_'. $field['field_name'] => $table); } } function content_views_field_query_handler($field, &$fieldinfo, &$query) { if (in_array($field['handler'], array('content_views_field_handler_group', 'content_views_field_handler_first', 'content_views_field_handler_last'))) { // we manage the addition of fields ourselves // if not multiple field, add the columns to the query if (!$fieldinfo['content_field']['multiple']) { $query->add_field($field['field'], $field['tablename'], $field['queryname']); foreach ($fieldinfo['addlfields'] as $name) { $query->add_field($name, $field['tablename'], "$field[tablename]_$name"); } } // if multiple field, no field gets added (they are retrieved later // in content_views_field_handler in order to avoid duplicate results) else { // if the field is sortable (table sort), then we have to join the table // ("Node: Distinct" will be required to avoid duplicates...) if ($field['sortable']) { $query->ensure_table($field['tablename']); } } // make sure views default query builder does not add anything $fieldinfo['notafield'] = true; unset($fieldinfo['addlfields']); } } function content_views_field_handler_group($field_info, $field_data, $value, $data, $from = 0, $count = 'all', $order = 'ASC') { $field = $field_info['content_field']; $items = array(); if ($field['multiple']) { $table_alias = "node_data_$field[field_name]"; foreach ($field_info['content_db_info']['columns'] as $column => $attributes) { $query_columns[] = "$table_alias.$attributes[column] AS $column"; } $query_columns[] = "$table_alias.delta AS delta"; // Note : this query doesn't need to run through db_rewrite_sql, since the // nids we retrieve have been selected by the views query, which already takes // care of this. $query = "SELECT ". implode(', ', $query_columns) . " FROM {node} node". " LEFT JOIN {". $field_info['content_db_info']['table'] ."} $table_alias ON node.vid = $table_alias.vid". " WHERE node.nid = ". $data->nid . " ORDER BY $table_alias.delta $order"; // Select all deltas or only a subset. // Currently only 'all' and first / last items are proposed to the user. $result = ($count == 'all') ? db_query($query) : db_query_range($query, $from, $count); while ($item = db_fetch_array($result)) { $item['#delta'] = $item[delta]; unset($item['delta']); $items[] = content_format($field, $item, $field_data['options'], $data); } return theme('content_view_multiple_field', $items, $field, $data); } else { return content_views_field_handler_ungroup($field_info, $field_data, $value, $data); } } function content_views_field_handler_first($field_info, $field_data, $value, $data) { return content_views_field_handler_group($field_info, $field_data, $value, $data, 0, 1, 'ASC'); } function content_views_field_handler_last($field_info, $field_data, $value, $data) { return content_views_field_handler_group($field_info, $field_data, $value, $data, 0, 1, 'DESC'); } function content_views_field_handler_ungroup($field_info, $field_data, $value, $data) { $field = $field_info['content_field']; $item = array(); foreach ($field_info['content_db_info']['columns'] as $column => $attributes) { $view_column_name = $field_data['tablename'] .'_'. $attributes['column']; $item[$column] = $data->$view_column_name; } $item['#delta'] = $data->{$field_data['tablename'] .'_delta'}; return content_format($field, $item, $field_data['options'], $data); } function theme_content_view_multiple_field($items, $field, $data) { foreach ($items as $item) { if (!empty($item) || $item == '0') { $output .= '