AttachmentShowRelated.php 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445
  1. <?php
  2. // {{{ License
  3. // This file is part of GNU social - https://www.gnu.org/software/social
  4. //
  5. // GNU social is free software: you can redistribute it and/or modify
  6. // it under the terms of the GNU Affero General Public License as published by
  7. // the Free Software Foundation, either version 3 of the License, or
  8. // (at your option) any later version.
  9. //
  10. // GNU social is distributed in the hope that it will be useful,
  11. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  12. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  13. // GNU Affero General Public License for more details.
  14. //
  15. // You should have received a copy of the GNU Affero General Public License
  16. // along with GNU social. If not, see <http://www.gnu.org/licenses/>.
  17. // }}}
  18. namespace Plugin\AttachmentShowRelated;
  19. use App\Core\DB\DB;
  20. use App\Core\Event;
  21. use App\Core\Modules\Plugin;
  22. use App\Util\Formatting;
  23. class AttachmentShowRelated extends Plugin
  24. {
  25. public function onAppendRightPanelBlock($vars, &$res): bool
  26. {
  27. if ($vars['path'] == 'attachment_show') {
  28. $related_notes = DB::dql('select n from attachment_to_note an ' .
  29. 'join note n with n.id = an.note_id ' .
  30. 'where an.attachment_id = :attachment_id', ['attachment_id' => $vars['vars']['attachment_id']]);
  31. $related_tags = DB::dql('select distinct t.tag ' .
  32. 'from attachment_to_note an join note_tag t with an.note_id = t.note_id ' .
  33. 'where an.attachment_id = :attachment_id', ['attachment_id' => $vars['vars']['attachment_id']]);
  34. $res[] = Formatting::twigRenderFile('attachmentShowRelated/attachmentRelatedNotes.html.twig', ['related_notes' => $related_notes]);
  35. $res[] = Formatting::twigRenderFile('attachmentShowRelated/attachmentRelatedTags.html.twig', ['related_tags' => $related_tags]);
  36. }
  37. return Event::next;
  38. }
  39. }