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/ui/function/LittleDoctorActivity.java | 191 ++++++++++++++++++++++++++++++++++++++++++++++- 1 files changed, 187 insertions(+), 4 deletions(-) diff --git a/app/src/main/java/com/application/zhangshi_app_android/ui/function/LittleDoctorActivity.java b/app/src/main/java/com/application/zhangshi_app_android/ui/function/LittleDoctorActivity.java index c0b8fa9..e3f61bc 100644 --- a/app/src/main/java/com/application/zhangshi_app_android/ui/function/LittleDoctorActivity.java +++ b/app/src/main/java/com/application/zhangshi_app_android/ui/function/LittleDoctorActivity.java @@ -1,20 +1,40 @@ package com.application.zhangshi_app_android.ui.function; import androidx.appcompat.app.AppCompatActivity; +import androidx.lifecycle.Observer; +import android.content.Intent; import android.os.Bundle; +import android.view.MotionEvent; +import android.view.View; +import android.widget.PopupWindow; +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.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.HonorCollectionRvAdapter; import com.application.zhangshi_app_android.adapter.LittleDoctorRvAdapter; +import com.application.zhangshi_app_android.bean.FamilyMemorabiliaBean; +import com.application.zhangshi_app_android.bean.LittleDoctorBean; import com.application.zhangshi_app_android.databinding.ActivityLittleDoctorBinding; import com.application.zhangshi_app_android.ui.DLBaseActivity; + +import java.util.List; + +import io.reactivex.functions.Consumer; public class LittleDoctorActivity extends DLBaseActivity<ActivityLittleDoctorBinding,LittleDoctorActivityViewModel> { private LittleDoctorRvAdapter adapter; + private boolean isSearchLayoutVisible; + private PopupWindow mOperatePopupWindow; + @Override public int getLayoutId() { @@ -33,13 +53,64 @@ @Override public void initView() { - adapter = new LittleDoctorRvAdapter(this); + //涓嬫媺鍒锋柊甯冨眬 + binding.refreshLayout.setEnableRefresh(false); + binding.refreshLayout.setEnableLoadMore(true); + binding.refreshLayout.setEnableOverScrollDrag(true); + binding.refreshLayout.setOnLoadMoreListener(refreshLayout -> { + viewModel.getMoreLittleDoctors(); + }); + //recyclerView閫傞厤鍣� + adapter = new LittleDoctorRvAdapter(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(View.inflate(this,R.layout.pop_operate,null)); + mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_new_to_old).setVisibility(View.GONE); + mOperatePopupWindow.getContentView().findViewById(R.id.tv_from_old_to_new).setVisibility(View.GONE); + setOnClickListener( + mOperatePopupWindow.getContentView().findViewById(R.id.tv_add), + mOperatePopupWindow.getContentView().findViewById(R.id.tv_select) + ); + //鐐瑰嚮鏀惧ぇ闀滄寜閽樉绀哄嚭鎼滅储妗� + 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.dropExpand(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.getLittleDoctors(); + 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(), LittleDoctorDetailActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1)); + } + }); } @Override @@ -49,9 +120,121 @@ @Override public void initLiveDataObserve() { - viewModel.getDataListLiveData().observe(this, homeDevices -> { - adapter.setData(homeDevices); + viewModel.getDataListLiveData().observe(this, list -> { + adapter.setData(list); }); + viewModel.getCheckListLiveData().observe(this, checkList -> { + if (0 == viewModel.getOperateTypeLiveData().getValue()){ + return; + } + if (checkList.isEmpty()){ + viewModel.getOperateTypeLiveData().setValue(1); + }else{ + viewModel.getOperateTypeLiveData().setValue(2); + } + }); + viewModel.getMoreListLiveData().observe(this, moreList -> { + adapter.addData(moreList); + }); + 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 (LittleDoctorBean bean : beans) { + adapter.removeItem(bean); + } + }); + + //瑙傚療鏁版嵁鐨勫彉鍖栵紝鏈夊彉鍖栧寘鎷坊鍔犮�佷慨鏀广�佸垹闄ら兘浼氬彂閫佹秷鎭紝鎺ユ敹鍒版秷鎭悗閲嶆柊鑾峰彇鏁版嵁杩涜鍒锋柊 + RxBus.getInstance().toObservable(this, LittleDoctorBean.class) + .subscribe(bean -> { + viewModel.getLittleDoctors(); + }); + } + + + @Override + protected void dataNull() { + super.dataNull(); + binding.layoutDataNull.setVisibility(View.VISIBLE); + 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_add){ + AppManager.getAppManager().startActivity(new Intent(this, LittleDoctorDetailActivity.class).putExtra(BaseConfig.EXTRA_TYPE,1)); + mOperatePopupWindow.dismiss(); + }else if (id == R.id.tv_select){ + viewModel.getOperateTypeLiveData().postValue(1); + mOperatePopupWindow.dismiss(); + } + } + + @Override + protected void onDestroy() { + super.onDestroy(); + if (mOperatePopupWindow != null){ + mOperatePopupWindow.dismiss(); + } + } + + @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); } } \ No newline at end of file -- Gitblit v1.9.1