MyAgreementsScreen: Use REST API to get agreements
The "status" column is removed. With the new REST API, the agreement is either signed or not. Change-Id: I2235675c88d35c719ae922832f5308fea13cc56b
This commit is contained in:
		
				
					committed by
					
						
						David Pursehouse
					
				
			
			
				
	
			
			
			
						parent
						
							78ee73822f
						
					
				
				
					commit
					c22142958e
				
			@@ -288,6 +288,12 @@ public class AccountApi {
 | 
			
		||||
      .post(GpgKeysInput.delete(fingerprints), cb);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  /** List contributor agreements */
 | 
			
		||||
  public static void getAgreements(String account,
 | 
			
		||||
      AsyncCallback<JsArray<AgreementInfo>> cb) {
 | 
			
		||||
    new RestApi("/accounts/").id(account).view("agreements").get(cb);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private static class GpgKeysInput extends JavaScriptObject {
 | 
			
		||||
    static GpgKeysInput add(String key) {
 | 
			
		||||
      return createWithAdd(Natives.arrayOf(key));
 | 
			
		||||
 
 | 
			
		||||
@@ -141,11 +141,8 @@ public interface AccountConstants extends Constants {
 | 
			
		||||
  String errorDialogTitleRegisterNewEmail();
 | 
			
		||||
 | 
			
		||||
  String newAgreement();
 | 
			
		||||
  String agreementStatus();
 | 
			
		||||
  String agreementName();
 | 
			
		||||
  String agreementDescription();
 | 
			
		||||
  String agreementStatus_EXPIRED();
 | 
			
		||||
  String agreementStatus_VERIFIED();
 | 
			
		||||
 | 
			
		||||
  String newAgreementSelectTypeHeading();
 | 
			
		||||
  String newAgreementNoneAvailable();
 | 
			
		||||
 
 | 
			
		||||
@@ -151,10 +151,7 @@ errorDialogTitleRegisterNewEmail = Email Registration Failed
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
newAgreement = New Contributor Agreement
 | 
			
		||||
agreementStatus = Status
 | 
			
		||||
agreementName = Name
 | 
			
		||||
agreementStatus_EXPIRED = Expired
 | 
			
		||||
agreementStatus_VERIFIED = Verified
 | 
			
		||||
agreementDescription = Description
 | 
			
		||||
 | 
			
		||||
newAgreementSelectTypeHeading = Select an agreement type:
 | 
			
		||||
 
 | 
			
		||||
@@ -0,0 +1,26 @@
 | 
			
		||||
// Copyright (C) 2016 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.account;
 | 
			
		||||
 | 
			
		||||
import com.google.gwt.core.client.JavaScriptObject;
 | 
			
		||||
 | 
			
		||||
public class AgreementInfo extends JavaScriptObject {
 | 
			
		||||
  public final native String name() /*-{ return this.name; }-*/;
 | 
			
		||||
  public final native String description() /*-{ return this.description; }-*/;
 | 
			
		||||
  public final native String url() /*-{ return this.url; }-*/;
 | 
			
		||||
 | 
			
		||||
  protected AgreementInfo() {
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
@@ -16,14 +16,17 @@ package com.google.gerrit.client.account;
 | 
			
		||||
 | 
			
		||||
import com.google.gerrit.client.Gerrit;
 | 
			
		||||
import com.google.gerrit.client.rpc.ScreenLoadCallback;
 | 
			
		||||
import com.google.gerrit.client.rpc.Natives;
 | 
			
		||||
import com.google.gerrit.client.ui.FancyFlexTable;
 | 
			
		||||
import com.google.gerrit.client.ui.Hyperlink;
 | 
			
		||||
import com.google.gerrit.common.PageLinks;
 | 
			
		||||
import com.google.gerrit.common.data.AgreementInfo;
 | 
			
		||||
import com.google.gerrit.common.data.ContributorAgreement;
 | 
			
		||||
import com.google.gwt.core.client.JsArray;
 | 
			
		||||
import com.google.gwt.user.client.ui.Anchor;
 | 
			
		||||
import com.google.gwt.user.client.ui.FlexTable.FlexCellFormatter;
 | 
			
		||||
 | 
			
		||||
import java.util.List;
 | 
			
		||||
 | 
			
		||||
public class MyAgreementsScreen extends SettingsScreen {
 | 
			
		||||
  private AgreementTable agreements;
 | 
			
		||||
 | 
			
		||||
@@ -39,71 +42,54 @@ public class MyAgreementsScreen extends SettingsScreen {
 | 
			
		||||
  @Override
 | 
			
		||||
  protected void onLoad() {
 | 
			
		||||
    super.onLoad();
 | 
			
		||||
    Util.ACCOUNT_SVC.myAgreements(new ScreenLoadCallback<AgreementInfo>(this) {
 | 
			
		||||
    AccountApi.getAgreements(
 | 
			
		||||
        "self", new ScreenLoadCallback<JsArray<AgreementInfo>>(this) {
 | 
			
		||||
      @Override
 | 
			
		||||
      public void preDisplay(final AgreementInfo result) {
 | 
			
		||||
        agreements.display(result);
 | 
			
		||||
      }
 | 
			
		||||
    });
 | 
			
		||||
      public void preDisplay(JsArray<AgreementInfo> result) {
 | 
			
		||||
        agreements.display(Natives.asList(result));
 | 
			
		||||
      }});
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  private static class AgreementTable extends FancyFlexTable<ContributorAgreement> {
 | 
			
		||||
    AgreementTable() {
 | 
			
		||||
      table.setWidth("");
 | 
			
		||||
      table.setText(0, 1, Util.C.agreementStatus());
 | 
			
		||||
      table.setText(0, 2, Util.C.agreementName());
 | 
			
		||||
      table.setText(0, 3, Util.C.agreementDescription());
 | 
			
		||||
      table.setText(0, 1, Util.C.agreementName());
 | 
			
		||||
      table.setText(0, 2, Util.C.agreementDescription());
 | 
			
		||||
 | 
			
		||||
      final FlexCellFormatter fmt = table.getFlexCellFormatter();
 | 
			
		||||
      for (int c = 1; c < 4; c++) {
 | 
			
		||||
      FlexCellFormatter fmt = table.getFlexCellFormatter();
 | 
			
		||||
      for (int c = 1; c < 3; c++) {
 | 
			
		||||
        fmt.addStyleName(0, c, Gerrit.RESOURCES.css().dataHeader());
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    void display(final AgreementInfo result) {
 | 
			
		||||
    void display(List<AgreementInfo> result) {
 | 
			
		||||
      while (1 < table.getRowCount()) {
 | 
			
		||||
        table.removeRow(table.getRowCount() - 1);
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      for (final String k : result.accepted) {
 | 
			
		||||
        addOne(result, k);
 | 
			
		||||
      for (AgreementInfo info : result) {
 | 
			
		||||
        addOne(info);
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    void addOne(final AgreementInfo info, final String k) {
 | 
			
		||||
      final int row = table.getRowCount();
 | 
			
		||||
    void addOne(AgreementInfo info) {
 | 
			
		||||
      int row = table.getRowCount();
 | 
			
		||||
      table.insertRow(row);
 | 
			
		||||
      applyDataRowStyle(row);
 | 
			
		||||
 | 
			
		||||
      final ContributorAgreement cla = info.agreements.get(k);
 | 
			
		||||
      final String statusName;
 | 
			
		||||
      if (cla == null) {
 | 
			
		||||
        statusName = Util.C.agreementStatus_EXPIRED();
 | 
			
		||||
      String url = info.url();
 | 
			
		||||
      if (url != null && url.length() > 0) {
 | 
			
		||||
        Anchor a = new Anchor(info.name(), url);
 | 
			
		||||
        a.setTarget("_blank");
 | 
			
		||||
        table.setWidget(row, 1, a);
 | 
			
		||||
      } else {
 | 
			
		||||
        statusName = Util.C.agreementStatus_VERIFIED();
 | 
			
		||||
        table.setText(row, 1, info.name());
 | 
			
		||||
      }
 | 
			
		||||
      table.setText(row, 1, statusName);
 | 
			
		||||
 | 
			
		||||
      if (cla == null) {
 | 
			
		||||
        table.setText(row, 2, "");
 | 
			
		||||
        table.setText(row, 3, "");
 | 
			
		||||
      } else {
 | 
			
		||||
        final String url = cla.getAgreementUrl();
 | 
			
		||||
        if (url != null && url.length() > 0) {
 | 
			
		||||
          final Anchor a = new Anchor(cla.getName(), url);
 | 
			
		||||
          a.setTarget("_blank");
 | 
			
		||||
          table.setWidget(row, 2, a);
 | 
			
		||||
        } else {
 | 
			
		||||
          table.setText(row, 2, cla.getName());
 | 
			
		||||
        }
 | 
			
		||||
        table.setText(row, 3, cla.getDescription());
 | 
			
		||||
      }
 | 
			
		||||
      final FlexCellFormatter fmt = table.getFlexCellFormatter();
 | 
			
		||||
      for (int c = 1; c < 4; c++) {
 | 
			
		||||
      table.setText(row, 2, info.description());
 | 
			
		||||
      FlexCellFormatter fmt = table.getFlexCellFormatter();
 | 
			
		||||
      for (int c = 1; c < 3; c++) {
 | 
			
		||||
        fmt.addStyleName(row, c, Gerrit.RESOURCES.css().dataCell());
 | 
			
		||||
      }
 | 
			
		||||
 | 
			
		||||
      setRowItem(row, cla);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user