mirror of
https://github.com/Karaka-Management/oms-News.git
synced 2026-02-15 16:08:42 +00:00
bug fixes and permission tests
This commit is contained in:
parent
46b8229720
commit
f76af5afc1
|
|
@ -143,6 +143,13 @@
|
||||||
"null": false,
|
"null": false,
|
||||||
"foreignTable": "account",
|
"foreignTable": "account",
|
||||||
"foreignKey": "account_id"
|
"foreignKey": "account_id"
|
||||||
|
},
|
||||||
|
"news_seen_news": {
|
||||||
|
"name": "news_seen_news",
|
||||||
|
"type": "INT",
|
||||||
|
"null": false,
|
||||||
|
"foreignTable": "news",
|
||||||
|
"foreignKey": "news_id"
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -70,39 +70,38 @@ final class BackendController extends Controller implements DashboardElementInte
|
||||||
|
|
||||||
if ($request->getData('ptype') === 'p') {
|
if ($request->getData('ptype') === 'p') {
|
||||||
$view->setData('news',
|
$view->setData('news',
|
||||||
$mapperQuery->where('id', (int) ($request->getData('id') ?? 0), '<')
|
$data = $mapperQuery->where('id', (int) ($request->getData('id') ?? 0), '<')
|
||||||
->limit(25)->execute()
|
->limit(25)->execute()
|
||||||
);
|
);
|
||||||
} elseif ($request->getData('ptype') === 'n') {
|
} elseif ($request->getData('ptype') === 'n') {
|
||||||
$view->setData('news',
|
$view->setData('news',
|
||||||
$mapperQuery->where('id', (int) ($request->getData('id') ?? 0), '>')
|
$data = $mapperQuery->where('id', (int) ($request->getData('id') ?? 0), '>')
|
||||||
->limit(25)->execute()
|
->limit(25)->execute()
|
||||||
);
|
);
|
||||||
} else {
|
} else {
|
||||||
$view->setData('news',
|
$view->setData('news',
|
||||||
$mapperQuery->where('id', 0, '>')
|
$data = $mapperQuery->where('id', 0, '>')
|
||||||
->limit(25)->execute()
|
->limit(25)->execute()
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$seen = NewsSeenMapper::get()->where('seenBy', $request->header->account)->execute();
|
$ids = [];
|
||||||
$view->setData('seen', $seen->seenAt);
|
foreach ($data as $news) {
|
||||||
|
$ids[] = $news->getId();
|
||||||
// @async
|
|
||||||
// @todo: Seen needs field which defines which news article is seen!!!!
|
|
||||||
if ($seen instanceof NullNewsSeen) {
|
|
||||||
$seen = new NewsSeen();
|
|
||||||
$seen->seenBy = (int) $request->header->account;
|
|
||||||
$seen->seenAt = new \DateTime('now');
|
|
||||||
|
|
||||||
NewsSeenMapper::create()->execute($seen);
|
|
||||||
} else {
|
|
||||||
$newSeen = clone $seen;
|
|
||||||
$newSeen->seenAt = new \DateTime('now');
|
|
||||||
|
|
||||||
NewsSeenMapper::update()->execute($newSeen);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$seenObjects = NewsSeenMapper::getAll()
|
||||||
|
->where('seenBy', $request->header->account)
|
||||||
|
->where('news', $ids, 'in')
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
$seen = [];
|
||||||
|
foreach ($seenObjects as $seenObject) {
|
||||||
|
$seen[] = $seenObject->news;
|
||||||
|
}
|
||||||
|
|
||||||
|
$view->setData('seen', $seen);
|
||||||
|
|
||||||
return $view;
|
return $view;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -172,6 +171,20 @@ final class BackendController extends Controller implements DashboardElementInte
|
||||||
return $view;
|
return $view;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
$seen = NewsSeenMapper::get()
|
||||||
|
->where('news', (int) $request->getData('id'))
|
||||||
|
->where('seenBy', $request->header->account)
|
||||||
|
->execute();
|
||||||
|
|
||||||
|
if ($seen instanceof NullNewsSeen) {
|
||||||
|
$seen = new NewsSeen();
|
||||||
|
$seen->seenBy = (int) $request->header->account;
|
||||||
|
$seen->news = (int) $request->getData('id');
|
||||||
|
$seen->seenAt = new \DateTime('now');
|
||||||
|
|
||||||
|
NewsSeenMapper::create()->execute($seen);
|
||||||
|
}
|
||||||
|
|
||||||
$view->setTemplate('/Modules/News/Theme/Backend/news-single');
|
$view->setTemplate('/Modules/News/Theme/Backend/news-single');
|
||||||
$view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1000601001, $request, $response));
|
$view->addData('nav', $this->app->moduleManager->get('Navigation')->createNavigationMid(1000601001, $request, $response));
|
||||||
$view->addData('news', $article);
|
$view->addData('news', $article);
|
||||||
|
|
|
||||||
|
|
@ -36,6 +36,8 @@ class NewsSeen
|
||||||
|
|
||||||
public int $seenBy = 0;
|
public int $seenBy = 0;
|
||||||
|
|
||||||
|
public int $news = 0;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Constructor.
|
* Constructor.
|
||||||
*
|
*
|
||||||
|
|
|
||||||
|
|
@ -23,11 +23,6 @@ use phpOMS\DataStorage\Database\Mapper\DataMapperFactory;
|
||||||
* @license OMS License 1.0
|
* @license OMS License 1.0
|
||||||
* @link https://orange-management.org
|
* @link https://orange-management.org
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*
|
|
||||||
* @todo Orange-Management/oms-News#???
|
|
||||||
* Too complicated select.
|
|
||||||
* I think the default getAll etc. is too complicated and has too many joins which are not really required.
|
|
||||||
* Check and fix!
|
|
||||||
*/
|
*/
|
||||||
final class NewsSeenMapper extends DataMapperFactory
|
final class NewsSeenMapper extends DataMapperFactory
|
||||||
{
|
{
|
||||||
|
|
@ -38,9 +33,10 @@ final class NewsSeenMapper extends DataMapperFactory
|
||||||
* @since 1.0.0
|
* @since 1.0.0
|
||||||
*/
|
*/
|
||||||
public const COLUMNS = [
|
public const COLUMNS = [
|
||||||
'news_seen_id' => ['name' => 'news_seen_id', 'type' => 'int', 'internal' => 'id'],
|
'news_seen_id' => ['name' => 'news_seen_id', 'type' => 'int', 'internal' => 'id'],
|
||||||
'news_seen_at' => ['name' => 'news_seen_at', 'type' => 'DateTime', 'internal' => 'seenAt'],
|
'news_seen_at' => ['name' => 'news_seen_at', 'type' => 'DateTime', 'internal' => 'seenAt'],
|
||||||
'news_seen_by' => ['name' => 'news_seen_by', 'type' => 'int', 'internal' => 'seenBy'],
|
'news_seen_news' => ['name' => 'news_seen_news', 'type' => 'int', 'internal' => 'news'],
|
||||||
|
'news_seen_by' => ['name' => 'news_seen_by', 'type' => 'int', 'internal' => 'seenBy'],
|
||||||
];
|
];
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
|
||||||
|
|
@ -18,7 +18,7 @@ use phpOMS\Utils\Parser\Markdown\Markdown;
|
||||||
/** @var \phpOMS\Views\View $this */
|
/** @var \phpOMS\Views\View $this */
|
||||||
/** @var \Modules\News\Models\NewsArticle[] $newsList */
|
/** @var \Modules\News\Models\NewsArticle[] $newsList */
|
||||||
$newsList = $this->getData('news');
|
$newsList = $this->getData('news');
|
||||||
$seenAt = $this->getData('seen');
|
$seen = $this->getData('seen') ?? [];
|
||||||
|
|
||||||
$previous = empty($newsList) ? '{/prefix}news/dashboard' : '{/prefix}news/dashboard?{?}&id=' . \reset($newsList)->getId() . '&ptype=p';
|
$previous = empty($newsList) ? '{/prefix}news/dashboard' : '{/prefix}news/dashboard?{?}&id=' . \reset($newsList)->getId() . '&ptype=p';
|
||||||
$next = empty($newsList) ? '{/prefix}news/dashboard' : '{/prefix}news/dashboard?{?}&id=' . \end($newsList)->getId() . '&ptype=n';
|
$next = empty($newsList) ? '{/prefix}news/dashboard' : '{/prefix}news/dashboard?{?}&id=' . \end($newsList)->getId() . '&ptype=n';
|
||||||
|
|
@ -32,13 +32,13 @@ echo $this->getData('nav')->render(); ?>
|
||||||
?>
|
?>
|
||||||
<div class="portlet">
|
<div class="portlet">
|
||||||
<div class="portlet-head">
|
<div class="portlet-head">
|
||||||
<?= $seenAt->getTimestamp() < $news->publish->getTimestamp() ? '<strong>' : ''; ?>
|
<?= !($isSeen = \in_array($news->getId(), $seen)) ? '<strong>' : ''; ?>
|
||||||
<a href="<?= $url; ?>"><?= $this->printHtml($news->title); ?></a>
|
<a href="<?= $url; ?>"><?= $this->printHtml($news->title); ?></a>
|
||||||
<span class="floatRight">
|
<span class="floatRight">
|
||||||
<a class="content" href="<?= $profile; ?>"><?= $this->printHtml($news->createdBy->name3 . ' ' . $news->createdBy->name2 . ' ' . $news->createdBy->name1); ?>
|
<a class="content" href="<?= $profile; ?>"><?= $this->printHtml($news->createdBy->name3 . ' ' . $news->createdBy->name2 . ' ' . $news->createdBy->name1); ?>
|
||||||
</a> - <?= $news->publish->format('Y-m-d'); ?>
|
</a> - <?= $news->publish->format('Y-m-d'); ?>
|
||||||
</span>
|
</span>
|
||||||
<?= $seenAt->getTimestamp() < $news->publish->getTimestamp() ? '</strong>' : ''; ?>
|
<?= !$isSeen ? '</strong>' : ''; ?>
|
||||||
</div>
|
</div>
|
||||||
<div class="portlet-body">
|
<div class="portlet-body">
|
||||||
<article>
|
<article>
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user