From f4a6d4f0996238f9c85e4986deffe69a1c8256e6 Mon Sep 17 00:00:00 2001
From: lmw <125975490@qq.com>
Date: 星期三, 04 九月 2024 20:47:58 +0800
Subject: [PATCH] 员工流程

---
 app/src/main/java/com/lotaai/canguiayw/OpenDoorFragment.java |  101 +++++++++++++++++++++++++++++++++++++++++++++++++-
 1 files changed, 98 insertions(+), 3 deletions(-)

diff --git a/app/src/main/java/com/lotaai/canguiayw/OpenDoorFragment.java b/app/src/main/java/com/lotaai/canguiayw/OpenDoorFragment.java
index 028d614..6ec4fde 100644
--- a/app/src/main/java/com/lotaai/canguiayw/OpenDoorFragment.java
+++ b/app/src/main/java/com/lotaai/canguiayw/OpenDoorFragment.java
@@ -12,28 +12,46 @@
 import android.widget.AdapterView;
 import android.widget.Button;
 import android.widget.GridView;
+import android.widget.TextView;
 import android.widget.ThemedSpinnerAdapter;
 
 import androidx.fragment.app.Fragment;
 
+import com.blankj.utilcode.util.CacheDiskUtils;
+import com.blankj.utilcode.util.GsonUtils;
 import com.blankj.utilcode.util.LogUtils;
 import com.liys.lswitch.BaseSwitch;
 import com.liys.lswitch.LSwitch;
+import com.lotaai.canguiayw.common.HttpLoggerInterceptor;
+import com.lotaai.canguiayw.common.HttpUrlDefine;
 import com.lotaai.canguiayw.common.SettingConfig;
+import com.lotaai.canguiayw.data.BaseDto;
 import com.lotaai.canguiayw.device.CanGuiCommand;
 import com.lotaai.canguiayw.device.CanguiStatus;
 import com.lotaai.canguiayw.device.DeviceMessage;
 import com.lotaai.canguiayw.device.DeviceType;
 import com.lotaai.canguiayw.device.MessageType;
 import com.lotaai.canguiayw.view.GridTableAdapter;
+import com.lotaai.canguiayw.view.GridTableAdapterNew;
+import com.pranavpandey.android.dynamic.toasts.DynamicToast;
 
 import org.greenrobot.eventbus.EventBus;
 import org.greenrobot.eventbus.Subscribe;
 import org.greenrobot.eventbus.ThreadMode;
 
+import java.io.IOException;
 import java.util.ArrayList;
 import java.util.Collections;
 import java.util.List;
+import java.util.concurrent.TimeUnit;
+
+import okhttp3.Call;
+import okhttp3.Callback;
+import okhttp3.FormBody;
+import okhttp3.OkHttpClient;
+import okhttp3.Request;
+import okhttp3.RequestBody;
+import okhttp3.Response;
 
 public class OpenDoorFragment extends Fragment {
 
@@ -53,6 +71,7 @@
     private Button fugui003;
     private Button fugui004;
     private Button fugui005;
+    private TextView tv_close;
     private int cureentSelectGui = 0;
     private boolean isCanRun = false;
 
@@ -119,6 +138,7 @@
         fugui003 = root.findViewById(R.id.gui003);
         fugui004 = root.findViewById(R.id.gui004);
         fugui005 = root.findViewById(R.id.gui005);
+        tv_close = root.findViewById(R.id.tv_close);
         for (int g = 0; g < SettingConfig.getInstance().statusList.size(); g++) {
             if (SettingConfig.getInstance().statusList.get(g).getGuiHao() == 0) {
                 if (zhugui.getVisibility() != View.VISIBLE) {
@@ -222,6 +242,13 @@
                 cureentSelectGui = 5;
 
                 initView();
+            }
+        });
+
+        tv_close.setOnClickListener(new View.OnClickListener() {
+            @Override
+            public void onClick(View view) {
+                requireActivity().finish();
             }
         });
     }
@@ -352,15 +379,23 @@
             }
         }
         Collections.sort(gridStatusList);
-        GridTableAdapter adapter = new GridTableAdapter(context, gridStatusList, R.layout.framgment_tablegrid_item);
+        if (gridStatusList.size() == 8){
+            CanguiStatus e = new CanguiStatus();
+            e.setGridNo(-1);
+            gridStatusList.add(4, e);
+        }
+        GridTableAdapterNew adapter = new GridTableAdapterNew(context, gridStatusList, R.layout.item_box_new);
         gridtable = root.findViewById(R.id.gridtable);
         gridtable.setAdapter(adapter);
         gridtable.setOnItemClickListener(new AdapterView.OnItemClickListener() {
             @Override
             public void onItemClick(AdapterView<?> adapterView, View view, int i, long l) {
                 CanguiStatus cangui = gridStatusList.get(i);
-                ((CunOjbActivity) getActivity()).setData(cangui);
-
+                if (cangui.getGridNo()!=-1){
+                    //存餐
+                    takeCheckCode(((CunOjbActivity) getActivity()).pickupCode,0,cangui.getGridNo(),((CunOjbActivity) getActivity()).isHand);
+                }
+//                ((CunOjbActivity) getActivity()).setData(cangui);
                /* View item = gridtable.getChildAt(i).findViewById(R.id.gridLineLayout);
                 if (checkIsSelectedAndOrRemove(cangui,true)) {
                     item.setBackgroundColor(Color.GRAY);
@@ -371,6 +406,66 @@
         });
     }
 
+    public void takeCheckCode(String code, final int guino, final int gridno, int isHand) {
+        HttpLoggerInterceptor loggingInterceptor = new HttpLoggerInterceptor(true);
+        OkHttpClient client = new OkHttpClient.Builder()
+                .connectTimeout(20, TimeUnit.SECONDS)//响应时间,读取时间
+                .readTimeout(20, TimeUnit.SECONDS)
+                .callTimeout(20, TimeUnit.SECONDS)
+                .addInterceptor(loggingInterceptor)//添加日志拦截器
+                .build();
+
+        LogUtils.i(CacheDiskUtils.getInstance().getString(SettingConfig.getInstance().Cache_Device_Code), code);
+        RequestBody body = new FormBody.Builder()
+                .build();
+
+        final Request request = new Request.Builder()
+                .url(HttpUrlDefine.checkStatus + "?pickNum=" + code + "&boxNum=" + guino + "&cartNum=" + gridno+ "&isHand=" + isHand+ "&sn=" + CacheDiskUtils.getInstance().getString(SettingConfig.getInstance().Cache_Device_Code))
+                /*  .addHeader("language", "zh-CN")*/
+                .post(body)
+                .build();
+        client.newCall(request).enqueue(new Callback() {
+            @Override
+            public void onFailure(Call call, IOException e) {
+                requireActivity().runOnUiThread(new Runnable() {
+                    @Override
+                    public void run() {
+                        DynamicToast.makeError(context, "Request error!", 3).show();
+                    }
+                });
+
+            }
+
+            @Override
+            public void onResponse(Call call, Response response) throws IOException {
+                String result = response.body().string();
+                LogUtils.i("获取到的数据:" + result);
+                final BaseDto baseDto = GsonUtils.fromJson(result, BaseDto.class);
+                requireActivity().runOnUiThread(new Runnable() {
+                    @Override
+                    public void run() {
+                        if (baseDto.getCode() == 200) {
+                           byte[] command = CanGuiCommand.getInstance().controlGridCommand(guino,
+                                    gridno, 1, 255, 0, 0, 0, 0);
+                            DeviceMessage message = new DeviceMessage();
+                            message.setMessageType(MessageType.SENDMESSAGE.ordinal());
+                            message.setDeviceType(DeviceType.CANGUI.ordinal());
+                            message.setMessageByte(command);
+                            EventBus.getDefault().post(message);
+                            // new Handler(Looper.getMainLooper()).postDelayed(() -> finish(), 3000);
+                            ((CunOjbActivity)requireActivity()).showResult("Place meal into the box.");
+                        } else {
+                            DynamicToast.makeError(context, baseDto.getMsg(), 3).show();
+                        }
+                    }
+                });
+
+
+            }
+        });
+    }
+
+
     /**
      * @param status
      * @param isControl 是否从控制删除和添加,选中变不选,不选变选

--
Gitblit v1.7.1