From 82e57df230ecb744af6c8865f80870ba03c86d89 Mon Sep 17 00:00:00 2001
From: Linjiajia <319408893@qq.com>
Date: 星期二, 25 七月 2023 22:18:27 +0800
Subject: [PATCH] 基本功能完成

---
 app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java |  165 +++++++++++++++++++++++++++++++++++++-----------------
 1 files changed, 112 insertions(+), 53 deletions(-)

diff --git a/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java b/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java
index 6ab1686..5e1ab0c 100644
--- a/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java
+++ b/app/src/main/java/com/application/zhangshi_app_android/adapter/TourismRvAdapter.java
@@ -3,31 +3,50 @@
 import android.content.Context;
 import android.content.Intent;
 import android.view.View;
-import android.view.animation.Animation;
-import android.view.animation.Transformation;
+import android.widget.CompoundButton;
 import android.widget.FrameLayout;
 
 
+import androidx.recyclerview.widget.GridLayoutManager;
+
+import com.android.app_base.base.BaseConfig;
 import com.android.app_base.base.adapter.BaseRVAdapter;
+import com.android.app_base.base.dialog.BaseDialog;
+import com.android.app_base.base.dialog.UIDialog;
 import com.android.app_base.manager.AppManager;
+import com.android.app_base.utils.Utils;
 import com.application.zhangshi_app_android.R;
+import com.application.zhangshi_app_android.bean.DailyConsumeRecordBean;
+import com.application.zhangshi_app_android.bean.FamilyMemorabiliaBean;
 import com.application.zhangshi_app_android.bean.TourismBean;
+import com.application.zhangshi_app_android.databinding.ItemFamilyMemorabiliaBinding;
 import com.application.zhangshi_app_android.databinding.ItemTourismBinding;
+import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaActivityViewModel;
+import com.application.zhangshi_app_android.ui.function.FamilyMemorabiliaDetailActivity;
+import com.application.zhangshi_app_android.ui.function.TourismActivityViewModel;
 import com.application.zhangshi_app_android.ui.function.TourismDetailActivity;
 import com.application.zhangshi_app_android.ui.function.TourismExperienceActivity;
 
+import java.util.ArrayList;
+import java.util.HashMap;
+import java.util.List;
+import java.util.Map;
 
 
 /**
  * @author Ljj
  * @date 2023.04.28. 21:18
- * @desc
+ * @desc 鏃呮父缁忓巻鍒楄〃 Adapter
  */
 public class TourismRvAdapter extends BaseRVAdapter<TourismBean, ItemTourismBinding, TourismRvAdapter.ViewHolder> {
-    public TourismRvAdapter(Context context) {
-        super(context);
-    }
+    private final TourismActivityViewModel viewModel;
+    private boolean isCheckable;
+    private final Map<TourismBean, Boolean> expendMap = new HashMap<>();
 
+    public TourismRvAdapter(Context context, TourismActivityViewModel viewModel) {
+        super(context);
+        this.viewModel = viewModel;
+    }
     @Override
     protected int getLayoutId() {
         return R.layout.item_tourism;
@@ -46,76 +65,116 @@
         }else {
             holder.getBinding().cardView.setCardBackgroundColor(mContext.getColor(R.color.color_card_pink));
         }
+        if (!expendMap.containsKey(getItem(position))){
+            expendMap.put(getItem(position),false);
+        }
+        if (Boolean.TRUE.equals(expendMap.get(getItem(position)))){
+            holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_unfold);
+            holder.getBinding().cardView.post(() -> {
+                holder.getBinding().cardView.getLayoutParams().height = FrameLayout.LayoutParams.WRAP_CONTENT;
+                holder.getBinding().cardView.requestLayout();
+            });
+        }else{
+            holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_fold);
+            holder.getBinding().cardView.post(() -> {
+                holder.getBinding().cardView.getLayoutParams().height = holder.getBinding().layoutTitle.getMeasuredHeight();
+                holder.getBinding().cardView.requestLayout();
+            });
+        }
+        if (isCheckable){
+            holder.getBinding().checkbox.setVisibility(View.VISIBLE);
+            holder.getBinding().checkbox.setOnCheckedChangeListener(new CompoundButton.OnCheckedChangeListener() {
+                @Override
+                public void onCheckedChanged(CompoundButton buttonView, boolean isChecked) {
+                    if (viewModel.getCheckListLiveData().getValue() == null){
+                        viewModel.getCheckListLiveData().setValue(new ArrayList<>());
+                    }
+                    List<TourismBean> list = new ArrayList<>(viewModel.getCheckListLiveData().getValue());
+                    if (isChecked){
+                        if (!list.contains(mDataList.get(position))){
+                            list.add(mDataList.get(position));
+                        }
+                    }else{
+                        list.remove(mDataList.get(position));
+                    }
+                    viewModel.getCheckListLiveData().setValue(list);
+                }
+            });
+            holder.getBinding().checkbox.setChecked(viewModel.getCheckListLiveData().getValue().contains(mDataList.get(position)));
+        }else{
+            holder.getBinding().checkbox.setVisibility(View.GONE);
+        }
         holder.getBinding().layoutTitle.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View view) {
-                if (holder.isExpended){
+                if (Boolean.TRUE.equals(expendMap.get(getItem(position)))){
                     int initialHeight = holder.getBinding().cardView.getMeasuredHeight();
                     int collapsedHeight = holder.getBinding().layoutTitle.getMeasuredHeight();
-                    int distanceToCollapse = (int) (initialHeight - collapsedHeight);
-
-                    Animation a = new Animation() {
-                        @Override
-                        protected void applyTransformation(float interpolatedTime, Transformation t) {
-                            if (interpolatedTime == 1){
-                            }
-                            holder.getBinding().cardView.getLayoutParams().height = (int) (initialHeight - (distanceToCollapse * interpolatedTime));
-                            holder.getBinding().cardView.requestLayout();
-                        }
-
-                        @Override
-                        public boolean willChangeBounds() {
-                            return true;
-                        }
-                    };
-                    a.setDuration(500);
-                    holder.getBinding().cardView.startAnimation(a);
-                    holder.isExpended = false;
+                    Utils.pullCollapse(holder.getBinding().cardView,initialHeight,collapsedHeight);
+                    holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_fold);
+                    expendMap.put(getItem(position),false);
                 }else{
                     final int initialHeight = holder.getBinding().cardView.getMeasuredHeight();
                     holder.getBinding().cardView.measure(FrameLayout.LayoutParams.MATCH_PARENT, FrameLayout.LayoutParams.WRAP_CONTENT);
                     int targetHeight = holder.getBinding().cardView.getMeasuredHeight();
-                    int distanceToExpand = targetHeight - initialHeight;
-                    Animation a = new Animation() {
-                        @Override
-                        protected void applyTransformation(float interpolatedTime, Transformation t) {
-                            if (interpolatedTime == 1){
-                            }
-                            holder.getBinding().cardView.getLayoutParams().height = (int) (initialHeight + (distanceToExpand * interpolatedTime));
-                            holder.getBinding().cardView.requestLayout();
-                        }
-
-                        @Override
-                        public boolean willChangeBounds() {
-                            return true;
-                        }
-                    };
-                    a.setDuration(500);
-                    holder.getBinding().cardView.startAnimation(a);
-                    holder.isExpended = true;
+                    Utils.dropExpand(holder.getBinding().cardView,initialHeight,targetHeight);
+                    holder.getBinding().ivFold.setBackgroundResource(R.drawable.ic_unfold);
+                    expendMap.put(getItem(position),true);
                 }
             }
         });
-        holder.getBinding().layoutContent.setOnClickListener(v -> {
-            AppManager.getAppManager().startActivity(
-                    new Intent(getRecyclerView().getContext(), TourismDetailActivity.class)
-                            .putExtra("bean",mDataList.get(position)));
+        holder.itemView.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                AppManager.getAppManager().startActivity(
+                        new Intent(getRecyclerView().getContext(), TourismDetailActivity.class)
+                                .putExtra(BaseConfig.EXTRA_TYPE,0)
+                                .putExtra("bean",mDataList.get(position)));
+            }
         });
-
+        holder.getBinding().layoutModify.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                AppManager.getAppManager().startActivity(
+                        new Intent(getRecyclerView().getContext(), TourismDetailActivity.class)
+                                .putExtra(BaseConfig.EXTRA_TYPE,2)
+                                .putExtra("bean",mDataList.get(position)));
+            }
+        });
+        holder.getBinding().layoutDelete.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                new UIDialog.Builder(mContext)
+                        .setTitle("鎮ㄧ‘瀹氳鍒犻櫎璇ラ」鐩悧")
+                        .setContent("椤圭洰鍒犻櫎鍚庡皢鏃犳硶鎭㈠")
+                        .setConfirm("纭畾")
+                        .setCancel("鍙栨秷")
+                        .setListener(new UIDialog.OnListener() {
+                            @Override
+                            public void onConfirm(BaseDialog dialog) {
+                                viewModel.deleteItem(mDataList.get(position));
+                            }
+                        })
+                        .show();
+            }
+        });
         holder.getBinding().tvDetail.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
                 AppManager.getAppManager().startActivity(
                         new Intent(getRecyclerView().getContext(), TourismExperienceActivity.class)
-                                .putExtra("bean",mDataList.get(position)));
+                                .putExtra("id",mDataList.get(position).getId()));
             }
         });
-
     }
 
-    public static class ViewHolder extends BaseRVAdapter.BaseViewHolder<ItemTourismBinding> {
-        private boolean isExpended;
+    public void setCheckable(boolean b) {
+        isCheckable = b;
+        notifyItemRangeChanged(0,getItemCount());
+    }
 
+
+    public static class ViewHolder extends BaseViewHolder<ItemTourismBinding>{
         public ViewHolder(ItemTourismBinding binding) {
             super(binding);
         }

--
Gitblit v1.9.1