Change style of commit message box display and use UiBinder.
Put a box around the commit message with a title and emphasis on the commit summary. The <pre> element for the body is hidden if only the summary is submitted. Changed CommitMessageBlock widget to use UiBinder. Change-Id: I1a8642c99e1b2e57cfe04f26e6e359b9ad0476fe
This commit is contained in:
@@ -14,29 +14,57 @@
|
||||
|
||||
package com.google.gerrit.client.changes;
|
||||
|
||||
import com.google.gerrit.client.Gerrit;
|
||||
import com.google.gerrit.client.ui.CommentLinkProcessor;
|
||||
import com.google.gwt.user.client.ui.Composite;
|
||||
import com.google.gwt.user.client.ui.HTML;
|
||||
|
||||
import com.google.gwt.core.client.GWT;
|
||||
import com.google.gwt.dom.client.PreElement;
|
||||
import com.google.gwt.dom.client.Style.Display;
|
||||
import com.google.gwt.uibinder.client.UiBinder;
|
||||
import com.google.gwt.uibinder.client.UiField;
|
||||
import com.google.gwt.user.client.ui.HTMLPanel;
|
||||
import com.google.gwtexpui.safehtml.client.SafeHtml;
|
||||
import com.google.gwtexpui.safehtml.client.SafeHtmlBuilder;
|
||||
|
||||
public class CommitMessageBlock extends Composite {
|
||||
private final HTML description;
|
||||
interface Binder extends UiBinder<HTMLPanel, CommitMessageBlock> {
|
||||
}
|
||||
|
||||
private static Binder uiBinder = GWT.create(Binder.class);
|
||||
|
||||
@UiField
|
||||
PreElement commitSummaryPre;
|
||||
@UiField
|
||||
PreElement commitBodyPre;
|
||||
|
||||
public CommitMessageBlock() {
|
||||
description = new HTML();
|
||||
description.setStyleName(Gerrit.RESOURCES.css().changeScreenDescription());
|
||||
initWidget(description);
|
||||
initWidget(uiBinder.createAndBindUi(this));
|
||||
}
|
||||
|
||||
public void display(final String commitMessage) {
|
||||
SafeHtml msg = new SafeHtmlBuilder().append(commitMessage);
|
||||
msg = msg.linkify();
|
||||
msg = CommentLinkProcessor.apply(msg);
|
||||
msg = new SafeHtmlBuilder().openElement("p").append(msg).closeElement("p");
|
||||
msg = msg.replaceAll("\n\n", "</p><p>");
|
||||
msg = msg.replaceAll("\n", "<br />");
|
||||
SafeHtml.set(description, msg);
|
||||
String[] splitCommitMessage = commitMessage.split("\n", 2);
|
||||
|
||||
String commitSummary = splitCommitMessage[0];
|
||||
String commitBody = "";
|
||||
if (splitCommitMessage.length > 1) {
|
||||
commitBody = splitCommitMessage[1];
|
||||
}
|
||||
|
||||
// Linkify commit summary
|
||||
SafeHtml commitSummaryLinkified = new SafeHtmlBuilder().append(commitSummary);
|
||||
commitSummaryLinkified = commitSummaryLinkified.linkify();
|
||||
commitSummaryLinkified = CommentLinkProcessor.apply(commitSummaryLinkified);
|
||||
commitSummaryPre.setInnerHTML(commitSummaryLinkified.asString());
|
||||
|
||||
// Hide commit body if there is no body
|
||||
if (commitBody.trim().isEmpty()) {
|
||||
commitBodyPre.getStyle().setDisplay(Display.NONE);
|
||||
} else {
|
||||
// Linkify commit body
|
||||
SafeHtml commitBodyLinkified = new SafeHtmlBuilder().append(commitBody);
|
||||
commitBodyLinkified = commitBodyLinkified.linkify();
|
||||
commitBodyLinkified = CommentLinkProcessor.apply(commitBodyLinkified);
|
||||
commitBodyPre.setInnerHTML(commitBodyLinkified.asString());
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user