/[drupal]/contributions/modules/views_multiblock/views_multiblock_views.inc
ViewVC logotype

Contents of /contributions/modules/views_multiblock/views_multiblock_views.inc

Parent Directory Parent Directory | Revision Log Revision Log | View Revision Graph Revision Graph


Revision 1.1 - (show annotations) (download) (as text)
Wed Jun 13 05:23:48 2007 UTC (2 years, 5 months ago) by morrissinger
Branch: MAIN
CVS Tags: DRUPAL-5--1-0, HEAD
Branch point for: DRUPAL-5
File MIME type: text/x-php
Initial commit of views_multiblock module. This module allows you to use one view to generate many different blocks.
1 <?php
2 // $Id$
3
4 /**
5 * @file
6 * Provides a default view for views_multiblock.
7 */
8
9 /**
10 * Provides a default view for views_multiblock
11 */
12 function views_multiblock_views_default_views() {
13 $view = new stdClass();
14 $view->name = 'views_multiblock';
15
16 $view->description = 'Views_Multiblock Default View';
17 $view->access = array ('anonymous user');
18 $view->view_args_php = '';
19 $view->page = TRUE;
20 $view->page_title = '';
21 $view->page_header = '';
22 $view->page_header_format = '1';
23 $view->page_footer = '';
24 $view->page_footer_format = '1';
25 $view->page_empty = '';
26 $view->page_empty_format = '1';
27 $view->page_type = 'teaser';
28 $view->url = 'vm';
29 $view->use_pager = TRUE;
30 $view->nodes_per_page = '10';
31 $view->block = TRUE;
32 $view->block_title = '';
33 $view->block_header = '';
34 $view->block_header_format = '1';
35 $view->block_footer = '';
36 $view->block_footer_format = '1';
37 $view->block_empty = '';
38 $view->block_empty_format = '1';
39 $view->block_type = 'views_multiblock';
40 $view->nodes_per_block = '1';
41 $view->block_more = TRUE;
42 $view->block_use_page_header = FALSE;
43 $view->block_use_page_footer = FALSE;
44 $view->block_use_page_empty = FALSE;
45 $view->sort = array (
46 array (
47 'tablename' => 'node',
48 'field' => 'sticky',
49 'sortorder' => 'ASC',
50 'options' => '',
51 ),
52 array (
53 'tablename' => 'node',
54 'field' => 'changed',
55 'sortorder' => 'DESC',
56 'options' => 'normal',
57 ),
58 array (
59 'tablename' => 'node',
60 'field' => 'title',
61 'sortorder' => 'ASC',
62 'options' => '',
63 ),
64 );
65 $view->argument = array (
66 array (
67 'type' => 'taxid',
68 'argdefault' => '7',
69 'title' => '%1',
70 'options' => '',
71 'wildcard' => '',
72 'wildcard_substitution' => '',
73 ),
74 array (
75 'type' => 'node_feed',
76 'argdefault' => '2',
77 'title' => '',
78 'options' => 'News Feed',
79 'wildcard' => '',
80 'wildcard_substitution' => '',
81 ),
82 );
83 $view->field = array (
84 array (
85 'tablename' => 'node',
86 'field' => 'title',
87 'label' => '',
88 'handler' => 'views_handler_field_nodelink',
89 'options' => 'link',
90 ),
91 array (
92 'tablename' => 'node',
93 'field' => 'changed',
94 'label' => '',
95 'handler' => 'views_handler_field_date_small',
96 ),
97 array (
98 'tablename' => 'node',
99 'field' => 'body',
100 'label' => '',
101 'handler' => 'views_handler_field_teaser',
102 ),
103
104 );
105 $view->filter = array (
106 array (
107 'tablename' => 'node',
108 'field' => 'status',
109 'operator' => '=',
110 'options' => '',
111 'value' => '1',
112 ),
113 );
114
115 $view->exposed_filter = array ();
116
117 $view->requires = array(node);
118 $views[$view->name] = $view;
119
120 return $views;
121 }
122
123 /**
124 * Define additional view type names.
125 */
126 function views_multiblock_info() {
127 return array(
128 'views_multiblock' => array('label' => 'Views_Multiblock'),
129 );
130 }
131
132 /**
133 * Implementation of hook_views_style_plugins()
134 */
135 function views_multiblock_views_style_plugins() {
136
137 $plugins = array();
138 $types = views_multiblock_view_types();
139 foreach ($types as $name => $type) {
140 $plugins[$name] = array(
141 'name' => $type,
142 'theme' => 'views_multiblock_display',
143 'validate' => 'views_ui_plugin_validate_table',
144 'needs_fields' => TRUE,
145 'needs_table_header' => FALSE,
146 );
147 }
148
149 return $plugins;
150 }
151
152 /**
153 * Possible views page display types
154 */
155 function views_multiblock_view_types() {
156 return array('views_multiblock' => t('Views_Multiblock'));
157 }
158
159 /**
160 * A form element for a view selector
161 */
162 function _views_multiblock_view_type_form($view = NULL) {
163 $form['views_multiblock_view'] = array(
164 '#type' => 'select',
165 '#options' => views_multiblock_view_types(),
166 '#default_value' => $view ? $view->page_type : 'views_multiblock',
167 '#title' => t('View'),
168 );
169 return $form;
170 }
171
172 /***********************************************************
173 * THEME FUNCTIONS
174 */
175
176 /**
177 * Views_Multiblock plugin theme, overrides default views theme
178 */
179 function theme_views_multiblock_display($view, $nodes) {
180 //Organize the fields
181 foreach($view->field as $field) {
182 $fields[$field['fullname']] = $field;
183 }
184
185 //Generate output
186 $output = NULL;
187 foreach($nodes as $key => $node) {
188 $output[] .= theme('views_multiblock_node', $node, $fields, $view);
189 }
190
191 $output = implode('<hr class="views_multiblock_separator" />' . "\n", $output);
192
193 return $output;
194 }
195
196 /**
197 * Theme an individual views_multiblock node
198 */
199 function theme_views_multiblock_node($node, $fields, $view) {
200 //Handles an apparent bug with views that modifies the $node->node_changed element to be $node->node_changed_changed instead.
201 if(isset($node->node_changed_changed)) {
202 $node->node_changed = $node->node_changed_changed;
203 unset($node->node_changed_changed);
204 }
205
206 //Theme each field
207 foreach($fields as $key => $field) {
208 $fields[$key]['view'] = views_theme_field('views_handle_field', $field['queryname'], _views_get_fields(), $field, $node, $view);
209
210 }
211
212 //Build the output for each node
213 $output = NULL;
214 if(user_access('administer nodes')) {
215 $output .= theme('views_multiblock_edit_link', $node);
216 }
217 foreach($fields as $key => $field) {
218 if ($field['view']) {
219 $output .= '<div class="views_multiblock_field views_multiblock_' . $field['field'] . '">' . $field['view'] . '</div>' . "\n";
220 }
221 }
222
223 return $output;
224
225 }
226
227 /**
228 * Theme a node edit link
229 */
230 function theme_views_multiblock_edit_link($node) {
231 return '<div style="float: right; position: relative; padding-top: 2em; font-size: 0.9em;"><sup>' . l(t('edit'), "node/$node->nid/edit") . '</sup></div>' . "\n";
232 }

  ViewVC Help
Powered by ViewVC 1.1.2