mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-20 12:58:46 +01:00
Planner view categories
- Use standard order (hierarchy / alphabetical) - Implement hidden rows preference - If no specific categories are chosen, group into top-level categories
This commit is contained in:
parent
d67cbb39e7
commit
db675f2fda
@ -468,8 +468,11 @@ var et2_calendar_planner = et2_valueWidget.extend([et2_IDetachedDOM, et2_IResize
|
|||||||
},
|
},
|
||||||
// Draw a single row
|
// Draw a single row
|
||||||
draw_row: function(sort_key, label, events) {
|
draw_row: function(sort_key, label, events) {
|
||||||
|
if(['user','both'].indexOf(egw.preference('planner_show_empty_rows','calendar')) !== -1 || events.length)
|
||||||
|
{
|
||||||
return this._drawRow(sort_key, label,events,this.options.start_date, this.options.end_date);
|
return this._drawRow(sort_key, label,events,this.options.start_date, this.options.end_date);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
// Group by month has one row for each month
|
// Group by month has one row for each month
|
||||||
@ -583,7 +586,56 @@ var et2_calendar_planner = et2_valueWidget.extend([et2_IDetachedDOM, et2_IResize
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
row_labels: function() {
|
row_labels: function() {
|
||||||
return [{id:'',label: egw.lang('none'), data: {}}];
|
var im = this.getInstanceManager();
|
||||||
|
var categories = et2_selectbox.cat_options({
|
||||||
|
_type:'select-cat',
|
||||||
|
getInstanceManager: function() {return im;}
|
||||||
|
},{application: 'calendar'});
|
||||||
|
|
||||||
|
var labels = [];
|
||||||
|
if(!app.calendar.state.cat_id)
|
||||||
|
{
|
||||||
|
labels.push({id:'',value:'',label: egw.lang('none'), data: {}});
|
||||||
|
labels = labels.concat(categories);
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
var cat_id = app.calendar.state.cat_id;
|
||||||
|
if(typeof cat_id == 'string')
|
||||||
|
{
|
||||||
|
cat_id = cat_id.split(',');
|
||||||
|
}
|
||||||
|
for(var i = 0; i < cat_id.length; i++)
|
||||||
|
{
|
||||||
|
// Find label for that category
|
||||||
|
for(var j = 0; j < categories.length; j++)
|
||||||
|
{
|
||||||
|
if(categories[j].value == cat_id[i])
|
||||||
|
{
|
||||||
|
categories[j].id = categories[j].value;
|
||||||
|
labels.push(categories[j]);
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// Get its children
|
||||||
|
labels = labels.concat(et2_selectbox.cat_options({
|
||||||
|
_type:'select-cat',
|
||||||
|
getInstanceManager: function() {return im;}
|
||||||
|
},{other:[,,,'calendar',cat_id[i]]}));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
for(var i = labels.length -1; i >= 0; i--)
|
||||||
|
{
|
||||||
|
labels[i].id = labels[i].value;
|
||||||
|
if(!app.calendar.state.cat_id && labels[i].id != labels[i].main)
|
||||||
|
{
|
||||||
|
labels.splice(i,1);
|
||||||
|
continue;
|
||||||
|
}
|
||||||
|
labels[i].data = {cat_id: labels[i].id};
|
||||||
|
}
|
||||||
|
return labels;
|
||||||
},
|
},
|
||||||
group: function(labels, rows, event) {
|
group: function(labels, rows, event) {
|
||||||
var cats = event.category;
|
var cats = event.category;
|
||||||
@ -594,53 +646,46 @@ var et2_calendar_planner = et2_valueWidget.extend([et2_IDetachedDOM, et2_IResize
|
|||||||
for(var cat = 0; cat < cats.length; cat++)
|
for(var cat = 0; cat < cats.length; cat++)
|
||||||
{
|
{
|
||||||
var label_index = false;
|
var label_index = false;
|
||||||
var category = cats[cat];
|
var category = cats[cat] ? parseInt(cats[cat],10) : false;
|
||||||
if(category == '0' || !category) category = '';
|
if(category == 0 || !category) category = '';
|
||||||
for(var i = 0; i < labels.length; i++)
|
for(var i = 0; i < labels.length; i++)
|
||||||
{
|
{
|
||||||
if(labels[i].id == category)
|
if(labels[i].id == category)
|
||||||
{
|
{
|
||||||
|
// If there's no cat filter, only show the top level
|
||||||
|
if(!app.calendar.state.cat_id)
|
||||||
|
{
|
||||||
|
for(var j = 0; j < labels.length; j++)
|
||||||
|
{
|
||||||
|
if(labels[j].id == labels[i].main)
|
||||||
|
{
|
||||||
|
label_index = j;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
break;
|
||||||
|
}
|
||||||
label_index = i;
|
label_index = i;
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
if(label_index === false)
|
|
||||||
{
|
|
||||||
label_index = labels.length;
|
|
||||||
labels.push({id: category, label: '', data: {cat_id:category}});
|
|
||||||
var im = this.getInstanceManager();
|
|
||||||
// Fake it to use the cache / call
|
|
||||||
var categories = et2_selectbox.cat_options({
|
|
||||||
_type:'select-cat',
|
|
||||||
getInstanceManager: function() {return im;}
|
|
||||||
}, {application:event.app||'calendar'});
|
|
||||||
if(categories && !categories.length)
|
|
||||||
{
|
|
||||||
// Categories not loaded. They've started, but it's too late now
|
|
||||||
// Try again once they're all loaded
|
|
||||||
this.invalidate();
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
for(var i in categories )
|
|
||||||
{
|
|
||||||
if(parseInt(categories[i].value) === parseInt(category))
|
|
||||||
{
|
|
||||||
labels[labels.length-1].label = categories[i].label;
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if(typeof rows[label_index] === 'undefined')
|
if(typeof rows[label_index] === 'undefined')
|
||||||
{
|
{
|
||||||
rows[label_index] = [];
|
rows[label_index] = [];
|
||||||
}
|
}
|
||||||
|
if(rows[label_index].indexOf(event) === -1)
|
||||||
|
{
|
||||||
rows[label_index].push(event);
|
rows[label_index].push(event);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
draw_row: function(sort_key, label, events) {
|
draw_row: function(sort_key, label, events) {
|
||||||
|
if(['cat','both'].indexOf(egw.preference('planner_show_empty_rows','calendar')) !== -1 || events.length)
|
||||||
|
{
|
||||||
return this._drawRow(sort_key, label,events,this.options.start_date, this.options.end_date);
|
return this._drawRow(sort_key, label,events,this.options.start_date, this.options.end_date);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -781,11 +826,14 @@ var et2_calendar_planner = et2_valueWidget.extend([et2_IDetachedDOM, et2_IResize
|
|||||||
var row = grouper.draw_row.call(this,labels[key].id, labels[key].label, events[key] || []);
|
var row = grouper.draw_row.call(this,labels[key].id, labels[key].label, events[key] || []);
|
||||||
|
|
||||||
// Add extra data for clicking on row
|
// Add extra data for clicking on row
|
||||||
|
if(row)
|
||||||
|
{
|
||||||
for(var extra in labels[key].data)
|
for(var extra in labels[key].data)
|
||||||
{
|
{
|
||||||
row.getDOMNode().dataset[extra] = labels[key].data[extra];
|
row.getDOMNode().dataset[extra] = labels[key].data[extra];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Adjust header if there's a scrollbar
|
// Adjust header if there's a scrollbar
|
||||||
this.gridHeader.css('margin-right', (this.rows.width() - this.rows.children().first().width()) + 'px')
|
this.gridHeader.css('margin-right', (this.rows.width() - this.rows.children().first().width()) + 'px')
|
||||||
|
@ -570,6 +570,7 @@ class etemplate_widget_menupopup extends etemplate_widget
|
|||||||
$options[$cat['id']] = array(
|
$options[$cat['id']] = array(
|
||||||
'label' => $s,
|
'label' => $s,
|
||||||
'title' => $cat['description'],
|
'title' => $cat['description'],
|
||||||
|
'main' => (int)$cat['main']
|
||||||
);
|
);
|
||||||
// Send data too
|
// Send data too
|
||||||
if(is_array($cat['data']))
|
if(is_array($cat['data']))
|
||||||
|
Loading…
Reference in New Issue
Block a user