summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGeorg Ehrke <ownclouddev@georgswebsite.de>2012-01-13 13:57:46 +0100
committerGeorg Ehrke <ownclouddev@georgswebsite.de>2012-01-13 13:57:46 +0100
commitf9c4975a456940bb24cacd6723a37f2857fbc65c (patch)
tree139837d5ef3a7ae554113a700eddd897103d737a
parent28e15fd4873d22b5ab804d6e4cec3f345551a02e (diff)
downloadnextcloud-server-f9c4975a456940bb24cacd6723a37f2857fbc65c.tar.gz
nextcloud-server-f9c4975a456940bb24cacd6723a37f2857fbc65c.zip
improve import form for calendar
-rw-r--r--apps/calendar/js/loader.js39
-rw-r--r--apps/calendar/templates/part.import.php75
2 files changed, 48 insertions, 66 deletions
diff --git a/apps/calendar/js/loader.js b/apps/calendar/js/loader.js
index c21c20275e2..50a7b082d98 100644
--- a/apps/calendar/js/loader.js
+++ b/apps/calendar/js/loader.js
@@ -2,10 +2,43 @@ Calendar_Import={
importdialog: function(filename){
var path = $('#dir').val();
$('body').append('<div id="calendar_import"></div>');
- $('#calendar_import').load(OC.filePath('calendar', 'ajax', 'importdialog.php'), {filename:filename, path:path}, Calendar_Import.initdialog());
+ $('#calendar_import').load(OC.filePath('calendar', 'ajax', 'importdialog.php'), {filename:filename, path:path}, function(){Calendar_Import.initdialog(filename);});
},
- initdialog: function(){
-
+ initdialog: function(filename){
+ $("#calendar_import_dialog").dialog({
+ width : 500,
+ close : function() {
+ $(this).dialog('destroy').remove();
+ $("#calendar_import").remove();
+ }
+ });
+ $('#progressbar').progressbar({value: 87});
+ $('#startimport').click(function(){
+ var filename = $('#filename').val();
+ var path = $('#path').val();
+ if($('#calendar option:selected').val() == 'newcal'){
+ var method = 'new';
+ var calname = $('#newcalendar').val();
+ var calname = $.trim(calname);
+ if(calname == ''){
+ $('#newcalendar').css('background-color', '#FF2626');
+ return false;
+ }
+ }else{
+ var method = 'old';
+ }
+ $('#newcalendar').attr('readonly', 'readonly');
+ $('#calendar').attr('disabled', 'disabled');
+ $.post(OC.filePath('calendar', '', 'import.php'), {'method':method, 'calname':calname, 'path':path, 'file':filename}, function(){});
+ $('#progressbar').slideDown('slow');
+ });
+ $('#calendar').change(function(){
+ if($('#calendar option:selected').val() == 'newcal'){
+ $('#newcalform').slideDown('slow');
+ }else{
+ $('#newcalform').slideUp('slow');
+ }
+ });
},
getimportstatus: function(){
diff --git a/apps/calendar/templates/part.import.php b/apps/calendar/templates/part.import.php
index b8805e6b6ef..13685cfb273 100644
--- a/apps/calendar/templates/part.import.php
+++ b/apps/calendar/templates/part.import.php
@@ -1,69 +1,18 @@
-<div id="importdialog" title="<?php echo $l->t("Import Ical File"); ?>">
+<div id="calendar_import_dialog" title="<?php echo $l->t("Import a calendar file"); ?>">
<input type="hidden" id="filename" value="<?php echo $_GET["filename"];?>">
<input type="hidden" id="path" value="<?php echo $_GET["path"];?>">
-<div id="first"><strong style="text-align: center;margin: 0 auto;"><?php echo $l->t("How to import the new calendar?");?></strong>
-<br><br>
-<input style="float: left;" type="button" value="<?php echo $l->t("Import into an existing calendar"); ?>" onclick="$('#first').css('display', 'none');$('#existingcal').css('display', 'block');">
-<input style="float: right;" type="button" value="<?php echo $l->t("Import into a new calendar");?>" onclick="$('#first').css('display', 'none');$('#newcal').css('display', 'block');">
-</div>
-<div id="existingcal" style="display: none;">
-<strong><?php echo $l->t("Please choose the calendar"); ?></strong><br><br>
-<form id="inputradioform">
+<p style="text-align:center;"><b><?php echo $l->t('Please choose the calendar'); ?></b></h2>
+<select style="width:100%;" id="calendar" name="calendar">
<?php
-$calendars = OC_Calendar_Calendar::allCalendars(OC_User::getUser());
-foreach($calendars as $calendar){
- echo '<input type="radio" style="width: 20px;" name="calendar" id="radio_' . $calendar["id"] . '" value="' . $calendar["id"] . '">' . $calendar["displayname"] . '<br>';
-}
+$calendar_options = OC_Calendar_Calendar::allCalendars(OC_User::getUser());
+$calendar_options[] = array('id'=>'newcal', 'displayname'=>$l->t('create a new calendar'));
+echo html_select_options($calendar_options, $calendar_options[0]['id'], array('value'=>'id', 'label'=>'displayname'));
?>
-</form>
-<br><br>
-<input type="button" value="<?php echo $l->t("Import");?>!" onclick="importcal('existing');">
-<br><br>
-<input type="button" value="<?php echo $l->t("Back");?>" onclick="$('#existingcal').css('display', 'none');$('#first').css('display', 'block');">
+</select>
+<div id="newcalform" style="display: none;">
+ <input type="text" style="width: 97%;" placeholder="<?php echo $l->t('Name of new calendar'); ?>" id="newcalendar" name="newcalendar">
</div>
-<div id="newcal" style="display: none;">
-<strong><?php echo $l->t("Please fill out the form"); ?></strong>
-<!-- modified part of part.editcalendar.php -->
-<table width="100%" style="border: 0;">
-<tr>
-<th><?php echo $l->t('Displayname') ?></th>
-<td>
-<input id="displayname" type="text" value="">
-</td>
-</tr>
-</table>
-<!-- end of modified part -->
+<input type="button" value="<?php echo $l->t("Import");?>!" id="startimport">
<br><br>
-<input type="button" value="<?php echo $l->t("Import");?>!" onclick="importcal('new');">
-<br><br>
-<input type="button" value="<?php echo $l->t("Back");?>" onclick="$('#newcal').css('display', 'none');$('#first').css('display', 'block');">
-</div>
-</div>
-<script type="text/javascript">
-$("input:radio[name='calendar']:first").attr("checked","checked");
-$("#importdialog").dialog({
- width : 500,
- close : function(event, ui) {
- $(this).dialog('destroy').remove();
- $("#importdialogholder").remove();
- }
-});
-function importcal(importtype){
- var path = $("#path").val();
- var file = $("#filename").val();
- if(importtype == "existing"){
- var calid = $("input:radio[name='calendar']:checked").val();
- $.getJSON(OC.filePath('calendar', '', 'import.php') + "?import=existing&calid=" + calid + "&path=" + path + "&file=" + file, function(){
- $("#importdialog").dialog('destroy').remove();
- $("#importdialogholder").remove();
- });
- }
- if(importtype == "new"){
- var calname = $("#displayname").val();
- $.post(OC.filePath('calendar', '', 'import.php'), {'import':'new', 'calname':calname, 'path':path, 'file':file}, function(){
- $("#importdialog").dialog('destroy').remove();
- $("#importdialogholder").remove();
- });
- }
-}
-</script> \ No newline at end of file
+<div id="progressbar" style="display: none;"></div>
+</div> \ No newline at end of file