mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-15 02:19:39 +01:00
A better way to make keywords only apply to list view, not the other views.
This commit is contained in:
parent
6a8b5bc629
commit
9252607705
@ -1587,6 +1587,19 @@ app.classes.calendar = AppJS.extend(
|
|||||||
// it will work for other users too.
|
// it will work for other users too.
|
||||||
state.owner = 0;
|
state.owner = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// Keywords are only for list view
|
||||||
|
if(state.view == 'listview')
|
||||||
|
{
|
||||||
|
var listview = app.classes.calendar.views.listview.etemplates[0] &&
|
||||||
|
app.classes.calendar.views.listview.etemplates[0].widgetContainer &&
|
||||||
|
app.classes.calendar.views.listview.etemplates[0].widgetContainer.getWidgetById('nm');
|
||||||
|
if(listview && listview.activeFilters && listview.activeFilters.search)
|
||||||
|
{
|
||||||
|
state.keywords = listview.activeFilters.search;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Don't store date or first and last
|
// Don't store date or first and last
|
||||||
delete state.date;
|
delete state.date;
|
||||||
delete state.first;
|
delete state.first;
|
||||||
@ -1899,7 +1912,6 @@ app.classes.calendar = AppJS.extend(
|
|||||||
{
|
{
|
||||||
view.etemplates[i].resize();
|
view.etemplates[i].resize();
|
||||||
}
|
}
|
||||||
this.state = jQuery.extend({},state.state);
|
|
||||||
|
|
||||||
// List view (nextmatch) has slightly different fields
|
// List view (nextmatch) has slightly different fields
|
||||||
if(state.state.view === 'listview')
|
if(state.state.view === 'listview')
|
||||||
@ -1957,6 +1969,8 @@ app.classes.calendar = AppJS.extend(
|
|||||||
nm.controller._grid.doInvalidate = false;
|
nm.controller._grid.doInvalidate = false;
|
||||||
} catch (e) {}
|
} catch (e) {}
|
||||||
}
|
}
|
||||||
|
delete state.state.keywords;
|
||||||
|
this.state = jQuery.extend({},state.state);
|
||||||
|
|
||||||
/* Update re-orderable calendars */
|
/* Update re-orderable calendars */
|
||||||
this._sortable();
|
this._sortable();
|
||||||
@ -1984,6 +1998,10 @@ app.classes.calendar = AppJS.extend(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else if (widget.id == 'keywords')
|
||||||
|
{
|
||||||
|
widget.set_value('');
|
||||||
|
}
|
||||||
else if(typeof state.state[widget.id] !== 'undefined' && state.state[widget.id] != widget.getValue())
|
else if(typeof state.state[widget.id] !== 'undefined' && state.state[widget.id] != widget.getValue())
|
||||||
{
|
{
|
||||||
// Update widget. This may trigger an infinite loop of
|
// Update widget. This may trigger an infinite loop of
|
||||||
@ -2358,7 +2376,6 @@ app.classes.calendar = AppJS.extend(
|
|||||||
filter:'custom', // Must be custom to get start & end dates
|
filter:'custom', // Must be custom to get start & end dates
|
||||||
status_filter: state.filter,
|
status_filter: state.filter,
|
||||||
cat_id: cat_id,
|
cat_id: cat_id,
|
||||||
search: state.keywords,
|
|
||||||
csv_export: false
|
csv_export: false
|
||||||
});
|
});
|
||||||
// Show ajax loader
|
// Show ajax loader
|
||||||
@ -2695,70 +2712,6 @@ app.classes.calendar = AppJS.extend(
|
|||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
|
||||||
/**
|
|
||||||
* Initializes actions and handlers on sidebox (delete)
|
|
||||||
* Extended from parent to automatically add change handlers for resource
|
|
||||||
* menu items.
|
|
||||||
*
|
|
||||||
* @param {jQuery} sidebox jQuery of DOM node
|
|
||||||
*/
|
|
||||||
_init_sidebox: function(sidebox)
|
|
||||||
{
|
|
||||||
if( this._super.apply(this, arguments) )
|
|
||||||
{
|
|
||||||
sidebox.parentsUntil('#calendar_sidebox_content')
|
|
||||||
.find('.egw_fw_ui_category_content').not(sidebox.parent())
|
|
||||||
.on('change.sidebox', 'select:not(.et2_selectbox),input[type!="checkbox"]', this, function(event) {
|
|
||||||
var state = {};
|
|
||||||
var name = this.name.replace('[]','');
|
|
||||||
var value = $j(this).val();
|
|
||||||
|
|
||||||
// Handle special value like r0, which removes all r
|
|
||||||
if(typeof value == 'string' && parseInt(value.substring(1)==0) ||
|
|
||||||
value[0] && typeof value[0] == 'string' && parseInt(value[0].substring(1))==0)
|
|
||||||
{
|
|
||||||
value = typeof value == 'string' ? value : value[0];
|
|
||||||
var type = value.substring(0,1);
|
|
||||||
state[name] = [];
|
|
||||||
for(var key in app.calendar.state[name])
|
|
||||||
{
|
|
||||||
var cur_item = app.calendar.state[name][key];
|
|
||||||
if(cur_item && (cur_item+'').substring(0,1) != type)
|
|
||||||
{
|
|
||||||
state[name].push(cur_item);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
$j('option', this).removeAttr('selected');
|
|
||||||
return app.calendar.update_state(state);
|
|
||||||
}
|
|
||||||
// Here we look for things like owner: ['r1,r2'] and change them
|
|
||||||
// to owner: ['r1','r2']
|
|
||||||
state[name] = value;
|
|
||||||
for(var key in state)
|
|
||||||
{
|
|
||||||
if(state[key] && typeof state[key].length !== 'undefined')
|
|
||||||
{
|
|
||||||
for(var sub_key in state[key])
|
|
||||||
{
|
|
||||||
if(typeof state[key][sub_key] == 'string' && state[key][sub_key].indexOf(',') !== -1)
|
|
||||||
{
|
|
||||||
var explode_me = state[key][sub_key];
|
|
||||||
delete state[key][sub_key];
|
|
||||||
jQuery.extend(state[key], explode_me.split(','));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
// Add to, not replace, current value
|
|
||||||
if(typeof state[key] == 'object' && typeof app.calendar.state[key] == 'object')
|
|
||||||
{
|
|
||||||
jQuery.merge(state[key],app.calendar.state[key]);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
app.calendar.update_state(state);
|
|
||||||
});
|
|
||||||
}
|
|
||||||
},
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* The sidebox filters use some non-standard and not-exposed options. They
|
* The sidebox filters use some non-standard and not-exposed options. They
|
||||||
* are set up here.
|
* are set up here.
|
||||||
|
@ -38,7 +38,7 @@ Egroupware
|
|||||||
</rows>
|
</rows>
|
||||||
</grid>
|
</grid>
|
||||||
<select id="view" class="et2_fullWidth" onchange="app.calendar.update_state(JSON.parse(widget.getValue()));"/>
|
<select id="view" class="et2_fullWidth" onchange="app.calendar.update_state(JSON.parse(widget.getValue()));"/>
|
||||||
<textbox id="keywords" class="et2_fullWidth" blur="Search" onchange="app.calendar.update_state({view: 'listview',keywords: widget.getValue()});window.setTimeout(function() {widget.set_value('');},100);return false;"/>
|
<textbox id="keywords" class="et2_fullWidth" blur="Search" onchange="app.calendar.update_state({view: 'listview',keywords: widget.getValue()});return false;"/>
|
||||||
<hbox id="date_header" class="et2_fullWidth">
|
<hbox id="date_header" class="et2_fullWidth">
|
||||||
<buttononly id="header_today" label="Today" onclick="var tempDate = new Date();
|
<buttononly id="header_today" label="Today" onclick="var tempDate = new Date();
|
||||||
var today = new Date(tempDate.getFullYear(), tempDate.getMonth(), tempDate.getDate(),0,-tempDate.getTimezoneOffset(),0);
|
var today = new Date(tempDate.getFullYear(), tempDate.getMonth(), tempDate.getDate(),0,-tempDate.getTimezoneOffset(),0);
|
||||||
|
Loading…
Reference in New Issue
Block a user