LatexNotes.php 1.8 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061
  1. <?php
  2. declare(strict_types = 1);
  3. // {{{ License
  4. // This file is part of GNU social - https://www.gnu.org/software/social
  5. //
  6. // GNU social is free software: you can redistribute it and/or modify
  7. // it under the terms of the GNU Affero General Public License as published by
  8. // the Free Software Foundation, either version 3 of the License, or
  9. // (at your option) any later version.
  10. //
  11. // GNU social is distributed in the hope that it will be useful,
  12. // but WITHOUT ANY WARRANTY; without even the implied warranty of
  13. // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  14. // GNU Affero General Public License for more details.
  15. //
  16. // You should have received a copy of the GNU Affero General Public License
  17. // along with GNU social. If not, see <http://www.gnu.org/licenses/>.
  18. // }}}
  19. /**
  20. * LaTeX note support for GNU social
  21. *
  22. * @package GNUsocial
  23. * @category Plugin
  24. *
  25. * @author Phablulo <phablulo@gmail.com>
  26. * @copyright 2018-2019, 2021 Free Software Foundation, Inc http://www.fsf.org
  27. * @license https://www.gnu.org/licenses/agpl.html GNU AGPL v3 or later
  28. */
  29. namespace Plugin\LatexNotes;
  30. use App\Core\Event;
  31. use App\Core\Modules\Plugin;
  32. use PhpLatex_Parser;
  33. use PhpLatex_Renderer_Html;
  34. class LatexNotes extends Plugin
  35. {
  36. public function onPostingAvailableContentTypes(array &$types): bool
  37. {
  38. $types['LaTeX'] = 'application/x-latex';
  39. return Event::next;
  40. }
  41. public function onRenderNoteContent($content, $content_type, &$rendered): bool
  42. {
  43. if ($content_type !== 'application/x-latex') {
  44. return Event::next;
  45. }
  46. // https://github.com/xemlock/php-latex
  47. $parser = new PhpLatex_Parser();
  48. $parsedTree = $parser->parse($content);
  49. $htmlRenderer = new PhpLatex_Renderer_Html();
  50. $rendered = $htmlRenderer->render($parsedTree);
  51. return Event::stop;
  52. }
  53. }