mirror of
https://github.com/ClaytonWWilson/Listify.git
synced 2025-12-15 18:28:47 +00:00
Merge branch 'master' into intra-list-ordering
This commit is contained in:
commit
f84bc2014d
@ -2,6 +2,7 @@ import java.sql.Connection;
|
|||||||
import java.sql.PreparedStatement;
|
import java.sql.PreparedStatement;
|
||||||
import java.sql.ResultSet;
|
import java.sql.ResultSet;
|
||||||
import java.sql.SQLException;
|
import java.sql.SQLException;
|
||||||
|
import java.util.ArrayList;
|
||||||
import java.util.HashMap;
|
import java.util.HashMap;
|
||||||
import java.util.Map;
|
import java.util.Map;
|
||||||
|
|
||||||
@ -9,6 +10,7 @@ public class ChainGetter implements CallHandler {
|
|||||||
private final Connection connection;
|
private final Connection connection;
|
||||||
|
|
||||||
private final String GET_CHAIN = "SELECT * FROM Chain WHERE chainID = ?;";
|
private final String GET_CHAIN = "SELECT * FROM Chain WHERE chainID = ?;";
|
||||||
|
private final String GET_CHAINS = "SELECT chainID FROM Chain;";
|
||||||
|
|
||||||
public ChainGetter(Connection connection, String cognitoID) {
|
public ChainGetter(Connection connection, String cognitoID) {
|
||||||
this.connection = connection;
|
this.connection = connection;
|
||||||
@ -16,8 +18,21 @@ public class ChainGetter implements CallHandler {
|
|||||||
|
|
||||||
@Override
|
@Override
|
||||||
public Object conductAction(Map<String, Object> bodyMap, HashMap<String, String> queryMap, String cognitoID) throws SQLException {
|
public Object conductAction(Map<String, Object> bodyMap, HashMap<String, String> queryMap, String cognitoID) throws SQLException {
|
||||||
|
Integer id = Integer.parseInt(queryMap.get("id"));
|
||||||
|
if (id == -1) {
|
||||||
|
PreparedStatement getChains = connection.prepareStatement(GET_CHAINS);
|
||||||
|
System.out.println(getChains);
|
||||||
|
ResultSet getChainsResults = getChains.executeQuery();
|
||||||
|
System.out.println(getChainsResults);
|
||||||
|
ArrayList<Integer> chainIDs = new ArrayList<>();
|
||||||
|
while (getChainsResults.next()) {
|
||||||
|
chainIDs.add(getChainsResults.getInt("chainID"));
|
||||||
|
}
|
||||||
|
return chainIDs;
|
||||||
|
}
|
||||||
|
|
||||||
PreparedStatement statement = connection.prepareStatement(GET_CHAIN);
|
PreparedStatement statement = connection.prepareStatement(GET_CHAIN);
|
||||||
statement.setInt(1, Integer.parseInt(queryMap.get("id")));
|
statement.setInt(1, id);
|
||||||
System.out.println(statement);
|
System.out.println(statement);
|
||||||
ResultSet queryResults = statement.executeQuery();
|
ResultSet queryResults = statement.executeQuery();
|
||||||
queryResults.first();
|
queryResults.first();
|
||||||
|
|||||||
@ -21,10 +21,6 @@ public class List {
|
|||||||
this.uiPosition = uiPosition;
|
this.uiPosition = uiPosition;
|
||||||
}
|
}
|
||||||
|
|
||||||
public void addItemEntry(ItemEntry entry) {
|
|
||||||
entries.add(entry);
|
|
||||||
}
|
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public String toString() {
|
public String toString() {
|
||||||
return "List{" +
|
return "List{" +
|
||||||
@ -38,10 +34,6 @@ public class List {
|
|||||||
'}';
|
'}';
|
||||||
}
|
}
|
||||||
|
|
||||||
public ItemEntry[] getEntries() {
|
|
||||||
return entries.toArray(new ItemEntry[entries.size()]);
|
|
||||||
}
|
|
||||||
|
|
||||||
public Integer getItemID() {
|
public Integer getItemID() {
|
||||||
return itemID;
|
return itemID;
|
||||||
}
|
}
|
||||||
@ -88,5 +80,12 @@ public class List {
|
|||||||
|
|
||||||
public void setUiPosition(Integer uiPosition) {
|
public void setUiPosition(Integer uiPosition) {
|
||||||
this.uiPosition = uiPosition;
|
this.uiPosition = uiPosition;
|
||||||
|
|
||||||
|
public ItemEntry[] getEntries() {
|
||||||
|
return entries.toArray(new ItemEntry[entries.size()]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addItemEntry(ItemEntry entry) {
|
||||||
|
entries.add(entry);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
37
Lambdas/Lists/ListShare/src/ListShare.java
Normal file
37
Lambdas/Lists/ListShare/src/ListShare.java
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
package com.example.listify.data;
|
||||||
|
|
||||||
|
public class ListShare {
|
||||||
|
Integer listID;
|
||||||
|
String shareWithEmail;
|
||||||
|
ArrayList<ListShare> other;
|
||||||
|
|
||||||
|
public ListShare(ResultSet listRow) throws SQLException {
|
||||||
|
this.listID = listRow.getInt("listID");
|
||||||
|
this.shareWithEmail = listRow.getString("userID");
|
||||||
|
other = new ArrayList<>();
|
||||||
|
}
|
||||||
|
|
||||||
|
public Integer getListID() {
|
||||||
|
return listID;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setListID(Integer listID) {
|
||||||
|
this.listID = listID;
|
||||||
|
}
|
||||||
|
|
||||||
|
public String getShareWithEmail() {
|
||||||
|
return shareWithEmail;
|
||||||
|
}
|
||||||
|
|
||||||
|
public void setShareWithEmail(String shareWithEmail) {
|
||||||
|
this.shareWithEmail = shareWithEmail;
|
||||||
|
}
|
||||||
|
|
||||||
|
public ListShare[] getEntries() {
|
||||||
|
return other.toArray(new ListShare[other.size()]);
|
||||||
|
}
|
||||||
|
|
||||||
|
public void addtoList(ListShare entry) {
|
||||||
|
other.add(entry);
|
||||||
|
}
|
||||||
|
}
|
||||||
12
Lambdas/Lists/ListShare/src/ListShareDELETE.java
Normal file
12
Lambdas/Lists/ListShare/src/ListShareDELETE.java
Normal file
@ -0,0 +1,12 @@
|
|||||||
|
import com.amazonaws.services.lambda.runtime.Context;
|
||||||
|
import com.amazonaws.services.lambda.runtime.RequestHandler;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class ListShareDELETE implements RequestHandler<Map<String,Object>, Object> {
|
||||||
|
|
||||||
|
public Object handleRequest(Map<String, Object> inputMap, Context unfilled) {
|
||||||
|
return BasicHandler.handleRequest(inputMap, unfilled, ListShareDeleter.class);
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
65
Lambdas/Lists/ListShare/src/ListShareDeleter.java
Normal file
65
Lambdas/Lists/ListShare/src/ListShareDeleter.java
Normal file
@ -0,0 +1,65 @@
|
|||||||
|
import java.security.AccessControlException;
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class ListShareDeleter implements CallHandler {
|
||||||
|
private final Connection connection;
|
||||||
|
private final String cognitoID;
|
||||||
|
|
||||||
|
private final String GET_LIST_ACCESS = "SELECT * FROM List WHERE (owner = ? AND listID = ?);";
|
||||||
|
private final String REMOVE_SHAREE = "DELETE FROM ListSharee WHERE listID = ? AND user = ?;";
|
||||||
|
|
||||||
|
public ListShareDeleter(Connection connection, String cognitoID) {
|
||||||
|
this.connection = connection;
|
||||||
|
this.cognitoID = cognitoID;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object conductAction(Map<String, Object> bodyMap, HashMap<String, String> queryMap, String cognitoID) throws SQLException {
|
||||||
|
Integer listID = Integer.parseInt(queryMap.get("id"));
|
||||||
|
|
||||||
|
InvokeRequest invokeRequest = new InvokeRequest();
|
||||||
|
invokeRequest.setFunctionName("UserGET");
|
||||||
|
invokeRequest.setPayload("{" +
|
||||||
|
" \"body\": {" +
|
||||||
|
" \"emailToCheck\": \"" + bodyMap.get("shareWithEmail").toString() + "\"" +
|
||||||
|
" }," +
|
||||||
|
" \"params\": {" +
|
||||||
|
" \"querystring\": {" +
|
||||||
|
" }" +
|
||||||
|
" }," +
|
||||||
|
" \"context\": {" +
|
||||||
|
" \"sub\": \"not used\"" +
|
||||||
|
" }" +
|
||||||
|
"}");
|
||||||
|
InvokeResult invokeResult = AWSLambdaClientBuilder.defaultClient().invoke(invokeRequest);
|
||||||
|
|
||||||
|
String shareeID = new String(invokeResult.getPayload().array()).replace("\"", "");
|
||||||
|
|
||||||
|
//Ensure that the user who is unsharing a list is the owner of that list
|
||||||
|
PreparedStatement accessCheck = connection.prepareStatement(GET_LIST_ACCESS);
|
||||||
|
accessCheck.setString(1, cognitoID);
|
||||||
|
accessCheck.setInt(2, listID);
|
||||||
|
|
||||||
|
ResultSet userLists = accessCheck.executeQuery();
|
||||||
|
|
||||||
|
//User does not own the list; unshare attempt fails
|
||||||
|
if (!userLists.next()) {
|
||||||
|
throw new AccessControlException("User does not have access to list");
|
||||||
|
}
|
||||||
|
|
||||||
|
//Unshare the list with the specified sharee
|
||||||
|
PreparedStatement unshareList = connection.prepareStatement(REMOVE_SHAREE);
|
||||||
|
unshareList.setInt(1, listID);
|
||||||
|
unshareList.setInt(2, shareeID);
|
||||||
|
|
||||||
|
cleanAccess.executeUpdate();
|
||||||
|
connection.commit();
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
11
Lambdas/Lists/ListShare/src/ListShareGET.java
Normal file
11
Lambdas/Lists/ListShare/src/ListShareGET.java
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
import com.amazonaws.services.lambda.runtime.Context;
|
||||||
|
import com.amazonaws.services.lambda.runtime.RequestHandler;
|
||||||
|
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class ListShareGET implements RequestHandler<Map<String,Object>, Object> {
|
||||||
|
|
||||||
|
public Object handleRequest(Map<String, Object> inputMap, Context unfilled) {
|
||||||
|
return BasicHandler.handleRequest(inputMap, unfilled, ListShareGetter.class);
|
||||||
|
}
|
||||||
|
}
|
||||||
40
Lambdas/Lists/ListShare/src/ListShareGetter.java
Normal file
40
Lambdas/Lists/ListShare/src/ListShareGetter.java
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.ResultSet;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
|
||||||
|
public class ListShareGetter implements CallHandler{
|
||||||
|
private final Connection connection;
|
||||||
|
private final String cognitoID;
|
||||||
|
|
||||||
|
private final String GET_LISTS = "SELECT * FROM ListSharee WHERE listID = ?;";
|
||||||
|
|
||||||
|
public ListShareGetter(Connection connection, String cognitoID) {
|
||||||
|
this.connection = connection;
|
||||||
|
this.cognitoID = cognitoID;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object conductAction(Map<String, Object> bodyMap, HashMap<String, String> queryMap, String cognitoID) throws SQLException {
|
||||||
|
Integer listID = Integer.parseInt(queryMap.get("id"));
|
||||||
|
|
||||||
|
PreparedStatement getList = connection.prepareStatement(GET_LIST);
|
||||||
|
getList.setInt(1, listID);
|
||||||
|
|
||||||
|
ResultSet getListResults = getList.executeQuery();
|
||||||
|
getListResults.first();
|
||||||
|
|
||||||
|
//ListShare object to hold the data values of the first row retrived
|
||||||
|
ListShare first = new ListShare(getListResults);
|
||||||
|
|
||||||
|
//Insert the ListShare objects to hold the data of the remaining rows into first's ListShare list
|
||||||
|
while (getListResults.next()) {
|
||||||
|
first.addtoList(new ListShare(getListResults));
|
||||||
|
}
|
||||||
|
|
||||||
|
return first;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -283,7 +283,7 @@ public class ListPage extends AppCompatActivity implements Requestor.Receiver {
|
|||||||
|
|
||||||
|
|
||||||
MyAdapter (Context c, ArrayList<String> names, ArrayList<String> stores, ArrayList<String> prices, ArrayList<String> quantity, ArrayList<String> images) {
|
MyAdapter (Context c, ArrayList<String> names, ArrayList<String> stores, ArrayList<String> prices, ArrayList<String> quantity, ArrayList<String> images) {
|
||||||
super(c, R.layout.activity_listproductentry, R.id.productView, names);
|
super(c, R.layout.shopping_list_product_entry, R.id.productView, names);
|
||||||
context = c;
|
context = c;
|
||||||
pNames = names;
|
pNames = names;
|
||||||
pStores = stores;
|
pStores = stores;
|
||||||
@ -296,7 +296,7 @@ public class ListPage extends AppCompatActivity implements Requestor.Receiver {
|
|||||||
@Override
|
@Override
|
||||||
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
|
public View getView(int position, @Nullable View convertView, @NonNull ViewGroup parent) {
|
||||||
LayoutInflater layoutInflater = (LayoutInflater) getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
LayoutInflater layoutInflater = (LayoutInflater) getApplicationContext().getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
View listproduct = layoutInflater.inflate(R.layout.activity_listproductentry, parent,false);
|
View listproduct = layoutInflater.inflate(R.layout.shopping_list_product_entry, parent,false);
|
||||||
|
|
||||||
decrQuan = (Button) listproduct.findViewById(R.id.buttonDecr);
|
decrQuan = (Button) listproduct.findViewById(R.id.buttonDecr);
|
||||||
incrQuan = (Button) listproduct.findViewById(R.id.buttonIncr);
|
incrQuan = (Button) listproduct.findViewById(R.id.buttonIncr);
|
||||||
|
|||||||
102
Listify/app/src/main/java/com/example/listify/ListSharees.java
Normal file
102
Listify/app/src/main/java/com/example/listify/ListSharees.java
Normal file
@ -0,0 +1,102 @@
|
|||||||
|
package com.example.listify;
|
||||||
|
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.os.Bundle;
|
||||||
|
import android.util.Log;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.ArrayAdapter;
|
||||||
|
import android.widget.Button;
|
||||||
|
import android.widget.EditText;
|
||||||
|
import android.widget.ImageView;
|
||||||
|
import android.widget.ListView;
|
||||||
|
import android.widget.ProgressBar;
|
||||||
|
import android.widget.TextView;
|
||||||
|
|
||||||
|
import com.bumptech.glide.Glide;
|
||||||
|
import com.example.listify.adapter.ShareeSwipeableAdapter;
|
||||||
|
import com.example.listify.adapter.ShoppingListsSwipeableAdapter;
|
||||||
|
import com.example.listify.data.Chain;
|
||||||
|
import com.example.listify.data.Item;
|
||||||
|
import com.example.listify.data.List;
|
||||||
|
import com.example.listify.data.ListEntry;
|
||||||
|
import com.example.listify.data.ListShare;
|
||||||
|
|
||||||
|
import org.json.JSONException;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.text.DecimalFormat;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import androidx.annotation.NonNull;
|
||||||
|
import androidx.annotation.Nullable;
|
||||||
|
import androidx.appcompat.app.AppCompatActivity;
|
||||||
|
|
||||||
|
import static com.example.listify.MainActivity.am;
|
||||||
|
|
||||||
|
public class ListSharees extends AppCompatActivity implements Requestor.Receiver {
|
||||||
|
ShareeSwipeableAdapter myAdapter;
|
||||||
|
Requestor requestor;
|
||||||
|
ProgressBar loadingListItems;
|
||||||
|
|
||||||
|
|
||||||
|
DecimalFormat df = new DecimalFormat("0.00");
|
||||||
|
|
||||||
|
// TODO: Display a message if their list is empty
|
||||||
|
@Override
|
||||||
|
protected void onCreate(@Nullable Bundle savedInstanceState) {
|
||||||
|
super.onCreate(savedInstanceState);
|
||||||
|
setContentView(R.layout.activity_listofsharees);
|
||||||
|
|
||||||
|
final int listID = (int) getIntent().getSerializableExtra("listID");
|
||||||
|
|
||||||
|
Properties configs = new Properties();
|
||||||
|
try {
|
||||||
|
configs = AuthManager.loadProperties(this, "android.resource://" + getPackageName() + "/raw/auths.json");
|
||||||
|
} catch (IOException | JSONException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
requestor = new Requestor(am, configs.getProperty("apiKey"));
|
||||||
|
requestor.getObject(Integer.toString(listID), ListShare.class, this);
|
||||||
|
|
||||||
|
loadingListItems = findViewById(R.id.progress_loading_list_items);
|
||||||
|
loadingListItems.setVisibility(View.VISIBLE);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public void acceptDelivery(Object delivered) {
|
||||||
|
ListShare sharee = (ListShare) delivered;
|
||||||
|
|
||||||
|
if(sharee != null) {
|
||||||
|
SynchronousReceiver<ListShare> listShareReceiver = new SynchronousReceiver<>();
|
||||||
|
requestor.getObject(Integer.toString(sharee.getListID()), ListShare.class, listShareReceiver, listShareReceiver);
|
||||||
|
|
||||||
|
ArrayList<ListShare> resultList = new ArrayList<>();
|
||||||
|
ListShare result;
|
||||||
|
|
||||||
|
try {
|
||||||
|
result = listShareReceiver.await();
|
||||||
|
}
|
||||||
|
catch (Exception e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
result = null;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(result != null) {
|
||||||
|
resultList.add(result);
|
||||||
|
|
||||||
|
for(ListShare r : result.getEntries()) {
|
||||||
|
resultList.add(r);
|
||||||
|
}
|
||||||
|
|
||||||
|
myAdapter = new ShareeSwipeableAdapter(this, resultList);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -0,0 +1,128 @@
|
|||||||
|
package com.example.listify.adapter;
|
||||||
|
|
||||||
|
import android.app.Activity;
|
||||||
|
import android.app.AlertDialog;
|
||||||
|
import android.content.Context;
|
||||||
|
import android.content.DialogInterface;
|
||||||
|
import android.content.Intent;
|
||||||
|
import android.view.LayoutInflater;
|
||||||
|
import android.view.View;
|
||||||
|
import android.view.ViewGroup;
|
||||||
|
import android.widget.BaseAdapter;
|
||||||
|
import android.widget.EditText;
|
||||||
|
import android.widget.TextView;
|
||||||
|
import android.widget.Toast;
|
||||||
|
|
||||||
|
import com.chauthai.swipereveallayout.SwipeRevealLayout;
|
||||||
|
import com.chauthai.swipereveallayout.ViewBinderHelper;
|
||||||
|
import com.example.listify.AuthManager;
|
||||||
|
import com.example.listify.ListPage;
|
||||||
|
import com.example.listify.R;
|
||||||
|
import com.example.listify.Requestor;
|
||||||
|
import com.example.listify.data.List;
|
||||||
|
import com.example.listify.data.ListShare;
|
||||||
|
|
||||||
|
import org.json.JSONException;
|
||||||
|
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Properties;
|
||||||
|
|
||||||
|
import static com.example.listify.MainActivity.am;
|
||||||
|
|
||||||
|
public class ShareeSwipeableAdapter extends BaseAdapter {
|
||||||
|
private Activity activity;
|
||||||
|
private ArrayList<ListShare> sharees;
|
||||||
|
private LayoutInflater inflater;
|
||||||
|
private final ViewBinderHelper binderHelper;
|
||||||
|
|
||||||
|
public ShareeSwipeableAdapter(Activity activity, ArrayList<ListShare> sharees){
|
||||||
|
binderHelper = new ViewBinderHelper();
|
||||||
|
this.activity = activity;
|
||||||
|
this.sharees = sharees;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public int getCount() {
|
||||||
|
return sharees.size();
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public Object getItem(int position) {
|
||||||
|
return sharees.get(position);
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public long getItemId(int position) {
|
||||||
|
return position;
|
||||||
|
}
|
||||||
|
|
||||||
|
@Override
|
||||||
|
public View getView(int position, View convertView, ViewGroup parent) {
|
||||||
|
ViewHolder holder;
|
||||||
|
|
||||||
|
Properties configs = new Properties();
|
||||||
|
try {
|
||||||
|
configs = AuthManager.loadProperties(activity, "android.resource://" + activity.getPackageName() + "/raw/auths.json");
|
||||||
|
} catch (IOException | JSONException e) {
|
||||||
|
e.printStackTrace();
|
||||||
|
}
|
||||||
|
Requestor requestor = new Requestor(am, configs.getProperty("apiKey"));
|
||||||
|
|
||||||
|
if (inflater == null) {
|
||||||
|
inflater = (LayoutInflater)activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
|
||||||
|
}
|
||||||
|
if (convertView == null) {
|
||||||
|
convertView = inflater.inflate(R.layout.shopping_lists_swipeable_name_item, null);
|
||||||
|
|
||||||
|
holder = new ViewHolder();
|
||||||
|
holder.swipeLayout = (SwipeRevealLayout)convertView.findViewById(R.id.swipe_layout);
|
||||||
|
holder.frontView = convertView.findViewById(R.id.front_layout);
|
||||||
|
holder.deleteList = convertView.findViewById(R.id.delete_list);
|
||||||
|
holder.shareList = convertView.findViewById(R.id.share_list);
|
||||||
|
holder.textView = (TextView) convertView.findViewById(R.id.shopping_list_name);
|
||||||
|
|
||||||
|
convertView.setTag(holder);
|
||||||
|
} else {
|
||||||
|
holder = (ViewHolder) convertView.getTag();
|
||||||
|
}
|
||||||
|
|
||||||
|
final ListShare currSharee = sharees.get(position);
|
||||||
|
|
||||||
|
// Bind the view to the unique list ID
|
||||||
|
binderHelper.bind(holder.swipeLayout, currSharee.getShareWithEmail());
|
||||||
|
|
||||||
|
holder.textView.setText(currSharee.getShareWithEmail());
|
||||||
|
|
||||||
|
holder.deleteList.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
holder.shareList.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
holder.frontView.setOnClickListener(new View.OnClickListener() {
|
||||||
|
@Override
|
||||||
|
public void onClick(View v) {
|
||||||
|
|
||||||
|
}
|
||||||
|
});
|
||||||
|
|
||||||
|
return convertView;
|
||||||
|
}
|
||||||
|
|
||||||
|
private class ViewHolder {
|
||||||
|
SwipeRevealLayout swipeLayout;
|
||||||
|
View frontView;
|
||||||
|
View deleteList;
|
||||||
|
View shareList;
|
||||||
|
TextView textView;
|
||||||
|
}
|
||||||
|
}
|
||||||
@ -70,10 +70,6 @@ public class List {
|
|||||||
this.lastUpdated = lastUpdated;
|
this.lastUpdated = lastUpdated;
|
||||||
}
|
}
|
||||||
|
|
||||||
public ListEntry[] getEntries() {
|
|
||||||
return entries;
|
|
||||||
}
|
|
||||||
|
|
||||||
public boolean isShared() {
|
public boolean isShared() {
|
||||||
return shared;
|
return shared;
|
||||||
}
|
}
|
||||||
@ -88,5 +84,8 @@ public class List {
|
|||||||
|
|
||||||
public void setUiPosition(Integer uiPosition) {
|
public void setUiPosition(Integer uiPosition) {
|
||||||
this.uiPosition = uiPosition;
|
this.uiPosition = uiPosition;
|
||||||
|
|
||||||
|
public ListEntry[] getEntries() {
|
||||||
|
return entries;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@ -9,9 +9,10 @@ import java.util.Map;
|
|||||||
public class ListShare {
|
public class ListShare {
|
||||||
Integer listID;
|
Integer listID;
|
||||||
String shareWithEmail;
|
String shareWithEmail;
|
||||||
|
final ListShare[] other;
|
||||||
Integer permissionLevel;
|
Integer permissionLevel;
|
||||||
|
|
||||||
private static final Map<Integer, String> keysToPerms;
|
private static final Map<Integer, String> keysToPerms;
|
||||||
|
|
||||||
static {
|
static {
|
||||||
//All keys should be a prime number > 1
|
//All keys should be a prime number > 1
|
||||||
//All keys need to be maintained here and in List module->ListPermissions class on the Lambda side
|
//All keys need to be maintained here and in List module->ListPermissions class on the Lambda side
|
||||||
@ -22,18 +23,20 @@ public class ListShare {
|
|||||||
keysToPermsTemp.put(7, "share");
|
keysToPermsTemp.put(7, "share");
|
||||||
keysToPerms = Collections.unmodifiableMap(keysToPermsTemp);
|
keysToPerms = Collections.unmodifiableMap(keysToPermsTemp);
|
||||||
}
|
}
|
||||||
|
|
||||||
public ListShare(Integer listID, String shareWithEmail, Integer permissionLevel) {
|
public ListShare(Integer listID, String shareWithEmail, Integer permissionLevel, ListShare[] other) {
|
||||||
this.listID = listID;
|
this.listID = listID;
|
||||||
this.shareWithEmail = shareWithEmail;
|
this.shareWithEmail = shareWithEmail;
|
||||||
this.permissionLevel = permissionLevel;
|
this.permissionLevel = permissionLevel;
|
||||||
|
this.other = other
|
||||||
}
|
}
|
||||||
|
|
||||||
public ListShare(Integer listID, String shareWithEmail, String permissionsRaw) {
|
public ListShare(Integer listID, String shareWithEmail, String permissionsRaw, ListShare[] other) {
|
||||||
String permissions = permissionsRaw.toLowerCase();
|
String permissions = permissionsRaw.toLowerCase();
|
||||||
this.listID = listID;
|
this.listID = listID;
|
||||||
this.shareWithEmail = shareWithEmail;
|
this.shareWithEmail = shareWithEmail;
|
||||||
permissionLevel = 1;
|
permissionLevel = 1;
|
||||||
|
this.other = other;
|
||||||
for (Map.Entry<Integer, String> keytoPermEntry: keysToPerms.entrySet()) {
|
for (Map.Entry<Integer, String> keytoPermEntry: keysToPerms.entrySet()) {
|
||||||
if (permissions.contains(keytoPermEntry.getValue())) {
|
if (permissions.contains(keytoPermEntry.getValue())) {
|
||||||
permissionLevel *= keytoPermEntry.getKey();
|
permissionLevel *= keytoPermEntry.getKey();
|
||||||
@ -62,6 +65,7 @@ public class ListShare {
|
|||||||
}
|
}
|
||||||
toReturn.append("]}");
|
toReturn.append("]}");
|
||||||
return toReturn.toString();
|
return toReturn.toString();
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
public Integer getListID() {
|
public Integer getListID() {
|
||||||
@ -79,7 +83,11 @@ public class ListShare {
|
|||||||
public void setShareWithEmail(String shareWithEmail) {
|
public void setShareWithEmail(String shareWithEmail) {
|
||||||
this.shareWithEmail = shareWithEmail;
|
this.shareWithEmail = shareWithEmail;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public ListShare[] getEntries() {
|
||||||
|
return other;
|
||||||
|
}
|
||||||
|
|
||||||
public Integer getPermissionLevel() {
|
public Integer getPermissionLevel() {
|
||||||
return permissionLevel;
|
return permissionLevel;
|
||||||
}
|
}
|
||||||
@ -87,5 +95,4 @@ public class ListShare {
|
|||||||
public void setPermissionLevel(Integer permissionLevel) {
|
public void setPermissionLevel(Integer permissionLevel) {
|
||||||
this.permissionLevel = permissionLevel;
|
this.permissionLevel = permissionLevel;
|
||||||
}
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|||||||
22
Listify/app/src/main/res/layout/activity_listofsharees.xml
Normal file
22
Listify/app/src/main/res/layout/activity_listofsharees.xml
Normal file
@ -0,0 +1,22 @@
|
|||||||
|
<RelativeLayout
|
||||||
|
xmlns:android="http://schemas.android.com/apk/res/android"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent">
|
||||||
|
|
||||||
|
<ProgressBar
|
||||||
|
android:id="@+id/progress_loading_list_items"
|
||||||
|
style="?android:attr/progressBarStyleLarge"
|
||||||
|
android:layout_width="wrap_content"
|
||||||
|
android:layout_height="wrap_content"
|
||||||
|
android:layout_centerHorizontal="true"
|
||||||
|
android:layout_centerVertical="true"
|
||||||
|
android:indeterminate="true"
|
||||||
|
android:visibility="gone"/>
|
||||||
|
|
||||||
|
<ListView
|
||||||
|
android:id="@+id/listOfSharees"
|
||||||
|
android:layout_width="match_parent"
|
||||||
|
android:layout_height="match_parent"
|
||||||
|
android:layout_marginTop="0dp" />
|
||||||
|
|
||||||
|
</RelativeLayout>
|
||||||
Loading…
Reference in New Issue
Block a user