int i, j = 0;
int sequence = 0;
char weekday_labels[7][32];
+ long weekstart = 0;
+
+ get_pref_long("weekstart", &weekstart, 17);
+ if (weekstart > 6) weekstart = 0;
lprintf(9, "display_edit_individual_event(%ld) calview=%s year=%s month=%s day=%s\n",
msgnum, bstr("calview"), bstr("year"), bstr("month"), bstr("day")
t_start.is_utc = 1;
}
- display_icaltimetype_as_webform(&t_start, "dtstart");
+ display_icaltimetype_as_webform(&t_start, "dtstart", 0);
wprintf("<INPUT TYPE=\"checkbox\" id=\"alldayevent\" NAME=\"alldayevent\" "
"VALUE=\"yes\" onclick=\"eventEditAllDay();\""
/* t_end = icaltime_from_timet(now, 0); */
}
}
- display_icaltimetype_as_webform(&t_end, "dtend");
+ display_icaltimetype_as_webform(&t_end, "dtend", 0);
wprintf("</TD></TR>\n");
wprintf("<TR><TD><B>");
/* blank recurrence with some sensible defaults */
memset(&recur, 0, sizeof(struct icalrecurrencetype));
recur.count = 3;
+ recur.until = icaltime_null_time();
recur.interval = 1;
recur.freq = ICAL_WEEKLY_RECURRENCE;
}
"onclick=\"RecurrenceShowHide();\""
" %s >%s",
(rrule ? "CHECKED=\"CHECKED\"" : "" ),
- _("This is a repeating event")
+ _("This is a recurring event")
);
- wprintf("<div id=\"rrule\">\n"); /* begin 'rrule' div */
+ wprintf("<div id=\"rrule_div\">\n"); /* begin 'rrule_div' div */
wprintf("<table border=0 width=100%%>\n"); /* same table style as the event tab */
_("never")
};
-
-
-
wprintf("<tr><td><b>");
wprintf(_("Recurrence rule"));
wprintf("</b></td><td>");
+
if ((recur.freq < 0) || (recur.freq > 6)) recur.freq = 4;
wprintf("%s ", _("Repeats every"));
wprintf("<input type=\"text\" name=\"interval\" maxlength=\"3\" size=\"3\" ");
- wprintf("value=\"%d\"> ", recur.interval);
+ wprintf("value=\"%d\"> ", recur.interval);
wprintf("<select name=\"freq\" id=\"freq_selector\" size=\"1\" "
"onChange=\"RecurrenceShowHide();\">\n");
}
}
- for (i=0; i<7; ++i) {
+ for (j=0; j<7; ++j) {
+ i = ((j + (int)weekstart) % 7);
wprintf("<input type=\"checkbox\" name=\"weekday%d\" value=\"yes\"", i);
if (weekday_is_selected[i]) wprintf(" checked");
wprintf(">%s</input>\n", weekday_labels[i]);
wprintf("</td></tr>\n");
-
-
+ int which_rrend_is_preselected = 0;
+ if (!icaltime_is_null_time(recur.until)) which_rrend_is_preselected = 2;
+ if (recur.count > 0) which_rrend_is_preselected = 1;
wprintf("<tr><td><b>");
wprintf(_("Recurrence range"));
wprintf("<input type=\"radio\" name=\"rrend\" id=\"rrend_none\" "
"%s onChange=\"RecurrenceShowHide();\">",
- (1 ? "checked" : "")
+ ((which_rrend_is_preselected == 0) ? "checked" : "")
);
wprintf("%s</input><br />\n", _("No ending date"));
wprintf("<input type=\"radio\" name=\"rrend\" id=\"rrend_count\" "
"%s onChange=\"RecurrenceShowHide();\">",
- (0 ? "checked" : "")
+ ((which_rrend_is_preselected == 1) ? "checked" : "")
);
- wprintf(_("Repeat this event %d times"), 0);
- wprintf("</input><br />\n");
+ wprintf(_("Repeat this event"));
+ wprintf("</input> ");
+ wprintf("<input type=\"text\" name=\"rrcount\" id=\"rrcount\" maxlength=\"3\" size=\"3\" ");
+ wprintf("value=\"%d\"> ", recur.count);
+ wprintf(_("times"));
+ wprintf("<br />\n");
wprintf("<input type=\"radio\" name=\"rrend\" id=\"rrend_until\" "
"%s onChange=\"RecurrenceShowHide();\">",
- (0 ? "checked" : "")
+ ((which_rrend_is_preselected == 2) ? "checked" : "")
);
- wprintf(_("Repeat this event until %s"), "FIXME");
- wprintf("</input><br />\n");
-
- wprintf("</td></tr>\n");
-
+ wprintf(_("Repeat this event until "));
+ wprintf("</input>");
+ if (icaltime_is_null_time(recur.until)) {
+ recur.until = icaltime_add(t_start, icaldurationtype_from_int(604800));
+ }
+ display_icaltimetype_as_webform(&recur.until, "rruntil", 1);
+ wprintf("<br />\n");
+ wprintf("</td></tr>\n");
wprintf("</table>\n");
wprintf("</div>\n"); /* end 'rrule' div */
wprintf("</div>\n");
- wprintf("<script type=\"text/javascript\"> \n"
+ StrBufAppendPrintf(WC->trailing_javascript,
"eventEditAllDay(); \n"
"RecurrenceShowHide(); \n"
- "</script> \n"
);
address_book_popup();
wDumpContent(1);