. */ declare(strict_types=1); namespace Fisharebest\Webtrees\Module; use Fisharebest\Webtrees\Auth; use Fisharebest\Webtrees\Carbon; use Fisharebest\Webtrees\I18N; use Fisharebest\Webtrees\Tree; use Illuminate\Database\Capsule\Manager as DB; use stdClass; use Symfony\Component\HttpFoundation\RedirectResponse; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\HttpFoundation\Response; use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException; /** * Class UserJournalModule */ class UserJournalModule extends AbstractModule implements ModuleBlockInterface { use ModuleBlockTrait; /** * How should this module be identified in the control panel, etc.? * * @return string */ public function title(): string { /* I18N: Name of a module */ return I18N::translate('Journal'); } /** * A sentence describing what this module does. * * @return string */ public function description(): string { /* I18N: Description of the “Journal” module */ return I18N::translate('A private area to record notes or keep a journal.'); } /** * Generate the HTML content of this block. * * @param Tree $tree * @param int $block_id * @param string $ctype * @param string[] $cfg * * @return string */ public function getBlock(Tree $tree, int $block_id, string $ctype = '', array $cfg = []): string { $articles = DB::table('news') ->where('user_id', '=', Auth::id()) ->orderByDesc('updated') ->get() ->map(function (stdClass $row): stdClass { $row->updated = Carbon::make($row->updated); return $row; }); $content = view('modules/user_blog/list', [ 'articles' => $articles, 'block_id' => $block_id, 'limit' => 5, ]); if ($ctype !== '') { return view('modules/block-template', [ 'block' => str_replace('_', '-', $this->name()), 'id' => $block_id, 'config_url' => '', 'title' => $this->title(), 'content' => $content, ]); } return $content; } /** {@inheritdoc} */ public function loadAjax(): bool { return false; } /** {@inheritdoc} */ public function isUserBlock(): bool { return true; } /** {@inheritdoc} */ public function isTreeBlock(): bool { return false; } /** * Update the configuration for a block. * * @param Request $request * @param int $block_id * * @return void */ public function saveBlockConfiguration(Request $request, int $block_id) { } /** * An HTML form to edit block settings * * @param Tree $tree * @param int $block_id * * @return void */ public function editBlockConfiguration(Tree $tree, int $block_id) { } /** * @param Request $request * * @return Response */ public function getEditJournalAction(Request $request): Response { if (!Auth::check()) { throw new AccessDeniedHttpException(); } $news_id = $request->get('news_id'); if ($news_id > 0) { $row = DB::table('news') ->where('news_id', '=', $news_id) ->where('user_id', '=', Auth::id()) ->first(); } else { $row = (object) [ 'body' => '', 'subject' => '', ]; } $title = I18N::translate('Add/edit a journal/news entry'); return $this->viewResponse('modules/user_blog/edit', [ 'body' => $row->body, 'news_id' => $news_id, 'subject' => $row->subject, 'title' => $title, ]); } /** * @param Request $request * @param Tree $tree * * @return RedirectResponse */ public function postEditJournalAction(Request $request, Tree $tree): RedirectResponse { if (!Auth::check()) { throw new AccessDeniedHttpException(); } $news_id = $request->get('news_id'); $subject = $request->get('subject'); $body = $request->get('body'); if ($news_id > 0) { DB::table('news') ->where('news_id', '=', $news_id) ->where('user_id', '=', Auth::id()) ->update([ 'body' => $body, 'subject' => $subject, ]); } else { DB::table('news')->insert([ 'body' => $body, 'subject' => $subject, 'user_id' => Auth::id(), ]); } $url = route('user-page', [ 'ged' => $tree->name(), ]); return new RedirectResponse($url); } /** * @param Request $request * @param Tree $tree * * @return RedirectResponse */ public function postDeleteJournalAction(Request $request, Tree $tree): RedirectResponse { $news_id = $request->get('news_id'); DB::table('news') ->where('news_id', '=', $news_id) ->where('user_id', '=', Auth::id()) ->delete(); $url = route('user-page', [ 'ged' => $tree->name(), ]); return new RedirectResponse($url); } }