Mercurial > hg > rr-repo
comparison sites/all/modules/ctools/page_manager/plugins/tasks/comment_reply.inc @ 0:ff03f76ab3fe
initial version
author | danieleb <danielebarchiesi@me.com> |
---|---|
date | Wed, 21 Aug 2013 18:51:11 +0100 |
parents | |
children |
comparison
equal
deleted
inserted
replaced
-1:000000000000 | 0:ff03f76ab3fe |
---|---|
1 <?php | |
2 /** | |
3 * Specialized implementation of hook_page_manager_task_tasks(). See api-task.html for | |
4 * more information. | |
5 */ | |
6 function page_manager_comment_reply_page_manager_tasks() { | |
7 if (!module_exists('comment')) { | |
8 return; | |
9 } | |
10 | |
11 return array( | |
12 // This is a 'page' task and will fall under the page admin UI | |
13 'task type' => 'page', | |
14 | |
15 'title' => t('Comment Reply page'), | |
16 'admin title' => t('Comment Reply page'), | |
17 'admin description' => t('When enabled, this overrides the default Drupal behavior for the site contact page at <em>/contact</em>. If no variant is selected, the default Drupal contact form will be used.'), | |
18 'admin path' => 'comment/reply/%node', | |
19 | |
20 // Menu hooks so that we can alter the node/%node menu entry to point to us. | |
21 'hook menu alter' => 'page_manager_comment_reply_menu_alter', | |
22 | |
23 // This is task uses 'context' handlers and must implement these to give the | |
24 // handler data it needs. | |
25 'handler type' => 'context', | |
26 'get arguments' => 'page_manager_comment_reply_get_arguments', | |
27 'get context placeholders' => 'page_manager_comment_reply_get_contexts', | |
28 | |
29 // Allow this to be enabled or disabled: | |
30 'disabled' => variable_get('page_manager_comment_reply_disabled', TRUE), | |
31 'enable callback' => 'page_manager_comment_reply_enable', | |
32 'access callback' => 'page_manager_comment_reply_check', | |
33 ); | |
34 } | |
35 | |
36 /** | |
37 * Callback to enable/disable the page from the UI. | |
38 */ | |
39 function page_manager_comment_reply_enable($cache, $status) { | |
40 variable_set('page_manager_comment_reply_disabled', $status); | |
41 // Set a global flag so that the menu routine knows it needs | |
42 // to set a message if enabling cannot be done. | |
43 if (!$status) { | |
44 $GLOBALS['page_manager_enabling_comment_reply'] = TRUE; | |
45 } | |
46 } | |
47 | |
48 | |
49 /** | |
50 * Entry point for our overridden comment. | |
51 * | |
52 */ | |
53 function page_manager_comment_reply_page($node, $pid = NULL){ | |
54 // Load my task plugin | |
55 $task = page_manager_get_task('comment_reply'); | |
56 | |
57 // Load the node into a context. | |
58 ctools_include('context'); | |
59 ctools_include('context-task-handler'); | |
60 | |
61 $contexts = ctools_context_handler_get_task_contexts($task, '', array($node, $pid)); | |
62 | |
63 if (array_key_exists('argument_cid_3', $contexts) && $contexts['argument_cid_3']->data->nid != $node->nid) { | |
64 // Attempting to reply to a comment not belonging to the current nid. | |
65 drupal_set_message(t('The comment you are replying to does not exist.'), 'error'); | |
66 drupal_goto("node/$node->nid"); | |
67 } | |
68 | |
69 $output = ctools_context_handler_render($task, '', $contexts, array($node, $pid)); | |
70 if ($output != FALSE) { | |
71 return $output; | |
72 } | |
73 | |
74 $function = 'comment_reply'; | |
75 foreach (module_implements('page_manager_override') as $module) { | |
76 $call = $module . '_page_manager_override'; | |
77 if (($rc = $call('comment_reply')) && function_exists($rc)) { | |
78 $function = $rc; | |
79 break; | |
80 } | |
81 } | |
82 | |
83 module_load_include('inc', 'comment', 'comment.pages'); | |
84 return $function($node, $pid); | |
85 } | |
86 | |
87 /** | |
88 * Callback to get arguments provided by this task handler. | |
89 * | |
90 * Since this is the node view and there is no UI on the arguments, we | |
91 * create dummy arguments that contain the needed data. | |
92 */ | |
93 function page_manager_comment_reply_get_arguments($task, $subtask_id) { | |
94 return array( | |
95 array( | |
96 'keyword' => 'node', | |
97 'identifier' => t('Node being commented on'), | |
98 'id' => 2, | |
99 'name' => 'entity_id:node', | |
100 'settings' => array(), | |
101 ), | |
102 array( | |
103 'keyword' => 'comment', | |
104 'identifier' => t('Comment being replied to'), | |
105 'id' => 3, | |
106 'name' => 'entity_id:comment', | |
107 'settings' => array(), | |
108 ), | |
109 ); | |
110 } | |
111 | |
112 /** | |
113 * Callback to get context placeholders provided by this handler. | |
114 */ | |
115 function page_manager_comment_reply_get_contexts($task, $subtask_id) { | |
116 return ctools_context_get_placeholders_from_argument(page_manager_comment_reply_get_arguments($task, $subtask_id)); | |
117 } | |
118 | |
119 /** | |
120 * Callback defined by page_manager_node_view_page_manager_tasks(). | |
121 * | |
122 * Alter the node view input so that node view comes to us rather than the | |
123 * normal node view process. | |
124 */ | |
125 function page_manager_comment_reply_menu_alter(&$items, $task) { | |
126 if (variable_get('page_manager_comment_reply_disabled', TRUE)) { | |
127 return; | |
128 } | |
129 // Override the node view handler for our purpose. | |
130 $callback = $items['comment/reply/%node']['page callback']; | |
131 if ($callback == 'comment_reply' || variable_get('page_manager_override_anyway', FALSE)) { | |
132 $items['comment/reply/%node']['page callback'] = 'page_manager_comment_reply_page'; | |
133 $items['comment/reply/%node']['file path'] = $task['path']; | |
134 $items['comment/reply/%node']['file'] = $task['file']; | |
135 } | |
136 else { | |
137 // automatically disable this task if it cannot be enabled. | |
138 variable_set('page_manager_comment_reply_disabled', TRUE); | |
139 if (!empty($GLOBALS['page_manager_enabling_comment_reply'])) { | |
140 drupal_set_message(t('Page manager module is unable to enable comment/reply/%node because some other module already has overridden with %callback.', array('%callback' => $callback)), 'error'); | |
141 } | |
142 } | |
143 | |
144 // @todo override node revision handler as well? | |
145 } | |
146 | |
147 /** | |
148 * Callback to determine if a page is accessible. | |
149 * | |
150 * @param $task | |
151 * The task plugin. | |
152 * @param $subtask_id | |
153 * The subtask id | |
154 * @param $contexts | |
155 * The contexts loaded for the task. | |
156 * @return | |
157 * TRUE if the current user can access the page. | |
158 */ | |
159 function page_manager_comment_reply_access_check($task, $subtask_id, $contexts) { | |
160 $context = reset($contexts); | |
161 return TRUE; | |
162 } |