comment.html.twig 4.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. {#
  2. /**
  3. * @file
  4. * Default theme implementation for comments.
  5. *
  6. * Available variables:
  7. * - author: Comment author. Can be a link or plain text.
  8. * - content: The content-related items for the comment display. Use
  9. * {{ content }} to print them all, or print a subset such as
  10. * {{ content.field_example }}. Use the following code to temporarily suppress
  11. * the printing of a given child element:
  12. * @code
  13. * {{ content|without('field_example') }}
  14. * @endcode
  15. * - created: Formatted date and time for when the comment was created.
  16. * Preprocess functions can reformat it by calling format_date() with the
  17. * desired parameters on the 'comment.created' variable.
  18. * - changed: Formatted date and time for when the comment was last changed.
  19. * Preprocess functions can reformat it by calling format_date() with the
  20. * desired parameters on the 'comment.changed' variable.
  21. * - permalink: Comment permalink.
  22. * - submitted: Submission information created from author and created
  23. * during template_preprocess_comment().
  24. * - user_picture: The comment author's profile picture.
  25. * - status: Comment status. Possible values are:
  26. * unpublished, published, or preview.
  27. * - title: Comment title, linked to the comment.
  28. * - attributes: HTML attributes for the containing element.
  29. * The attributes.class may contain one or more of the following classes:
  30. * - comment: The current template type; e.g., 'theming hook'.
  31. * - by-anonymous: Comment by an unregistered user.
  32. * - by-{entity-type}-author: Comment by the author of the parent entity,
  33. * eg. by-node-author.
  34. * - preview: When previewing a new or edited comment.
  35. * The following applies only to viewers who are registered users:
  36. * - unpublished: An unpublished comment visible only to administrators.
  37. * - title_prefix: Additional output populated by modules, intended to be
  38. * displayed in front of the main title tag that appears in the template.
  39. * - title_suffix: Additional output populated by modules, intended to be
  40. * displayed after the main title tag that appears in the template.
  41. * - content_attributes: List of classes for the styling of the comment content.
  42. * - title_attributes: Same as attributes, except applied to the main title
  43. * tag that appears in the template.
  44. *
  45. * These variables are provided to give context about the parent comment (if
  46. * any):
  47. * - comment_parent: Full parent comment entity (if any).
  48. * - parent_author: Equivalent to author for the parent comment.
  49. * - parent_created: Equivalent to created for the parent comment.
  50. * - parent_changed: Equivalent to changed for the parent comment.
  51. * - parent_title: Equivalent to title for the parent comment.
  52. * - parent_permalink: Equivalent to permalink for the parent comment.
  53. * - parent: A text string of parent comment submission information created from
  54. * 'parent_author' and 'parent_created' during template_preprocess_comment().
  55. * This information is presented to help screen readers follow lengthy
  56. * discussion threads. You can hide this from sighted users using the class
  57. * visually-hidden.
  58. *
  59. * These two variables are provided for context:
  60. * - comment: Full comment object.
  61. * - entity: Entity the comments are attached to.
  62. *
  63. * @see template_preprocess_comment()
  64. *
  65. * @ingroup themeable
  66. */
  67. #}
  68. <article{{ attributes }}>
  69. {% if title %}
  70. {{ title_prefix }}
  71. {% endif %}
  72. {#
  73. Hide the "new" indicator by default, let a piece of JavaScript ask
  74. the server which comments are new for the user. Rendering the final
  75. "new" indicator here would break the render cache.
  76. #}
  77. <mark class="hidden new" data-comment-timestamp="{{ new_indicator_timestamp }}"></mark>
  78. {% if title %}
  79. <h3{{ title_attributes.addClass('title') }}>{{ title }}</h3>
  80. {{ title_suffix }}
  81. {% endif %}
  82. <footer>
  83. {{ user_picture }}
  84. <p class="submitted">{{ submitted }}</p>
  85. {#
  86. Indicate the semantic relationship between parent and child comments
  87. for accessibility. The list is difficult to navigate in a screen
  88. reader without this information.
  89. #}
  90. {% if parent %}
  91. <p class="visually-hidden">{{ parent }}</p>
  92. {% endif %}
  93. {{ permalink }}
  94. </footer>
  95. <div{{ content_attributes.addClass('content') }}>
  96. {{ content|without('links') }}
  97. </div>
  98. {% if content.links %}
  99. {{ content.links }}
  100. {% endif %}
  101. </article>