mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-13 17:38:19 +01:00
Fix insert into document from sidebox dropdown
This commit is contained in:
parent
7ccbdfe871
commit
cdc3ad9a10
@ -267,7 +267,6 @@ class calendar_ui
|
|||||||
// retrieve saved states from prefs
|
// retrieve saved states from prefs
|
||||||
if(!$states)
|
if(!$states)
|
||||||
{
|
{
|
||||||
error_log('HERE');
|
|
||||||
$states = unserialize($this->bo->cal_prefs['saved_states']);
|
$states = unserialize($this->bo->cal_prefs['saved_states']);
|
||||||
error_log(array2string($states));
|
error_log(array2string($states));
|
||||||
}
|
}
|
||||||
@ -605,6 +604,8 @@ class calendar_ui
|
|||||||
$menu_title = lang('Calendar Menu');
|
$menu_title = lang('Calendar Menu');
|
||||||
display_sidebox($appname,$menu_title,$file);
|
display_sidebox($appname,$menu_title,$file);
|
||||||
|
|
||||||
|
$this->sidebox_etemplate();
|
||||||
|
|
||||||
// resources menu hooks
|
// resources menu hooks
|
||||||
foreach ($this->bo->resources as $resource)
|
foreach ($this->bo->resources as $resource)
|
||||||
{
|
{
|
||||||
@ -636,6 +637,16 @@ class calendar_ui
|
|||||||
{
|
{
|
||||||
if($content['merge'])
|
if($content['merge'])
|
||||||
{
|
{
|
||||||
|
// View from sidebox is JSON encoded
|
||||||
|
$this->manage_states(array_merge($content,json_decode($content['view'],true)));
|
||||||
|
if($content['first'])
|
||||||
|
{
|
||||||
|
$this->first = egw_time::to($content['first'],'ts');
|
||||||
|
}
|
||||||
|
if($content['last'])
|
||||||
|
{
|
||||||
|
$this->last = egw_time::to($content['last'],'ts');
|
||||||
|
}
|
||||||
$_GET['merge'] = $content['merge'];
|
$_GET['merge'] = $content['merge'];
|
||||||
$this->merge();
|
$this->merge();
|
||||||
return;
|
return;
|
||||||
|
@ -218,17 +218,20 @@ class calendar_uiviews extends calendar_ui
|
|||||||
// handle views in other files
|
// handle views in other files
|
||||||
if (!isset($this->public_functions[$this->view]) && $this->view !== 'listview')
|
if (!isset($this->public_functions[$this->view]) && $this->view !== 'listview')
|
||||||
{
|
{
|
||||||
$GLOBALS['egw']->redirect_link('/index.php',array('menuaction'=>$this->view_menuaction,'ajax'=>'true'),'calendar');
|
$this->view = 'week';
|
||||||
}
|
}
|
||||||
// get manual to load the right page
|
// get manual to load the right page
|
||||||
$GLOBALS['egw_info']['flags']['params']['manual'] = array('page' => 'ManualCalendar'.ucfirst($this->view));
|
$GLOBALS['egw_info']['flags']['params']['manual'] = array('page' => 'ManualCalendar'.ucfirst($this->view));
|
||||||
|
|
||||||
// Sidebox & iframe for old views
|
// Sidebox & iframe for old views
|
||||||
if(in_array($this->view,array('year','planner')))
|
if(in_array($this->view,array('year','planner')) && $_GET['view'])
|
||||||
{
|
{
|
||||||
|
$GLOBALS['egw_info']['flags']['nonavbar'] = true;
|
||||||
|
$this->manage_states($_GET);
|
||||||
$old_calendar = $this->{$this->view}();
|
$old_calendar = $this->{$this->view}();
|
||||||
|
echo $old_calendar;
|
||||||
|
return;
|
||||||
}
|
}
|
||||||
$this->sidebox_etemplate(array('old_calendar' => $old_calendar));
|
|
||||||
|
|
||||||
// Load the different views once, we'll switch between them on the client side
|
// Load the different views once, we'll switch between them on the client side
|
||||||
$tmpl = new etemplate_new('calendar.todo');
|
$tmpl = new etemplate_new('calendar.todo');
|
||||||
|
@ -151,11 +151,10 @@ app.classes.calendar = AppJS.extend(
|
|||||||
init: function()
|
init: function()
|
||||||
{
|
{
|
||||||
// make calendar object available, even if not running in top window, as sidebox does
|
// make calendar object available, even if not running in top window, as sidebox does
|
||||||
if (window.top !== window && !egw(window).is_popup())
|
if (window.top !== window && !egw(window).is_popup() && window.top.app.calendar)
|
||||||
{
|
{
|
||||||
// we have to explicitly delete old object or IE11 complains about accessing an already freed script
|
window.app.calendar = window.top.app.calendar;
|
||||||
delete window.top.app.calendar;
|
return;
|
||||||
window.top.app.calendar = this;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
// call parent
|
// call parent
|
||||||
@ -368,6 +367,17 @@ app.classes.calendar = AppJS.extend(
|
|||||||
{
|
{
|
||||||
return _url.replace(/menuaction=[^&]+/, 'menuaction=calendar.calendar_uilist.listview&ajax=true');
|
return _url.replace(/menuaction=[^&]+/, 'menuaction=calendar.calendar_uilist.listview&ajax=true');
|
||||||
}
|
}
|
||||||
|
else if (this.sidebox_et2 && typeof this.views[state.view] == 'undefined')
|
||||||
|
{
|
||||||
|
this.sidebox_et2.getWidgetById('iframe').set_src(_url);
|
||||||
|
this.sidebox
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else if (_url.indexOf('menuaction=calendar.calendar_uiviews') >= 0)
|
||||||
|
{
|
||||||
|
this.sidebox_et2.getWidgetById('iframe').set_src(_url);
|
||||||
|
return true;
|
||||||
}
|
}
|
||||||
// can not load our own index page, has to be done by framework
|
// can not load our own index page, has to be done by framework
|
||||||
return false;
|
return false;
|
||||||
@ -1237,6 +1247,11 @@ app.classes.calendar = AppJS.extend(
|
|||||||
*/
|
*/
|
||||||
update_state: function(_set)
|
update_state: function(_set)
|
||||||
{
|
{
|
||||||
|
// Make sure we're running in top window
|
||||||
|
if(window !== window.top)
|
||||||
|
{
|
||||||
|
return window.top.app.calendar.update_state(_set);
|
||||||
|
}
|
||||||
var changed = [];
|
var changed = [];
|
||||||
var new_state = jQuery.extend({}, this.state);
|
var new_state = jQuery.extend({}, this.state);
|
||||||
if (typeof _set == 'object')
|
if (typeof _set == 'object')
|
||||||
@ -1276,11 +1291,6 @@ app.classes.calendar = AppJS.extend(
|
|||||||
state = egw_script_tag.getAttribute('data-calendar-state');
|
state = egw_script_tag.getAttribute('data-calendar-state');
|
||||||
state = state ? JSON.parse(state) : {};
|
state = state ? JSON.parse(state) : {};
|
||||||
}
|
}
|
||||||
// we are currently in list-view
|
|
||||||
if (this.et2 && this.et2.getWidgetById('nm'))
|
|
||||||
{
|
|
||||||
jQuery.extend(state, this._super.apply(this, arguments)); // call default implementation
|
|
||||||
}
|
|
||||||
|
|
||||||
// Don't store current user in state to allow admins to create favourites for all
|
// Don't store current user in state to allow admins to create favourites for all
|
||||||
// Should make no difference for normal users.
|
// Should make no difference for normal users.
|
||||||
@ -1318,9 +1328,26 @@ app.classes.calendar = AppJS.extend(
|
|||||||
{
|
{
|
||||||
state.state.date = new Date();
|
state.state.date = new Date();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
// Hide other views
|
||||||
|
for(var _view in this.views)
|
||||||
|
{
|
||||||
|
if(state.state.view != _view && this.views[_view])
|
||||||
|
{
|
||||||
|
for(var i = 0; i < this.views[_view].etemplates.length; i++)
|
||||||
|
{
|
||||||
|
$j(this.views[_view].etemplates[i].DOMContainer).hide();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$j(this.sidebox_et2.getInstanceManager().DOMContainer).hide();
|
||||||
|
|
||||||
// Check for a supported client-side view
|
// Check for a supported client-side view
|
||||||
if(this.views[state.state.view])
|
if(this.views[state.state.view] &&
|
||||||
|
// Check that the view is instanciated
|
||||||
|
typeof this.views[state.state.view].etemplates[0] !== 'string' && this.views[state.state.view].etemplates[0].widgetContainer
|
||||||
|
)
|
||||||
{
|
{
|
||||||
// Doing an update - this includes the selected view, and the sidebox
|
// Doing an update - this includes the selected view, and the sidebox
|
||||||
// We set a flag to ignore changes from the sidebox which would
|
// We set a flag to ignore changes from the sidebox which would
|
||||||
@ -1378,13 +1405,13 @@ app.classes.calendar = AppJS.extend(
|
|||||||
{
|
{
|
||||||
// Need to redo the number of grids
|
// Need to redo the number of grids
|
||||||
var value = [];
|
var value = [];
|
||||||
var date = view.set_start_date(state.state);
|
var date = state.state.first = view.set_start_date(state.state);
|
||||||
|
|
||||||
// Determine the different end date
|
// Determine the different end date
|
||||||
switch(state.state.view)
|
switch(state.state.view)
|
||||||
{
|
{
|
||||||
case 'month':
|
case 'month':
|
||||||
var end = view.set_end_date(state.state);
|
var end = state.state.last = view.set_end_date(state.state);
|
||||||
grid_count = Math.ceil((end - date) / (1000 * 60 * 60 * 24) / 7);
|
grid_count = Math.ceil((end - date) / (1000 * 60 * 60 * 24) / 7);
|
||||||
// fall through
|
// fall through
|
||||||
case 'weekN':
|
case 'weekN':
|
||||||
@ -1400,9 +1427,10 @@ app.classes.calendar = AppJS.extend(
|
|||||||
value.push(val);
|
value.push(val);
|
||||||
date.setUTCHours(24*7);
|
date.setUTCHours(24*7);
|
||||||
}
|
}
|
||||||
|
state.state.last=val.end_date;
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
var end = view.set_end_date(state.state);
|
var end = state.state.last = view.set_end_date(state.state);
|
||||||
for(var owner = 0; owner < grid_count && owner < state.state.owner.length; owner++)
|
for(var owner = 0; owner < grid_count && owner < state.state.owner.length; owner++)
|
||||||
{
|
{
|
||||||
value.push({
|
value.push({
|
||||||
@ -1430,6 +1458,8 @@ app.classes.calendar = AppJS.extend(
|
|||||||
if(typeof view[updater] === 'function')
|
if(typeof view[updater] === 'function')
|
||||||
{
|
{
|
||||||
var value = view[updater].call(this,state.state);
|
var value = view[updater].call(this,state.state);
|
||||||
|
if(updater === 'set_start_date') state.state.first = value.toJSON();
|
||||||
|
if(updater === 'set_end_date') state.state.last = value.toJSON();
|
||||||
|
|
||||||
// Set value
|
// Set value
|
||||||
for(var i = 0; i < view.etemplates.length; i++)
|
for(var i = 0; i < view.etemplates.length; i++)
|
||||||
@ -1444,19 +1474,9 @@ app.classes.calendar = AppJS.extend(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
// Include first & last dates in state, mostly for server side processing
|
||||||
|
if(state.state.first && state.state.first.toJSON) state.state.first = state.state.first.toJSON()
|
||||||
// Hide other views
|
if(state.state.last && state.state.last.toJSON) state.state.last = state.state.last.toJSON()
|
||||||
for(var _view in this.views)
|
|
||||||
{
|
|
||||||
if(state.state.view != _view && this.views[_view])
|
|
||||||
{
|
|
||||||
for(var i = 0; i < this.views[_view].etemplates.length; i++)
|
|
||||||
{
|
|
||||||
$j(this.views[_view].etemplates[i].DOMContainer).hide();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
// Show the templates for the current view
|
// Show the templates for the current view
|
||||||
for(var i = 0; i < view.etemplates.length; i++)
|
for(var i = 0; i < view.etemplates.length; i++)
|
||||||
@ -1605,7 +1625,8 @@ app.classes.calendar = AppJS.extend(
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
// setting internal state now, that linkHandler does not intercept switching from listview to any old view
|
// setting internal state now, that linkHandler does not intercept switching from listview to any old view
|
||||||
this.state = state;
|
this.state = jQuery.extend({},state.state);
|
||||||
|
$j(this.sidebox_et2.getInstanceManager().DOMContainer).show();
|
||||||
|
|
||||||
var query = jQuery.extend({menuaction: menuaction},state.state||{});
|
var query = jQuery.extend({menuaction: menuaction},state.state||{});
|
||||||
|
|
||||||
|
@ -31,7 +31,7 @@ Egroupware
|
|||||||
<buttononly align="center" class="sideboxstar" id="week" image="week" label="Weekview" onclick="app.calendar.update_state({view:'week'});"/>
|
<buttononly align="center" class="sideboxstar" id="week" image="week" label="Weekview" onclick="app.calendar.update_state({view:'week'});"/>
|
||||||
<buttononly align="center" class="sideboxstar" id="weekN" image="multiweek" label="Multiple week view" onclick="app.calendar.update_state({view:'weekN'});"/>
|
<buttononly align="center" class="sideboxstar" id="weekN" image="multiweek" label="Multiple week view" onclick="app.calendar.update_state({view:'weekN'});"/>
|
||||||
<buttononly align="center" class="sideboxstar" id="month" image="month" label="Multiple week view" onclick="app.calendar.update_state({view:'month'});"/>
|
<buttononly align="center" class="sideboxstar" id="month" image="month" label="Multiple week view" onclick="app.calendar.update_state({view:'month'});"/>
|
||||||
<buttononly align="center" class="sideboxstar" id="planner" image="planner" label="Group planner"/>
|
<buttononly align="center" class="sideboxstar" id="planner" image="planner" label="Group planner" onclick="app.calendar.update_state({view:'planner'});"/>
|
||||||
<buttononly align="center" class="sideboxstar" id="listview" image="list" label="Listview" onclick="app.calendar.update_state({view:'listview'});"/>
|
<buttononly align="center" class="sideboxstar" id="listview" image="list" label="Listview" onclick="app.calendar.update_state({view:'listview'});"/>
|
||||||
</row>
|
</row>
|
||||||
</rows>
|
</rows>
|
||||||
@ -39,6 +39,8 @@ Egroupware
|
|||||||
<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" onchange="app.calendar.update_state({keywords: widget.getValue()});"/>
|
<textbox id="keywords" class="et2_fullWidth" onchange="app.calendar.update_state({keywords: widget.getValue()});"/>
|
||||||
<date id="date" class="et2_fullWidth" inline="true" onchange="app.calendar.update_state({date:widget.getValue(),view:'day'});"/>
|
<date id="date" class="et2_fullWidth" inline="true" onchange="app.calendar.update_state({date:widget.getValue(),view:'day'});"/>
|
||||||
|
<textbox type="hidden" id="first"/>
|
||||||
|
<textbox type="hidden" id="last"/>
|
||||||
<hbox width="100%">
|
<hbox width="100%">
|
||||||
<select-cat id="cat_id" empty_label="All categories" width="86%" onchange="app.calendar.update_state({cat_id: widget.getValue()});"/>
|
<select-cat id="cat_id" empty_label="All categories" width="86%" onchange="app.calendar.update_state({cat_id: widget.getValue()});"/>
|
||||||
<button align="right" id="cat_id_multiple" image="category"/>
|
<button align="right" id="cat_id_multiple" image="category"/>
|
||||||
@ -50,8 +52,8 @@ Egroupware
|
|||||||
<taglist id="owner" class="et2_fullWidth" onchange="app.calendar.update_state({owner: widget.getValue()});" autocomplete_params=''/>
|
<taglist id="owner" class="et2_fullWidth" onchange="app.calendar.update_state({owner: widget.getValue()});" autocomplete_params=''/>
|
||||||
-->
|
-->
|
||||||
<select id="filter" no_lang="true" class="et2_fullWidth" onchange="app.calendar.update_state({filter: widget.getValue()});"/>
|
<select id="filter" no_lang="true" class="et2_fullWidth" onchange="app.calendar.update_state({filter: widget.getValue()});"/>
|
||||||
<select id="merge" empty_label="Insert in document" onchange="widget.getInstanceManager().postSubmit();widget.set_value('');" class="et2_fullWidth"/>/>
|
<select id="merge" empty_label="Insert in document" onchange="if(widget.getValue()) {widget.getInstanceManager().postSubmit();}window.setTimeout(function() {widget.set_value('');},100);return false;" class="et2_fullWidth"/>/>
|
||||||
</vbox>
|
</vbox>
|
||||||
<html id="old_calendar"/>
|
<iframe id="iframe" width="100%" height="100%"/>
|
||||||
</template>
|
</template>
|
||||||
</overlay>
|
</overlay>
|
||||||
|
Loading…
Reference in New Issue
Block a user