This repository has been archived on 2025-06-21. You can view files and clone it, but you cannot make any changes to it's state, such as pushing and creating new issues, pull requests or comments.
suitedesk/modules/calendar/includes/calendar.views.inc

233 lines
8.5 KiB
PHP

<?php
/**
* Implementation of hook_views_query()
*
* Handle the date_popup calendar goto date.
*/
function calendar_views_query_alter(&$view, &$query) {
// Check if a new date has been selected and if so redirect.
if (isset($_POST['calendar_goto']) && $_POST['view_name'] == $view->name) {
require_once('./'. drupal_get_path('module', 'date_api') .'/date_api_elements.inc');
$format = date_limit_format(variable_get('date_format_short', 'm/d/Y - H:i'), array('year', 'month', 'day'));
$date = date_convert_from_custom($_POST['calendar_goto']['date'], $format);
switch ($_POST['calendar_type']) {
case 'year':
$arg = date_pad(date_part_extract($date, 'year'), 4);
break;
case 'month':
$arg = date_pad(date_part_extract($date, 'year'), 4) .'-'. date_pad(date_part_extract($date, 'month'));
break;
case 'week':
$ww = date_day_of_week($date, DATE_ISO);
$ww = variable_get('date_first_day', 1) ? ($ww == 0 ? 6 : $ww - 1) : $ww;
$date = date('Y-m-d', strtotime("-$ww days", strtotime($date)));
$arg = date_pad(date_part_extract($date, 'year'), 4) .'-W'. date_pad(date_week($date));
break;
default:
$arg = date_pad(date_part_extract($date, 'year'), 4) .'-'. date_pad(date_part_extract($date, 'month')) .'-'. date_pad(date_part_extract($date, 'day'));
break;
}
drupal_goto(str_replace($_POST['calendar_previous_arg'], $arg, $_POST['view_url']));
exit();
}
}
function calendar_views_pre_view(&$view, &$display_id, &$args) {
//
}
/**
* @file
*
* Creates calendar displays of Views results.
*
* Create a new calendar by enabling or cloning the default calendar,
* changing the date argument to use the correct date field(s), and setting
* up the year, month, day, week, and block views with the desired styles
* and fields.
*
* Unlike previous versions of the Calendar module, there is just a single
* Date argument instead of year, month, and day arguments. The argument
* value will be YYYY-MM-DD for a day, YYYY-MM for a month, YYYY for a
* year, and YYYY-W99 for a week. There is a default option to set the
* argument to the current date when the argument is empty.
*
* A calendar display creates calendar navigation and links to
* multiple displays for the year, month, day, or week views. The actual
* displays are created by attaching calendar views that use whatever
* styles are desired for those pages.
*
* Calendar views are attachments to create the year, month, day,
* and week displays. They can be set to use any style, either a
* calendar style or any other Views style, like teasers or lists.
* If you don't want to use one of them, don't attach it to
* anything. Only the attached views will show up in the calendar.
*
* A calendar block will create a calendar block for the
* view results. Attach a block view to the block and set up the
* desired style in the block view.
*/
/**
* Implementation of hook_views_plugins
*/
function calendar_views_plugins() {
$path = drupal_get_path('module', 'calendar');
$theme_path = $path;
if (module_exists('calendar_multiday')) {
$theme_path = drupal_get_path('module', 'calendar_multiday');
}
$views_path = drupal_get_path('module', 'views');
require_once "./$theme_path/theme/theme.inc";
$data = array(
'module' => 'calendar', // This just tells our themes are elsewhere.
'display' => array(
// Parents are not really displays, just needed so the files can
// be included.
'parent' => array(
'no ui' => TRUE,
'handler' => 'views_plugin_display',
'path' => "$views_path/plugins",
'parent' => '',
),
'page' => array(
'no ui' => TRUE,
'handler' => 'views_plugin_display_page',
'path' => "$views_path/plugins",
'parent' => 'parent',
),
'block' => array(
'no ui' => TRUE,
'handler' => 'views_plugin_display_block',
'path' => "$views_path/plugins",
'parent' => 'parent',
),
'attachment' => array(
'no ui' => TRUE,
'handler' => 'views_plugin_display_attachment',
'path' => "$views_path/plugins",
'parent' => 'parent',
),
'calendar_attachment' => array(
'handler' => 'calendar_plugin_display_attachment',
'path' => "$path/includes",
'parent' => 'attachment',
'no ui' => TRUE,
),
// Main calendar display plugin.
'calendar' => array(
'title' => t('Calendar page'),
'help' => t('Calendar page. Attach Calendar period attachments to this page, set to show the year, month, day, and week views.'),
'handler' => 'calendar_plugin_display_page',
'path' => "$path/includes",
'parent' => 'page',
'theme' => 'views_view',
'no ui' => TRUE,
//'no remove' => TRUE,
'uses hook menu' => TRUE,
'uses hook block' => FALSE,
'use ajax' => TRUE,
'use pager' => FALSE,
'accept attachments' => TRUE,
'admin' => t('Calendar page'),
'help topic' => 'getting-started',
'js' => array(
'misc/farbtastic/farbtastic.js',
drupal_get_path('module', 'calendar') .'/js/calendar_colorpicker.js',
),
),
// Calendar block display plugin.
'calendar_block' => array(
'title' => t('Calendar block'),
'help' => t('Calendar page. Attach a Calendar period attachment to this block, set to show the year, month, day, or week view.'),
'handler' => 'calendar_plugin_display_block',
'path' => "$path/includes",
'parent' => 'block',
'theme' => 'views_view',
'no ui' => TRUE,
//'no remove' => TRUE,
'uses hook block' => TRUE,
'use ajax' => TRUE,
'use pager' => FALSE,
'use more' => TRUE,
'accept attachments' => TRUE,
'admin' => t('Calendar block'),
'help topic' => 'getting-started',
),
// Display plugins for calendar displays.
'calendar_period' => array(
'title' => t('Calendar period'),
'help' => t('An attachment for a Year, Month, Day, or Week calendar display, using any style you choose. Attach to a Calendar page and/or a Calendar block.'),
'handler' => 'calendar_plugin_display_attachment',
'path' => "$path/includes",
'file' => 'calendar_plugin_display_attachment.inc',
'parent' => 'calendar_attachment',
'theme' => 'views_view',
'no ui' => TRUE,
//'no remove' => TRUE,
'use ajax' => TRUE,
'use pager' => TRUE,
'admin' => t('Calendar page year, month, week, or day view'),
'help topic' => 'getting-started',
),
),
'style' => array(
'parent' => array(
// this isn't really a display but is necessary so the file can
// be included.
'no ui' => TRUE,
'handler' => 'views_plugin_style',
'path' => "$views_path/plugins",
'parent' => '',
),
// Style plugin for the navigation.
'calendar_nav' => array(
'title' => t('Calendar navigation'),
'help' => t('Creates back/next navigation and calendar links.'),
'handler' => 'calendar_plugin_style',
'path' => "$path/includes",
'parent' => 'parent',
'theme' => 'calendar_main',
'theme file' => 'theme.inc',
'theme path' => "$theme_path/theme",
'uses row plugin' => FALSE,
'uses fields' => TRUE,
'uses options' => FALSE,
'type' => 'calendar', // Only used on calendar page or block displays.
'even empty' => TRUE,
),
'calendar_style' => array(
'title' => t('Calendar'),
'help' => t('Displays Views results in a calendar.'),
'handler' => 'calendar_view_plugin_style',
'path' => "$path/includes",
'parent' => 'calendar_nav',
'theme' => 'calendar_month',
'theme file' => 'theme.inc',
'theme path' => "$theme_path/theme",
'additional themes' => array(
'calendar_year' => 'style',
'calendar_day' => 'style',
'calendar_week' => 'style',
'calendar_mini' => 'style',
),
'uses row plugin' => FALSE,
'uses fields' => TRUE,
'uses options' => TRUE,
'type' => 'normal',
'even empty' => TRUE,
),
),
);
if (module_exists('calendar_multiday')) {
$data['style']['calendar_style']['additional themes'] += array(
'calendar_day_overlap' => 'style',
'calendar_week_overlap' => 'style',
);
}
return $data;
}