2020-01-22 23:18:14 +01:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Friendica\Module;
|
|
|
|
|
|
|
|
use Exception;
|
|
|
|
use Friendica\BaseModule;
|
|
|
|
use Friendica\Content\Pager;
|
|
|
|
use Friendica\Core\Renderer;
|
|
|
|
use Friendica\Core\System;
|
|
|
|
use Friendica\DI;
|
2020-01-24 18:32:38 +01:00
|
|
|
use Friendica\Model\Notification;
|
2020-01-22 23:18:14 +01:00
|
|
|
use Friendica\Network\HTTPException\ForbiddenException;
|
|
|
|
|
2020-01-22 23:31:00 +01:00
|
|
|
/**
|
|
|
|
* Base Module for each tab of the notification display
|
|
|
|
*
|
|
|
|
* General possibility to print it as JSON as well
|
|
|
|
*/
|
2020-01-22 23:18:14 +01:00
|
|
|
abstract class BaseNotifications extends BaseModule
|
|
|
|
{
|
|
|
|
/** @var array Array of URL parameters */
|
|
|
|
const URL_TYPES = [
|
2020-01-24 18:32:38 +01:00
|
|
|
Notification::NETWORK => 'network',
|
|
|
|
Notification::SYSTEM => 'system',
|
|
|
|
Notification::HOME => 'home',
|
|
|
|
Notification::PERSONAL => 'personal',
|
|
|
|
Notification::INTRO => 'intros',
|
2020-01-22 23:18:14 +01:00
|
|
|
];
|
|
|
|
|
|
|
|
/** @var array Array of the allowed notifies and their printable name */
|
|
|
|
const PRINT_TYPES = [
|
2020-01-24 18:32:38 +01:00
|
|
|
Notification::NETWORK => 'Network',
|
|
|
|
Notification::SYSTEM => 'System',
|
|
|
|
Notification::HOME => 'Home',
|
|
|
|
Notification::PERSONAL => 'Personal',
|
|
|
|
Notification::INTRO => 'Introductions',
|
2020-01-22 23:18:14 +01:00
|
|
|
];
|
|
|
|
|
2020-01-24 18:32:38 +01:00
|
|
|
/** @var array The array of access keys for notification pages */
|
2020-01-22 23:18:14 +01:00
|
|
|
const ACCESS_KEYS = [
|
2020-01-24 18:32:38 +01:00
|
|
|
Notification::NETWORK => 'w',
|
|
|
|
Notification::SYSTEM => 'y',
|
|
|
|
Notification::HOME => 'h',
|
|
|
|
Notification::PERSONAL => 'r',
|
|
|
|
Notification::INTRO => 'i',
|
2020-01-22 23:18:14 +01:00
|
|
|
];
|
|
|
|
|
2020-01-22 23:31:00 +01:00
|
|
|
/** @var int The default count of items per page */
|
2020-01-22 23:37:23 +01:00
|
|
|
const ITEMS_PER_PAGE = 20;
|
2020-01-22 23:18:14 +01:00
|
|
|
|
2020-01-22 23:31:00 +01:00
|
|
|
/** @var boolean True, if ALL entries should get shown */
|
2020-01-22 23:37:23 +01:00
|
|
|
protected static $showAll;
|
2020-01-22 23:31:00 +01:00
|
|
|
/** @var int The determined start item of the current page */
|
2020-01-22 23:37:23 +01:00
|
|
|
protected static $firstItemNum;
|
2020-01-22 23:18:14 +01:00
|
|
|
|
|
|
|
/**
|
2020-01-24 18:32:38 +01:00
|
|
|
* Collects all notifications from the backend
|
2020-01-22 23:18:14 +01:00
|
|
|
*
|
|
|
|
* @return array The determined notification array
|
2020-01-24 18:32:38 +01:00
|
|
|
* ['header', 'notifications']
|
2020-01-22 23:18:14 +01:00
|
|
|
*/
|
2020-01-24 18:32:38 +01:00
|
|
|
abstract public static function getNotifications();
|
2020-01-22 23:18:14 +01:00
|
|
|
|
|
|
|
public static function init(array $parameters = [])
|
|
|
|
{
|
|
|
|
if (!local_user()) {
|
|
|
|
throw new ForbiddenException(DI::l10n()->t('Permission denied.'));
|
|
|
|
}
|
|
|
|
|
|
|
|
$page = ($_REQUEST['page'] ?? 0) ?: 1;
|
|
|
|
|
2020-01-22 23:37:23 +01:00
|
|
|
self::$firstItemNum = ($page * self::ITEMS_PER_PAGE) - self::ITEMS_PER_PAGE;
|
|
|
|
self::$showAll = ($_REQUEST['show'] ?? '') === 'all';
|
2020-01-22 23:18:14 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
public static function post(array $parameters = [])
|
|
|
|
{
|
|
|
|
$request_id = DI::args()->get(1);
|
|
|
|
|
|
|
|
if ($request_id === 'all') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($request_id) {
|
|
|
|
$intro = DI::intro()->selectFirst(['id' => $request_id, 'uid' => local_user()]);
|
|
|
|
|
|
|
|
switch ($_POST['submit']) {
|
|
|
|
case DI::l10n()->t('Discard'):
|
|
|
|
$intro->discard();
|
|
|
|
break;
|
|
|
|
case DI::l10n()->t('Ignore'):
|
|
|
|
$intro->ignore();
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
DI::baseUrl()->redirect('notifications/intros');
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public static function rawContent(array $parameters = [])
|
|
|
|
{
|
|
|
|
// If the last argument of the query is NOT json, return
|
|
|
|
if (DI::args()->get(DI::args()->getArgc() - 1) !== 'json') {
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2020-01-24 18:32:38 +01:00
|
|
|
System::jsonExit(static::getNotifications()['notifs'] ?? []);
|
2020-01-22 23:18:14 +01:00
|
|
|
}
|
|
|
|
|
2020-01-22 23:31:00 +01:00
|
|
|
/**
|
|
|
|
* Shows the printable result of notifications for a specific tab
|
|
|
|
*
|
2020-01-24 18:32:38 +01:00
|
|
|
* @param string $header The notification header
|
|
|
|
* @param array $content The array with the notifications
|
|
|
|
* @param string $noContent The string in case there are no notifications
|
|
|
|
* @param array $showLink The possible links at the top
|
2020-01-22 23:31:00 +01:00
|
|
|
*
|
|
|
|
* @return string The rendered output
|
|
|
|
*
|
|
|
|
* @throws \Friendica\Network\HTTPException\InternalServerErrorException
|
|
|
|
*/
|
2020-01-24 18:32:38 +01:00
|
|
|
protected static function printContent(string $header, array $content, string $noContent, array $showLink)
|
2020-01-22 23:18:14 +01:00
|
|
|
{
|
|
|
|
// Get the nav tabs for the notification pages
|
|
|
|
$tabs = self::getTabs();
|
|
|
|
|
|
|
|
// Set the pager
|
2020-01-22 23:37:23 +01:00
|
|
|
$pager = new Pager(DI::args()->getQueryString(), self::ITEMS_PER_PAGE);
|
2020-01-22 23:18:14 +01:00
|
|
|
|
2020-01-23 00:16:34 +01:00
|
|
|
$notif_tpl = Renderer::getMarkupTemplate('notifications/notifications.tpl');
|
2020-01-22 23:18:14 +01:00
|
|
|
return Renderer::replaceMacros($notif_tpl, [
|
2020-01-24 18:32:38 +01:00
|
|
|
'$notif_header' => $header ?? DI::l10n()->t('Notifications'),
|
2020-01-22 23:18:14 +01:00
|
|
|
'$tabs' => $tabs,
|
2020-01-24 18:32:38 +01:00
|
|
|
'$notif_content' => $content,
|
|
|
|
'$notif_nocontent' => $noContent,
|
|
|
|
'$notif_show_lnk' => $showLink,
|
|
|
|
'$notif_paginate' => $pager->renderMinimal(count($content))
|
2020-01-22 23:18:14 +01:00
|
|
|
]);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* List of pages for the Notifications TabBar
|
|
|
|
*
|
|
|
|
* @return array with with notifications TabBar data
|
|
|
|
* @throws Exception
|
|
|
|
*/
|
|
|
|
private static function getTabs()
|
|
|
|
{
|
|
|
|
$selected = DI::args()->get(1, '');
|
|
|
|
|
|
|
|
$tabs = [];
|
|
|
|
|
|
|
|
foreach (self::URL_TYPES as $type => $url) {
|
|
|
|
$tabs[] = [
|
|
|
|
'label' => DI::l10n()->t(self::PRINT_TYPES[$type]),
|
|
|
|
'url' => 'notifications/' . $url,
|
|
|
|
'sel' => (($selected == $url) ? 'active' : ''),
|
|
|
|
'id' => $type . '-tab',
|
|
|
|
'accesskey' => self::ACCESS_KEYS[$type],
|
|
|
|
];
|
|
|
|
}
|
|
|
|
|
|
|
|
return $tabs;
|
|
|
|
}
|
|
|
|
}
|