uc_product.features.inc in Ubercart 6.2
Same filename and directory in other branches
Features integration for Ubercart product classes.
File
uc_product/uc_product.features.incView source
<?php
/**
* @file
* Features integration for Ubercart product classes.
*/
/**
* Implements hook_features_export_options().
*/
function uc_product_classes_features_export_options() {
$classes = array();
foreach (uc_product_node_info() as $type => $info) {
$classes[$type] = $info['name'];
}
return $classes;
}
/**
* Implements hook_features_export().
*/
function uc_product_classes_features_export($data, &$export, $module_name = '') {
$export['dependencies']['uc_product'] = 'uc_product';
foreach ($data as $class) {
$export['features']['uc_product_classes'][$class] = $class;
}
// Create a pipe for the CCK fields and variables to be exported.
// This used to just return $pipe = array('node' => $data); but this
// stopped working in Features 6.x-1.2. See http://drupal.org/node/1404486
$pipe = node_features_export($data, $export, $module_name);
// If strongarm is available, export the shippable and image settings.
if (module_exists('strongarm')) {
foreach ($data as $class) {
$pipe['variable'][] = "uc_product_shippable_{$class}";
$pipe['variable'][] = "uc_image_{$class}";
}
}
return $pipe;
}
/**
* Implements hook_features_export_render().
*/
function uc_product_classes_features_export_render($module, $data, $export = NULL) {
$output = node_features_export_render($module, $data, $export);
return array(
'uc_product_default_classes' => $output['node_info'],
);
}
/**
* Implements hook_features_revert().
*
* @see node_features_revert()
*/
function uc_product_classes_features_revert($module) {
if ($default_types = features_get_default('uc_product_classes', $module)) {
foreach ($default_types as $type_name => $type_info) {
// We need to de-activate any missing fields. De-activating allows us to
// preserve data. We de-activate by setting the widget_active flag to 0;
// widget_active is incorrectly named, and really should be
// instance_active
if (module_exists('content')) {
// Our existing fields ($fields) needs to be the first argument here,
// so only fields that don't exist in code can be de-activated.
if ($deleted_fields = array_diff(content_features_fields_normal($type_name), content_features_fields_default($type_name))) {
foreach ($deleted_fields as $field_name) {
db_query("UPDATE {" . content_instance_tablename() . "} SET widget_active = 0 WHERE field_name = '%s' AND type_name = '%s'", $field_name, $type_name);
}
}
}
// Delete node types
// We don't use node_type_delete() because we do not actually
// want to delete the node type (and invoke hook_node_type()).
// This can lead to bad consequences like CCK deleting field
// storage in the DB.
db_query("DELETE FROM {node_type} WHERE type = '%s'", $type_name);
db_query("DELETE FROM {uc_product_classes} WHERE pcid = '%s'", $type_name);
}
uc_product_node_info(TRUE);
node_types_rebuild();
menu_rebuild();
}
}
Functions
Name![]() |
Description |
---|---|
uc_product_classes_features_export | Implements hook_features_export(). |
uc_product_classes_features_export_options | Implements hook_features_export_options(). |
uc_product_classes_features_export_render | Implements hook_features_export_render(). |
uc_product_classes_features_revert | Implements hook_features_revert(). |