Merge "Refactor AbandonChangeDialog and RestoreChangeDialog classes."

This commit is contained in:
Shawn Pearce 2011-04-21 10:06:19 -07:00 committed by Android Code Review
commit ede3a8358b
3 changed files with 69 additions and 180 deletions

View File

@ -1,134 +0,0 @@
// Copyright (C) 2009 The Android Open Source Project
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
package com.google.gerrit.client.changes;
import com.google.gerrit.client.Gerrit;
import com.google.gerrit.client.rpc.GerritCallback;
import com.google.gerrit.client.ui.SmallHeading;
import com.google.gerrit.common.data.ChangeDetail;
import com.google.gerrit.reviewdb.PatchSet;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.logical.shared.CloseEvent;
import com.google.gwt.event.logical.shared.CloseHandler;
import com.google.gwt.user.client.DOM;
import com.google.gwt.user.client.rpc.AsyncCallback;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.PopupPanel;
import com.google.gwtexpui.globalkey.client.GlobalKey;
import com.google.gwtexpui.globalkey.client.NpTextArea;
import com.google.gwtexpui.user.client.AutoCenterDialogBox;
public class AbandonChangeDialog extends AutoCenterDialogBox implements CloseHandler<PopupPanel>{
private final FlowPanel panel;
private final NpTextArea message;
private final Button sendButton;
private final Button cancelButton;
private final PatchSet.Id psid;
private final AsyncCallback<ChangeDetail> callback;
private boolean buttonClicked = false;
public AbandonChangeDialog(final PatchSet.Id psi,
final AsyncCallback<ChangeDetail> callback) {
super(/* auto hide */false, /* modal */true);
setGlassEnabled(true);
psid = psi;
this.callback = callback;
addStyleName(Gerrit.RESOURCES.css().abandonChangeDialog());
setText(Util.C.abandonChangeTitle());
panel = new FlowPanel();
add(panel);
panel.add(new SmallHeading(Util.C.headingAbandonMessage()));
final FlowPanel mwrap = new FlowPanel();
mwrap.setStyleName(Gerrit.RESOURCES.css().abandonMessage());
panel.add(mwrap);
message = new NpTextArea();
message.setCharacterWidth(60);
message.setVisibleLines(10);
message.setSpellCheck(true);
mwrap.add(message);
final FlowPanel buttonPanel = new FlowPanel();
panel.add(buttonPanel);
sendButton = new Button(Util.C.buttonAbandonChangeSend());
sendButton.addClickHandler(new ClickHandler() {
@Override
public void onClick(final ClickEvent event) {
sendButton.setEnabled(false);
cancelButton.setEnabled(false);
Util.MANAGE_SVC.abandonChange(psid, message.getText().trim(),
new GerritCallback<ChangeDetail>() {
public void onSuccess(ChangeDetail result) {
buttonClicked = true;
if (callback != null) {
callback.onSuccess(result);
}
hide();
}
@Override
public void onFailure(Throwable caught) {
sendButton.setEnabled(true);
cancelButton.setEnabled(true);
super.onFailure(caught);
}
});
}
});
buttonPanel.add(sendButton);
cancelButton = new Button(Util.C.buttonAbandonChangeCancel());
DOM.setStyleAttribute(cancelButton.getElement(), "marginLeft", "300px");
cancelButton.addClickHandler(new ClickHandler() {
@Override
public void onClick(final ClickEvent event) {
buttonClicked = true;
if (callback != null) {
callback.onFailure(null);
}
hide();
}
});
buttonPanel.add(cancelButton);
addCloseHandler(this);
}
@Override
public void center() {
super.center();
GlobalKey.dialog(this);
message.setFocus(true);
}
@Override
public void onClose(CloseEvent<PopupPanel> event) {
if (!buttonClicked) {
// the dialog was closed without one of the buttons being pressed
// e.g. the user pressed ESC to close the dialog
if (callback != null) {
callback.onFailure(null);
}
}
}
}

View File

@ -32,7 +32,7 @@ import com.google.gwtexpui.globalkey.client.GlobalKey;
import com.google.gwtexpui.globalkey.client.NpTextArea;
import com.google.gwtexpui.user.client.AutoCenterDialogBox;
public class RestoreChangeDialog extends AutoCenterDialogBox implements CloseHandler<PopupPanel>{
public abstract class CommentedChangeActionDialog extends AutoCenterDialogBox implements CloseHandler<PopupPanel>{
private final FlowPanel panel;
private final NpTextArea message;
private final Button sendButton;
@ -42,23 +42,26 @@ public class RestoreChangeDialog extends AutoCenterDialogBox implements CloseHan
private boolean buttonClicked = false;
public RestoreChangeDialog(final PatchSet.Id psi,
final AsyncCallback<ChangeDetail> callback) {
public CommentedChangeActionDialog(final PatchSet.Id psi,
final AsyncCallback<ChangeDetail> callback, final String dialogTitle,
final String dialogHeading, final String buttonSend,
final String buttonCancel, final String dialogStyle,
final String messageStyle) {
super(/* auto hide */false, /* modal */true);
setGlassEnabled(true);
psid = psi;
this.callback = callback;
addStyleName(Gerrit.RESOURCES.css().abandonChangeDialog());
setText(Util.C.restoreChangeTitle());
addStyleName(dialogStyle);
setText(dialogTitle);
panel = new FlowPanel();
add(panel);
panel.add(new SmallHeading(Util.C.headingRestoreMessage()));
panel.add(new SmallHeading(dialogHeading));
final FlowPanel mwrap = new FlowPanel();
mwrap.setStyleName(Gerrit.RESOURCES.css().abandonMessage());
mwrap.setStyleName(messageStyle);
panel.add(mwrap);
message = new NpTextArea();
@ -69,36 +72,18 @@ public class RestoreChangeDialog extends AutoCenterDialogBox implements CloseHan
final FlowPanel buttonPanel = new FlowPanel();
panel.add(buttonPanel);
sendButton = new Button(Util.C.buttonRestoreChangeSend());
sendButton = new Button(buttonSend);
sendButton.addClickHandler(new ClickHandler() {
@Override
public void onClick(final ClickEvent event) {
sendButton.setEnabled(false);
cancelButton.setEnabled(false);
Util.MANAGE_SVC.restoreChange(psid, message.getText().trim(),
new GerritCallback<ChangeDetail>() {
@Override
public void onSuccess(ChangeDetail result) {
buttonClicked = true;
if (callback != null) {
callback.onSuccess(result);
}
hide();
}
@Override
public void onFailure(Throwable caught) {
sendButton.setEnabled(true);
cancelButton.setEnabled(true);
super.onFailure(caught);
}
});
onSend();
}
});
buttonPanel.add(sendButton);
cancelButton = new Button(Util.C.buttonRestoreChangeCancel());
cancelButton = new Button(buttonCancel);
DOM.setStyleAttribute(cancelButton.getElement(), "marginLeft", "300px");
cancelButton.addClickHandler(new ClickHandler() {
@Override
@ -132,4 +117,34 @@ public class RestoreChangeDialog extends AutoCenterDialogBox implements CloseHan
}
}
}
public abstract void onSend();
public PatchSet.Id getPatchSetId() {
return psid;
}
public String getMessageText() {
return message.getText().trim();
}
public GerritCallback<ChangeDetail> createCallback() {
return new GerritCallback<ChangeDetail>(){
@Override
public void onSuccess(ChangeDetail result) {
buttonClicked = true;
if (callback != null) {
callback.onSuccess(result);
}
hide();
}
@Override
public void onFailure(Throwable caught) {
sendButton.setEnabled(true);
cancelButton.setEnabled(true);
super.onFailure(caught);
}
};
}
}

View File

@ -401,16 +401,14 @@ class PatchSetComplexDisclosurePanel extends ComplexDisclosurePanel implements O
@Override
public void onClick(final ClickEvent event) {
b.setEnabled(false);
new AbandonChangeDialog(patchSet.getId(),
new AsyncCallback<ChangeDetail>() {
public void onSuccess(ChangeDetail result) {
changeScreen.update(result);
new CommentedChangeActionDialog(patchSet.getId(), createCommentedCallback(b),
Util.C.abandonChangeTitle(), Util.C.headingAbandonMessage(),
Util.C.buttonAbandonChangeSend(), Util.C.buttonAbandonChangeCancel(),
Gerrit.RESOURCES.css().abandonChangeDialog(), Gerrit.RESOURCES.css().abandonMessage()) {
public void onSend() {
Util.MANAGE_SVC.abandonChange(getPatchSetId() , getMessageText(), createCallback());
}
public void onFailure(Throwable caught) {
b.setEnabled(true);
}
}).center();
}.center();
}
});
actionsPanel.add(b);
@ -422,16 +420,14 @@ class PatchSetComplexDisclosurePanel extends ComplexDisclosurePanel implements O
@Override
public void onClick(final ClickEvent event) {
b.setEnabled(false);
new RestoreChangeDialog(patchSet.getId(),
new AsyncCallback<ChangeDetail>() {
public void onSuccess(ChangeDetail result) {
changeScreen.update(result);
new CommentedChangeActionDialog(patchSet.getId(), createCommentedCallback(b),
Util.C.restoreChangeTitle(), Util.C.headingRestoreMessage(),
Util.C.buttonRestoreChangeSend(), Util.C.buttonRestoreChangeCancel(),
Gerrit.RESOURCES.css().abandonChangeDialog(), Gerrit.RESOURCES.css().abandonMessage()) {
public void onSend() {
Util.MANAGE_SVC.restoreChange(getPatchSetId(), getMessageText(), createCallback());
}
public void onFailure(Throwable caught) {
b.setEnabled(true);
}
}).center();
}.center();
}
});
actionsPanel.add(b);
@ -541,4 +537,16 @@ class PatchSetComplexDisclosurePanel extends ComplexDisclosurePanel implements O
patchTable.setActive(active);
}
}
private AsyncCallback<ChangeDetail> createCommentedCallback(final Button b) {
return new AsyncCallback<ChangeDetail>() {
public void onSuccess(ChangeDetail result) {
changeScreen.update(result);
}
public void onFailure(Throwable caught) {
b.setEnabled(true);
}
};
}
}