*/
void display_icaltimetype_as_webform(struct icaltimetype *t, char *prefix, int date_only) {
+ wcsession *WCC = WC;
int i;
time_t now;
struct tm tm_now;
localtime_r(&tt, &tm);
}
- wprintf("<input type=\"text\" name=\"");
- wprintf(prefix);
- wprintf("\" id=\"");
- wprintf(prefix);
- wprintf("\" size=\"10\" maxlength=\"10\" value=\"");
+ wc_printf("<input type=\"text\" name=\"");
+ StrBufAppendBufPlain(WCC->WBuf, prefix, -1, 0);
+ wc_printf("\" id=\"");
+ StrBufAppendBufPlain(WCC->WBuf, prefix, -1, 0);
+ wc_printf("\" size=\"10\" maxlength=\"10\" value=\"");
wc_strftime(timebuf, 32, "%Y-%m-%d", &tm);
- wprintf(timebuf);
- wprintf("\">");
+ StrBufAppendBufPlain(WCC->WBuf, timebuf, -1, 0);
+ wc_printf("\">");
StrBufAppendPrintf(WC->trailing_javascript, "attachDatePicker('");
StrBufAppendPrintf(WC->trailing_javascript, prefix);
* This keeps the data model consistent.
*/
if (date_only) {
- wprintf("<div style=\"display:none\">");
+ wc_printf("<div style=\"display:none\">");
}
- wprintf(_("Hour: "));
- wprintf("<SELECT NAME=\"%s_hour\" SIZE=\"1\">\n", prefix);
+ wc_printf("<span ID=\"");
+ StrBufAppendBufPlain(WCC->WBuf, prefix, -1, 0);
+ wc_printf("_time\">");
+ wc_printf(_("Hour: "));
+ wc_printf("<SELECT NAME=\"%s_hour\" SIZE=\"1\">\n", prefix);
for (i=0; i<=23; ++i) {
if (time_format == WC_TIMEFORMAT_24) {
- wprintf("<OPTION %s VALUE=\"%d\">%d</OPTION>\n",
+ wc_printf("<OPTION %s VALUE=\"%d\">%d</OPTION>\n",
((tm.tm_hour == i) ? "SELECTED" : ""),
i, i
);
}
else {
- wprintf("<OPTION %s VALUE=\"%d\">%s</OPTION>\n",
+ wc_printf("<OPTION %s VALUE=\"%d\">%s</OPTION>\n",
((tm.tm_hour == i) ? "SELECTED" : ""),
i, hourname[i]
);
}
}
- wprintf("</SELECT>\n");
+ wc_printf("</SELECT>\n");
- wprintf(_("Minute: "));
- wprintf("<SELECT NAME=\"%s_minute\" SIZE=\"1\">\n", prefix);
+ wc_printf(_("Minute: "));
+ wc_printf("<SELECT NAME=\"%s_minute\" SIZE=\"1\">\n", prefix);
for (i=0; i<=59; ++i) {
if ( (i % 5 == 0) || (tm.tm_min == i) ) {
- wprintf("<OPTION %s VALUE=\"%d\">:%02d</OPTION>\n",
+ wc_printf("<OPTION %s VALUE=\"%d\">:%02d</OPTION>\n",
((tm.tm_min == i) ? "SELECTED" : ""),
i, i
);
}
}
- wprintf("</SELECT>\n");
+ wc_printf("</SELECT></span>\n");
if (date_only) {
- wprintf("</div>");
+ wc_printf("</div>");
}
}
*/
void icaltime_from_webform(struct icaltimetype *t, char *prefix) {
char vname[32];
- struct tm tm;
- struct icaltimetype t2;
- /* Stuff tm with zero values */
- memset(&tm, 0, sizeof(struct tm));
+ if (!t) return;
- /* Get the year/month/date all in one shot */
- strptime((char*)BSTR(prefix), "%Y-%m-%d", &tm);
+ /* Stuff with zero values */
+ memset(t, 0, sizeof(struct icaltimetype));
+
+ /* Get the year/month/date all in one shot -- it will be in ISO YYYY-MM-DD format */
+ sscanf((char*)BSTR(prefix), "%04d-%02d-%02d", &t->year, &t->month, &t->day);
/* hour */
sprintf(vname, "%s_hour", prefix);
- tm.tm_hour = IBSTR(vname);
+ t->hour = IBSTR(vname);
/* minute */
sprintf(vname, "%s_minute", prefix);
- tm.tm_min = IBSTR(vname);
+ t->minute = IBSTR(vname);
- /* now convert to icaltimetyepe */
- t2 = icaltime_from_timet_with_zone(mktime(&tm), 0, get_default_icaltimezone());
- t2.zone = get_default_icaltimezone();
- memcpy(t, &t2, sizeof(struct icaltimetype));
+ /* time zone is set to the default zone for this server */
+ t->is_utc = 0;
+ t->is_date = 0;
+ t->zone = get_default_icaltimezone();
}
* Get date (no time) from a web form and convert it into an icaltimetype struct.
*/
void icaltime_from_webform_dateonly(struct icaltimetype *t, char *prefix) {
- struct tm tm;
- time_t tm_t;
- struct icaltimetype t2;
-
- /* Stuff tm with zero values */
- memset(&tm, 0, sizeof(struct tm));
-
- /* Convert from string to icaltimetype */
- strptime((char *)BSTR(prefix), "%Y-%m-%d", &tm);
- tm_t = mktime(&tm);
- t2 = icaltime_from_timet(tm_t, 1);
- memcpy(t, &t2, sizeof(struct icaltimetype));
+ if (!t) return;
+
+ /* Stuff with zero values */
+ memset(t, 0, sizeof(struct icaltimetype));
+
+ /* Get the year/month/date all in one shot -- it will be in ISO YYYY-MM-DD format */
+ sscanf((char*)BSTR(prefix), "%04d-%02d-%02d", &t->year, &t->month, &t->day);
+
+ /* time zone is set to the default zone for this server */
+ t->is_utc = 1;
+ t->is_date = 1;
}
* Utility function to encapsulate a subcomponent into a full VCALENDAR.
*
* We also scan for any date/time properties that reference timezones, and attach
- * those timezones along with the supplied subcomponent. (Yes, I used a fixed
- * size array in order to avoid complexity. Increase the size if you think you
- * need to, but if you're really referencing more than 5 time zones in a single
- * calendar event, it probably means you're an idiot and deserve to lose.)
+ * those timezones along with the supplied subcomponent. (Increase the size of the array if you need to.)
+ *
+ * Note: if you change anything here, change it in Citadel server's ical_send_out_invitations() too.
*/
icalcomponent *ical_encapsulate_subcomponent(icalcomponent *subcomp) {
icalcomponent *encaps;
|| (icalproperty_isa(p) == ICAL_MINDATE_PROPERTY)
|| (icalproperty_isa(p) == ICAL_RECURRENCEID_PROPERTY)
) {
- t = icalproperty_get_dtstart(p); // it's safe to use dtstart for all of them
+ t = icalproperty_get_dtstart(p); /*/ it's safe to use dtstart for all of them */
if ((icaltime_is_valid_time(t)) && (z=icaltime_get_timezone(t), z)) {
zone_already_attached = 0;