From efafbbf142c81c233c71de636a2d3ce9dc2124f0 Mon Sep 17 00:00:00 2001
From: Linjiajia <319408893@qq.com>
Date: 星期二, 12 九月 2023 19:20:05 +0800
Subject: [PATCH] 修复bug

---
 app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java |  413 +++++++++++++++++++++++++++++++++++++---------------------
 1 files changed, 265 insertions(+), 148 deletions(-)

diff --git a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java
index 56f247e..7d689e7 100644
--- a/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java
+++ b/app/src/main/java/com/application/zhangshi_app_android/ui/function/FamilyMemorabiliaActivity.java
@@ -1,50 +1,48 @@
 package com.application.zhangshi_app_android.ui.function;
 
-import android.content.DialogInterface;
 import android.content.Intent;
-import android.graphics.drawable.ColorDrawable;
-import android.view.KeyEvent;
-import android.view.LayoutInflater;
+import android.text.Editable;
+import android.text.TextUtils;
+import android.text.TextWatcher;
+import android.view.MotionEvent;
 import android.view.View;
-import android.view.ViewGroup;
-import android.view.inputmethod.EditorInfo;
-import android.widget.Button;
 import android.widget.PopupWindow;
-import android.widget.TextView;
 
-import androidx.annotation.IdRes;
-import androidx.annotation.LayoutRes;
-import androidx.appcompat.app.AlertDialog;
-import androidx.drawerlayout.widget.DrawerLayout;
 import androidx.lifecycle.Observer;
 
 import com.android.app_base.base.BaseConfig;
 import com.android.app_base.base.dialog.BaseDialog;
 import com.android.app_base.base.dialog.UIDialog;
-import com.android.app_base.base.view.BaseActivity;
 import com.android.app_base.manager.AppManager;
 import com.android.app_base.utils.ScreenSizeUtils;
+import com.android.app_base.utils.Utils;
+import com.android.app_base.utils.rxbus.RxBus;
 import com.android.app_base.widget.LinearItemDecoration;
 import com.application.zhangshi_app_android.BR;
 import com.application.zhangshi_app_android.R;
 import com.application.zhangshi_app_android.adapter.FamilyMemorabiliaRvAdapter;
 import com.application.zhangshi_app_android.bean.FamilyMemorabiliaBean;
 import com.application.zhangshi_app_android.databinding.ActivityFamilyMemorabiliaBinding;
+import com.application.zhangshi_app_android.ui.DLBaseActivity;
+import com.github.gzuliyujiang.wheelpicker.DatePicker;
+import com.github.gzuliyujiang.wheelpicker.contract.OnDatePickedListener;
 
+import java.util.Calendar;
 import java.util.List;
+
+import io.reactivex.functions.Consumer;
 
 /**
  * @author Ljj
  * @date 2023.03.18. 10:00
  * @desc 瀹跺ぇ浜嬭 Activity
  */
-public class FamilyMemorabiliaActivity extends BaseActivity<ActivityFamilyMemorabiliaBinding,FamilyMemorabiliaActivityViewModel> {
+public class FamilyMemorabiliaActivity extends DLBaseActivity<ActivityFamilyMemorabiliaBinding,FamilyMemorabiliaActivityViewModel>{
 
     FamilyMemorabiliaRvAdapter adapter;
     private PopupWindow mOperatePopupWindow;
-    private PopupWindow mSearchPopupWindow;
-    private int operateType = 0;
-    private int searchType = 0;
+    private boolean isSearchLayoutVisible;
+    private int dateType; //0:寮�濮嬫椂闂� 1:缁撴潫鏃堕棿
 
     @Override
     public int getLayoutId() {
@@ -63,187 +61,306 @@
 
     @Override
     public void initView() {
+        //涓嬫媺鍒锋柊甯冨眬
+        binding.refreshLayout.setEnableRefresh(false);
+        binding.refreshLayout.setEnableLoadMore(true);
+        binding.refreshLayout.setEnableOverScrollDrag(true);
+        binding.refreshLayout.setOnLoadMoreListener(refreshLayout -> {
+            viewModel.getMoreFamilyMemorabilia();
+        });
+        //recyclerView閫傞厤鍣�
         adapter = new FamilyMemorabiliaRvAdapter(this,viewModel);
         LinearItemDecoration itemDecoration = new LinearItemDecoration();
         itemDecoration.setBottomSpace((int) getResources().getDimension(com.android.app_base.R.dimen.dp_12));
         itemDecoration.setHorizontalSpace((int) getResources().getDimension(com.android.app_base.R.dimen.dp_20));
-        itemDecoration.setFirstTop((int) getResources().getDimension(com.android.app_base.R.dimen.dp_20));
         binding.recyclerView.addItemDecoration(itemDecoration);
         binding.recyclerView.setAdapter(adapter);
-
-
-        mOperatePopupWindow = initPopUpWindow(R.layout.pop_operate);
-        mOperatePopupWindow.getContentView().findViewById(R.id.tv_add).setOnClickListener(v -> {
-            AppManager.getAppManager().startActivity(new Intent(this,CreateFamilyProjectActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1));
-        });
-        mOperatePopupWindow.getContentView().findViewById(R.id.tv_select).setOnClickListener(v -> {
-            binding.ivOperate.setBackgroundResource(R.drawable.ic_operate_finish);
-            operateType = 1;
-            adapter.setCheckable(true);
-            mOperatePopupWindow.dismiss();
-        });
-        mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_new_to_old).setOnClickListener(v -> {
-            viewModel.changeOrder(true);
-            mOperatePopupWindow.dismiss();
-        });
-        mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_old_to_new).setOnClickListener(v -> {
-            viewModel.changeOrder(false);
-            mOperatePopupWindow.dismiss();
-        });
-        binding.ivOperate.setOnClickListener(v -> {
-            if (operateType == 0){
-                mOperatePopupWindow.showAsDropDown(binding.ivOperate,-ScreenSizeUtils.dip2px(this,85) +binding.ivOperate.getWidth(),0);
-            } else if (operateType == 1) {
-                binding.ivOperate.setBackgroundResource(R.drawable.ic_operate);
-                operateType = 0;
-                adapter.setCheckable(false);
-            } else {
-                new UIDialog.Builder(this)
-                        .setTitle("鎮ㄧ‘瀹氳鍒犻櫎椤圭洰鍚�")
-                        .setContent("椤圭洰鍒犻櫎鍚庡皢鏃犳硶鎭㈠")
-                        .setConfirm("纭畾")
-                        .setCancel("鍙栨秷")
-                        .setListener(new UIDialog.OnListener() {
-                            @Override
-                            public void onConfirm(BaseDialog dialog) {
-                                viewModel.delete();
-                            }
-                        })
-                        .show();
-            }
-        });
-
-        mSearchPopupWindow = initPopUpWindow(R.layout.pop_search);
-        binding.ivSearchType.setOnClickListener(v -> {
-            mSearchPopupWindow.showAsDropDown(binding.etSearch,0,0);
-        });
+        //鍙充笂瑙掓搷浣滃脊绐�
+        mOperatePopupWindow = initPopUpWindow(View.inflate(this,R.layout.pop_operate,null));
+        setOnClickListener(
+                mOperatePopupWindow.getContentView().findViewById(R.id.tv_add),
+                mOperatePopupWindow.getContentView().findViewById(R.id.tv_select),
+                mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_new_to_old),
+                mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_old_to_new),
+                mOperatePopupWindow.getContentView().findViewById(R.id.tv_own_top)
+        );
+        //鐐瑰嚮鏀惧ぇ闀滄寜閽樉绀哄嚭鎼滅储妗�
         binding.ivSearchDefault.setOnClickListener(v -> {
             binding.layoutSearch.setVisibility(View.VISIBLE);
             binding.layoutDefault.setVisibility(View.GONE);
         });
+        //鐐瑰嚮鎼滅储妗嗚彍鍗曚笅鎷夊嚭 鎼滅储鍙傛暟
+        binding.ivSearchType.setOnClickListener(v -> {
+            if (!isSearchLayoutVisible){
+                binding.layoutSearchParameter.measure(View.MeasureSpec.UNSPECIFIED, View.MeasureSpec.UNSPECIFIED);
+                int targetHeight = binding.layoutSearchParameter.getMeasuredHeight();
+                Utils.pullCollapse(binding.containerSearchParameter,0,targetHeight);
+                isSearchLayoutVisible = true;
+            }
+        });
+        //鎼滅储鍙傛暟layout娣诲姞绌虹偣鍑讳簨浠讹紝闃叉鐐瑰嚮瀹冨唴閮╲iew鏃跺畠鍚庨潰鐨剅ecycler杩樿兘鍝嶅簲鐐瑰嚮浜嬩欢
+        binding.layoutSearchParameter.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+            }
+        });
+        //鐐瑰嚮鎼滅储鎸夐挳杩涜鎼滅储
+        binding.ivSearch.setOnClickListener(v -> {
+            viewModel.getFamilyMemorabilia();
+            binding.layoutSearch.setVisibility(View.GONE);
+            binding.layoutDefault.setVisibility(View.VISIBLE);
+            binding.tvTitle.setText("鎼滅储缁撴灉");
+            hideSoftKeyboard();
+        });
+        //鐐瑰嚮娣诲姞鎸夐挳璺宠浆鍒板垱寤哄澶т簨璁伴〉闈�
         binding.fabAdd.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
-                AppManager.getAppManager().startActivity(new Intent(getSelfActivity(),CreateFamilyProjectActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1));
+                AppManager.getAppManager().startActivity(new Intent(getSelfActivity(), FamilyMemorabiliaDetailActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1));
             }
         });
-
-        setOnClickListener(
-                mSearchPopupWindow.getContentView().findViewById(R.id.tv_global_search),
-                mSearchPopupWindow.getContentView().findViewById(R.id.tv_search_in_family_memorabilia),
-                mSearchPopupWindow.getContentView().findViewById(R.id.tv_search_by_title),
-                mSearchPopupWindow.getContentView().findViewById(R.id.tv_search_by_people),
-                mSearchPopupWindow.getContentView().findViewById(R.id.tv_search_by_time),
-                mSearchPopupWindow.getContentView().findViewById(R.id.tv_search_by_place));
-
-
-        binding.etSearch.setOnEditorActionListener(new TextView.OnEditorActionListener() {
+        binding.etStartTime.addTextChangedListener(new TextWatcher() {
             @Override
-            public boolean onEditorAction(TextView v, int actionId, KeyEvent event) {
-                if ((actionId == EditorInfo.IME_ACTION_UNSPECIFIED || actionId == EditorInfo.IME_ACTION_SEARCH)
-                        && event != null) {
-                    viewModel.getFamilyMemorabilia(searchType);
-                    hideSoftKeyboard();
-                    return true;
+            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+            }
+
+            @Override
+            public void onTextChanged(CharSequence s, int start, int before, int count) {
+                if (!TextUtils.isEmpty(s)) {
+                    binding.ivTimeClear.setVisibility(View.VISIBLE);
+                } else {
+                    if (TextUtils.isEmpty(binding.etEndTime.getText().toString())) {
+                        binding.ivTimeClear.setVisibility(View.INVISIBLE);
+                    }
                 }
-                return false;
+            }
+
+            @Override
+            public void afterTextChanged(Editable s) {
+
             }
         });
+        binding.etEndTime.addTextChangedListener(new TextWatcher() {
+            @Override
+            public void beforeTextChanged(CharSequence s, int start, int count, int after) {
+            }
 
-        binding.ivMenu.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onTextChanged(CharSequence s, int start, int before, int count) {
+                if (!TextUtils.isEmpty(s)) {
+                    binding.ivTimeClear.setVisibility(View.VISIBLE);
+                } else {
+                    if (TextUtils.isEmpty(binding.etStartTime.getText().toString())) {
+                        binding.ivTimeClear.setVisibility(View.INVISIBLE);
+                    }
+                }            }
+
+            @Override
+            public void afterTextChanged(Editable s) {
+
+            }
+        });
+        binding.etStartTime.setOnClickListener(new View.OnClickListener() {
             @Override
             public void onClick(View v) {
-                binding.drawerLayout.open();
+                hideSoftKeyboard();
+                DatePicker datePicker = getDatePicker();
+                datePicker.setTitle("璇烽�夋嫨寮�濮嬫椂闂�");
+                datePicker.setOnDatePickedListener(new OnDatePickedListener() {
+                    @Override
+                    public void onDatePicked(int year, int month, int day) {
+                        //浠yyy-MM-dd鐨勬牸寮忔樉绀猴紝鏈堟棩灏忎簬10鏃跺墠闈㈣ˉ0
+                        binding.etStartTime.setText(String.format("%d-%02d-%02d", year, month, day));
+                        if (binding.etEndTime.getText().toString().isEmpty()){
+                            binding.etEndTime.setText(String.format("%d-%02d-%02d", year, month, day));
+                        }else {
+                            //姣旇緝寮�濮嬫椂闂村拰缁撴潫鏃堕棿鐨勫ぇ灏�
+                            String startTime = binding.etStartTime.getText().toString();
+                            String endTime = binding.etEndTime.getText().toString();
+                            if (Utils.compareDate(startTime,endTime) > 0){
+                                //浜ゆ崲
+                                binding.etStartTime.setText(endTime);
+                                binding.etEndTime.setText(startTime);
+                            }
+                        }
+                    }
+                });
+                datePicker.show();
             }
         });
-        binding.drawerLayout.setScrimColor(getResources().getColor(R.color.color_shadow));
+        binding.etEndTime.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                hideSoftKeyboard();
+                DatePicker datePicker = getDatePicker();
+                datePicker.setTitle("璇烽�夋嫨缁撴潫鏃堕棿");
+                datePicker.setOnDatePickedListener(new OnDatePickedListener() {
+                    @Override
+                    public void onDatePicked(int year, int month, int day) {
+                        binding.etEndTime.setText(String.format("%d-%02d-%02d", year, month, day));
+                        if (binding.etStartTime.getText().toString().isEmpty()){
+                            binding.etStartTime.setText(String.format("%d-%02d-%02d", year, month, day));
+                        }else {
+                            //姣旇緝寮�濮嬫椂闂村拰缁撴潫鏃堕棿鐨勫ぇ灏�
+                            String startTime = binding.etStartTime.getText().toString();
+                            String endTime = binding.etEndTime.getText().toString();
+                            if (Utils.compareDate(startTime,endTime) > 0){
+                                //浜ゆ崲
+                                binding.etStartTime.setText(endTime);
+                                binding.etEndTime.setText(startTime);
+                            }
+                        }
+                    }
+                });
+                datePicker.show();
+            }
+        });
+        binding.ivTimeClear.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View v) {
+                binding.etStartTime.setText("");
+                binding.etEndTime.setText("");
+            }
+        });
     }
 
     @Override
     public void initData() {
-        viewModel.getFamilyMemorabilia(searchType);
+        viewModel.getFamilyMemorabilia();
+    }
+
+    @Override
+    public boolean dispatchTouchEvent(MotionEvent event) {
+        float x = event.getX();
+        float y = event.getY();
+        if (isSearchLayoutVisible){
+            if (!Utils.isPointInsideView(x, y, binding.layoutSearchParameter)) {
+                Utils.pullCollapse(binding.containerSearchParameter, binding.layoutSearchParameter.getMeasuredHeight(),0);
+                isSearchLayoutVisible = false;
+                return true;
+            }
+        }
+        return super.dispatchTouchEvent(event);
     }
 
     @Override
     public void initLiveDataObserve() {
-        viewModel.getCheckListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() {
-            @Override
-            public void onChanged(List<FamilyMemorabiliaBean> familyMemorabiliaBeans) {
-                if (operateType == 0){
-                    return;
-                }
-                if (familyMemorabiliaBeans.isEmpty()){
-                    binding.ivOperate.setBackgroundResource(R.drawable.ic_operate_finish);
-                    operateType = 1;
-                }else{
-                    binding.ivOperate.setBackgroundResource(R.drawable.ic_delete_white);
-                    operateType = 2;
-                }
-            }
-        });
         viewModel.getDataListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() {
             @Override
             public void onChanged(List<FamilyMemorabiliaBean> familyMemorabiliaBeans) {
                 adapter.setData(familyMemorabiliaBeans);
             }
         });
+        viewModel.getCheckListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() {
+            @Override
+            public void onChanged(List<FamilyMemorabiliaBean> familyMemorabiliaBeans) {
+                if (viewModel.getOperateTypeLiveData().getValue() == 0){
+                    return;
+                }
+                if (familyMemorabiliaBeans.isEmpty()){
+                    viewModel.getOperateTypeLiveData().setValue(1);
+                }else{
+                    viewModel.getOperateTypeLiveData().setValue(2);
+                }
+            }
+        });
+        viewModel.getMoreListLiveData().observe(this, new Observer<List<FamilyMemorabiliaBean>>() {
+            @Override
+            public void onChanged(List<FamilyMemorabiliaBean> familyMemorabiliaBeans) {
+                adapter.addData(familyMemorabiliaBeans);
+            }
+        });
+        viewModel.getOperateTypeLiveData().observe(this, integer -> {
+            if (integer == 0){
+                binding.ivOperate.setBackgroundResource(R.drawable.ic_operate);
+                binding.ivOperate.setOnClickListener(v -> {
+                    mOperatePopupWindow.showAsDropDown(binding.ivOperate,-ScreenSizeUtils.dip2px(this,85) +binding.ivOperate.getWidth(),0);
+                });
+                adapter.setCheckable(false);
+            }else if (integer == 1){
+                binding.ivOperate.setBackgroundResource(R.drawable.ic_operate_finish);
+                binding.ivOperate.setOnClickListener(v -> {
+                    viewModel.getOperateTypeLiveData().postValue(0);
+                });
+                adapter.setCheckable(true);
+            }else if (integer == 2){
+                binding.ivOperate.setBackgroundResource(R.drawable.ic_delete_white);
+                binding.ivOperate.setOnClickListener(v -> {
+                    new UIDialog.Builder(this)
+                            .setTitle("鎮ㄧ‘瀹氳鍒犻櫎閫変腑鐨勯」鐩悧")
+                            .setContent("椤圭洰鍒犻櫎鍚庡皢鏃犳硶鎭㈠")
+                            .setConfirm("纭畾")
+                            .setCancel("鍙栨秷")
+                            .setListener(new UIDialog.OnListener() {
+                                @Override
+                                public void onConfirm(BaseDialog dialog) {
+                                    viewModel.deleteCheckList();
+                                }
+                            })
+                            .show();
+                });
+            }
+        });
+        viewModel.getFinishDeleteListLiveData().observe(this, beans -> {
+            for (FamilyMemorabiliaBean bean : beans) {
+                adapter.removeItem(bean);
+            }
+        });
+        //瑙傚療瀹跺ぇ浜嬭鏁版嵁鐨勫彉鍖栵紝鏈夊彉鍖栧寘鎷坊鍔犮�佷慨鏀广�佸垹闄ら兘浼氬彂閫佹秷鎭紝鎺ユ敹鍒版秷鎭悗閲嶆柊鑾峰彇鏁版嵁
+        RxBus.getInstance().toObservable(this, FamilyMemorabiliaBean.class)
+                .subscribe(bean -> {
+                    viewModel.getFamilyMemorabilia();
+                });
     }
 
-
-    private PopupWindow initPopUpWindow(@LayoutRes int layoutId){
-        PopupWindow popupWindow = new PopupWindow(this);
-        // 璁剧疆甯冨眬鏂囦欢
-        popupWindow.setContentView(LayoutInflater.from(this).inflate(layoutId, null));
-        // 涓轰簡閬垮厤閮ㄥ垎鏈哄瀷涓嶆樉绀猴紝闇�瑕侀噸鏂拌缃竴涓嬪楂�
-        popupWindow.setWidth(ViewGroup.LayoutParams.WRAP_CONTENT);
-        popupWindow.setHeight(ViewGroup.LayoutParams.WRAP_CONTENT);
-        // 璁剧疆pop閫忔槑鏁堟灉
-        popupWindow.setBackgroundDrawable(new ColorDrawable(0x0000));
-        // 璁剧疆pop鍑哄叆鍔ㄧ敾
-        popupWindow.setAnimationStyle(com.android.app_base.R.style.pop_add);
-        // 璁剧疆pop鑾峰彇鐒︾偣锛屽鏋滀负false鐐瑰嚮杩斿洖鎸夐挳浼氶��鍑哄綋鍓岮ctivity锛屽鏋減op涓湁Editor鐨勮瘽锛宖ocusable蹇呴』瑕佷负true
-        popupWindow.setFocusable(true);
-        // 璁剧疆pop鍙偣鍑伙紝涓篺alse鐐瑰嚮浜嬩欢鏃犳晥锛岄粯璁や负true
-        popupWindow.setTouchable(true);
-        // 璁剧疆鐐瑰嚮pop澶栦晶娑堝け锛岄粯璁や负false锛涘湪focusable涓簍rue鏃剁偣鍑诲渚у缁堟秷澶�
-        popupWindow.setOutsideTouchable(true);
-        return popupWindow;
-    }
 
     @Override
     protected void dataNull() {
         super.dataNull();
         binding.layoutDataNull.setVisibility(View.VISIBLE);
-        binding.recyclerView.setVisibility(View.GONE);
+        binding.refreshLayout.setVisibility(View.GONE);
+    }
+
+    @Override
+    protected void dataFinish() {
+        super.dataFinish();
+        binding.refreshLayout.finishLoadMore();
+    }
+
+    @Override
+    protected void hide() {
+        super.hide();
+        binding.layoutDataNull.setVisibility(View.GONE);
+        binding.refreshLayout.setVisibility(View.VISIBLE);
+        binding.refreshLayout.finishLoadMore();
     }
 
     @Override
     public void onClick(View v) {
         int id = v.getId();
-        if (id == R.id.tv_global_search){
-            searchType = 0;
-            binding.etSearch.setHint("鍏ㄥ眬鎼滅储");
-            mSearchPopupWindow.dismiss();
-        }else if (id == R.id.tv_search_in_family_memorabilia) {
-            searchType = 1;
-            mSearchPopupWindow.dismiss();
-            binding.etSearch.setHint("鍦ㄢ�滃澶т簨璁扳�濆唴鎼滅储");
-        }else if (id == R.id.tv_search_by_title) {
-            searchType = 2;
-            mSearchPopupWindow.dismiss();
-            binding.etSearch.setHint("鎸夆�滃ぇ浜嬭鏍囬鈥濇悳绱�");
-        }else if (id == R.id.tv_search_by_people) {
-            searchType = 3;
-            mSearchPopupWindow.dismiss();
-            binding.etSearch.setHint("鎸夆�滀汉鐗┾�濇悳绱�");
-        }else if (id == R.id.tv_search_by_time) {
-            searchType = 4;
-            mSearchPopupWindow.dismiss();
-            binding.etSearch.setHint("鎸夆�滄椂闂粹�濇悳绱�");
-        }else if (id == R.id.tv_search_by_place) {
-            searchType = 5;
-            mSearchPopupWindow.dismiss();
-            binding.etSearch.setHint("鎸夆�滃湴鐐光�濇悳绱�");
+        if (id == R.id.tv_add){
+            AppManager.getAppManager().startActivity(new Intent(this, FamilyMemorabiliaDetailActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1));
+        }else if (id == R.id.tv_select){
+            viewModel.getOperateTypeLiveData().postValue(1);
+            mOperatePopupWindow.dismiss();
+        } else if (id == R.id.tv_from_new_to_old) {
+            viewModel.changeOrder(true);
+            mOperatePopupWindow.dismiss();
+        } else if (id == R.id.tv_from_old_to_new) {
+            viewModel.changeOrder(false);
+            mOperatePopupWindow.dismiss();
+        } else if (id == R.id.tv_own_top) {
+            viewModel.ownTop();
+            mOperatePopupWindow.dismiss();
         }
     }
+
+    @Override
+    protected void onDestroy() {
+        super.onDestroy();
+        if (mOperatePopupWindow != null){
+            mOperatePopupWindow.dismiss();
+        }
+    }
+
 }
\ No newline at end of file

--
Gitblit v1.9.1