Skip to content

Add markdown preview to issue, MR and milestone descriptions.

Witrem requested to merge github/fork/booktree/markdown-preview-everywhere into master

Created by: cirosantilli

Fixes both feedbacks 5409046 and 5209446.

Before this MR, markdown could only be previewed on notes (comments on issues, MR, MR diff notes, commits, snippets).

Now it can also be previewed for descriptions at creation and edit of:

  • issues
  • merge requests
  • milestones

It is still not possible to preview it for:

  • wiki (gfm / rdoc)
  • readme / blob (any format possible)

since in those cases the situation is a bit more complicated because there can be multiple possible formats of input markup, so I decided then to leave those for a future MR.

As a reference to what is feasible, GitHub only has a single wiki format, and handles file previews somewhat intelligently based on extension.

For the custom merge request commit messages, see doubts below.

Screenshots

The preview button is disabled if the input is empty:

screenshot from 2014-02-18 14 29 10 button deactivate

In the past, it was invisible, but I felt this behavior was better because:

  • it matches that of the submit button
  • you always know where the button is, so it is less surprising

Input not empty:

screenshot from 2014-02-14 12 05 23 issue before preview

New issue preview:

screenshot from 2014-02-14 15 06 11 issue preview

Header anchors appear only if the displayed markdown will have them also.

The situation is exactly analogous for MR and Milestone descriptions.

Comments and diff notes preview behave like before, but their style now matches that of the description inputs:

screenshot from 2014-02-20 22 46 39 comment preview 2

screenshot from 2014-02-20 22 48 36 diff note 2

The preview for comments has no header anchors.

So that the Preview / Write button always be at the same place I have:

  1. enabled scroll vertical for the preview
  2. disabled textarea resizing

screenshot from 2014-04-14 22 54 00 scroll

Doubts

  1. Where should I put the default .gfm-input-and-preview CSS? For now I left it at generic/forms for lack of better place, but I also see the following possibilities:
  • common
  • typography
  • a new file named generic/markup-preview or something
  1. On stylesheets/generic/forms.scss, I had to add the lines:
background-color: white;
border: 1px solid rgb(204, 204, 204);
border-radius: 4px;
color: rgb(51, 51, 51);

whose only objective is to restore the default format set by Twitter Bootstrap for site when inside other divs.

For example, inside the green merge request div the preview would be green.

How to do that without resetting every single property manually?

I asked it on StackOverflow to no avail so far.

  1. Shall I document the markdown rendering as part of the REST API? GitHub does.

If yes, what should be the response status in case of invalid values, e.g. tru instead of true? Microsoft says 400: http://msdn.microsoft.com/en-us/library/windowsazure/dd179357.aspx

  1. What is the correct place to put integration tests, spec/features, features, or both are OK?

Having both is bad because it requires developers to look into both to see it tests already exist or not.

Implementation notes

  1. The functionality was essentially extracted from the existing notes preview under javacripts/notes.js and view/project/notes/_form.html.haml, encapsulated into javascripts/markup_preview.js and views/shared/_markup_input_and_preview.html.haml, and used uniformly on all implemented previews.

  2. Removed .js-notify-commit-author CSS class since it is not used in any view anymore.

  3. Removed duplicate of method setupNoteForm, which was absolutely identical to the other one once js-notify-commit-author was removed.

  4. Extracted GitLab.GfmAutoComplete.setup() from setupNoteForm into setupDiscussionNoteForm, since it was only being called from two places:

  • setupMainTargetNoteForm, which is only called once for the page, call which will be made by the extracted new MarkupPreview call.
  • setupDiscussionNoteForm, to where it was extracted.
  1. Removed class js-gfm-input from:
  • group create and edit forms on group and admin pages
  • wall
  • merge request edit commit message, since it is not possible to preview it, and it does not really render like normal gfm.

since those inputs are currently never rendered as markdown.

Removed .note_text_and_preview CSS class from wall since it has no preview. This was the last occurrence of that class, so removed it from existence and ported its style from notes.css to wall.css with new name new-wall-note. The appearance and behavior of the wall are untouched.

  1. Modified _commit_box_html.haml to use the markdown method instead of gfm, like every other place that renders markdown.

  2. Modified file view to use a single technique for the reserved space for the header anchor links: .wiki inside a container with padding.

  3. Renamed no_header_anchors option to header_anchors.

  4. Corrected some always passing tests which assumed that visible: false does not target visible elements: it actually targets both visible and invisible elements: http://rubydoc.info/github/jnicklas/capybara/master/Capybara/Node/Finders#find-instance_method. Those tests need should_not visible:true instead.

Merge request reports

Loading