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:
Nathan Gray 2015-12-16 22:54:00 +00:00
parent d67cbb39e7
commit db675f2fda
2 changed files with 82 additions and 33 deletions

View File

@ -468,7 +468,10 @@ 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) {
return this._drawRow(sort_key, label,events,this.options.start_date, this.options.end_date); 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);
}
} }
}, },
@ -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,51 +646,44 @@ 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)
{ {
label_index = i; // If there's no cat filter, only show the top level
break; if(!app.calendar.state.cat_id)
}
}
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; for(var j = 0; j < labels.length; j++)
{
if(labels[j].id == labels[i].main)
{
label_index = j;
break;
}
}
break; break;
} }
label_index = i;
break;
} }
} }
if(typeof rows[label_index] === 'undefined') if(typeof rows[label_index] === 'undefined')
{ {
rows[label_index] = []; rows[label_index] = [];
} }
rows[label_index].push(event); if(rows[label_index].indexOf(event) === -1)
{
rows[label_index].push(event);
}
} }
}, },
draw_row: function(sort_key, label, events) { draw_row: function(sort_key, label, events) {
return this._drawRow(sort_key, label,events,this.options.start_date, this.options.end_date); 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);
}
} }
} }
}, },
@ -781,9 +826,12 @@ 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
for(var extra in labels[key].data) if(row)
{ {
row.getDOMNode().dataset[extra] = labels[key].data[extra]; for(var extra in labels[key].data)
{
row.getDOMNode().dataset[extra] = labels[key].data[extra];
}
} }
} }

View File

@ -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']))