From 3e2436955a5daf512098dc879c470ee88ce003eb Mon Sep 17 00:00:00 2001
From: fengxiang <110431245@qq.com>
Date: Fri, 22 Dec 2017 16:12:48 +0800
Subject: [PATCH] Merge remote-tracking branch 'origin/master'

---
 src/main/java/com/moral/service/impl/AccountServiceImpl.java |   66 +++++++++++++++++++++++++++++++++
 1 files changed, 66 insertions(+), 0 deletions(-)

diff --git a/src/main/java/com/moral/service/impl/AccountServiceImpl.java b/src/main/java/com/moral/service/impl/AccountServiceImpl.java
index fada657..c25281e 100644
--- a/src/main/java/com/moral/service/impl/AccountServiceImpl.java
+++ b/src/main/java/com/moral/service/impl/AccountServiceImpl.java
@@ -7,19 +7,31 @@
 import static org.apache.commons.lang3.StringUtils.isNumeric;
 import static org.springframework.util.ObjectUtils.isEmpty;
 
+import java.util.Date;
 import java.util.HashMap;
+import java.util.List;
 import java.util.Map;
 import java.util.Set;
 
 import javax.annotation.Resource;
 
 import org.springframework.stereotype.Service;
+import org.springframework.transaction.annotation.Transactional;
+import org.springframework.util.ObjectUtils;
 
+import com.github.pagehelper.PageHelper;
+import com.moral.common.bean.Constants;
+import com.moral.common.bean.PageBean;
 import com.moral.common.exception.BusinessException;
+import com.moral.common.util.Crypto;
+import com.moral.common.util.ResourceUtil;
 import com.moral.entity.Account;
 import com.moral.mapper.AccountMapper;
 import com.moral.service.AccountService;
 import com.moral.service.OrganizationService;
+
+import tk.mybatis.mapper.entity.Example;
+import tk.mybatis.mapper.entity.Example.Criteria;
 
 @Service
 public class AccountServiceImpl implements AccountService {
@@ -79,4 +91,58 @@
 		}
 	}
 
+	@Override
+	public PageBean<Account> getAccountListByPage(Map<String, Object> parameters) {
+		Example example = new Example(Account.class);
+		Criteria criteria = example.createCriteria();
+		if (parameters.containsKey("accountName")) {
+			criteria.andLike("accountName", "%" + (String) parameters.get("accountName") + "%");
+		}
+		if (parameters.containsKey("mobile")) {
+			criteria.andLike("mobile", "%" + (String) parameters.get("mobile") + "%");
+		}
+		if (parameters.containsKey("isDelete")) {
+			criteria.andEqualTo("isDelete", parameters.get("isDelete"));
+		}
+		if (parameters.containsKey("sorter")) {
+			example.setOrderByClause((String) parameters.get("sorter"));
+		}
+		PageHelper.startPage(Integer.valueOf((String) parameters.get("pageIndex")), Integer.valueOf((String) parameters.get("pageSize")));
+		List<Account> accounts = accountMapper.selectByExample(example);
+		return new PageBean<Account>(accounts);
+	}
+
+	@Override
+	@Transactional
+	public Integer saveOrUpdateAccount(Account account) {
+		if (ObjectUtils.isEmpty(account.getId())) {
+			account.setIsDelete(Constants.IS_DELETE_FALSE);
+			account.setCreateTime(new Date());
+			account.setPassword(Crypto.md5(ResourceUtil.getValue("password")));
+			return accountMapper.insertSelective(account);
+		} else {
+			return accountMapper.updateByPrimaryKeySelective(account);
+		}
+	}
+
+	@Override
+	@Transactional
+	public Integer deleteAccountByLogic(Account account) {
+		account.setIsDelete(Constants.IS_DELETE_TRUE);
+		if (account.getId() > 0) {
+			throw new BusinessException("hahahahahah..................");
+		}
+		return accountMapper.updateByPrimaryKeySelective(account);
+	}
+
+	@Override
+	@Transactional
+	public Integer deleteAccountsByLogic(List<Integer> ids) {
+		Account account = new Account();
+		account.setIsDelete(Constants.IS_DELETE_TRUE);
+		Example example = new Example(Account.class);
+		example.or().andIn("id", ids);
+		return accountMapper.updateByExampleSelective(account, example);
+	}
+
 }

--
Gitblit v1.8.0