sujinwen
2017-07-25 c7caa54d8d58af6159f2c758ad5d6687d461a333
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
package cn.com.basic.face.service.sync.up;
 
import com.alibaba.fastjson.JSONArray;
 
import org.xutils.http.RequestParams;
import org.xutils.x;
 
import java.text.SimpleDateFormat;
import java.util.List;
 
import cn.com.basic.face.base.BaseApplication;
import cn.com.basic.face.discern.common.BaseCommonCallBack;
import cn.com.basic.face.discern.common.SqliteSqlBean;
import cn.com.basic.face.service.sqlite.DictionaryDao;
import cn.com.basic.face.service.sqlite.SynchronRecordDao;
import cn.com.basic.face.util.AppApi;
import cn.com.basic.face.util.SqliteSqlUtil;
 
/**
 *
 * dictionary双向同步
 * Created by SJW on 2017/7/25 0025.
 */
 
public class DictionaryUpSync extends BaseSync {
 
    public static  DeviceUpSync instance=new DeviceUpSync();
    public static DeviceUpSync getInstance(){
        return instance;
    }
 
 
    /***
     * dictionary表双向同步
     */
    public void doSync() {
        try{
            String tableName = "dictionary";
            RequestParams params = new RequestParams(AppApi.BASE_URL + AppApi.TWO_WAY_SYNCHRON);
            SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss");
            final String temp=tableName;
            params.addBodyParameter("tableName", tableName);
            params.addBodyParameter("synDate", SynchronRecordDao.getInstance().getSynRecord(tableName).getSynchronTime());
            params.addBodyParameter("data", JSONArray.toJSONString(DictionaryDao.getInstance().getDictionayList(BaseApplication.getInstance().getAndroidDevice().getCompanyId())));
            params.addBodyParameter("deviceCompanyId",BaseApplication.getInstance().getAndroidDevice().getCompanyId());
            x.http().post(params, new BaseCommonCallBack() {
                public void success() {
                    DictionaryDao.getInstance().delDictionary(BaseApplication.getInstance().getAndroidDevice().getCompanyId());
                    List<SqliteSqlBean> result= getExtraList(SqliteSqlBean.class);
                    SqliteSqlUtil.insert(getExtraList(SqliteSqlBean.class));
                    sync();
                }
            });
        }catch(Exception e){
            e.printStackTrace();
        }
    }
 
    /***
     * 查询dictionary表是否有需要同步的数据
     * @return
     */
    public boolean hasMore() {
        int count= DictionaryDao.getInstance().getSynDataCount();
        if(count==0){
            return false;
        }
        return true;
    }
 
}