Merge pull request #12086 from nupplaphil/feat/move_cal
Move event export to src/Module/Events/Export
This commit is contained in:
commit
ffa31d6641
10 changed files with 170 additions and 104 deletions
44
mod/cal.php
44
mod/cal.php
|
@ -34,7 +34,6 @@ use Friendica\Model\Event;
|
||||||
use Friendica\Model\Item;
|
use Friendica\Model\Item;
|
||||||
use Friendica\Model\User;
|
use Friendica\Model\User;
|
||||||
use Friendica\Module\BaseProfile;
|
use Friendica\Module\BaseProfile;
|
||||||
use Friendica\Module\Response;
|
|
||||||
use Friendica\Network\HTTPException;
|
use Friendica\Network\HTTPException;
|
||||||
use Friendica\Util\DateTimeFormat;
|
use Friendica\Util\DateTimeFormat;
|
||||||
use Friendica\Util\Temporal;
|
use Friendica\Util\Temporal;
|
||||||
|
@ -101,15 +100,8 @@ function cal_content(App $a)
|
||||||
$m = 0;
|
$m = 0;
|
||||||
$ignored = (!empty($_REQUEST['ignored']) ? intval($_REQUEST['ignored']) : 0);
|
$ignored = (!empty($_REQUEST['ignored']) ? intval($_REQUEST['ignored']) : 0);
|
||||||
|
|
||||||
$format = 'ical';
|
|
||||||
if (DI::args()->getArgc() == 4 && DI::args()->getArgv()[2] == 'export') {
|
|
||||||
$mode = 'export';
|
|
||||||
$format = DI::args()->getArgv()[3];
|
|
||||||
}
|
|
||||||
|
|
||||||
// Setup permissions structures
|
// Setup permissions structures
|
||||||
$owner_uid = intval($owner['uid']);
|
$owner_uid = intval($owner['uid']);
|
||||||
$nick = $owner['nickname'];
|
|
||||||
|
|
||||||
$contact_id = DI::userSession()->getRemoteContactID($owner['uid']);
|
$contact_id = DI::userSession()->getRemoteContactID($owner['uid']);
|
||||||
|
|
||||||
|
@ -258,40 +250,4 @@ function cal_content(App $a)
|
||||||
|
|
||||||
return $o;
|
return $o;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($mode == 'export') {
|
|
||||||
if (!$owner_uid) {
|
|
||||||
DI::sysmsg()->addNotice(DI::l10n()->t('User not found'));
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
|
|
||||||
// Get the export data by uid
|
|
||||||
$evexport = Event::exportListByUserId($owner_uid, $format);
|
|
||||||
|
|
||||||
if (!$evexport["success"]) {
|
|
||||||
if ($evexport["content"]) {
|
|
||||||
DI::sysmsg()->addNotice(DI::l10n()->t('This calendar format is not supported'));
|
|
||||||
} else {
|
|
||||||
DI::sysmsg()->addNotice(DI::l10n()->t('No exportable data found'));
|
|
||||||
}
|
|
||||||
|
|
||||||
// If it the own calendar return to the events page
|
|
||||||
// otherwise to the profile calendar page
|
|
||||||
if (DI::userSession()->getLocalUserId() === $owner_uid) {
|
|
||||||
$return_path = "events";
|
|
||||||
} else {
|
|
||||||
$return_path = "cal/" . $nick;
|
|
||||||
}
|
|
||||||
|
|
||||||
DI::baseUrl()->redirect($return_path);
|
|
||||||
}
|
|
||||||
|
|
||||||
// If nothing went wrong we can echo the export content
|
|
||||||
if ($evexport["success"]) {
|
|
||||||
header('content-disposition: attachment; filename="' . DI::l10n()->t('calendar') . '-' . $nick . '.' . $evexport["extension"] . '"');
|
|
||||||
System::httpExit($evexport["content"], Response::TYPE_BLANK, 'text/calendar');
|
|
||||||
}
|
|
||||||
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -670,7 +670,6 @@ class Event
|
||||||
switch ($format) {
|
switch ($format) {
|
||||||
// Format the exported data as a CSV file.
|
// Format the exported data as a CSV file.
|
||||||
case "csv":
|
case "csv":
|
||||||
header("Content-type: text/csv");
|
|
||||||
$o .= '"Subject", "Start Date", "Start Time", "Description", "End Date", "End Time", "Location"' . PHP_EOL;
|
$o .= '"Subject", "Start Date", "Start Time", "Description", "End Date", "End Time", "Location"' . PHP_EOL;
|
||||||
|
|
||||||
foreach ($events as $event) {
|
foreach ($events as $event) {
|
||||||
|
@ -691,7 +690,6 @@ class Event
|
||||||
|
|
||||||
// Format the exported data as a ics file.
|
// Format the exported data as a ics file.
|
||||||
case "ical":
|
case "ical":
|
||||||
header("Content-type: text/ics");
|
|
||||||
$o = 'BEGIN:VCALENDAR' . PHP_EOL
|
$o = 'BEGIN:VCALENDAR' . PHP_EOL
|
||||||
. 'VERSION:2.0' . PHP_EOL
|
. 'VERSION:2.0' . PHP_EOL
|
||||||
. 'PRODID:-//friendica calendar export//0.1//EN' . PHP_EOL;
|
. 'PRODID:-//friendica calendar export//0.1//EN' . PHP_EOL;
|
||||||
|
@ -705,6 +703,8 @@ class Event
|
||||||
// also long lines SHOULD be split at 75 characters length
|
// also long lines SHOULD be split at 75 characters length
|
||||||
foreach ($events as $event) {
|
foreach ($events as $event) {
|
||||||
$o .= 'BEGIN:VEVENT' . PHP_EOL;
|
$o .= 'BEGIN:VEVENT' . PHP_EOL;
|
||||||
|
$o .= 'UID:' . $event['id'] . PHP_EOL;
|
||||||
|
$o .= 'DTSTAMP:' . DateTimeFormat::utc($event['created'], 'Ymd\THis\Z') . PHP_EOL;
|
||||||
|
|
||||||
if ($event['start']) {
|
if ($event['start']) {
|
||||||
$o .= 'DTSTART:' . DateTimeFormat::utc($event['start'], 'Ymd\THis\Z') . PHP_EOL;
|
$o .= 'DTSTART:' . DateTimeFormat::utc($event['start'], 'Ymd\THis\Z') . PHP_EOL;
|
||||||
|
@ -736,7 +736,6 @@ class Event
|
||||||
}
|
}
|
||||||
|
|
||||||
$o .= 'END:VEVENT' . PHP_EOL;
|
$o .= 'END:VEVENT' . PHP_EOL;
|
||||||
$o .= PHP_EOL;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
$o .= 'END:VCALENDAR' . PHP_EOL;
|
$o .= 'END:VCALENDAR' . PHP_EOL;
|
||||||
|
@ -768,7 +767,7 @@ class Event
|
||||||
return $return;
|
return $return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$fields = ['start', 'finish', 'summary', 'desc', 'location', 'nofinish'];
|
$fields = ['id', 'created', 'start', 'finish', 'summary', 'desc', 'location', 'nofinish'];
|
||||||
|
|
||||||
$conditions = ['uid' => $uid, 'cid' => 0];
|
$conditions = ['uid' => $uid, 'cid' => 0];
|
||||||
|
|
||||||
|
|
109
src/Module/Calendar/Export.php
Normal file
109
src/Module/Calendar/Export.php
Normal file
|
@ -0,0 +1,109 @@
|
||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* @copyright Copyright (C) 2010-2022, the Friendica project
|
||||||
|
*
|
||||||
|
* @license GNU AGPL version 3 or any later version
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
namespace Friendica\Module\Calendar;
|
||||||
|
|
||||||
|
use Friendica\App;
|
||||||
|
use Friendica\BaseModule;
|
||||||
|
use Friendica\Core\L10n;
|
||||||
|
use Friendica\Core\Session\Capability\IHandleUserSessions;
|
||||||
|
use Friendica\Model\Event;
|
||||||
|
use Friendica\Model\User;
|
||||||
|
use Friendica\Module\Response;
|
||||||
|
use Friendica\Navigation\SystemMessages;
|
||||||
|
use Friendica\Network\HTTPException;
|
||||||
|
use Friendica\Util\Profiler;
|
||||||
|
use Psr\Log\LoggerInterface;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Controller to export a calendar from a given user
|
||||||
|
*/
|
||||||
|
class Export extends BaseModule
|
||||||
|
{
|
||||||
|
const EXPORT_ICAL = 'ical';
|
||||||
|
const EXPORT_CSV = 'csv';
|
||||||
|
|
||||||
|
const DEFAULT_EXPORT = self::EXPORT_ICAL;
|
||||||
|
|
||||||
|
/** @var IHandleUserSessions */
|
||||||
|
protected $session;
|
||||||
|
/** @var SystemMessages */
|
||||||
|
protected $sysMessages;
|
||||||
|
|
||||||
|
public function __construct(L10n $l10n, App\BaseURL $baseUrl, App\Arguments $args, LoggerInterface $logger, Profiler $profiler, Response $response, IHandleUserSessions $session, SystemMessages $sysMessages, array $server, array $parameters = [])
|
||||||
|
{
|
||||||
|
parent::__construct($l10n, $baseUrl, $args, $logger, $profiler, $response, $server, $parameters);
|
||||||
|
|
||||||
|
$this->session = $session;
|
||||||
|
$this->sysMessages = $sysMessages;
|
||||||
|
}
|
||||||
|
|
||||||
|
protected function rawContent(array $request = [])
|
||||||
|
{
|
||||||
|
$owner = User::getByNickname($this->parameters['nickname'], ['uid']);
|
||||||
|
if (empty($owner)) {
|
||||||
|
throw new HTTPException\NotFoundException($this->t('User not found.'));
|
||||||
|
}
|
||||||
|
$ownerUid = $owner['uid'];
|
||||||
|
$format = $this->parameters['format'] ?: static::DEFAULT_EXPORT;
|
||||||
|
|
||||||
|
// Get the export data by uid
|
||||||
|
$evexport = Event::exportListByUserId($ownerUid, $format);
|
||||||
|
|
||||||
|
if (!$evexport["success"]) {
|
||||||
|
if ($evexport["content"]) {
|
||||||
|
$this->sysMessages->addNotice($this->t('This calendar format is not supported'));
|
||||||
|
} else {
|
||||||
|
$this->sysMessages->addNotice($this->t('No exportable data found'));
|
||||||
|
}
|
||||||
|
|
||||||
|
// If it is the own calendar return to the events page
|
||||||
|
// otherwise to the profile calendar page
|
||||||
|
if ($this->session->getLocalUserId() === $ownerUid) {
|
||||||
|
$returnPath = 'events';
|
||||||
|
} else {
|
||||||
|
$returnPath = 'events/' . $this->parameters['nickname'];
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->baseUrl->redirect($returnPath);
|
||||||
|
}
|
||||||
|
|
||||||
|
// If nothing went wrong we can echo the export content
|
||||||
|
if ($evexport["success"]) {
|
||||||
|
$this->response->setHeader(sprintf('Content-Disposition: attachment; filename="%s-%s.%s"',
|
||||||
|
$this->t('calendar'),
|
||||||
|
$this->parameters['nickname'],
|
||||||
|
$evexport["extension"]
|
||||||
|
));
|
||||||
|
|
||||||
|
switch ($format) {
|
||||||
|
case static::EXPORT_ICAL:
|
||||||
|
$this->response->setType(Response::TYPE_BLANK, 'text/ics');
|
||||||
|
break;
|
||||||
|
case static::EXPORT_CSV:
|
||||||
|
$this->response->setType(Response::TYPE_BLANK, 'text/csv');
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
|
||||||
|
$this->response->addContent($evexport['content']);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
|
@ -19,7 +19,7 @@
|
||||||
*
|
*
|
||||||
*/
|
*/
|
||||||
|
|
||||||
namespace Friendica\Module\Events;
|
namespace Friendica\Module\Calendar;
|
||||||
|
|
||||||
use Friendica\Core\System;
|
use Friendica\Core\System;
|
||||||
use Friendica\Database\DBA;
|
use Friendica\Database\DBA;
|
||||||
|
@ -51,17 +51,17 @@ class Json extends \Friendica\BaseModule
|
||||||
$start = sprintf('%d-%d-%d %d:%d:%d', $y, $m, 1, 0, 0, 0);
|
$start = sprintf('%d-%d-%d %d:%d:%d', $y, $m, 1, 0, 0, 0);
|
||||||
$finish = sprintf('%d-%d-%d %d:%d:%d', $y, $m, $dim, 23, 59, 59);
|
$finish = sprintf('%d-%d-%d %d:%d:%d', $y, $m, $dim, 23, 59, 59);
|
||||||
|
|
||||||
if (!empty($_GET['start'])) {
|
if (!empty($request['start'])) {
|
||||||
$start = $_GET['start'];
|
$start = $request['start'];
|
||||||
}
|
}
|
||||||
|
|
||||||
if (!empty($_GET['end'])) {
|
if (!empty($request['end'])) {
|
||||||
$finish = $_GET['end'];
|
$finish = $request['end'];
|
||||||
}
|
}
|
||||||
|
|
||||||
// put the event parametes in an array so we can better transmit them
|
// put the event parametes in an array so we can better transmit them
|
||||||
$event_params = [
|
$event_params = [
|
||||||
'event_id' => intval($_GET['id'] ?? 0),
|
'event_id' => intval($request['id'] ?? 0),
|
||||||
'start' => $start,
|
'start' => $start,
|
||||||
'finish' => $finish,
|
'finish' => $finish,
|
||||||
'ignore' => 0,
|
'ignore' => 0,
|
|
@ -365,6 +365,9 @@ return [
|
||||||
|
|
||||||
'/bookmarklet' => [Module\Bookmarklet::class, [R::GET]],
|
'/bookmarklet' => [Module\Bookmarklet::class, [R::GET]],
|
||||||
|
|
||||||
|
'/calendar/{nickname}/export[/{format}]' => [Module\Calendar\Export::class, [R::GET]],
|
||||||
|
'/calendar/json' => [Module\Calendar\Json::class, [R::GET]],
|
||||||
|
|
||||||
'/community[/{content}]' => [Module\Conversation\Community::class, [R::GET]],
|
'/community[/{content}]' => [Module\Conversation\Community::class, [R::GET]],
|
||||||
|
|
||||||
'/compose[/{type}]' => [Module\Item\Compose::class, [R::GET, R::POST]],
|
'/compose[/{type}]' => [Module\Item\Compose::class, [R::GET, R::POST]],
|
||||||
|
@ -398,8 +401,6 @@ return [
|
||||||
'/dirfind' => [Module\Search\Directory::class, [R::GET]],
|
'/dirfind' => [Module\Search\Directory::class, [R::GET]],
|
||||||
'/directory' => [Module\Directory::class, [R::GET]],
|
'/directory' => [Module\Directory::class, [R::GET]],
|
||||||
|
|
||||||
'/events/json' => [Module\Events\Json::class, [R::GET]],
|
|
||||||
|
|
||||||
'/featured/{nickname}' => [Module\ActivityPub\Featured::class, [R::GET]],
|
'/featured/{nickname}' => [Module\ActivityPub\Featured::class, [R::GET]],
|
||||||
|
|
||||||
'/feed' => [
|
'/feed' => [
|
||||||
|
|
|
@ -8,7 +8,7 @@ msgid ""
|
||||||
msgstr ""
|
msgstr ""
|
||||||
"Project-Id-Version: 2022.12-dev\n"
|
"Project-Id-Version: 2022.12-dev\n"
|
||||||
"Report-Msgid-Bugs-To: \n"
|
"Report-Msgid-Bugs-To: \n"
|
||||||
"POT-Creation-Date: 2022-10-31 19:59+0000\n"
|
"POT-Creation-Date: 2022-11-02 14:17+0000\n"
|
||||||
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n"
|
||||||
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
"Last-Translator: FULL NAME <EMAIL@ADDRESS>\n"
|
||||||
"Language-Team: LANGUAGE <LL@li.org>\n"
|
"Language-Team: LANGUAGE <LL@li.org>\n"
|
||||||
|
@ -18,7 +18,7 @@ msgstr ""
|
||||||
"Content-Transfer-Encoding: 8bit\n"
|
"Content-Transfer-Encoding: 8bit\n"
|
||||||
|
|
||||||
|
|
||||||
#: mod/cal.php:45 mod/cal.php:49 mod/redir.php:35 mod/redir.php:176
|
#: mod/cal.php:44 mod/cal.php:48 mod/redir.php:35 mod/redir.php:176
|
||||||
#: src/Module/Contact/Follow.php:69 src/Module/Conversation/Community.php:193
|
#: src/Module/Contact/Follow.php:69 src/Module/Conversation/Community.php:193
|
||||||
#: src/Module/Debug/ItemBody.php:38 src/Module/Diaspora/Receive.php:57
|
#: src/Module/Debug/ItemBody.php:38 src/Module/Diaspora/Receive.php:57
|
||||||
#: src/Module/Item/Follow.php:41 src/Module/Item/Ignore.php:41
|
#: src/Module/Item/Follow.php:41 src/Module/Item/Ignore.php:41
|
||||||
|
@ -27,8 +27,9 @@ msgstr ""
|
||||||
msgid "Access denied."
|
msgid "Access denied."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:62 mod/cal.php:79 mod/photos.php:68 mod/photos.php:139
|
#: mod/cal.php:61 mod/cal.php:78 mod/photos.php:68 mod/photos.php:139
|
||||||
#: mod/photos.php:793 src/Model/Profile.php:234 src/Module/Feed.php:72
|
#: mod/photos.php:793 src/Model/Profile.php:234
|
||||||
|
#: src/Module/Calendar/Export.php:63 src/Module/Feed.php:72
|
||||||
#: src/Module/HCard.php:51 src/Module/Profile/Common.php:40
|
#: src/Module/HCard.php:51 src/Module/Profile/Common.php:40
|
||||||
#: src/Module/Profile/Common.php:51 src/Module/Profile/Contacts.php:39
|
#: src/Module/Profile/Common.php:51 src/Module/Profile/Contacts.php:39
|
||||||
#: src/Module/Profile/Contacts.php:49 src/Module/Profile/Media.php:38
|
#: src/Module/Profile/Contacts.php:49 src/Module/Profile/Media.php:38
|
||||||
|
@ -38,73 +39,54 @@ msgstr ""
|
||||||
msgid "User not found."
|
msgid "User not found."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:121 mod/display.php:259 src/Module/Profile/Profile.php:93
|
#: mod/cal.php:113 mod/display.php:259 src/Module/Profile/Profile.php:93
|
||||||
#: src/Module/Profile/Profile.php:108 src/Module/Profile/Status.php:109
|
#: src/Module/Profile/Profile.php:108 src/Module/Profile/Status.php:109
|
||||||
#: src/Module/Update/Profile.php:55
|
#: src/Module/Update/Profile.php:55
|
||||||
msgid "Access to this profile has been restricted."
|
msgid "Access to this profile has been restricted."
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:242 mod/events.php:375 src/Content/Nav.php:196
|
#: mod/cal.php:234 mod/events.php:375 src/Content/Nav.php:196
|
||||||
#: src/Content/Nav.php:260 src/Module/BaseProfile.php:84
|
#: src/Content/Nav.php:260 src/Module/BaseProfile.php:84
|
||||||
#: src/Module/BaseProfile.php:95 view/theme/frio/theme.php:241
|
#: src/Module/BaseProfile.php:95 view/theme/frio/theme.php:241
|
||||||
#: view/theme/frio/theme.php:245
|
#: view/theme/frio/theme.php:245
|
||||||
msgid "Events"
|
msgid "Events"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:243 mod/events.php:376
|
#: mod/cal.php:235 mod/events.php:376
|
||||||
msgid "View"
|
msgid "View"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:244 mod/events.php:378
|
#: mod/cal.php:236 mod/events.php:378
|
||||||
msgid "Previous"
|
msgid "Previous"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:245 mod/events.php:379 src/Module/Install.php:214
|
#: mod/cal.php:237 mod/events.php:379 src/Module/Install.php:214
|
||||||
msgid "Next"
|
msgid "Next"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:248 mod/events.php:384 src/Model/Event.php:460
|
#: mod/cal.php:240 mod/events.php:384 src/Model/Event.php:460
|
||||||
msgid "today"
|
msgid "today"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:249 mod/events.php:385 src/Model/Event.php:461
|
#: mod/cal.php:241 mod/events.php:385 src/Model/Event.php:461
|
||||||
#: src/Util/Temporal.php:341
|
#: src/Util/Temporal.php:341
|
||||||
msgid "month"
|
msgid "month"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:250 mod/events.php:386 src/Model/Event.php:462
|
#: mod/cal.php:242 mod/events.php:386 src/Model/Event.php:462
|
||||||
#: src/Util/Temporal.php:342
|
#: src/Util/Temporal.php:342
|
||||||
msgid "week"
|
msgid "week"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:251 mod/events.php:387 src/Model/Event.php:463
|
#: mod/cal.php:243 mod/events.php:387 src/Model/Event.php:463
|
||||||
#: src/Util/Temporal.php:343
|
#: src/Util/Temporal.php:343
|
||||||
msgid "day"
|
msgid "day"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:252 mod/events.php:388
|
#: mod/cal.php:244 mod/events.php:388
|
||||||
msgid "list"
|
msgid "list"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/cal.php:264 src/Console/User.php:182 src/Model/User.php:663
|
|
||||||
#: src/Module/Admin/Users/Active.php:73 src/Module/Admin/Users/Blocked.php:74
|
|
||||||
#: src/Module/Admin/Users/Index.php:80 src/Module/Admin/Users/Pending.php:71
|
|
||||||
#: src/Module/Api/Twitter/ContactEndpoint.php:74
|
|
||||||
msgid "User not found"
|
|
||||||
msgstr ""
|
|
||||||
|
|
||||||
#: mod/cal.php:273
|
|
||||||
msgid "This calendar format is not supported"
|
|
||||||
msgstr ""
|
|
||||||
|
|
||||||
#: mod/cal.php:275
|
|
||||||
msgid "No exportable data found"
|
|
||||||
msgstr ""
|
|
||||||
|
|
||||||
#: mod/cal.php:291
|
|
||||||
msgid "calendar"
|
|
||||||
msgstr ""
|
|
||||||
|
|
||||||
#: mod/display.php:140 mod/photos.php:797
|
#: mod/display.php:140 mod/photos.php:797
|
||||||
#: src/Module/Conversation/Community.php:187 src/Module/Directory.php:48
|
#: src/Module/Conversation/Community.php:187 src/Module/Directory.php:48
|
||||||
#: src/Module/Search/Index.php:64
|
#: src/Module/Search/Index.php:64
|
||||||
|
@ -391,7 +373,7 @@ msgid "Description:"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: mod/events.php:505 src/Content/Widget/VCard.php:104 src/Model/Event.php:80
|
#: mod/events.php:505 src/Content/Widget/VCard.php:104 src/Model/Event.php:80
|
||||||
#: src/Model/Event.php:107 src/Model/Event.php:469 src/Model/Event.php:919
|
#: src/Model/Event.php:107 src/Model/Event.php:469 src/Model/Event.php:918
|
||||||
#: src/Model/Profile.php:373 src/Module/Contact/Profile.php:370
|
#: src/Model/Profile.php:373 src/Module/Contact/Profile.php:370
|
||||||
#: src/Module/Directory.php:147 src/Module/Notifications/Introductions.php:187
|
#: src/Module/Directory.php:147 src/Module/Notifications/Introductions.php:187
|
||||||
#: src/Module/Profile/Profile.php:193
|
#: src/Module/Profile/Profile.php:193
|
||||||
|
@ -1629,6 +1611,13 @@ msgstr ""
|
||||||
msgid "Enter user nickname: "
|
msgid "Enter user nickname: "
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
#: src/Console/User.php:182 src/Model/User.php:663
|
||||||
|
#: src/Module/Admin/Users/Active.php:73 src/Module/Admin/Users/Blocked.php:74
|
||||||
|
#: src/Module/Admin/Users/Index.php:80 src/Module/Admin/Users/Pending.php:71
|
||||||
|
#: src/Module/Api/Twitter/ContactEndpoint.php:74
|
||||||
|
msgid "User not found"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
#: src/Console/User.php:202
|
#: src/Console/User.php:202
|
||||||
msgid "Enter new password: "
|
msgid "Enter new password: "
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
@ -3548,12 +3537,12 @@ msgid "l F d, Y \\@ g:i A \\G\\M\\TP (e)"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:73 src/Model/Event.php:90 src/Model/Event.php:467
|
#: src/Model/Event.php:73 src/Model/Event.php:90 src/Model/Event.php:467
|
||||||
#: src/Model/Event.php:901
|
#: src/Model/Event.php:900
|
||||||
msgid "Starts:"
|
msgid "Starts:"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:76 src/Model/Event.php:96 src/Model/Event.php:468
|
#: src/Model/Event.php:76 src/Model/Event.php:96 src/Model/Event.php:468
|
||||||
#: src/Model/Event.php:905
|
#: src/Model/Event.php:904
|
||||||
msgid "Finishes:"
|
msgid "Finishes:"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
@ -3585,32 +3574,32 @@ msgstr ""
|
||||||
msgid "Delete event"
|
msgid "Delete event"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:857 src/Module/Debug/Localtime.php:38
|
#: src/Model/Event.php:856 src/Module/Debug/Localtime.php:38
|
||||||
msgid "l F d, Y \\@ g:i A"
|
msgid "l F d, Y \\@ g:i A"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:858
|
#: src/Model/Event.php:857
|
||||||
msgid "D g:i A"
|
msgid "D g:i A"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:859
|
#: src/Model/Event.php:858
|
||||||
msgid "g:i A"
|
msgid "g:i A"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:920 src/Model/Event.php:922
|
#: src/Model/Event.php:919 src/Model/Event.php:921
|
||||||
msgid "Show map"
|
msgid "Show map"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:921
|
#: src/Model/Event.php:920
|
||||||
msgid "Hide map"
|
msgid "Hide map"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:1014
|
#: src/Model/Event.php:1013
|
||||||
#, php-format
|
#, php-format
|
||||||
msgid "%s's birthday"
|
msgid "%s's birthday"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
#: src/Model/Event.php:1015
|
#: src/Model/Event.php:1014
|
||||||
#, php-format
|
#, php-format
|
||||||
msgid "Happy Birthday %s"
|
msgid "Happy Birthday %s"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
@ -6677,6 +6666,18 @@ msgstr ""
|
||||||
msgid "The post was created"
|
msgid "The post was created"
|
||||||
msgstr ""
|
msgstr ""
|
||||||
|
|
||||||
|
#: src/Module/Calendar/Export.php:73
|
||||||
|
msgid "This calendar format is not supported"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: src/Module/Calendar/Export.php:75
|
||||||
|
msgid "No exportable data found"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
|
#: src/Module/Calendar/Export.php:92
|
||||||
|
msgid "calendar"
|
||||||
|
msgstr ""
|
||||||
|
|
||||||
#: src/Module/Contact.php:88
|
#: src/Module/Contact.php:88
|
||||||
#, php-format
|
#, php-format
|
||||||
msgid "%d contact edited."
|
msgid "%d contact edited."
|
||||||
|
|
|
@ -81,7 +81,7 @@
|
||||||
week: '{{$i18n.week|escape:'quotes'}}',
|
week: '{{$i18n.week|escape:'quotes'}}',
|
||||||
day: '{{$i18n.day|escape:'quotes'}}'
|
day: '{{$i18n.day|escape:'quotes'}}'
|
||||||
},
|
},
|
||||||
events: '{{$baseurl}}{{$module_url}}/json/',
|
events: '{{$baseurl}}/calendar/json',
|
||||||
header: {
|
header: {
|
||||||
left: 'prev,next today',
|
left: 'prev,next today',
|
||||||
center: 'title',
|
center: 'title',
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
<h3>{{$etitle}}</h3>
|
<h3>{{$etitle}}</h3>
|
||||||
|
|
||||||
<ul class="sidebar-calendar-export-ul">
|
<ul class="sidebar-calendar-export-ul">
|
||||||
<li role="menuitem" class="sidebar-calendar-export-li"><a href="{{$baseurl}}/cal/{{$user}}/export/ical">{{$export_ical}}</a></li>
|
<li role="menuitem" class="sidebar-calendar-export-li"><a href="{{$baseurl}}/calendar/{{$user}}/export/ical">{{$export_ical}}</a></li>
|
||||||
<li role="menuitem" class="sidebar-calendar-export-li"><a href="{{$baseurl}}/cal/{{$user}}/export/csv">{{$export_csv}}</a></li>
|
<li role="menuitem" class="sidebar-calendar-export-li"><a href="{{$baseurl}}/calendar/{{$user}}/export/csv">{{$export_csv}}</a></li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
|
|
|
@ -22,7 +22,7 @@
|
||||||
year: yesterday.getFullYear(),
|
year: yesterday.getFullYear(),
|
||||||
month: yesterday.getMonth(),
|
month: yesterday.getMonth(),
|
||||||
date: yesterday.getDate(),
|
date: yesterday.getDate(),
|
||||||
events: '{{$baseurl}}/events/json/',
|
events: '{{$baseurl}}/calendar/json',
|
||||||
header: false,
|
header: false,
|
||||||
timeFormat: 'H(:mm)',
|
timeFormat: 'H(:mm)',
|
||||||
defaultView: 'basicWeek',
|
defaultView: 'basicWeek',
|
||||||
|
|
|
@ -87,7 +87,7 @@
|
||||||
week: '{{$i18n.week|escape:'quotes'}}',
|
week: '{{$i18n.week|escape:'quotes'}}',
|
||||||
day: '{{$i18n.day|escape:'quotes'}}'
|
day: '{{$i18n.day|escape:'quotes'}}'
|
||||||
},
|
},
|
||||||
events: '{{$baseurl}}{{$module_url}}/json/',
|
events: '{{$baseurl}}/calendar/json',
|
||||||
header: {
|
header: {
|
||||||
left: 'prev,next today',
|
left: 'prev,next today',
|
||||||
center: 'title',
|
center: 'title',
|
||||||
|
|
Loading…
Reference in a new issue