use Friendica\Core\PConfig;
use Friendica\Core\System;
use Friendica\Database\DBM;
+use Friendica\Util\Map;
require_once 'include/bbcode.php';
-require_once 'include/map.php';
require_once 'include/datetime.php';
-require_once "include/conversation.php";
+require_once 'include/conversation.php';
function format_event_html($ev, $simple = false) {
if (! ((is_array($ev)) && count($ev))) {
// Include a map of the location if the [map] BBCode is used.
if (strpos($ev['location'], "[map") !== false) {
- $map = generate_named_map($ev['location']);
+ $map = Map::byLocation($ev['location']);
if ($map !== $ev['location']) {
$o.= $map;
}
/**
* @brief Convert an array with event data to bbcode.
- *
+ *
* @param array $ev Array which conains the event data.
* @return string The event as a bbcode formatted string.
*/
/**
* @brief Extract bbcode formatted event data from a string
* and convert it to html.
- *
+ *
* @params: string $s The string which should be parsed for event data.
* @return string The html output.
*/
/**
* @brief Extract bbcode formatted event data from a string.
- *
+ *
* @params: string $s The string which should be parsed for event data.
* @return array The array with the event information.
*/
/**
* @brief Delete an event from the event table.
- *
+ *
* Note: This function does only delete the event from the event table not its
* related entry in the item table.
- *
+ *
* @param int $event_id Event ID.
* @return void
*/
/**
* @brief Store the event.
- *
+ *
* Store the event in the event table and create an event item in the item table.
- *
+ *
* @param array $arr Array with event data.
* @return int The event id.
*/
$contact = $c[0];
}
-
// Existing event being modified.
-
if ($arr['id']) {
// has the event actually changed?
-
$r = q("SELECT * FROM `event` WHERE `id` = %d AND `uid` = %d LIMIT 1",
intval($arr['id']),
intval($arr['uid'])
if ((! DBM::is_result($r)) || ($r[0]['edited'] === $arr['edited'])) {
// Nothing has changed. Grab the item id to return.
-
$r = q("SELECT * FROM `item` WHERE `event-id` = %d AND `uid` = %d LIMIT 1",
intval($arr['id']),
intval($arr['uid'])
}
// The event changed. Update it.
-
- $r = q("UPDATE `event` SET
+ q("UPDATE `event` SET
`edited` = '%s',
`start` = '%s',
`finish` = '%s',
intval($arr['id']),
intval($arr['uid'])
);
+
$r = q("SELECT * FROM `item` WHERE `event-id` = %d AND `uid` = %d LIMIT 1",
intval($arr['id']),
intval($arr['uid'])
return $item_id;
} else {
// New event. Store it.
-
- $r = q("INSERT INTO `event` (`uid`,`cid`,`guid`,`uri`,`created`,`edited`,`start`,`finish`,`summary`, `desc`,`location`,`type`,
+ q("INSERT INTO `event` (`uid`,`cid`,`guid`,`uri`,`created`,`edited`,`start`,`finish`,`summary`, `desc`,`location`,`type`,
`adjust`,`nofinish`,`allow_cid`,`allow_gid`,`deny_cid`,`deny_gid`)
VALUES ( %d, %d, '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', '%s', %d, %d, '%s', '%s', '%s', '%s' ) ",
intval($arr['uid']),
$item_arr['object'] .= '</object>' . "\n";
$item_id = item_store($item_arr);
-
- $r = q("SELECT * FROM `user` WHERE `uid` = %d LIMIT 1",
- intval($arr['uid'])
- );
- //if (DBM::is_result($r))
- // $plink = System::baseUrl() . '/display/' . $r[0]['nickname'] . '/' . $item_id;
-
-
if ($item_id) {
- //q("UPDATE `item` SET `plink` = '%s', `event-id` = %d WHERE `uid` = %d AND `id` = %d",
- // dbesc($plink),
- // intval($event['id']),
- // intval($arr['uid']),
- // intval($item_id)
- //);
q("UPDATE `item` SET `event-id` = %d WHERE `uid` = %d AND `id` = %d",
intval($event['id']),
intval($arr['uid']),
/**
* @brief Create an array with translation strings used for events.
- *
+ *
* @return array Array with translations strings.
*/
function get_event_strings() {
/**
* @brief Get an event by its event ID.
*
- * @param type $owner_uid The User ID of the owner of the event
- * @param type $event_params An assoziative array with
- * int 'event_id' => The ID of the event in the event table
- * @param type $sql_extra
+ * @param int $owner_uid The User ID of the owner of the event
+ * @param array $event_params An assoziative array with
+ * int 'event_id' => The ID of the event in the event table
+ * @param string $sql_extra
* @return array Query result
*/
function event_by_id($owner_uid = 0, $event_params, $sql_extra = '') {
* string 'adjust_start' =>
*
* @param string $sql_extra Additional sql conditions (e.g. permission request).
- *
+ *
* @return array Query results.
*/
function events_by_date($owner_uid = 0, $event_params, $sql_extra = '') {
// Show edit and drop actions only if the user is the owner of the event and the event
// is a real event (no bithdays).
+ $edit = null;
+ $copy = null;
+ $drop = null;
if (local_user() && local_user() == $rr['uid'] && $rr['type'] == 'event') {
$edit = ((! $rr['cid']) ? array(System::baseUrl() . '/events/event/' . $rr['id'], t('Edit event'), '', '') : null);
$copy = ((! $rr['cid']) ? array(System::baseUrl() . '/events/copy/' . $rr['id'], t('Duplicate event'), '', '') : null);
* @param string $timezone The timezone of the user (not implemented yet).
*
* @return string Content according to selected export format.
+ *
+ * @todo Implement timezone support
*/
-function event_format_export ($events, $format = 'ical', $timezone) {
- if (! ((is_array($events)) && count($events))) {
+function event_format_export($events, $format = 'ical', $timezone)
+{
+ if (!((is_array($events)) && count($events))) {
return;
}
/**
* @brief Get all events for a user ID.
- *
+ *
* The query for events is done permission sensitive.
* If the user is the owner of the calendar he/she
* will get all of his/her available events.
/**
* @brief Format an item array with event data to HTML.
- *
+ *
* @param arr $item Array with item and event data.
* @return string HTML output.
*/
}
// Construct the map HTML.
if (isset($evloc['address'])) {
- $location['map'] = '<div class="map">' . generate_named_map($evloc['address']) . '</div>';
+ $location['map'] = '<div class="map">' . Map::byLocation($evloc['address']) . '</div>';
} elseif (isset($evloc['coordinates'])) {
- $location['map'] = '<div class="map">' . generate_map(str_replace('/', ' ', $evloc['coordinates'])) . '</div>';
+ $location['map'] = '<div class="map">' . Map::byCoordinates(str_replace('/', ' ', $evloc['coordinates'])) . '</div>';
}
// Construct the profile link (magic-auth).
/**
* @brief Format a string with map bbcode to an array with location data.
- *
+ *
* Note: The string must only contain location data. A string with no bbcode will be
* handled as location name.
- *
+ *
* @param string $s The string with the bbcode formatted location data.
- *
+ *
* @return array The array with the location data.
* 'name' => The name of the location,<br>
* 'address' => The address of the location,<br>