Refactoring: Merge AddMemberBox and AddIncludedGroupBox

Merge AddMemberBox and AddIncludedGroupBox into one class since most
of the coding is identical.

This refactoring is a preparation for allowing groups being added as
reviewers for a change. Otherwise to implement this feature it would
be needed to introduce a third class AddAccountOrAccountGroupBox
which would again be almost identical in coding. The idea is to just
have one class which can be used for all three cases.

Signed-off-by: Edwin Kempin <edwin.kempin@sap.com>
Change-Id: I667b6ba1ce8390c18e6ec2f1ef16d64f93926c01
This commit is contained in:
Edwin Kempin
2011-06-29 14:34:33 +02:00
parent a65637cccb
commit c4af33451e
6 changed files with 22 additions and 118 deletions

View File

@@ -18,7 +18,7 @@ import com.google.gerrit.client.Dispatcher;
import com.google.gerrit.client.Gerrit;
import com.google.gerrit.client.rpc.GerritCallback;
import com.google.gerrit.client.ui.AccountDashboardLink;
import com.google.gerrit.client.ui.AddIncludedGroupBox;
import com.google.gerrit.client.ui.AccountGroupSuggestOracle;
import com.google.gerrit.client.ui.AddMemberBox;
import com.google.gerrit.client.ui.FancyFlexTable;
import com.google.gerrit.client.ui.Hyperlink;
@@ -55,7 +55,7 @@ public class AccountGroupMembersScreen extends AccountGroupScreen {
private Button delMember;
private Panel includePanel;
private AddIncludedGroupBox addIncludeBox;
private AddMemberBox addIncludeBox;
private Button delInclude;
private FlowPanel noMembersInfo;
@@ -109,7 +109,9 @@ public class AccountGroupMembersScreen extends AccountGroupScreen {
}
private void initIncludeList() {
addIncludeBox = new AddIncludedGroupBox();
addIncludeBox =
new AddMemberBox(Util.C.buttonAddIncludedGroup(),
Util.C.defaultAccountGroupName(), new AccountGroupSuggestOracle());
addIncludeBox.addClickHandler(new ClickHandler() {
@Override

View File

@@ -20,6 +20,7 @@ import com.google.gerrit.client.Gerrit;
import com.google.gerrit.client.patches.PatchUtil;
import com.google.gerrit.client.rpc.GerritCallback;
import com.google.gerrit.client.ui.AccountDashboardLink;
import com.google.gerrit.client.ui.AccountSuggestOracle;
import com.google.gerrit.client.ui.AddMemberBox;
import com.google.gerrit.common.data.AccountInfoCache;
import com.google.gerrit.common.data.ApprovalDetail;
@@ -76,8 +77,10 @@ public class ApprovalTable extends Composite {
addReviewer = new FlowPanel();
addReviewer.setStyleName(Gerrit.RESOURCES.css().addReviewer());
addMemberBox = new AddMemberBox();
addMemberBox.setAddButtonText(Util.C.approvalTableAddReviewer());
addMemberBox =
new AddMemberBox(Util.C.approvalTableAddReviewer(),
Util.C.approvalTableAddReviewerHint(),
new AccountSuggestOracle());
addMemberBox.addClickHandler(new ClickHandler() {
@Override
public void onClick(final ClickEvent event) {

View File

@@ -80,6 +80,7 @@ public interface ChangeConstants extends Constants {
String approvalTableAddReviewer();
String approvalTableRemoveNotPermitted();
String approvalTableCouldNotRemove();
String approvalTableAddReviewerHint();
String changeInfoBlockOwner();
String changeInfoBlockProject();

View File

@@ -57,6 +57,7 @@ approvalTableReviewer = Reviewer
approvalTableAddReviewer = Add Reviewer
approvalTableRemoveNotPermitted = Not allowed to remove reviewer
approvalTableCouldNotRemove = Could not remove reviewer
approvalTableAddReviewerHint = Username or Email
changeInfoBlockOwner = Owner
changeInfoBlockProject = Project

View File

@@ -1,106 +0,0 @@
// Copyright (C) 2011 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.ui;
import com.google.gerrit.client.admin.Util;
import com.google.gerrit.client.ui.HintTextBox;
import com.google.gerrit.client.ui.RPCSuggestOracle;
import com.google.gwt.event.dom.client.ClickEvent;
import com.google.gwt.event.dom.client.ClickHandler;
import com.google.gwt.event.dom.client.KeyCodes;
import com.google.gwt.event.dom.client.KeyPressEvent;
import com.google.gwt.event.dom.client.KeyPressHandler;
import com.google.gwt.event.logical.shared.SelectionEvent;
import com.google.gwt.event.logical.shared.SelectionHandler;
import com.google.gwt.user.client.ui.Button;
import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.SuggestBox;
import com.google.gwt.user.client.ui.SuggestBox.DefaultSuggestionDisplay;
import com.google.gwt.user.client.ui.SuggestOracle.Suggestion;
public class AddIncludedGroupBox extends Composite {
private final FlowPanel addPanel;
private final Button addMember;
private final HintTextBox nameTxtBox;
private final SuggestBox nameTxt;
private boolean submitOnSelection;
public AddIncludedGroupBox() {
addPanel = new FlowPanel();
addMember = new Button(Util.C.buttonAddIncludedGroup());
nameTxtBox = new HintTextBox();
nameTxt = new SuggestBox(new RPCSuggestOracle(
new AccountGroupSuggestOracle()), nameTxtBox);
nameTxtBox.setVisibleLength(50);
nameTxtBox.setHintText(Util.C.defaultAccountGroupName());
nameTxtBox.addKeyPressHandler(new KeyPressHandler() {
@Override
public void onKeyPress(KeyPressEvent event) {
submitOnSelection = false;
if (event.getNativeEvent().getKeyCode() == KeyCodes.KEY_ENTER) {
if (((DefaultSuggestionDisplay) nameTxt.getSuggestionDisplay())
.isSuggestionListShowing()) {
submitOnSelection = true;
} else {
doAdd();
}
}
}
});
nameTxt.addSelectionHandler(new SelectionHandler<Suggestion>() {
@Override
public void onSelection(SelectionEvent<Suggestion> event) {
if (submitOnSelection) {
submitOnSelection = false;
doAdd();
}
}
});
addPanel.add(nameTxt);
addPanel.add(addMember);
initWidget(addPanel);
}
public void setAddButtonText(final String text) {
addMember.setText(text);
}
public void addClickHandler(final ClickHandler handler) {
addMember.addClickHandler(handler);
}
public String getText() {
String s = nameTxtBox.getText();
return s == null ? "" : s;
}
public void setEnabled(boolean enabled) {
addMember.setEnabled(enabled);
nameTxtBox.setEnabled(enabled);
}
public void setText(String text) {
nameTxtBox.setText(text);
}
private void doAdd() {
addMember.fireEvent(new ClickEvent() {});
}
}

View File

@@ -27,6 +27,7 @@ import com.google.gwt.user.client.ui.Composite;
import com.google.gwt.user.client.ui.FlowPanel;
import com.google.gwt.user.client.ui.SuggestBox;
import com.google.gwt.user.client.ui.SuggestBox.DefaultSuggestionDisplay;
import com.google.gwt.user.client.ui.SuggestOracle;
import com.google.gwt.user.client.ui.SuggestOracle.Suggestion;
public class AddMemberBox extends Composite {
@@ -37,14 +38,20 @@ public class AddMemberBox extends Composite {
private boolean submitOnSelection;
public AddMemberBox() {
this(Util.C.buttonAddGroupMember(), Util.C.defaultAccountName(),
new AccountSuggestOracle());
}
public AddMemberBox(final String buttonLabel, final String hint,
final SuggestOracle suggestOracle) {
addPanel = new FlowPanel();
addMember = new Button(Util.C.buttonAddGroupMember());
addMember = new Button(buttonLabel);
nameTxtBox = new HintTextBox();
nameTxt = new SuggestBox(new RPCSuggestOracle(
new AccountSuggestOracle()), nameTxtBox);
suggestOracle), nameTxtBox);
nameTxtBox.setVisibleLength(50);
nameTxtBox.setHintText(Util.C.defaultAccountName());
nameTxtBox.setHintText(hint);
nameTxtBox.addKeyPressHandler(new KeyPressHandler() {
@Override
public void onKeyPress(KeyPressEvent event) {
@@ -76,10 +83,6 @@ public class AddMemberBox extends Composite {
initWidget(addPanel);
}
public void setAddButtonText(final String text) {
addMember.setText(text);
}
public void addClickHandler(final ClickHandler handler) {
addMember.addClickHandler(handler);
}