page['htmlhead'] .= '" . t("Go back to the calendar") . " 
" . t("Import a ICS-file") . " ";
	$o .= '';
	return $o;
}
/**
 * @param array|Sabre_CalDAV_Calendar[] $calendars
 * @param array|int[] $calendars_selected
 * @param string $data_feed_url
 * @param string $view
 * @param int $theme
 * @param int $height_diff
 * @param bool $readonly
 * @param string $curr_day
 * @param array $add_params
 * @param bool $show_nav
 * @return string
 */
function wdcal_printCalendar($calendars, $calendars_selected, $data_feed_url, $view = "week", $theme = 0, $height_diff = 175, $readonly = false, $curr_day = "", $add_params = array(), $show_nav = true)
{
	$a            = get_app();
	$localization = wdcal_local::getInstanceByUser($a->user["uid"]);
	if (count($calendars_selected) == 0) foreach ($calendars as $c) {
		$prop                 = $c->getProperties(array("id"));
		$calendars_selected[] = $prop["id"];
	}
	$opts = array(
		"view"             => $view,
		"theme"            => $theme,
		"readonly"         => $readonly,
		"height_diff"      => $height_diff,
		"weekstartday"     => $localization->getFirstDayOfWeek(),
		"data_feed_url"    => $data_feed_url,
		"date_format_dm1"  => $localization->dateformat_js_dm1(),
		"date_format_dm2"  => $localization->dateformat_js_dm2(),
		"date_format_dm3"  => $localization->dateformat_js_dm3(),
		"date_format_full" => $localization->dateformat_datepicker_js(),
		"baseurl"          => $a->get_baseurl() . "/dav/wdcal/",
	);
	$x = '
	Available Calendars: ';
	foreach ($calendars as $cal) {
		$cal_id = $cal->getProperties(array("id", DAV_DISPLAYNAME));
		$x .= '
	
		Sorry, could not load your data, please try again later
	 ';
	if ($show_nav) {
		$x .= '
		
		 
		
		
		
		
			
		
			
		
			' . t("Date") . ' 
		
		
	';
	}
	$x .= '
	
';
	return $x;
}
/**
 * @param int $calendar_id
 * @param int $calendarobject_id
 * @return string
 */
function wdcal_getDetailPage($calendar_id, $calendarobject_id)
{
	$a = get_app();
	try {
		$details = null;
		$server  = dav_create_server(true, true, false);
		$cal     = dav_get_current_user_calendar_by_id($server, $calendar_id, DAV_ACL_READ);
		$obj     = Sabre_CalDAV_Backend_Common::loadCalendarobjectById($calendarobject_id);
		dav_get_current_user_calendarobject($server, $cal, $obj["uri"], DAV_ACL_READ); // Check permissions
		$calbackend = wdcal_calendar_factory_by_id($calendar_id);
		$redirect   = $calbackend->getItemDetailRedirect($calendar_id, $calendarobject_id);
		if ($redirect !== null) goaway($a->get_baseurl() . $redirect);
		$details = $obj;
	} catch (Exception $e) {
		info(t("Error") . ": " . $e);
		goaway($a->get_baseurl() . "/dav/wdcal/");
	}
	return print_r($details, true);
}
/**
 * @param int $calendar_id
 * @param int $uri
 * @return string
 */
function wdcal_getEditPage($calendar_id, $uri)
{
	$a            = get_app();
	$localization = wdcal_local::getInstanceByUser($a->user["uid"]);
	return wdcal_getEditPage_str($localization, $a->get_baseurl(), $calendar_id, $uri);
}
/**
 * @return string
 */
function wdcal_getNewPage()
{
	$a            = get_app();
	$localization = wdcal_local::getInstanceByUser($a->user["uid"]);
	return wdcal_getEditPage_str($localization, $a->get_baseurl(), 0, 0);
}
/**
 * @param App $a
 * @return string
 */
function wdcal_getSettingsPage(&$a)
{
	if (!local_user()) {
		notice(t('Permission denied.') . EOL);
		return '';
	}
	if (isset($_REQUEST["save"])) {
		check_form_security_token_redirectOnErr('/dav/settings/', 'calprop');
		set_pconfig($a->user["uid"], "dav", "dateformat", $_REQUEST["wdcal_date_format"]);
		info(t('The new values have been saved.'));
	}
	if (isset($_REQUEST["save_cals"])) {
		check_form_security_token_redirectOnErr('/dav/settings/', 'calprop');
		$r = q("SELECT * FROM %s%scalendars WHERE `namespace` = " . CALDAV_NAMESPACE_PRIVATE . " AND `namespace_id` = %d", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($a->user["uid"]));
		foreach ($r as $cal) {
			$backend = wdcal_calendar_factory($cal["namespace"], $cal["namespace_id"], $cal["uri"], $cal);
			$change_sql = "";
			$col = substr($_REQUEST["color"][$cal["id"]], 1);
			if (strtolower($col) != strtolower($cal["calendarcolor"])) $change_sql .= ", `calendarcolor` = '" . dbesc($col) . "'";
			if (!is_subclass_of($backend, "Sabre_CalDAV_Backend_Virtual")) {
				if ($_REQUEST["uri"][$cal["id"]] != $cal["uri"]) $change_sql .= ", `uri` = '" . dbesc($_REQUEST["uri"][$cal["id"]]) . "'";
				if ($_REQUEST["name"][$cal["id"]] != $cal["displayname"]) $change_sql .= ", `displayname` = '" . dbesc($_REQUEST["name"][$cal["id"]]) . "'";
			}
			if ($change_sql != "") {
				q("UPDATE %s%scalendars SET `ctag` = `ctag` + 1 $change_sql WHERE `id` = %d AND `namespace_id` = %d AND `namespace_id` = %d",
					CALDAV_SQL_DB, CALDAV_SQL_PREFIX, $cal["id"], CALDAV_NAMESPACE_PRIVATE, IntVal($a->user["uid"]));
				info(t('The calendar has been updated.'));
			}
		}
		if (isset($_REQUEST["uri"]["new"]) && $_REQUEST["uri"]["new"] != "" && $_REQUEST["name"]["new"] && $_REQUEST["name"]["new"] != "") {
			$order = q("SELECT MAX(`calendarorder`) ord FROM %s%scalendars WHERE `namespace_id` = %d AND `namespace_id` = %d",
				CALDAV_SQL_DB, CALDAV_SQL_PREFIX, CALDAV_NAMESPACE_PRIVATE, IntVal($a->user["uid"]));
			$neworder = $order[0]["ord"] + 1;
			q("INSERT INTO %s%scalendars (`namespace`, `namespace_id`, `calendarorder`, `calendarcolor`, `displayname`, `timezone`, `uri`, `has_vevent`, `ctag`)
				VALUES (%d, %d, %d, '%s', '%s', '%s', '%s', 1, 1)",
				CALDAV_SQL_DB, CALDAV_SQL_PREFIX, CALDAV_NAMESPACE_PRIVATE, IntVal($a->user["uid"]), $neworder, dbesc(strtolower(substr($_REQUEST["color"]["new"], 1))),
				dbesc($_REQUEST["name"]["new"]), dbesc($a->timezone), dbesc($_REQUEST["uri"]["new"])
			);
			info(t('The new calendar has been created.'));
		}
	}
	if (isset($_REQUEST["remove_cal"])) {
		check_form_security_token_redirectOnErr('/dav/settings/', 'del_cal', 't');
		$c = q("SELECT * FROM %s%scalendars WHERE `id` = %d AND `namespace_id` = %d AND `namespace_id` = %d",
			CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["remove_cal"]), CALDAV_NAMESPACE_PRIVATE, IntVal($a->user["uid"]));
		if (count($c) != 1) killme();
		$calobjs = q("SELECT `id` FROM %s%scalendarobjects WHERE `calendar_id` = %d", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["remove_cal"]));
		$newcal = q("SELECT * FROM %s%scalendars WHERE `id` != %d AND `namespace_id` = %d AND `namespace_id` = %d ORDER BY `calendarcolor` LIMIT 0,1",
			CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["remove_cal"]), CALDAV_NAMESPACE_PRIVATE, IntVal($a->user["uid"]));
		if (count($newcal) != 1) killme();
		q("UPDATE %s%scalendarobjects SET `calendar_id` = %d WHERE `calendar_id` = %d", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($newcal[0]["id"]), IntVal($c[0]["id"]));
		foreach ($calobjs as $calobj) renderCalDavEntry_calobj_id($calobj["id"]);
		q("DELETE FROM %s%scalendars WHERE `id` = %s", CALDAV_SQL_DB, CALDAV_SQL_PREFIX, IntVal($_REQUEST["remove_cal"]));
		q("UPDATE %s%scalendars SET `ctag` = `ctag` + 1 WHERE `id` = " . CALDAV_SQL_DB, CALDAV_SQL_PREFIX, $newcal[0]["id"]);
		info(t('The calendar has been deleted.'));
	}
	$o = "";
	$o .= "" . t("Go back to the calendar") . " ' . t('Calendar Settings') . ' ';
	$current_format = wdcal_local::getInstanceByUser($a->user["uid"]);
	$o .= '';
	$o .= '' . t('Calendars') . ' ';
	$o .= '';
	$baseurl = $a->get_baseurl();
	$o .= "";
	$o .= "" . t("Limitations") . " ";
	$o .= "- The native friendica events are embedded as read-only, half-transparent in the calendar." . t("Warning") . " ";
	$o .= "This plugin still is in a very early stage of development. Expect major bugs!" . t("Synchronization (iPhone, Thunderbird Lightning, Android, ...)") . " ";
	$o .= 'This plugin enables synchronization of your dates and contacts with CalDAV- and CardDAV-enabled programs or devices.' . t('Synchronizing this calendar with the iPhone') . ' ';
	$o .= "
	Go to the settings 
	Mail, contacts, settings 
	Add a new account 
	Other... 
	Calendar -> CalDAV-Account 
	Server:  " . $a->get_baseurl() . "/dav/ / Username/Password:  the same as your friendica-login  ";
	$o .= '' . t('Synchronizing your Friendica-Contacts with the iPhone') . ' ';
	$o .= "
	Go to the settings 
	Mail, contacts, settings 
	Add a new account 
	Other... 
	Contacts -> CardDAV-Account 
	Server:  " . $a->get_baseurl() . "/dav/ / Username/Password:  the same as your friendica-login  ";
	return $o;
}