summaryrefslogtreecommitdiff
path: root/modules
diff options
context:
space:
mode:
authorNeil Drumm <drumm@3064.no-reply.drupal.org>2006-10-31 17:01:04 +0000
committerNeil Drumm <drumm@3064.no-reply.drupal.org>2006-10-31 17:01:04 +0000
commit4573af1f55ce509ed3fe41f2fefe0826d41017ab (patch)
treebde8194188dc141364df371c7021e0cc76187bf7 /modules
parent12df72255cc05ef53fa546e1877275d2accac919 (diff)
downloadbrdo-4573af1f55ce509ed3fe41f2fefe0826d41017ab.tar.gz
brdo-4573af1f55ce509ed3fe41f2fefe0826d41017ab.tar.bz2
#80257 by Jaza. Add a hook for content type changes and use it for keeping vocabulary associations.
Diffstat (limited to 'modules')
-rw-r--r--modules/node/content_types.inc25
-rw-r--r--modules/node/node.module4
-rw-r--r--modules/taxonomy/taxonomy.module18
3 files changed, 37 insertions, 10 deletions
diff --git a/modules/node/content_types.inc b/modules/node/content_types.inc
index b7ef459c1..5a22f363c 100644
--- a/modules/node/content_types.inc
+++ b/modules/node/content_types.inc
@@ -275,16 +275,6 @@ function node_type_form_submit($form_id, $form_values) {
return 'admin/content/types/'. str_replace('_', '-', $type->old_type) .'/delete';
}
- if (!empty($form_values['old_type'])) {
- if ($type->old_type != $type->type) {
- $update_count = node_type_update_nodes($type->old_type, $type->type);
-
- if ($update_count) {
- drupal_set_message(t('Changed the content type of %update_count %posts from %old_type to %type.', array('%update_count' => $update_count, '%posts' => format_plural($update_count, 'post', 'posts'), '%old_type' => $type->old_type, '%type' => $type->type)));
- }
- }
- }
-
$status = node_type_save($type);
// Remove everything that's been saved already - whatever's left is assumed
@@ -338,6 +328,21 @@ function node_type_form_submit($form_id, $form_values) {
}
/**
+ * Implementation of hook_node_type().
+ */
+function node_node_type($op, $info) {
+ if (!empty($info->old_type) && $info->old_type != $info->type) {
+ $update_count = node_type_update_nodes($info->old_type, $info->type);
+
+ if ($update_count) {
+ $substr_pre = 'Changed the content type of ';
+ $substr_post = strtr(' from %old-type to %type.', array('%old-type' => theme('placeholder', $info->old_type), '%type' => theme('placeholder', $info->type)));
+ drupal_set_message(format_plural($update_count, $substr_pre .'@count post'. $substr_post, $substr_pre .'@count posts'. $substr_post));
+ }
+ }
+}
+
+/**
* Resets all of the relevant fields of a module-defined node type to their
* default values.
*
diff --git a/modules/node/node.module b/modules/node/node.module
index b8582ae00..a8c52d313 100644
--- a/modules/node/node.module
+++ b/modules/node/node.module
@@ -282,10 +282,14 @@ function node_type_save($info) {
if ($is_existing) {
db_query("UPDATE {node_type} SET type = '%s', name = '%s', module = '%s', has_title = %d, title_label = '%s', has_body = %d, body_label = '%s', description = '%s', help = '%s', min_word_count = %d, custom = %d, modified = %d, locked = %d WHERE type = '%s'", $info->type, $info->name, $info->module, $info->has_title, $info->title_label, $info->has_body, $info->body_label, $info->description, $info->help, $info->min_word_count, $info->custom, $info->modified, $info->locked, $existing_type);
+
+ module_invoke_all('node_type', 'update', $info);
return SAVED_UPDATED;
}
else {
db_query("INSERT INTO {node_type} (type, name, module, has_title, title_label, has_body, body_label, description, help, min_word_count, custom, modified, locked, orig_type) VALUES ('%s', '%s', '%s', %d, '%s', %d, '%s', '%s', '%s', %d, %d, %d, %d, '%s')", $info->type, $info->name, $info->module, $info->has_title, $info->title_label, $info->has_body, $info->body_label, $info->description, $info->help, $info->min_word_count, $info->custom, $info->modified, $info->locked, $info->orig_type);
+
+ module_invoke_all('node_type', 'insert', $info);
return SAVED_NEW;
}
}
diff --git a/modules/taxonomy/taxonomy.module b/modules/taxonomy/taxonomy.module
index c1c4372cd..40fde59c7 100644
--- a/modules/taxonomy/taxonomy.module
+++ b/modules/taxonomy/taxonomy.module
@@ -814,6 +814,24 @@ function taxonomy_node_delete($nid) {
}
/**
+ * Implementation of hook_node_type().
+ */
+function taxonomy_node_type($op, $info) {
+ if ($op == 'update' && !empty($info->old_type) && $info->type != $info->old_type) {
+ if (db_num_rows(db_query("SELECT * from {vocabulary_node_types} WHERE type = '%s'", $info->old_type))) {
+ db_query("UPDATE {vocabulary_node_types} SET type = '%s' WHERE type = '%s'", $info->type, $info->old_type);
+ $num_updated = db_affected_rows();
+
+ if ($num_updated) {
+ $substr_pre = 'Changed the content type association of ';
+ $substr_post = strtr(' from %old-type to %type.', array('%old-type' => theme('placeholder', $info->old_type), '%type' => theme('placeholder', $info->type)));
+ drupal_set_message(format_plural($num_updated, $substr_pre .'1 vocabulary'. $substr_post, $substr_pre .'@count vocabularies'. $substr_post));
+ }
+ }
+ }
+}
+
+/**
* Find all term objects related to a given term ID.
*/
function taxonomy_get_related($tid, $key = 'tid') {