From 071f6b9be2ba58323a259ea82d42c98676344f97 Mon Sep 17 00:00:00 2001
From: Georg Reisinger <43533139+GeorgReisinger@users.noreply.github.com>
Date: Sat, 26 Jan 2019 19:05:08 +0100
Subject: [PATCH] Refresh List, Gui
Refresch List by swipe
Gui update
    User image
    User Image round
    Full width CardView
---
 .idea/vcs.xml                                 |   6 +
 app/build.gradle                              |   2 +
 .../at/smartshopper/smartshopper/Dash.java    |  85 ++++++++--
 .../RoundCornersTransformation.java           | 152 ++++++++++++++++++
 .../smartshopper/ShoppinglistAdapter.java     |  13 +-
 app/src/main/res/layout/activity_dash.xml     |  29 ++--
 app/src/main/res/layout/cardview.xml          |  25 ++-
 7 files changed, 272 insertions(+), 40 deletions(-)
 create mode 100644 .idea/vcs.xml
 create mode 100644 app/src/main/java/at/smartshopper/smartshopper/RoundCornersTransformation.java
diff --git a/.idea/vcs.xml b/.idea/vcs.xml
new file mode 100644
index 0000000..94a25f7
--- /dev/null
+++ b/.idea/vcs.xml
@@ -0,0 +1,6 @@
+
+
+  
+    
+  
+
\ No newline at end of file
diff --git a/app/build.gradle b/app/build.gradle
index 36809f3..d22dc95 100644
--- a/app/build.gradle
+++ b/app/build.gradle
@@ -32,4 +32,6 @@ dependencies {
     implementation 'com.firebaseui:firebase-ui-auth:4.1.0'
     // http://mvnrepository.com/artifact/postgresql/postgresql
     implementation group: 'postgresql', name: 'postgresql', version: '9.1-901.jdbc4'
+    implementation 'com.squareup.picasso:picasso:2.71828'
+    implementation 'com.android.support:swiperefreshlayout:28.0.0-alpha1'
 }
diff --git a/app/src/main/java/at/smartshopper/smartshopper/Dash.java b/app/src/main/java/at/smartshopper/smartshopper/Dash.java
index 1c1e85c..9477ce9 100644
--- a/app/src/main/java/at/smartshopper/smartshopper/Dash.java
+++ b/app/src/main/java/at/smartshopper/smartshopper/Dash.java
@@ -1,11 +1,15 @@
 package at.smartshopper.smartshopper;
 
+import android.content.Intent;
 import android.net.Uri;
 import android.os.Bundle;
 import android.support.annotation.NonNull;
+import android.support.v4.widget.SwipeRefreshLayout;
 import android.support.v7.app.AppCompatActivity;
 import android.support.v7.widget.LinearLayoutManager;
 import android.support.v7.widget.RecyclerView;
+import android.view.View;
+import android.widget.Button;
 import android.widget.TabHost;
 
 import com.google.android.gms.tasks.OnCompleteListener;
@@ -23,6 +27,12 @@ import java.util.jar.JarInputStream;
 public class Dash extends AppCompatActivity {
 
     private Database db = new Database();
+    private SwipeRefreshLayout ownswiperefresh;
+
+    private void goLogin() {
+        Intent intent = new Intent(this, LoginActivity.class);
+        startActivity(intent);
+    }
 
 
     @Override
@@ -31,9 +41,17 @@ public class Dash extends AppCompatActivity {
         setContentView(R.layout.activity_dash);
 
 
-
         tabHoster();
 
+        Button logoutBtn = (Button) findViewById(R.id.logoutBtn);
+        logoutBtn.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                FirebaseAuth.getInstance().signOut();
+                goLogin();
+            }
+        });
+
 
         /*
         Get userinformations
@@ -44,9 +62,7 @@ public class Dash extends AppCompatActivity {
             String name = user.getDisplayName();
             String email = user.getEmail();
             Uri photoUrl = user.getPhotoUrl();
-            RecyclerView ownRecycleView = (RecyclerView) findViewById(R.id.ownrecycler);
-            ownRecycleView.setHasFixedSize(true);
-            ownRecycleView.setLayoutManager(new LinearLayoutManager(this));
+
 
             // Check if user's email is verified
             boolean emailVerified = user.isEmailVerified();
@@ -54,20 +70,67 @@ public class Dash extends AppCompatActivity {
             // The user's ID, unique to the Firebase project. Do NOT use this value to
             // authenticate with your backend server, if you have one. Use
             // FirebaseUser.getIdToken() instead.
-            String uid = user.getUid();
+            final String uid = user.getUid();
+
 
             try {
-                List ownListsList = db.getMyShoppinglists(uid);
-
-                ShoppinglistAdapter shpAdapter = new ShoppinglistAdapter(Dash.this, ownListsList);
-
-                ownRecycleView.setAdapter(shpAdapter);
-            }catch (JSONException e){
+                showOwnShoppingList(uid);
+            } catch (JSONException e) {
                 e.printStackTrace();
             }
+            ownswiperefresh = (SwipeRefreshLayout) findViewById(R.id.ownSwipe);
+
+            ownswiperefresh.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
+                @Override
+                public void onRefresh() {
+                    refreshOwnShoppinglist(uid);
+
+                }
+            });
+
+
         }
     }
 
+    /**
+     * Refreshed die eigene shoppinglist und veranlasst das das refreshen beendet wird
+     * @param uid Von dem benutzer von welchem die Shoppinglists angezeigt werden sollen
+     */
+    private void refreshOwnShoppinglist(String uid){
+        try {
+            showOwnShoppingList(uid);
+        } catch (JSONException e) {
+            e.printStackTrace();
+        }
+        refreshOwnShoppinglistFinish();
+    }
+
+    /**
+     * Stoppt das refreshen der OwnShoppinglist
+     */
+    private void refreshOwnShoppinglistFinish() {
+        // Update the adapter and notify data set changed
+        // ...
+
+        // Stop refresh animation
+        ownswiperefresh.setRefreshing(false);
+    }
+
+
+    /**
+     * Macht eine Datenbankverbindung und holt alle Shoppinglists die dem User gehören, diese werden auf dem recycled view angezeigt
+     *
+     * @param uid Die UserId damit von diesem user die shoppinglisten angezeigt werden
+     */
+    private void showOwnShoppingList(String uid) throws JSONException {
+        RecyclerView ownRecycleView = (RecyclerView) findViewById(R.id.ownrecycler);
+        ownRecycleView.setHasFixedSize(true);
+        ownRecycleView.setLayoutManager(new LinearLayoutManager(this));
+        List ownListsList = db.getMyShoppinglists(uid);
+        ShoppinglistAdapter shpAdapter = new ShoppinglistAdapter(Dash.this, ownListsList);
+        ownRecycleView.setAdapter(shpAdapter);
+    }
+
     /**
      * Ist dafür Zuständig das es Tabs in der App gibt. Ohne dieser Funktion werden die Tabs nichtmehr Angezeigt.
      * Hier wird auch der Name der Tabs gesetzt
diff --git a/app/src/main/java/at/smartshopper/smartshopper/RoundCornersTransformation.java b/app/src/main/java/at/smartshopper/smartshopper/RoundCornersTransformation.java
new file mode 100644
index 0000000..5ef900f
--- /dev/null
+++ b/app/src/main/java/at/smartshopper/smartshopper/RoundCornersTransformation.java
@@ -0,0 +1,152 @@
+package at.smartshopper.smartshopper;
+
+import android.graphics.Bitmap;
+import android.graphics.Bitmap.Config;
+import android.graphics.BitmapShader;
+import android.graphics.Canvas;
+import android.graphics.Paint;
+import android.graphics.Path;
+import android.graphics.RectF;
+import android.graphics.Shader;
+
+
+// enables hardware accelerated rounded corners
+// original idea here : http://www.curious-creature.org/2012/12/11/android-recipe-1-image-with-rounded-corners/
+// https://gist.github.com/aprock/6213395
+// https://gist.github.com/amardeshbd/06b491d4adb568b1b226a20d4953a180
+public class RoundCornersTransformation implements com.squareup.picasso.Transformation {
+    private final int radius;  // dp
+    private final int margin;  // dp
+    private String KEY = "";
+    private boolean topCorners = true;
+    private boolean bottomCorners = true;
+
+    /**
+     * Creates rounded transformation for all corners.
+     *
+     * @param radius radius is corner radii in dp
+     * @param margin margin is the board in dp
+     */
+    public RoundCornersTransformation(final int radius, final int margin) {
+        this.radius = radius;
+        this.margin = margin;
+        if (KEY.isEmpty()) KEY = "rounded_" + radius + margin;
+    }
+
+
+    /**
+     * Creates rounded transformation for top or bottom corners.
+     *
+     * @param radius radius is corner radii in dp
+     * @param margin margin is the board in dp
+     * @param topCornersOnly Rounded corner for top corners only.
+     * @param bottomCornersOnly Rounded corner for bottom corners only.
+     */
+    public RoundCornersTransformation(final int radius, final int margin, boolean topCornersOnly,
+                                      boolean bottomCornersOnly) {
+        this(radius, margin);
+        topCorners = topCornersOnly;
+        bottomCorners = bottomCornersOnly;
+        KEY = "rounded_" + radius + margin + topCorners + bottomCorners;
+    }
+
+    @Override
+    public Bitmap transform(final Bitmap source) {
+        final Paint paint = new Paint();
+        paint.setAntiAlias(true);
+        paint.setShader(new BitmapShader(source, Shader.TileMode.CLAMP, Shader.TileMode.CLAMP));
+
+        Bitmap output = Bitmap.createBitmap(source.getWidth(), source.getHeight(), Config.ARGB_8888);
+        Canvas canvas = new Canvas(output);
+        if(topCorners && bottomCorners) {
+            // Uses native method to draw symmetric rounded corners
+            canvas.drawRoundRect(new RectF(margin, margin, source.getWidth() - margin,
+                    source.getHeight() - margin), radius, radius, paint);
+        } else {
+            // Uses custom path to generate rounded corner individually
+            canvas.drawPath(RoundedRect(margin, margin, source.getWidth() - margin,
+                    source.getHeight() - margin, radius, radius, topCorners, topCorners,
+                    bottomCorners, bottomCorners), paint);
+        }
+
+
+        if (source != output) {
+            source.recycle();
+        }
+
+        return output;
+    }
+
+
+    @Override
+    public String key() {
+        return "rounded_" + radius + margin;
+//        return KEY;
+    }
+
+    /**
+     * Prepares a path for rounded corner selectively.
+     * Source taken from http://stackoverflow.com/a/35668889/6635889
+     * @param leftX The X coordinate of the left side of the rectangle
+     * @param topY The Y coordinate of the top of the rectangle
+     * @param rightX The X coordinate of the right side of the rectangle
+     * @param bottomY The Y coordinate of the bottom of the rectangle
+     * @param rx The x-radius of the oval used to round the corners
+     * @param ry The y-radius of the oval used to round the corners
+     * @param topLeft
+     * @param topRight
+     * @param bottomRight
+     * @param bottomLeft
+     * @return
+     */
+    public static Path RoundedRect(float leftX, float topY, float rightX, float bottomY, float rx,
+                                   float ry, boolean topLeft, boolean topRight, boolean
+                                           bottomRight, boolean bottomLeft) {
+        Path path = new Path();
+        if (rx < 0) rx = 0;
+        if (ry < 0) ry = 0;
+        float width = rightX - leftX;
+        float height = bottomY - topY;
+        if (rx > width / 2) rx = width / 2;
+        if (ry > height / 2) ry = height / 2;
+        float widthMinusCorners = (width - (2 * rx));
+        float heightMinusCorners = (height - (2 * ry));
+
+        path.moveTo(rightX, topY + ry);
+        if (topRight)
+            path.rQuadTo(0, -ry, -rx, -ry);//top-right corner
+        else{
+            path.rLineTo(0, -ry);
+            path.rLineTo(-rx,0);
+        }
+        path.rLineTo(-widthMinusCorners, 0);
+        if (topLeft)
+            path.rQuadTo(-rx, 0, -rx, ry); //top-left corner
+        else{
+            path.rLineTo(-rx, 0);
+            path.rLineTo(0,ry);
+        }
+        path.rLineTo(0, heightMinusCorners);
+
+        if (bottomLeft)
+            path.rQuadTo(0, ry, rx, ry);//bottom-left corner
+        else{
+            path.rLineTo(0, ry);
+            path.rLineTo(rx,0);
+        }
+
+        path.rLineTo(widthMinusCorners, 0);
+        if (bottomRight)
+            path.rQuadTo(rx, 0, rx, -ry); //bottom-right corner
+        else{
+            path.rLineTo(rx,0);
+            path.rLineTo(0, -ry);
+        }
+
+        path.rLineTo(0, -heightMinusCorners);
+
+        path.close();//Given close, last lineto can be removed.
+
+        return path;
+    }
+}
diff --git a/app/src/main/java/at/smartshopper/smartshopper/ShoppinglistAdapter.java b/app/src/main/java/at/smartshopper/smartshopper/ShoppinglistAdapter.java
index 7abab11..a26915b 100644
--- a/app/src/main/java/at/smartshopper/smartshopper/ShoppinglistAdapter.java
+++ b/app/src/main/java/at/smartshopper/smartshopper/ShoppinglistAdapter.java
@@ -1,6 +1,7 @@
 package at.smartshopper.smartshopper;
 
 import android.content.Context;
+import android.graphics.drawable.Drawable;
 import android.net.Uri;
 import android.support.v7.widget.RecyclerView;
 import android.view.LayoutInflater;
@@ -11,6 +12,7 @@ import android.widget.TextView;
 
 import com.google.firebase.auth.FirebaseAuth;
 import com.google.firebase.auth.FirebaseUser;
+import com.squareup.picasso.Picasso;
 
 import java.util.List;
 
@@ -33,13 +35,13 @@ public class ShoppinglistAdapter extends RecyclerView.Adapter
 
-                        
-
-                        
+                            android:layout_height="match_parent">
 
+                            
 
+                        
 
                     
 
@@ -84,14 +81,6 @@
                             android:layout_height="wrap_content"
                             android:text="Logout" />
 
-                        
-
                         
 
         
 
         
+
+        
     
 
 
\ No newline at end of file