|
@@ -8,21 +8,19 @@ import android.content.Intent
|
|
|
import android.net.Uri
|
|
|
import android.os.Bundle
|
|
|
import android.text.TextUtils
|
|
|
-import android.util.Log
|
|
|
+import android.text.TextWatcher
|
|
|
import android.view.LayoutInflater
|
|
|
+import android.widget.EditText
|
|
|
import android.widget.FrameLayout
|
|
|
import android.widget.ImageView
|
|
|
import android.widget.LinearLayout
|
|
|
-import android.widget.TextView
|
|
|
import androidx.databinding.Bindable
|
|
|
import androidx.lifecycle.MutableLiveData
|
|
|
import com.google.gson.Gson
|
|
|
import com.hwangjr.rxbus.RxBus
|
|
|
import com.qmuiteam.qmui.layout.QMUIFrameLayout
|
|
|
-import com.qmuiteam.qmui.skin.QMUISkinHelper
|
|
|
import com.qmuiteam.qmui.skin.QMUISkinValueBuilder
|
|
|
import com.qmuiteam.qmui.util.QMUIDisplayHelper
|
|
|
-import com.qmuiteam.qmui.util.QMUIResHelper
|
|
|
import com.qmuiteam.qmui.widget.dialog.QMUIDialog
|
|
|
import com.qmuiteam.qmui.widget.dialog.QMUIDialogAction
|
|
|
import com.qmuiteam.qmui.widget.popup.QMUIPopup
|
|
@@ -30,10 +28,9 @@ import com.qmuiteam.qmui.widget.popup.QMUIPopups
|
|
|
import com.qmuiteam.qmui.widget.roundwidget.QMUIRoundButton
|
|
|
import com.quansu.heifengwuliu.BR
|
|
|
import com.quansu.heifengwuliu.R
|
|
|
+import com.quansu.heifengwuliu.activity.EachOtherActivity
|
|
|
import com.quansu.heifengwuliu.activity.EvaluateActivity
|
|
|
-import com.quansu.heifengwuliu.activity.VehicleListActivity
|
|
|
-import com.quansu.heifengwuliu.config.ConfigRx
|
|
|
-import com.quansu.heifengwuliu.model.DataInfoBean
|
|
|
+import com.quansu.heifengwuliu.config.MIntentAction
|
|
|
import com.quansu.heifengwuliu.model.WaybillDetails
|
|
|
import com.quansu.heifengwuliu.utils.ChosePhotoUtils
|
|
|
import com.quansu.heifengwuliu.utils.net.NetEngine
|
|
@@ -43,7 +40,9 @@ import com.yanzhenjie.permission.AndPermission
|
|
|
import com.ysnows.base.base.BRepository
|
|
|
import com.ysnows.base.base.BViewModel
|
|
|
import com.ysnows.base.utils.UiSwitch
|
|
|
-import java.util.HashMap
|
|
|
+import com.ysnows.base.utils.UiUtils
|
|
|
+import com.ysnows.base.view.BView
|
|
|
+import java.util.*
|
|
|
|
|
|
|
|
|
/*
|
|
@@ -66,6 +65,7 @@ open class WaybillDetailsVModel : BViewModel<BRepository>() {
|
|
|
|
|
|
val isButShow: MutableLiveData<Boolean> = MutableLiveData<Boolean>(true)
|
|
|
|
|
|
+ var ll: LinearLayout? =null
|
|
|
|
|
|
|
|
|
|
|
@@ -91,7 +91,14 @@ open class WaybillDetailsVModel : BViewModel<BRepository>() {
|
|
|
10->tvTitle.value="运输轨迹"
|
|
|
20->tvTitle.value="运输轨迹"
|
|
|
30->tvTitle.value="去结算"
|
|
|
- 40->tvTitle.value= "待评价"
|
|
|
+ 40->{
|
|
|
+ if(null!=info.value!!.eva.my_eva){
|
|
|
+ order_state=50
|
|
|
+ tvTitle.value = "查看评价"
|
|
|
+ }else {
|
|
|
+ tvTitle.value = "待评价"
|
|
|
+ }
|
|
|
+ }
|
|
|
50->tvTitle.value="查看评价"
|
|
|
}
|
|
|
|
|
@@ -112,7 +119,14 @@ open class WaybillDetailsVModel : BViewModel<BRepository>() {
|
|
|
when(info.value!!.order.order_state){
|
|
|
10->tvTitle.value="开始送货"
|
|
|
20->tvTitle.value="已送达"
|
|
|
- 40->tvTitle.value="待评价"
|
|
|
+ 40->{
|
|
|
+ if(null!=info.value!!.eva.my_eva){
|
|
|
+ order_state=50
|
|
|
+ tvTitle.value = "查看评价"
|
|
|
+ }else {
|
|
|
+ tvTitle.value = "待评价"
|
|
|
+ }
|
|
|
+ }
|
|
|
50->tvTitle.value="查看评价"
|
|
|
}
|
|
|
|
|
@@ -129,7 +143,7 @@ open class WaybillDetailsVModel : BViewModel<BRepository>() {
|
|
|
|
|
|
fun toStartShip(order_id:String){
|
|
|
|
|
|
- if(type.value==0) {
|
|
|
+ if(type.value==0) {//货主端
|
|
|
//0->全部 10->待取货 20->运输中 30->待结算 40->待评价 50->已完成
|
|
|
// 10->tvTitle.value="运输轨迹"
|
|
|
// 20->tvTitle.value="运输轨迹"
|
|
@@ -146,16 +160,35 @@ open class WaybillDetailsVModel : BViewModel<BRepository>() {
|
|
|
if (order_state == 30) {
|
|
|
|
|
|
|
|
|
+ showPayDialog(order_id)
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
return
|
|
|
}
|
|
|
|
|
|
if (order_state == 40) {
|
|
|
+ //货主给司机评价
|
|
|
+
|
|
|
+ UiSwitch.bundleRes(repository().context as Activity, EvaluateActivity::class.java, Bundle().apply {
|
|
|
+ putString("order_id",order_id)
|
|
|
+ putString("url", info.value!!.driver.avatar)
|
|
|
+ putString("sn", info.value!!.order.order_sn)
|
|
|
+ putString("time", info.value!!.order.create_time)
|
|
|
+ }, MIntentAction.REQUEST_CODE_COMMENT)
|
|
|
+
|
|
|
|
|
|
|
|
|
return
|
|
|
}
|
|
|
if (order_state == 50) {
|
|
|
+ //查看评价
|
|
|
+ UiSwitch.bundle(repository().context, EachOtherActivity::class.java,
|
|
|
+ Bundle().apply {
|
|
|
+ putString("order_id",order_id)
|
|
|
|
|
|
+ }
|
|
|
+ )
|
|
|
|
|
|
return
|
|
|
}
|
|
@@ -183,22 +216,26 @@ open class WaybillDetailsVModel : BViewModel<BRepository>() {
|
|
|
}
|
|
|
if(order_state==40){//待评价--司机对货主的评价
|
|
|
|
|
|
- UiSwitch.bundle(repository().context, EvaluateActivity::class.java, Bundle().apply {
|
|
|
+ UiSwitch.bundleRes(repository().context as Activity, EvaluateActivity::class.java, Bundle().apply {
|
|
|
putString("order_id",order_id)
|
|
|
- })
|
|
|
+ putString("url", "")
|
|
|
+ putString("sn", info.value!!.order.order_sn)
|
|
|
+ putString("time", info.value!!.order.create_time)
|
|
|
+ },MIntentAction.REQUEST_CODE_COMMENT)
|
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
if(order_state==50){//查看评价
|
|
|
|
|
|
-
|
|
|
+ UiSwitch.bundle(repository().context, EachOtherActivity::class.java,
|
|
|
+ Bundle().apply {
|
|
|
+ putString("order_id",order_id)
|
|
|
+ }
|
|
|
+ )
|
|
|
}
|
|
|
|
|
|
|
|
|
-
|
|
|
-
|
|
|
-
|
|
|
}
|
|
|
|
|
|
|
|
@@ -314,4 +351,119 @@ open class WaybillDetailsVModel : BViewModel<BRepository>() {
|
|
|
|
|
|
|
|
|
|
|
|
+ fun showPayDialog(order_id: String){
|
|
|
+ var mNormalPopup = QMUIPopups.fullScreenPopup(repository().context)
|
|
|
+ val builder: QMUISkinValueBuilder = QMUISkinValueBuilder.acquire()
|
|
|
+ val frameLayout = QMUIFrameLayout(repository().context)
|
|
|
+
|
|
|
+ //自定义布局
|
|
|
+ val layoutInflater = repository().context?.getSystemService(Context.LAYOUT_INFLATER_SERVICE) as LayoutInflater
|
|
|
+ var layout = layoutInflater.inflate(R.layout.item_apy_car, null)
|
|
|
+ val butCancel: ImageView = layout.findViewById(R.id.iv_close)
|
|
|
+ val etMoney: EditText = layout.findViewById(R.id.et_money)
|
|
|
+
|
|
|
+ val butSure: QMUIRoundButton =layout.findViewById(R.id.but_sure)
|
|
|
+
|
|
|
+ val payPwdEditText: PasswordView = layout.findViewById(R.id.ppet)
|
|
|
+ var password=""
|
|
|
+
|
|
|
+
|
|
|
+ payPwdEditText.setPasswordListener(object : PasswordView.PasswordListener {
|
|
|
+ override fun keyEnterPress(pwd: String?, isComplete: Boolean) {
|
|
|
+ password= pwd!!
|
|
|
+ if(!TextUtils.isEmpty(password)&&password.length==6){
|
|
|
+ var money=etMoney.text.toString().trim()
|
|
|
+ if(TextUtils.isEmpty(money)){
|
|
|
+ toast("请输入支付金额")
|
|
|
+ return
|
|
|
+ }
|
|
|
+ getInfoPay(money,order_id,password)
|
|
|
+ mNormalPopup.dismiss()
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ override fun passwordChange(changeText: String?) {
|
|
|
+ }
|
|
|
+
|
|
|
+ override fun passwordComplete(pwd: String?) {
|
|
|
+ password=pwd!!
|
|
|
+ if(!TextUtils.isEmpty(password)&&password.length==6){
|
|
|
+
|
|
|
+ var money=etMoney.text.toString().trim()
|
|
|
+ if(TextUtils.isEmpty(money)){
|
|
|
+ toast("请输入支付金额")
|
|
|
+ return
|
|
|
+ }
|
|
|
+ getInfoPay(money,order_id,password)
|
|
|
+ mNormalPopup.dismiss()
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ })
|
|
|
+
|
|
|
+
|
|
|
+ butSure.setOnClickListener {
|
|
|
+ var money=etMoney.text.toString().trim()
|
|
|
+ if(TextUtils.isEmpty(money)){
|
|
|
+ toast("请输入支付金额")
|
|
|
+ return@setOnClickListener
|
|
|
+ }
|
|
|
+
|
|
|
+ if(!TextUtils.isEmpty(password)&&password.length==6){
|
|
|
+ getInfoPay(money,order_id,password)
|
|
|
+ mNormalPopup.dismiss()
|
|
|
+ }else{
|
|
|
+ toast("请输入支付密码")
|
|
|
+ return@setOnClickListener
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ }
|
|
|
+ butCancel.setOnClickListener {
|
|
|
+ mNormalPopup.dismiss()
|
|
|
+ }
|
|
|
+ builder.release();
|
|
|
+
|
|
|
+ val size= QMUIDisplayHelper.getScreenWidth(repository().context)
|
|
|
+
|
|
|
+ val lp: FrameLayout.LayoutParams = FrameLayout.LayoutParams(size,
|
|
|
+ FrameLayout.LayoutParams.WRAP_CONTENT)
|
|
|
+ frameLayout.addView(layout, lp)
|
|
|
+
|
|
|
+ mNormalPopup.addView(frameLayout)
|
|
|
+ mNormalPopup.onDismiss() {
|
|
|
+ }
|
|
|
+
|
|
|
+ mNormalPopup.dismissIfOutsideTouch(false)
|
|
|
+ mNormalPopup.animStyle(QMUIPopup.ANIM_GROW_FROM_CENTER)
|
|
|
+ mNormalPopup.show(ll)
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ fun getInfoPay(money:String,order_id: String,pay_pwd:String) {
|
|
|
+ repository().lreq(NetEngine.service.carPay(money,order_id,pay_pwd))
|
|
|
+ .doOnNext() {
|
|
|
+ if (it.ok(true)) {
|
|
|
+ order_state=40
|
|
|
+ tvTitle.value= "待评价"
|
|
|
+ }
|
|
|
+
|
|
|
+ }
|
|
|
+ .subscribe()
|
|
|
+ }
|
|
|
+
|
|
|
+ fun changeComment(){//发表完评论改变状态
|
|
|
+ order_state=50
|
|
|
+ tvTitle.value="查看评价"
|
|
|
+
|
|
|
}
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+}
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+
|