package cn.com.basic.face.service; import org.xutils.http.RequestParams; import org.xutils.x; import java.text.SimpleDateFormat; import java.util.ArrayList; import java.util.Date; import java.util.List; import cn.com.basic.face.base.BaseApplication; import cn.com.basic.face.base.MainActivity; import cn.com.basic.face.discern.common.BaseCommonCallBack; import cn.com.basic.face.discern.common.CommonVariables; import cn.com.basic.face.discern.common.ResultBean; import cn.com.basic.face.discern.query.condition.AttendanceDetailQueryCondition; import cn.com.basic.face.discern.query.condition.AttendanceQueryCondition; import cn.com.basic.face.discern.query.item.AttendanceDetailQueryItem; import cn.com.basic.face.discern.query.item.AttendanceQueryItem; import cn.com.basic.face.fragment.AttendanceFragment; import cn.com.basic.face.service.sqlite.AttendanceDao; import cn.com.basic.face.util.AppApi; import cn.com.basic.face.util.DateUtil; public class AttendanceMng extends BaseMng{ private static AttendanceMng instance = new AttendanceMng(); public static AttendanceMng getInstance() { return instance; } public void reloadLeftList(String searchText, final int pageNum, final boolean append) { if (!BaseApplication.deviceAvailable) { return; } if(BaseApplication.getInstance().networkAvailable()) { RequestParams params = new RequestParams(AppApi.BASE_URL + AppApi.Query.ATTENDANCE_QUERY); params.addBodyParameter(AttendanceQueryCondition.FieldNames.username, searchText); params.addBodyParameter(AttendanceQueryCondition.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId()); params.addBodyParameter(CommonVariables.Page.PAGE_NUM, pageNum + ""); params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, CommonVariables.Page.DEFAULT_PAGE_SIZE); x.http().post(params, new BaseCommonCallBack() { public void success() { reloadLeftListAfterReturn(append, resultBean); } }); } else { reloadLeftListAfterReturn(append, AttendanceDao.getInstance().reloadLeftList(searchText, pageNum, append)); } } private void reloadLeftListAfterReturn(final boolean append, ResultBean resultBean) { List list = resultBean.getList(AttendanceQueryItem.class); final List itemList = new ArrayList<>(); int i = 0; for (AttendanceQueryItem item : list) { itemList.add(item); i++; } addPageFooter(resultBean.hasMorePages(), resultBean.getPageNum(), itemList); if (BaseApplication.getInstance().networkAvailable()) { AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList, append); } else { MainActivity.getInstance().runOnUiThread(new Runnable() { @Override public void run() { AttendanceFragment.getInstance().get_fragment_attendance_left_list_view().show(itemList, append); } }); } } public void reloadAttendanceDetail(final AttendanceQueryItem item) { if (!BaseApplication.deviceAvailable) { return; } if (BaseApplication.getInstance().networkAvailable()) { try { SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd"); RequestParams params = new RequestParams(AppApi.BASE_URL +AppApi.Query.ATTENDANCE_DETAIL_QUERY); params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.time, sdf.format(new Date())); params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.registerId, item.getRegisterId()); params.addBodyParameter(AttendanceDetailQueryCondition.FieldNames.deviceCompanyId, BaseApplication.getInstance().getAndroidDevice().getCompanyId()); params.addBodyParameter(CommonVariables.Page.PAGE_SIZE, "20"); x.http().post(params, new BaseCommonCallBack() { public void success() { AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(getList(AttendanceDetailQueryItem.class)); } }); } catch (Exception e) { e.printStackTrace(); } } else { MainActivity.getInstance().runOnUiThread(new Runnable() { @Override public void run() { AttendanceFragment.getInstance().get_fragment_attendance_right_list_view().show(AttendanceDao.getInstance().reloadAttendanceDetail(item)); } }); } } public void removeBeforeToday() { try { String sql = "delete from attendance where 1=1 and time< '" + DateUtil.getYesterday() + "'"; MainActivity.getInstance().db.execSQL(sql); } catch (Exception e) { e.printStackTrace(); } } }