]> source.dussan.org Git - nextcloud-server.git/commitdiff
Add creating calendars with the web interface
authorBart Visscher <bartv@thisnet.nl>
Thu, 8 Sep 2011 10:29:29 +0000 (12:29 +0200)
committerBart Visscher <bartv@thisnet.nl>
Thu, 8 Sep 2011 10:29:29 +0000 (12:29 +0200)
apps/calendar/ajax/createcalendar.php [new file with mode: 0644]
apps/calendar/ajax/editcalendar.php
apps/calendar/ajax/newcalendar.php [new file with mode: 0644]
apps/calendar/ajax/updatecalendar.php
apps/calendar/js/calendar.js
apps/calendar/templates/part.choosecalendar.php
apps/calendar/templates/part.editcalendar.php

diff --git a/apps/calendar/ajax/createcalendar.php b/apps/calendar/ajax/createcalendar.php
new file mode 100644 (file)
index 0000000..e6e668a
--- /dev/null
@@ -0,0 +1,39 @@
+<?php
+/*************************************************
+ * ownCloud - Calendar Plugin                     *
+ *                                                *
+ * (c) Copyright 2011 Georg Ehrke                 *
+ * author: Georg Ehrke                            *
+ * email: ownclouddev at georgswebsite dot de     *
+ * homepage: ownclouddev.georgswebsite.de         *
+ * manual: ownclouddev.georgswebsite.de/manual    *
+ * License: GNU AFFERO GENERAL PUBLIC LICENSE     *
+ *                                                *
+ * If you are not able to view the License,       *
+ * <http://www.gnu.org/licenses/>                 *
+ * <http://ownclouddev.georgswebsite.de/license/> *
+ * please write to the Free Software Foundation.  *
+ * Address:                                       *
+ * 59 Temple Place, Suite 330, Boston,            *
+ * MA 02111-1307  USA                             *
+ *************************************************/
+require_once('../../../lib/base.php');
+
+$l10n = new OC_L10N('calendar');
+
+// We send json data
+header( "Content-Type: application/jsonrequest" );
+
+// Check if we are a user
+if( !OC_User::isLoggedIn()){
+       echo json_encode( array( "status" => "error", "data" => array( "message" => $l->t("Authentication error") )));
+       exit();
+}
+
+$userid = OC_User::getUser();
+$calendarid = OC_Calendar_Calendar::addCalendar($userid, $_POST['name'], $_POST['description'], 'VEVENT,VTODO,VJOURNAL', null, 0, $_POST['color']);
+OC_Calendar_Calendar::setCalendarActive($calendarid, 1);
+$calendar = OC_Calendar_Calendar::findCalendar($calendarid);
+$tmpl = new OC_Template('calendar', 'part.choosecalendar.rowfields');
+$tmpl->assign('calendar', $calendar);
+echo json_encode( array( "status" => "error", "data" => $tmpl->fetchPage().'' ));
index e32bf4586523edf2dc162fdec1f83d8ba72ffede..707544f4dd79412902125fc78d1fce101ae3c6d3 100644 (file)
@@ -24,6 +24,7 @@ if(!OC_USER::isLoggedIn()) {
 }
 $calendar = OC_Calendar_Calendar::findCalendar($_GET['calendarid']);
 $tmpl = new OC_Template("calendar", "part.editcalendar");
-$tmpl->assign('calendar',$calendar);
+$tmpl->assign('new', false);
+$tmpl->assign('calendar', $calendar);
 $tmpl->printPage();
 ?>
diff --git a/apps/calendar/ajax/newcalendar.php b/apps/calendar/ajax/newcalendar.php
new file mode 100644 (file)
index 0000000..88cadea
--- /dev/null
@@ -0,0 +1,35 @@
+<?php
+/*************************************************
+ * ownCloud - Calendar Plugin                     *
+ *                                                *
+ * (c) Copyright 2011 Georg Ehrke                 *
+ * author: Georg Ehrke                            *
+ * email: ownclouddev at georgswebsite dot de     *
+ * homepage: ownclouddev.georgswebsite.de         *
+ * manual: ownclouddev.georgswebsite.de/manual    *
+ * License: GNU AFFERO GENERAL PUBLIC LICENSE     *
+ *                                                *
+ * If you are not able to view the License,       *
+ * <http://www.gnu.org/licenses/>                 *
+ * <http://ownclouddev.georgswebsite.de/license/> *
+ * please write to the Free Software Foundation.  *
+ * Address:                                       *
+ * 59 Temple Place, Suite 330, Boston,            *
+ * MA 02111-1307  USA                             *
+ *************************************************/
+require_once('../../../lib/base.php');
+$l10n = new OC_L10N('calendar');
+if(!OC_USER::isLoggedIn()) {
+       die("<script type=\"text/javascript\">document.location = oc_webroot;</script>");
+}
+$calendar = array(
+       'id' => 'new',
+       'displayname' => 'Test',
+       'description' => 'Test calendar',
+       'calendarcolor' => 'black',
+);
+$tmpl = new OC_Template('calendar', 'part.editcalendar');
+$tmpl->assign('new', true);
+$tmpl->assign('calendar', $calendar);
+$tmpl->printPage();
+?>
index 2836dda218ae7e318847857c42c51dc4a0afceea..07cc32d5931bed683233178edd760021f37c9a2d 100644 (file)
@@ -34,6 +34,6 @@ $calendarid = $_POST['id'];
 OC_Calendar_Calendar::editCalendar($calendarid, $_POST['name'], $_POST['description'], null, null, null, $_POST['color']);
 OC_Calendar_Calendar::setCalendarActive($calendarid, $_POST['active']);
 $calendar = OC_Calendar_Calendar::findCalendar($calendarid);
-$tmpl = new OC_Template('calendar', 'part.calendar.row');
+$tmpl = new OC_Template('calendar', 'part.choosecalendar.rowfields');
 $tmpl->assign('calendar', $calendar);
 echo json_encode( array( "status" => "success", "data" => $tmpl->fetchPage() ));
index 928b1e0628258cbcff819bbc81c6dc5bd00508ca..e7c31cd7c9bbb563825f3266b3c3cda74e0291c5 100644 (file)
@@ -200,6 +200,10 @@ Calendar={
                },
                events:[],
                loadEvents:function(year){
+                       if( typeof (year) == 'undefined') {
+                               this.events = [];
+                               year = Calendar.Date.current.getFullYear();
+                       }
                        if( typeof (this.events[year]) == "undefined") {
                                this.events[year] = []
                        }
@@ -213,7 +217,9 @@ Calendar={
                                                $( "#parsingfail_dialog" ).dialog();
                                        });
                                } else {
-                                       Calendar.UI.events[year] = newevents[year];
+                                       if (typeof(newevents[year]) != 'undefined'){
+                                               Calendar.UI.events[year] = newevents[year];
+                                       }
                                        $(document).ready(function() {
                                                Calendar.UI.updateView();
                                        });
@@ -677,7 +683,7 @@ $(document).ready(function(){
        $('#listview #more_after').click(Calendar.UI.List.renderMoreAfter);
 });
 //event vars
-Calendar.UI.loadEvents(Calendar.Date.current.getFullYear());
+Calendar.UI.loadEvents();
 
 function oc_cal_switch2today() {
        Calendar.Date.current = new Date();
@@ -718,23 +724,40 @@ function oc_cal_calender_activation(checkbox, calendarid)
        $.post(oc_webroot + "/apps/calendar/ajax/activation.php", { calendarid: calendarid, active: checkbox.checked?1:0 },
          function(data) {
                checkbox.checked = data == 1;
-               Calendar.UI.loadEvents(Calendar.Date.current.getFullYear());
+               Calendar.UI.loadEvents();
          });
 }
 function oc_cal_editcalendar(object, calendarid){
-       $(object).closest('tr').load(oc_webroot + "/apps/calendar/ajax/editcalendar.php?calendarid="+calendarid);
+       var tr = $(document.createElement('tr'))
+               .load(oc_webroot + "/apps/calendar/ajax/editcalendar.php?calendarid="+calendarid);
+       $(object).closest('tr').after(tr).hide();
+}
+function oc_cal_newcalendar(object){
+       var tr = $(document.createElement('tr'))
+               .load(oc_webroot + "/apps/calendar/ajax/newcalendar.php");
+       $(object).closest('tr').after(tr).hide();
 }
-function oc_cal_editcalendar_submit(button, calendarid){
+function oc_cal_calendar_submit(button, calendarid){
        var displayname = $("#displayname_"+calendarid).val();
        var active = $("#active_"+calendarid+":checked").length;
        var description = $("#description_"+calendarid).val();
        var calendarcolor = $("#calendarcolor_"+calendarid).val();
 
-       $.post("ajax/updatecalendar.php", { id: calendarid, name: displayname, active: active, description: description, color: calendarcolor },
+       var url;
+       if (calendarid == 'new'){
+               url = "ajax/createcalendar.php";
+       }else{
+               url = "ajax/updatecalendar.php";
+       }
+       $.post(url, { id: calendarid, name: displayname, active: active, description: description, color: calendarcolor },
                function(data){
                        if(data.error == "true"){
                        }else{
-                               $(button).closest('tr').html(data.data)
+                               $(button).closest('tr').prev().html(data.data).show().next().remove();
+                               Calendar.UI.loadEvents();
                        }
                }, 'json');
 }
+function oc_cal_calendar_cancel(button, calendarid){
+       $(button).closest('tr').prev().show().next().remove();
+}
index 30866270ac5ab8202ba671389f9986f01ba44559..07e7573a8ab5cbf22d2543dfa1773874310020a1 100644 (file)
@@ -10,6 +10,11 @@ for($i = 0; $i < count($option_calendars); $i++){
        echo "</tr>";
 }
 ?>
+<tr>
+       <td colspan="4">
+               <a href="#" onclick="oc_cal_newcalendar(this);"><?php echo $l->t('New Calendar') ?></a>
+       </td>
+</tr>
 </table>
 <script type="text/javascript">
        $( "#choosecalendar_dialog" ).dialog({
index d6f4e9f16fff312611f8a9ea45f07bb31519d4e9..0bf2a572becb378cb2a4e18d32c8de40ced1669d 100644 (file)
@@ -1,4 +1,4 @@
-<td id="editcalendar_dialog" title="<?php echo $l->t("Edit calendar"); ?>" colspan="4">
+<td id="<?php echo $_['new'] ? 'new' : 'edit' ?>calendar_dialog" title="<?php echo $_['new'] ? $l->t("New calendar") : $l->t("Edit calendar"); ?>" colspan="4">
 <table width="100%" style="border: 0;">
 <tr>
        <th><?php echo $l->t('Displayname') ?></th>
@@ -6,15 +6,17 @@
                <input id="displayname_<?php echo $_['calendar']['id'] ?>" type="text" value="<?php echo $_['calendar']['displayname'] ?>">
        </td>
 </tr>
+<?php if (!$_['new']): ?>
 <tr>
        <td></td>
        <td>
-               <input id="active_<?php echo $_['calendar']['id'] ?>" type="checkbox"<?php echo ($_['calendar']['active'] ? ' checked="checked"' : '' ) ?>>
+               <input id="active_<?php echo $_['calendar']['id'] ?>" type="checkbox"<?php echo $_['calendar']['active'] ? ' checked="checked"' : '' ?>>
                <label for="active_<?php echo $_['calendar']['id'] ?>">
                        <?php echo $l->t('Active') ?>
                </label>
        </td>
 </tr>
+<?php endif; ?>
 <tr>
        <th><?php echo $l->t('Description') ?></th>
        <td>
@@ -28,5 +30,6 @@
        </td>
 </tr>
 </table>
-<input style="float: left;" type="button" onclick="oc_cal_editcalendar_submit(this, <?php echo $_['calendar']['id'] ?>);" value="<?php echo $l->t("Submit"); ?>">
+<input style="float: left;" type="button" onclick="oc_cal_calendar_submit(this, <?php echo $_['new'] ? "'new'" : $_['calendar']['id'] ?>);" value="<?php echo $_['new'] ? $l->t("Save") : $l->t("Submit"); ?>">
+<input style="float: left;" type="button" onclick="oc_cal_calendar_cancel(this, <?php echo $_['new'] ? "'new'" : $_['calendar']['id'] ?>);" value="<?php echo $l->t("Cancel"); ?>">
 </td>