blogentrylistitem.php 3.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102
  1. <?php
  2. /**
  3. * StatusNet - the distributed open-source microblogging tool
  4. * Copyright (C) 2011, StatusNet, Inc.
  5. *
  6. * NoticeListItem adapter for blog entries
  7. *
  8. * PHP version 5
  9. *
  10. * This program is free software: you can redistribute it and/or modify
  11. * it under the terms of the GNU Affero General Public License as published by
  12. * the Free Software Foundation, either version 3 of the License, or
  13. * (at your option) any later version.
  14. *
  15. * This program is distributed in the hope that it will be useful,
  16. * but WITHOUT ANY WARRANTY; without even the implied warranty of
  17. * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
  18. * GNU Affero General Public License for more details.
  19. *
  20. * You should have received a copy of the GNU Affero General Public License
  21. * along with this program. If not, see <http://www.gnu.org/licenses/>.
  22. *
  23. * @category Blog
  24. * @package StatusNet
  25. * @author Evan Prodromou <evan@status.net>
  26. * @copyright 2011 StatusNet, Inc.
  27. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
  28. * @link http://status.net/
  29. */
  30. if (!defined('STATUSNET')) {
  31. // This check helps protect against security problems;
  32. // your code file can't be executed directly from the web.
  33. exit(1);
  34. }
  35. /**
  36. * NoticeListItem adapter for blog entries
  37. *
  38. * @category General
  39. * @package StatusNet
  40. * @author Evan Prodromou <evan@status.net>
  41. * @copyright 2011 StatusNet, Inc.
  42. * @license http://www.fsf.org/licensing/licenses/agpl-3.0.html AGPL 3.0
  43. * @link http://status.net/
  44. */
  45. class BlogEntryListItem extends NoticeListItemAdapter
  46. {
  47. function showNotice()
  48. {
  49. $out = $this->nli->out;
  50. $out->elementStart('div', 'entry-title');
  51. $this->showAuthor();
  52. $this->showContent();
  53. $out->elementEnd('div');
  54. }
  55. function showContent()
  56. {
  57. $notice = $this->nli->notice;
  58. $out = $this->nli->out;
  59. $entry = Blog_entry::fromNotice($notice);
  60. if (empty($entry)) {
  61. throw new Exception('BlogEntryListItem used for non-blog notice.');
  62. }
  63. $out->elementStart('h4', array('class' => 'blog-entry-title'));
  64. $out->element('a', array('href' => $notice->getUrl()), $entry->title);
  65. $out->elementEnd('h4');
  66. // XXX: kind of a hack
  67. $actionName = $out->trimmed('action');
  68. if ($actionName == 'shownotice' ||
  69. $actionName == 'showblogentry' ||
  70. $actionName == 'conversation') {
  71. $out->elementStart('div', 'blog-entry-content');
  72. $out->raw($entry->content);
  73. $out->elementEnd('div');
  74. } else {
  75. if (!empty($entry->summary)) {
  76. $out->elementStart('div', 'blog-entry-summary');
  77. $out->raw($entry->summary);
  78. $out->elementEnd('div');
  79. }
  80. $url = ($entry->url) ? $entry->url : $notice->getUrl();
  81. $out->element('a',
  82. array('href' => $url,
  83. 'class' => 'blog-entry-link'),
  84. _('More...'));
  85. }
  86. }
  87. }