mirror of
https://github.com/EGroupware/egroupware.git
synced 2025-01-24 06:49:16 +01:00
* Calendar - Quick add dialog for new events
This commit is contained in:
parent
7debe27ada
commit
5e9cace2bc
@ -45,6 +45,7 @@ class calendar_hooks
|
|||||||
),
|
),
|
||||||
'add' => array(
|
'add' => array(
|
||||||
'menuaction' => 'calendar.calendar_uiforms.edit',
|
'menuaction' => 'calendar.calendar_uiforms.edit',
|
||||||
|
'template' => 'calendar.add'
|
||||||
),
|
),
|
||||||
'add_app' => 'link_app',
|
'add_app' => 'link_app',
|
||||||
'add_id' => 'link_id',
|
'add_id' => 'link_id',
|
||||||
@ -243,6 +244,14 @@ class calendar_hooks
|
|||||||
'admin' => False,
|
'admin' => False,
|
||||||
'default'=> '1', // 1 = week
|
'default'=> '1', // 1 = week
|
||||||
),*/
|
),*/
|
||||||
|
'new_event_dialog' => array(
|
||||||
|
'type' => 'select',
|
||||||
|
'label' => 'New event dialog',
|
||||||
|
'name' => 'new_event_dialog',
|
||||||
|
'values'=> array('add' => lang('Quick add'), 'edit' => lang('Regular edit')),
|
||||||
|
'help' => 'Use quick add or full edit dialog when creating a new event',
|
||||||
|
'default' => 'add',
|
||||||
|
),
|
||||||
'multiple_weeks' => array(
|
'multiple_weeks' => array(
|
||||||
'type' => 'select',
|
'type' => 'select',
|
||||||
'label' => 'Weeks in multiple week view',
|
'label' => 'Weeks in multiple week view',
|
||||||
@ -354,6 +363,16 @@ class calendar_hooks
|
|||||||
'xmlrpc' => False,
|
'xmlrpc' => False,
|
||||||
'admin' => False
|
'admin' => False
|
||||||
),
|
),
|
||||||
|
'default_category' => array(
|
||||||
|
'type' => 'multiselect',
|
||||||
|
'label' => 'New event category',
|
||||||
|
'name' => 'default_category',
|
||||||
|
'help' => 'Category automatically added to new events',
|
||||||
|
'values' => Api\Etemplate\Widget\Select::typeOptions('select-cat', ',,,calendar'),
|
||||||
|
'default' => '',
|
||||||
|
'xmlrpc' => False,
|
||||||
|
'admin' => False
|
||||||
|
),
|
||||||
'default-alarm' => array(
|
'default-alarm' => array(
|
||||||
'type' => 'date-duration',//'select',
|
'type' => 'date-duration',//'select',
|
||||||
'label' => lang('Default alarm for regular events').' ('.lang('empty = no alarm').')',
|
'label' => lang('Default alarm for regular events').' ('.lang('empty = no alarm').')',
|
||||||
|
@ -208,6 +208,10 @@ class calendar_uiforms extends calendar_ui
|
|||||||
$cat = (int)$cat;
|
$cat = (int)$cat;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
$cat_id = $this->cal_prefs['default_category'];
|
||||||
|
}
|
||||||
$duration = isset($_GET['duration']) ? (int)$_GET['duration'] : (int) $this->bo->cal_prefs['defaultlength']*60;
|
$duration = isset($_GET['duration']) ? (int)$_GET['duration'] : (int) $this->bo->cal_prefs['defaultlength']*60;
|
||||||
if(isset($_GET['end']))
|
if(isset($_GET['end']))
|
||||||
{
|
{
|
||||||
@ -635,6 +639,11 @@ class calendar_uiforms extends calendar_ui
|
|||||||
case 'exception': // create an exception in a recuring event
|
case 'exception': // create an exception in a recuring event
|
||||||
$msg = $this->_create_exception($event,$preserv);
|
$msg = $this->_create_exception($event,$preserv);
|
||||||
break;
|
break;
|
||||||
|
case 'edit':
|
||||||
|
// Going from add dialog to full edit dialog
|
||||||
|
unset($preserv['template']);
|
||||||
|
unset($event['template']);
|
||||||
|
break;
|
||||||
|
|
||||||
case 'copy': // create new event with copied content, some content need to be unset to make a "new" event
|
case 'copy': // create new event with copied content, some content need to be unset to make a "new" event
|
||||||
unset($event['id']);
|
unset($event['id']);
|
||||||
@ -1478,6 +1487,12 @@ class calendar_uiforms extends calendar_ui
|
|||||||
'no_popup' => isset($_GET['no_popup']),
|
'no_popup' => isset($_GET['no_popup']),
|
||||||
'template' => isset($_GET['template']) ? $_GET['template'] : (isset($_REQUEST['print']) ? 'calendar.print' : 'calendar.edit'),
|
'template' => isset($_GET['template']) ? $_GET['template'] : (isset($_REQUEST['print']) ? 'calendar.print' : 'calendar.edit'),
|
||||||
);
|
);
|
||||||
|
if($preserv['template'] && ($registry = Link::get_registry('calendar', 'add')) && $registry['template'] == $preserv['template'] &&
|
||||||
|
$this->cal_prefs['new_event_dialog'] == 'edit')
|
||||||
|
{
|
||||||
|
// User wants full thing
|
||||||
|
unset($preserv['template']);
|
||||||
|
}
|
||||||
$cal_id = (int) $_GET['cal_id'];
|
$cal_id = (int) $_GET['cal_id'];
|
||||||
if($_GET['action'])
|
if($_GET['action'])
|
||||||
{
|
{
|
||||||
|
@ -215,6 +215,7 @@ app.classes.calendar = (function(){ "use strict"; return AppJS.extend(
|
|||||||
this.state = content.data;
|
this.state = content.data;
|
||||||
break;
|
break;
|
||||||
|
|
||||||
|
case 'calendar.add':
|
||||||
case 'calendar.edit':
|
case 'calendar.edit':
|
||||||
if (typeof content.data['conflicts'] == 'undefined')
|
if (typeof content.data['conflicts'] == 'undefined')
|
||||||
{
|
{
|
||||||
@ -223,10 +224,13 @@ app.classes.calendar = (function(){ "use strict"; return AppJS.extend(
|
|||||||
{
|
{
|
||||||
this.set_enddate_visibility();
|
this.set_enddate_visibility();
|
||||||
this.check_recur_type();
|
this.check_recur_type();
|
||||||
this.edit_start_change();
|
this.edit_start_change(null, this.et2.getWidgetById('start'));
|
||||||
|
if(this.et2.getWidgetById('recur_exception'))
|
||||||
|
{
|
||||||
this.et2.getWidgetById('recur_exception').set_disabled(!content.data.recur_exception ||
|
this.et2.getWidgetById('recur_exception').set_disabled(!content.data.recur_exception ||
|
||||||
typeof content.data.recur_exception[0] == 'undefined');
|
typeof content.data.recur_exception[0] == 'undefined');
|
||||||
}
|
}
|
||||||
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this.freetime_search();
|
this.freetime_search();
|
||||||
|
37
calendar/templates/default/add.xet
Normal file
37
calendar/templates/default/add.xet
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
<?xml version="1.0" encoding="UTF-8"?>
|
||||||
|
<!DOCTYPE overlay PUBLIC "-//EGroupware GmbH//eTemplate 2//EN" "http://www.egroupware.org/etemplate2.dtd">
|
||||||
|
<!-- $Id$ -->
|
||||||
|
<overlay>
|
||||||
|
<template id="calendar.add" template="" lang="" group="0" version="19.1.000">
|
||||||
|
<grid width="100%">
|
||||||
|
<columns>
|
||||||
|
<column width="88"/>
|
||||||
|
<column width="130"/>
|
||||||
|
<column width="88"/>
|
||||||
|
<column width="130"/>
|
||||||
|
<column width="130"/>
|
||||||
|
</columns>
|
||||||
|
<rows>
|
||||||
|
<row class="dialogHeader" height="28">
|
||||||
|
<appicon/>
|
||||||
|
<textbox id="title" needed="1" size="75" maxlength="255" tabindex="1" class="et2_fullWidth" span="4" blur="Title"/>
|
||||||
|
</row>
|
||||||
|
<row class="dialogHeader2" height="28">
|
||||||
|
<description for="start" value="Start" width="88"/>
|
||||||
|
<date-time id="start" needed="1" class="required" onchange="app.calendar.edit_start_change"/>
|
||||||
|
<description for="duration" value="Duration" id="calendar_edit_duration" />
|
||||||
|
<menulist>
|
||||||
|
<menupopup statustext="Duration of the meeting" class="et2_fullWidth" id="duration" no_lang="1" onchange="app.calendar.set_enddate_visibility" options="Use end date,,,,,,,false"/>
|
||||||
|
</menulist>
|
||||||
|
<date-time id="end" onchange="app.calendar.edit_update_participant"/>
|
||||||
|
</row>
|
||||||
|
</rows>
|
||||||
|
</grid>
|
||||||
|
<hbox class="dialogFooterToolbar">
|
||||||
|
<button statustext="saves the changes made" label="Save" id="button[save]" image="save" background_image="1" />
|
||||||
|
<button statustext="Full edit dialog" label="Edit" id="button[edit]" image="edit" background_image="1"/>
|
||||||
|
<button statustext="Close the window" label="Cancel" id="button[cancel]" onclick="window.close();" image="cancel" background_image="1"/>
|
||||||
|
<checkbox label="Always use full edit dialog" id="always_edit_dialog" statustext="Always use the full edit dialog, not this little dialog" onchange="debugger;egw.set_preference('calendar',widget.id,widget.get_value() ? 'edit' : 'add');"/>
|
||||||
|
</hbox>
|
||||||
|
</template>
|
||||||
|
</overlay>
|
Loading…
Reference in New Issue
Block a user