mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-20 12:58:46 +01:00
WIP calendar report
This commit is contained in:
parent
cbbbf8e15b
commit
2e1e3d8727
278
calendar/inc/class.calendar_category_report.inc.php
Normal file
278
calendar/inc/class.calendar_category_report.inc.php
Normal file
@ -0,0 +1,278 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
/**
|
||||||
|
* EGroupware - Calendar's category report utility
|
||||||
|
*
|
||||||
|
* @link http://www.egroupware.org
|
||||||
|
* @package calendar
|
||||||
|
* @author Hadi Nategh <hn-AT-egroupware.org>
|
||||||
|
* @copyright (c) 2013-16 by Hadi Nategh <hn-AT-egroupware.org>
|
||||||
|
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
||||||
|
* @version $Id$
|
||||||
|
*/
|
||||||
|
|
||||||
|
use EGroupware\Api;
|
||||||
|
use EGroupware\Api\Link;
|
||||||
|
use EGroupware\Api\Framework;
|
||||||
|
use EGroupware\Api\Egw;
|
||||||
|
use EGroupware\Api\Etemplate;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* This class reports amount of events taken by users based
|
||||||
|
* on categories. The report would be based
|
||||||
|
* on start and end date and can be specified with several options
|
||||||
|
* for each category. The result of the report would be a CSV file
|
||||||
|
* consistent of user full name, categories names, and amount of time (hour|minute|second).
|
||||||
|
*
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
class calendar_category_report extends calendar_ui{
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Public functions allowed to get called
|
||||||
|
*
|
||||||
|
* @var type
|
||||||
|
*/
|
||||||
|
var $public_functions = array(
|
||||||
|
'index' => True,
|
||||||
|
);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Constructor
|
||||||
|
*/
|
||||||
|
function __construct()
|
||||||
|
{
|
||||||
|
parent::__construct(true); // call the parent's constructor
|
||||||
|
$this->tmpl = new Api\Etemplate('calendar.category_report');
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to check if the given date is a weekend date
|
||||||
|
*
|
||||||
|
* @param int $date timestamp as date
|
||||||
|
*
|
||||||
|
* @return boolean returns true if the date is weekend
|
||||||
|
*/
|
||||||
|
public static function isWeekend($date)
|
||||||
|
{
|
||||||
|
return (date('N',$date) >= 6);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to check if the given date is a holiday date
|
||||||
|
*
|
||||||
|
* @param int $date timestamp as date
|
||||||
|
*
|
||||||
|
* @return boolean returns true if the date is holiday
|
||||||
|
*/
|
||||||
|
public function isHoliday($date)
|
||||||
|
{
|
||||||
|
return array_key_exists(date('Ymd', $date), $this->bo->read_holidays(date('Y', $date)));
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
*
|
||||||
|
* @param type $week_sum
|
||||||
|
* @param type $day
|
||||||
|
* @param type $events
|
||||||
|
* @param type $cat_id
|
||||||
|
* @param type $holidays
|
||||||
|
* @param type $weekend
|
||||||
|
* @param type $min_days
|
||||||
|
* @param type $unit
|
||||||
|
*/
|
||||||
|
public function proccess_days(&$week_sum, &$day, $events, $cat_id, $holidays, $weekend, $min_days, $unit)
|
||||||
|
{
|
||||||
|
foreach ($events as &$event)
|
||||||
|
{
|
||||||
|
$categories = explode(',', $event['category']);
|
||||||
|
if (!in_array($cat_id, $categories) || ($weekend && self::isWeekend($event['start'])) || (!$holidays && $this->isHoliday($event['start']))) continue;
|
||||||
|
$day[$event['owner']][$cat_id][$event['id']] = array (
|
||||||
|
'weekN' => date('W', $event['start']),
|
||||||
|
'cat_id' => $cat_id,
|
||||||
|
'event_id' => $event['id'],
|
||||||
|
'amount' => $event['end'] - $event['start'],
|
||||||
|
'min_days' => $min_days,
|
||||||
|
'unit' => $unit
|
||||||
|
);
|
||||||
|
|
||||||
|
if ($min_days)
|
||||||
|
{
|
||||||
|
$week_sum[$event['owner']][date('W', $event['start'])][$cat_id][$event['id']][] = $event['end'] - $event['start'];
|
||||||
|
$week_sum[$event['owner']][date('W', $event['start'])][$cat_id]['min_days'] = $min_days;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Function to build holiday report index interface and logic
|
||||||
|
*
|
||||||
|
* @param type $content
|
||||||
|
*/
|
||||||
|
public function index ($content = null)
|
||||||
|
{
|
||||||
|
$api_cats = new Api\Categories($GLOBALS['egw_info']['user']['account_id'],'calendar');
|
||||||
|
if (is_null($content))
|
||||||
|
{
|
||||||
|
$cats = $api_cats->return_sorted_array($start=0, false, '', 'ASC', 'cat_name', true, 0, true);
|
||||||
|
$cats_status = $GLOBALS['egw_info']['user']['preferences']['calendar']['category_report'];
|
||||||
|
foreach ($cats as &$value)
|
||||||
|
{
|
||||||
|
$content['grid'][] = array(
|
||||||
|
'cat_id' => $value['id'],
|
||||||
|
'user' => '',
|
||||||
|
'weekend' => '',
|
||||||
|
'holidays' => '',
|
||||||
|
'min_days' => 0,
|
||||||
|
'unit' => 3600,
|
||||||
|
'enable' => true
|
||||||
|
);
|
||||||
|
}
|
||||||
|
if (is_array($cats_status))
|
||||||
|
{
|
||||||
|
$content['grid'] = array_replace_recursive($content['grid'], $cats_status);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
list($button) = @each($content['button']);
|
||||||
|
$result = $categories = array ();
|
||||||
|
$users = array_keys($GLOBALS['egw']->accounts->search(array('type'=>'accounts', active=>true)));
|
||||||
|
|
||||||
|
// report button pressed
|
||||||
|
if (!empty($button))
|
||||||
|
{
|
||||||
|
// shift the grid content by one because of the reserved first row
|
||||||
|
// for the header.
|
||||||
|
array_shift($content['grid']);
|
||||||
|
Api\Framework::ajax_set_preference('calendar', 'category_report',$content['grid']);
|
||||||
|
|
||||||
|
foreach ($content['grid'] as $key => $row)
|
||||||
|
{
|
||||||
|
if ($row['enable'])
|
||||||
|
{
|
||||||
|
$categories [$key] = $row['cat_id'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// query calendar for events
|
||||||
|
$events = $this->bo->search(array(
|
||||||
|
'start' => $content['start'],
|
||||||
|
'end' => $content['end'],
|
||||||
|
'users' => $users,
|
||||||
|
'cat_id' => $categories,
|
||||||
|
'daywise' => true
|
||||||
|
));
|
||||||
|
$days_sum = $weeks_sum = array ();
|
||||||
|
// iterate over found events
|
||||||
|
foreach($events as $day_index => $day_events)
|
||||||
|
{
|
||||||
|
|
||||||
|
if (is_array($day_events))
|
||||||
|
{
|
||||||
|
foreach ($categories as $row_id => $cat_id)
|
||||||
|
{
|
||||||
|
$this->proccess_days(
|
||||||
|
$weeks_sum,
|
||||||
|
$days_sum[$day_index],
|
||||||
|
$day_events,
|
||||||
|
$cat_id,
|
||||||
|
$content['grid'][$row_id]['holidays'],
|
||||||
|
$content['grid'][$row_id]['weekend'],
|
||||||
|
$content['grid'][$row_id]['min_days'],
|
||||||
|
$content['grid'][$row_id]['unit']
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
asort($days_sum);
|
||||||
|
ksort($days_sum);
|
||||||
|
$days_output = $min_days_output = array ();
|
||||||
|
|
||||||
|
foreach($days_sum as $day_index => $users)
|
||||||
|
{
|
||||||
|
foreach ($users as $user_id => $cat_ids)
|
||||||
|
{
|
||||||
|
foreach ($cat_ids as $cat_id => $event)
|
||||||
|
{
|
||||||
|
foreach ($event as $e)
|
||||||
|
{
|
||||||
|
$days_output[$user_id][$cat_id][$e['event_id']]['days'] =
|
||||||
|
$days_output[$user_id][$cat_id][$e['event_id']]['days'] + (int)$e['amount'];
|
||||||
|
$days_output[$user_id][$cat_id][$e['event_id']]['unit'] = $e['unit'];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
foreach ($weeks_sum as $user_id => $weeks)
|
||||||
|
{
|
||||||
|
foreach ($weeks as $week_id => $cat_ids)
|
||||||
|
{
|
||||||
|
foreach ($cat_ids as $cat_id => $events)
|
||||||
|
{
|
||||||
|
foreach ($events as $event_id => $e)
|
||||||
|
{
|
||||||
|
if ($event_id !== 'min_days')
|
||||||
|
{
|
||||||
|
$days = $weeks_sum[$user_id][$week_id][$cat_id][$event_id];
|
||||||
|
$min_days_output[$user_id][$cat_id][$event_id]['days'] =
|
||||||
|
$min_days_output[$user_id][$cat_id][$event_id]['days'] +
|
||||||
|
(count($days) >= (int)$events['min_days']?self::add_days($days):0);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// Replace value of those cats who have min_days set on with regular day calculation
|
||||||
|
// result array structure:
|
||||||
|
// [user_ids] =>
|
||||||
|
// [cat_ids] =>
|
||||||
|
// [event_ids] => [
|
||||||
|
// days: amount of event in second,
|
||||||
|
// unit: unit to be shown as output (in second, eg. 3600)
|
||||||
|
// ]
|
||||||
|
//
|
||||||
|
$result = array_replace_recursive($days_output, $min_days_output);
|
||||||
|
|
||||||
|
$fp = fopen('php://output', 'w');
|
||||||
|
foreach ($result as $user_id => $cat_ids)
|
||||||
|
{
|
||||||
|
foreach ($cat_ids as $cat_id => $events)
|
||||||
|
{
|
||||||
|
foreach ($events as &$e)
|
||||||
|
{
|
||||||
|
$r ['user_fullname'] = [Api\Accounts::id2name($user_id, 'account_fullname')];
|
||||||
|
$r [$api_cats->id2name($cat_id)] = ceil($e['days'] / (int)$e['unit']);
|
||||||
|
fputcsv($fp, array_keys($r));
|
||||||
|
fputcsv($fp, array_values($r));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
// unit selectbox options
|
||||||
|
$sel_options['unit'] = array (
|
||||||
|
3600 => array('label' => lang('hour'), 'title'=>'Output value in hour'),
|
||||||
|
60 => array('label' => lang('minute'), 'title'=>'Output value in minute'),
|
||||||
|
1 => array('label' => lang('second'), 'title'=>'Output value in second')
|
||||||
|
);
|
||||||
|
// Add an extra row for the grid header
|
||||||
|
array_unshift($content['grid'],array(''=> ''));
|
||||||
|
$preserv = $content;
|
||||||
|
$this->tmpl->exec('calendar.calendar_category_report.index', $content, $sel_options, array(), $preserv, 2);
|
||||||
|
}
|
||||||
|
|
||||||
|
public static function add_days ($days) {
|
||||||
|
$sum = 0;
|
||||||
|
foreach ($days as $val)
|
||||||
|
{
|
||||||
|
$sum = $sum + $val;
|
||||||
|
}
|
||||||
|
return $sum;
|
||||||
|
}
|
||||||
|
}
|
@ -1,154 +0,0 @@
|
|||||||
<?php
|
|
||||||
|
|
||||||
/**
|
|
||||||
* EGroupware - Calendar's holiday report utility
|
|
||||||
*
|
|
||||||
* @link http://www.egroupware.org
|
|
||||||
* @package calendar
|
|
||||||
* @author Hadi Nategh <hn-AT-egroupware.org>
|
|
||||||
* @copyright (c) 2013-16 by Hadi Nategh <hn-AT-egroupware.org>
|
|
||||||
* @license http://opensource.org/licenses/gpl-license.php GPL - GNU General Public License
|
|
||||||
* @version $Id$
|
|
||||||
*/
|
|
||||||
|
|
||||||
use EGroupware\Api;
|
|
||||||
use EGroupware\Api\Link;
|
|
||||||
use EGroupware\Api\Framework;
|
|
||||||
use EGroupware\Api\Egw;
|
|
||||||
use EGroupware\Api\Etemplate;
|
|
||||||
|
|
||||||
/**
|
|
||||||
* This class reports number of holidays taken by users based
|
|
||||||
* on categories defined as holidays. THe report would be based
|
|
||||||
* on start and end date and can be specified with several options
|
|
||||||
* for each category. The result of the report would be a CSV file
|
|
||||||
* consistent of user full name, categories names, and number of
|
|
||||||
* days/ or weeks.
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
class calendar_holiday_report extends calendar_ui{
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Public functions allowed to get called
|
|
||||||
*
|
|
||||||
* @var type
|
|
||||||
*/
|
|
||||||
var $public_functions = array(
|
|
||||||
'index' => True,
|
|
||||||
);
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Constructor
|
|
||||||
*/
|
|
||||||
function __construct()
|
|
||||||
{
|
|
||||||
parent::__construct(true); // call the parent's constructor
|
|
||||||
$this->tmpl = new Api\Etemplate('calendar.holiday_report');
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
|
||||||
* Function to build holiday report index interface and logic
|
|
||||||
*
|
|
||||||
* @param type $content
|
|
||||||
*/
|
|
||||||
public function index ($content = null)
|
|
||||||
{
|
|
||||||
$cat = new Api\Categories($GLOBALS['egw_info']['user']['account_id'],'calendar');
|
|
||||||
if (is_null($content))
|
|
||||||
{
|
|
||||||
$cats = $cat->return_sorted_array($start=0, false, '', 'ASC', 'cat_name', true, 0, true);
|
|
||||||
$cats_status = $GLOBALS['egw_info']['user']['preferences']['calendar']['holiday_report'];
|
|
||||||
foreach ($cats as &$value)
|
|
||||||
{
|
|
||||||
$content['grid'][] = array(
|
|
||||||
'cat_id' => $value['id'],
|
|
||||||
'user' => '',
|
|
||||||
'weekend' => '',
|
|
||||||
'holidays' => '',
|
|
||||||
'min_days' => 4,
|
|
||||||
'enable' => true
|
|
||||||
);
|
|
||||||
}
|
|
||||||
if (is_array($cats_status))
|
|
||||||
{
|
|
||||||
$content['grid'] = array_replace_recursive($content['grid'], $cats_status);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
list($button) = @each($content['button']);
|
|
||||||
$categories = array ();
|
|
||||||
$users_map = $GLOBALS['egw']->accounts->search(array('type'=>'accounts', active=>true));
|
|
||||||
$users = array_keys($users_map);
|
|
||||||
$result = array();
|
|
||||||
|
|
||||||
// report button pressed
|
|
||||||
if (!empty($button))
|
|
||||||
{
|
|
||||||
// shift the grid content by one because of the reserved first row
|
|
||||||
// for the header.
|
|
||||||
array_shift($content['grid']);
|
|
||||||
Api\Framework::ajax_set_preference('calendar', 'holiday_report',$content['grid']);
|
|
||||||
|
|
||||||
foreach ($content['grid'] as $row)
|
|
||||||
{
|
|
||||||
if ($row['enable'])
|
|
||||||
{
|
|
||||||
$categories [] = $row['cat_id'];
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
$params = array(
|
|
||||||
'startdate' => $content['start'],
|
|
||||||
'enddate' => $content['end'],
|
|
||||||
'users' => $users,
|
|
||||||
'cat_id' => $categories
|
|
||||||
);
|
|
||||||
$events = $this->bo->search($params);
|
|
||||||
|
|
||||||
// iterate over found events
|
|
||||||
foreach($events as $event)
|
|
||||||
{
|
|
||||||
$cats = explode(',',$event['category']);
|
|
||||||
if (is_array($cats))
|
|
||||||
{
|
|
||||||
foreach($cats as $val)
|
|
||||||
{
|
|
||||||
if (in_array($val, $categories)) $cat_index = (int)$val;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$result [$event['owner']]['user_name'] = $users_map[$event['owner']]['account_lid'];
|
|
||||||
|
|
||||||
// number of days of event (in sec)
|
|
||||||
$days = $event['end'] - $event['start'];
|
|
||||||
|
|
||||||
if (isset($result[$event['owner']][$cat->id2name($cat_index)]))
|
|
||||||
{
|
|
||||||
$result[$event['owner']][$cat->id2name($cat_index)] =
|
|
||||||
$result[$event['owner']][$cat->id2name($cat_index)] + $days;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
$result[$event['owner']][$cat->id2name($cat_index)] = $days;
|
|
||||||
}
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
// calculates total days for each user based on cats
|
|
||||||
foreach ($result as &$record)
|
|
||||||
{
|
|
||||||
$total = 0;
|
|
||||||
foreach($record as $c => $value)
|
|
||||||
{
|
|
||||||
if ($c != 'user_name') $total += (int)$value;
|
|
||||||
}
|
|
||||||
$record ['total_days'] = $total;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Add an extra row for the grid header
|
|
||||||
array_unshift($content['grid'],array(''=> ''));
|
|
||||||
$preserv = $content;
|
|
||||||
$this->tmpl->exec('calendar.calendar_holiday_report.index', $content, array(), array(), $preserv, 2);
|
|
||||||
}
|
|
||||||
}
|
|
@ -524,7 +524,9 @@ class calendar_ui
|
|||||||
);
|
);
|
||||||
$GLOBALS['egw']->framework->sidebox($appname,lang('Admin'),$file,'admin');
|
$GLOBALS['egw']->framework->sidebox($appname,lang('Admin'),$file,'admin');
|
||||||
}
|
}
|
||||||
display_sidebox('calendar', lang('Utilities'), array('Holiday report' => Egw::link('/index.php','menuaction=calendar.calendar_holiday_report.index&appname=calendar&ajax=true')));
|
display_sidebox('calendar', lang('Utilities'), array('Category report' => "javascript:egw_openWindowCentered2('".
|
||||||
|
Egw::link('/index.php',array('menuaction'=>'calendar.calendar_category_report.index','ajax'=>true),false).
|
||||||
|
"','_blank',870,610,'yes')" ));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -247,8 +247,8 @@ app.classes.calendar = (function(){ "use strict"; return AppJS.extend(
|
|||||||
this.filter_change();
|
this.filter_change();
|
||||||
},this),0);
|
},this),0);
|
||||||
break;
|
break;
|
||||||
case 'calendar.holiday_report':
|
case 'calendar.category_report':
|
||||||
this.holiday_report_init();
|
this.category_report_init();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -3746,12 +3746,12 @@ app.classes.calendar = (function(){ "use strict"; return AppJS.extend(
|
|||||||
* categories status.
|
* categories status.
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
holiday_report_init: function ()
|
category_report_init: function ()
|
||||||
{
|
{
|
||||||
var content = this.et2.getArrayMgr('content').data;
|
var content = this.et2.getArrayMgr('content').data;
|
||||||
for (var i=1;i<content.grid.length;i++)
|
for (var i=1;i<content.grid.length;i++)
|
||||||
{
|
{
|
||||||
if (content.grid[i] != null) this.holiday_report_enable({name:i+'', checked:content.grid[i]['enable']});
|
if (content.grid[i] != null) this.category_report_enable({name:i+'', checked:content.grid[i]['enable']});
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
@ -3761,7 +3761,7 @@ app.classes.calendar = (function(){ "use strict"; return AppJS.extend(
|
|||||||
* @param {type} _widget
|
* @param {type} _widget
|
||||||
* @returns {undefined}
|
* @returns {undefined}
|
||||||
*/
|
*/
|
||||||
holiday_report_enable: function (_widget)
|
category_report_enable: function (_widget)
|
||||||
{
|
{
|
||||||
var widgets = ['[user]','[weekend]','[holidays]','[min_days]'];
|
var widgets = ['[user]','[weekend]','[holidays]','[min_days]'];
|
||||||
var row_id = _widget.name.match(/\d+/);
|
var row_id = _widget.name.match(/\d+/);
|
||||||
|
@ -1495,4 +1495,4 @@ input#calendar-edit_location {padding-left: 0;}
|
|||||||
#calendar-edit_quantity.et2_textbox_ro {opacity:0.5;}
|
#calendar-edit_quantity.et2_textbox_ro {opacity:0.5;}
|
||||||
#calendar-edit_quantity, #calendar-edit_role {float:left;}
|
#calendar-edit_quantity, #calendar-edit_role {float:left;}
|
||||||
|
|
||||||
.holiday_report_cats {height:80%;overflow-y: auto;display:block;}
|
.category_report_cats {height:80%;overflow-y: auto;display:block;}
|
@ -10,11 +10,11 @@ Egroupware
|
|||||||
@version $Id$
|
@version $Id$
|
||||||
-->
|
-->
|
||||||
<overlay>
|
<overlay>
|
||||||
<template id="calendar.holiday_report" template="" lang="" group="0" version="16.2">
|
<template id="calendar.category_report" template="" lang="" group="0" version="16.2">
|
||||||
<hbox class="dialogHeader" height="28">
|
<hbox class="dialogHeader" height="28">
|
||||||
<description value="Holiday Report"/>
|
<description value="Category Report"/>
|
||||||
</hbox>
|
</hbox>
|
||||||
<grid width="100%" class="holiday_report_cats">
|
<grid width="100%" class="Category_report_cats">
|
||||||
<columns>
|
<columns>
|
||||||
<column width="10%"/>
|
<column width="10%"/>
|
||||||
<column width="90%"/>
|
<column width="90%"/>
|
||||||
@ -39,13 +39,17 @@ Egroupware
|
|||||||
<description align="center" statustext="Exclude weekend events from counting" value="Exclude Weekend"/>
|
<description align="center" statustext="Exclude weekend events from counting" value="Exclude Weekend"/>
|
||||||
<description align="center" statustext="Include holidays as counting days" value="Holidays"/>
|
<description align="center" statustext="Include holidays as counting days" value="Holidays"/>
|
||||||
<description align="center" statustext="Minimum days to count as a week" value="Min days"/>
|
<description align="center" statustext="Minimum days to count as a week" value="Min days"/>
|
||||||
|
<description align="center" statustext="Output unit" value="Output unit"/>
|
||||||
</row>
|
</row>
|
||||||
<row class="row">
|
<row class="row">
|
||||||
<checkbox id="${row}[enable]" onchange="app.calendar.holiday_report_enable"/>
|
<checkbox id="${row}[enable]" onchange="app.calendar.category_report_enable"/>
|
||||||
<taglist-cat id="${row}[cat_id]" readonly="true" width="500" class="select-cat"/>
|
<taglist-cat id="${row}[cat_id]" readonly="true" width="500" class="select-cat"/>
|
||||||
<checkbox align="center" id="${row}[weekend]"/>
|
<checkbox align="center" id="${row}[weekend]"/>
|
||||||
<checkbox align="center" id="${row}[holidays]"/>
|
<checkbox align="center" id="${row}[holidays]"/>
|
||||||
<textbox type="integer" align="center" id="${row}[min_days]"/>
|
<textbox type="integer" align="center" id="${row}[min_days]"/>
|
||||||
|
<menulist>
|
||||||
|
<menupopup align="center" id="${row}[unit]"/>
|
||||||
|
</menulist>
|
||||||
</row>
|
</row>
|
||||||
</rows>
|
</rows>
|
||||||
</grid>
|
</grid>
|
@ -1457,7 +1457,7 @@ input#calendar-edit_location {
|
|||||||
#calendar-edit_role {
|
#calendar-edit_role {
|
||||||
float: left;
|
float: left;
|
||||||
}
|
}
|
||||||
.holiday_report_cats {
|
.category_report_cats {
|
||||||
height: 80%;
|
height: 80%;
|
||||||
overflow-y: auto;
|
overflow-y: auto;
|
||||||
display: block;
|
display: block;
|
||||||
|
Loading…
Reference in New Issue
Block a user