|
|
@@ -1,16 +1,22 @@
|
|
|
package com.zhongzheng.modules.activity.service.impl;
|
|
|
|
|
|
import cn.hutool.core.bean.BeanUtil;
|
|
|
+import cn.hutool.core.convert.Convert;
|
|
|
import cn.hutool.core.util.StrUtil;
|
|
|
import com.baomidou.mybatisplus.extension.conditions.query.LambdaQueryChainWrapper;
|
|
|
import com.zhongzheng.common.utils.DateUtils;
|
|
|
import com.zhongzheng.modules.activity.bo.ActivityTaskUserAddBo;
|
|
|
+import com.zhongzheng.modules.activity.domain.ActivityGrade;
|
|
|
import com.zhongzheng.modules.activity.service.IActivityGradeService;
|
|
|
import com.zhongzheng.modules.activity.service.IActivityTaskService;
|
|
|
+import com.zhongzheng.modules.activity.service.IActivityTaskTimeService;
|
|
|
import com.zhongzheng.modules.activity.vo.ActivityGradeVo;
|
|
|
+import com.zhongzheng.modules.activity.vo.ActivityTaskTimeVo;
|
|
|
import com.zhongzheng.modules.activity.vo.ActivityTaskVo;
|
|
|
+import com.zhongzheng.modules.user.domain.User;
|
|
|
import com.zhongzheng.modules.user.service.IUserService;
|
|
|
import com.zhongzheng.modules.user.vo.UserVo;
|
|
|
+import lombok.Data;
|
|
|
import org.springframework.beans.factory.annotation.Autowired;
|
|
|
import org.springframework.stereotype.Service;
|
|
|
import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
|
|
|
@@ -23,11 +29,15 @@ import com.zhongzheng.modules.activity.domain.ActivityTaskUser;
|
|
|
import com.zhongzheng.modules.activity.mapper.ActivityTaskUserMapper;
|
|
|
import com.zhongzheng.modules.activity.vo.ActivityTaskUserVo;
|
|
|
import com.zhongzheng.modules.activity.service.IActivityTaskUserService;
|
|
|
+import org.springframework.transaction.annotation.Transactional;
|
|
|
import org.springframework.util.CollectionUtils;
|
|
|
|
|
|
-import java.util.Calendar;
|
|
|
-import java.util.Collection;
|
|
|
-import java.util.List;
|
|
|
+import java.lang.reflect.Field;
|
|
|
+import java.lang.reflect.Method;
|
|
|
+import java.math.BigDecimal;
|
|
|
+import java.text.ParseException;
|
|
|
+import java.text.SimpleDateFormat;
|
|
|
+import java.util.*;
|
|
|
import java.util.stream.Collectors;
|
|
|
|
|
|
/**
|
|
|
@@ -48,6 +58,9 @@ public class ActivityTaskUserServiceImpl extends ServiceImpl<ActivityTaskUserMap
|
|
|
@Autowired
|
|
|
private IActivityTaskService activityTaskService;
|
|
|
|
|
|
+ @Autowired
|
|
|
+ private IActivityTaskTimeService activityTaskTimeService;
|
|
|
+
|
|
|
|
|
|
@Override
|
|
|
public ActivityTaskUserVo queryById(Long userId){
|
|
|
@@ -117,22 +130,281 @@ public class ActivityTaskUserServiceImpl extends ServiceImpl<ActivityTaskUserMap
|
|
|
return this.removeByIds(ids);
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * 签到领取积分
|
|
|
+ *
|
|
|
+ * @param bo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
@Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
public boolean userTask(ActivityTaskUserAddBo bo) {
|
|
|
+ //判断是否是签到
|
|
|
+ if (bo.getTaskType() != 0){
|
|
|
+ throw new IllegalArgumentException("该请求是签到请求");
|
|
|
+ }
|
|
|
+
|
|
|
+ //判断是否领过过
|
|
|
+ validReceiver(bo);
|
|
|
+
|
|
|
+ //增加用户积分,并判断是否达到对应等级,更新等级
|
|
|
+ UserVo userVo = userService.queryById(bo.getUserId());
|
|
|
+ ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
+
|
|
|
+ //签到逻辑连续签到获得累加积分,断了为初始积分
|
|
|
+ LambdaQueryWrapper<ActivityTaskUser> lqw =Wrappers.lambdaQuery();;
|
|
|
+ lqw.eq(bo.getUserId() != null,ActivityTaskUser::getUserId,bo.getUserId());
|
|
|
+ lqw.eq(bo.getTaskType() != null, ActivityTaskUser::getTaskType, bo.getTaskType());
|
|
|
+ lqw.between( ActivityTaskUser::getCreateTime, getDateOne(),DateUtils.getNowTime());
|
|
|
+ List<ActivityTaskUser> list = this.list(lqw);
|
|
|
+ List<SignIn> signIn = new ArrayList<>();
|
|
|
+ list.forEach(s -> {
|
|
|
+ try {
|
|
|
+ signIn.add(new SignIn(s.getCreateTime().toString()));
|
|
|
+ } catch (ParseException e) {
|
|
|
+ e.printStackTrace();
|
|
|
+ }
|
|
|
+ });
|
|
|
+
|
|
|
+ //连续签到的天数,不包括今天,即第一天1积分第二天2积分
|
|
|
+ int continuousSignInDay = getContinuousSignInDay(signIn);
|
|
|
+ //天数*每次累加分数得出今天分数
|
|
|
+ int fen = activityTaskVo.getAccIntegral()*continuousSignInDay;
|
|
|
+ Long score = userVo.getIntegral()+fen;
|
|
|
+
|
|
|
+ //分数达到的等级赋予学生等级
|
|
|
//增加用户领取记录
|
|
|
ActivityTaskUser add = BeanUtil.toBean(bo, ActivityTaskUser.class);
|
|
|
- //判断是否领过过
|
|
|
+ add.setCreateTime(DateUtils.getNowTime());
|
|
|
+ add.setUpdateTime(DateUtils.getNowTime());
|
|
|
+ ActivityGradeVo list1 = activityGradeService.queryByInteger(score);
|
|
|
+ add.setScore(Convert.toStr(fen));
|
|
|
+
|
|
|
+ //增加用户积分和等级
|
|
|
+ userVo.setUserLevel(list1.getGrade());
|
|
|
+ increaseUser(userVo,score);
|
|
|
+
|
|
|
+ return this.save(add);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 完善信息领取积分
|
|
|
+ *
|
|
|
+ * @param bo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean information(ActivityTaskUserAddBo bo) throws IllegalAccessException {
|
|
|
+ //判断是否是完善信息
|
|
|
+ if (bo.getTaskType() != 1){
|
|
|
+ throw new IllegalArgumentException("该请求是完善信息");
|
|
|
+ }
|
|
|
validReceiver(bo);
|
|
|
+
|
|
|
+ ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
+
|
|
|
+ //得出已领取的分数是多少
|
|
|
+ LambdaQueryWrapper<ActivityTaskUser> lqw =Wrappers.lambdaQuery();;
|
|
|
+ lqw.eq(bo.getUserId() != null,ActivityTaskUser::getUserId,bo.getUserId());
|
|
|
+ lqw.eq(bo.getTaskType() != null, ActivityTaskUser::getTaskType, bo.getTaskType());
|
|
|
+ List<ActivityTaskUser> list = this.list(lqw);
|
|
|
+ BigDecimal bigDecimal = new BigDecimal("0");
|
|
|
+ if (!CollectionUtils.isEmpty(list)) {
|
|
|
+ for (ActivityTaskUser activityTaskUser : list) {
|
|
|
+ bigDecimal = bigDecimal.add(new BigDecimal(activityTaskUser.getScore()));
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
+ //userVO用户 有参值/总数 得出比例 乘以分数 四舍五入
|
|
|
+ UserVo userVo = userService.queryById(bo.getUserId());
|
|
|
+ Field[] field = userVo.getClass().getDeclaredFields();
|
|
|
+ Integer integer = countUser(userVo);
|
|
|
+ String num = String.valueOf(integer/ field.length);
|
|
|
+ BigDecimal result5 = new BigDecimal(activityTaskVo.getEndIntegral().toString()).divide(new BigDecimal(num),BigDecimal.ROUND_HALF_UP);
|
|
|
+
|
|
|
+ //增加用户领取记录
|
|
|
+ ActivityTaskUser add = BeanUtil.toBean(bo, ActivityTaskUser.class);
|
|
|
+ add.setScore(bigDecimal.subtract(result5).toString());
|
|
|
add.setCreateTime(DateUtils.getNowTime());
|
|
|
add.setUpdateTime(DateUtils.getNowTime());
|
|
|
- //增加用户积分,并判断是否达到对应等级,更新等级
|
|
|
+
|
|
|
+ //增加用户积分更新等级
|
|
|
+ Long Integer = userVo.getIntegral()+ Convert.toLong(bigDecimal.subtract(result5));
|
|
|
+ ActivityGradeVo list1 = activityGradeService.queryByInteger(Integer);
|
|
|
+ userVo.setUserLevel(list1.getGrade());
|
|
|
+ increaseUser(userVo,Integer);
|
|
|
+
|
|
|
+ return this.save(add);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 邀请好友
|
|
|
+ *
|
|
|
+ * @param bo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean invitation(ActivityTaskUserAddBo bo) {
|
|
|
+ //判断是否是邀请好友
|
|
|
+ if (bo.getTaskType() != 2){
|
|
|
+ throw new IllegalArgumentException("该请求是邀请好友");
|
|
|
+ }
|
|
|
+ validReceiver(bo);
|
|
|
+
|
|
|
+ ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
+
|
|
|
+ //增加用户积分
|
|
|
UserVo userVo = userService.queryById(bo.getUserId());
|
|
|
+ ActivityGradeVo list1 = activityGradeService.queryByInteger(userVo.getIntegral()+activityTaskVo.getStartIntegral());
|
|
|
+ userVo.setUserLevel(list1.getGrade());
|
|
|
+ increaseUser(userVo,userVo.getIntegral()+activityTaskVo.getStartIntegral());
|
|
|
+
|
|
|
+ //增加领取记录
|
|
|
+ ActivityTaskUser add = BeanUtil.toBean(bo, ActivityTaskUser.class);
|
|
|
+ add.setScore(Convert.toStr(activityTaskVo.getStartIntegral()));
|
|
|
+ return this.save(add);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 每日分享
|
|
|
+ *
|
|
|
+ * @param bo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean share(ActivityTaskUserAddBo bo) {
|
|
|
+ //判断是否是每日分享
|
|
|
+ if (bo.getTaskType() != 3){
|
|
|
+ throw new IllegalArgumentException("该请求是完善信息");
|
|
|
+ }
|
|
|
+ validReceiver(bo);
|
|
|
+
|
|
|
ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
|
|
|
+ //增加用户积分
|
|
|
+ UserVo userVo = userService.queryById(bo.getUserId());
|
|
|
+ ActivityGradeVo list1 = activityGradeService.queryByInteger(userVo.getIntegral()+activityTaskVo.getStartIntegral());
|
|
|
+ userVo.setUserLevel(list1.getGrade());
|
|
|
+ increaseUser(userVo,userVo.getIntegral()+activityTaskVo.getStartIntegral());
|
|
|
+
|
|
|
+ //增加领取记录
|
|
|
+ ActivityTaskUser add = BeanUtil.toBean(bo, ActivityTaskUser.class);
|
|
|
+ add.setScore(Convert.toStr(activityTaskVo.getStartIntegral()));
|
|
|
return this.save(add);
|
|
|
}
|
|
|
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 学习时长
|
|
|
+ *
|
|
|
+ * @param bo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean learnTime(ActivityTaskUserAddBo bo) {
|
|
|
+ //判断是否是每日分享
|
|
|
+ if (bo.getTaskType() != 4){
|
|
|
+ throw new IllegalArgumentException("该请求是完善信息");
|
|
|
+ }
|
|
|
+ validReceiver(bo);
|
|
|
+
|
|
|
+ ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
+
|
|
|
+ //增加用户积分
|
|
|
+ UserVo userVo = userService.queryById(bo.getUserId());
|
|
|
+ ActivityGradeVo list1 = activityGradeService.queryByInteger(userVo.getIntegral()+activityTaskVo.getStartIntegral());
|
|
|
+ userVo.setUserLevel(list1.getGrade());
|
|
|
+ increaseUser(userVo,userVo.getIntegral()+activityTaskVo.getStartIntegral());
|
|
|
+
|
|
|
+ //增加领取记录
|
|
|
+ ActivityTaskUser add = BeanUtil.toBean(bo, ActivityTaskUser.class);
|
|
|
+ add.setScore(Convert.toStr(activityTaskVo.getStartIntegral()));
|
|
|
+ return this.save(add);
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 模拟考试
|
|
|
+ *
|
|
|
+ * @param bo
|
|
|
+ * @return
|
|
|
+ */
|
|
|
+ @Override
|
|
|
+ @Transactional(rollbackFor = Exception.class)
|
|
|
+ public boolean practiceTest(ActivityTaskUserAddBo bo) {
|
|
|
+ //判断是否是模拟考试
|
|
|
+ if (bo.getTaskType() != 5){
|
|
|
+ throw new IllegalArgumentException("该请求是模拟考试");
|
|
|
+ }
|
|
|
+ validReceiver(bo);
|
|
|
+
|
|
|
+ ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
+ bo.setTaskId(activityTaskVo.getId());
|
|
|
+ ActivityTaskTimeVo activityTaskTimeVo = activityTaskTimeService.queryPractice(bo);
|
|
|
+
|
|
|
+ //增加用户积分
|
|
|
+ UserVo userVo = userService.queryById(bo.getUserId());
|
|
|
+ ActivityGradeVo list1 = activityGradeService.queryByInteger(userVo.getIntegral()+activityTaskVo.getStartIntegral());
|
|
|
+ userVo.setUserLevel(list1.getGrade());
|
|
|
+ increaseUser(userVo,userVo.getIntegral()+Convert.toLong(activityTaskTimeVo.getIntegral()));
|
|
|
+
|
|
|
+ //增加领取记录
|
|
|
+ ActivityTaskUser add = BeanUtil.toBean(bo, ActivityTaskUser.class);
|
|
|
+ add.setScore(Convert.toStr(activityTaskVo.getStartIntegral()));
|
|
|
+ return this.save(add);
|
|
|
+ }
|
|
|
+
|
|
|
+ private Boolean increaseUser(UserVo userVo,Long score){
|
|
|
+ User user = BeanUtil.toBean(userVo, User.class);
|
|
|
+ user.setIntegral(score);
|
|
|
+ user.setUpdateTime(DateUtils.getNowTime());
|
|
|
+ return userService.updateById(user);
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ *
|
|
|
+ * @author change
|
|
|
+ * @date 2021/6/23 14:38
|
|
|
+ * @param userVo
|
|
|
+ * @return Integer
|
|
|
+ */
|
|
|
+ public Integer countUser(UserVo userVo) throws IllegalAccessException {
|
|
|
+ // Java的反射
|
|
|
+ Field[] field = userVo.getClass().getDeclaredFields();
|
|
|
+ int count = 0;
|
|
|
+ for(int i=0; i<field.length; i++){
|
|
|
+ Field f = field[i];
|
|
|
+ f.setAccessible(true);
|
|
|
+ if (f.get(userVo) != null){
|
|
|
+ count++;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ return count;
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
+
|
|
|
+ //获得过去七天的日期
|
|
|
+ private Long getDateOne(){
|
|
|
+ Calendar c = Calendar.getInstance();
|
|
|
+ //过去七天
|
|
|
+ c.setTime(new Date());
|
|
|
+ c.add(Calendar.DATE, - 7);
|
|
|
+ Date d = c.getTime();
|
|
|
+
|
|
|
+ return d.getTime();
|
|
|
+ }
|
|
|
+
|
|
|
+
|
|
|
private void validReceiver(ActivityTaskUserAddBo bo) {
|
|
|
+ ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
switch (bo.getTaskType()){
|
|
|
//每日签到逻辑,当日有领取即无法签到
|
|
|
case 0:
|
|
|
@@ -151,7 +423,11 @@ public class ActivityTaskUserServiceImpl extends ServiceImpl<ActivityTaskUserMap
|
|
|
useWan.eq(bo.getTaskType() !=null,ActivityTaskUser::getTaskType,bo.getTaskType());
|
|
|
useWan.eq(bo.getUserId() !=null,ActivityTaskUser::getUserId,bo.getUserId());
|
|
|
List<ActivityTaskUser> listWan = this.list(useWan);
|
|
|
- if (!CollectionUtils.isEmpty(listWan) && listWan.size() > 0){
|
|
|
+ BigDecimal bigDecimal = new BigDecimal("0");
|
|
|
+ for (ActivityTaskUser activityTaskUser : listWan) {
|
|
|
+ bigDecimal = bigDecimal.add(new BigDecimal(activityTaskUser.getScore()));
|
|
|
+ }
|
|
|
+ if (bigDecimal.compareTo(new BigDecimal(activityTaskVo.getAccIntegral())) != 0){
|
|
|
throw new IllegalArgumentException("已完善信息领取完成,无法再次领取");
|
|
|
}
|
|
|
break;
|
|
|
@@ -161,10 +437,30 @@ public class ActivityTaskUserServiceImpl extends ServiceImpl<ActivityTaskUserMap
|
|
|
LambdaQueryChainWrapper<ActivityTaskUser> useMei = lambdaQuery();
|
|
|
useMei.eq(bo.getTaskType() !=null,ActivityTaskUser::getTaskType,bo.getTaskType());
|
|
|
useMei.eq(bo.getUserId() !=null,ActivityTaskUser::getUserId,bo.getUserId());
|
|
|
+ useMei.between(ActivityTaskUser::getCreateTime,getTimesmorning(),getTimesnight());
|
|
|
List<ActivityTaskUser> listMei = this.list(useMei);
|
|
|
- ActivityTaskVo activityTaskVo = activityTaskService.queryById(bo.getTaskId());
|
|
|
- if (!CollectionUtils.isEmpty(listMei) && listMei.size() > 0){
|
|
|
- throw new IllegalArgumentException("");
|
|
|
+ if (!CollectionUtils.isEmpty(listMei) && listMei.size() == 3){
|
|
|
+ throw new IllegalArgumentException("当日分享已达上线");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case 4:
|
|
|
+ LambdaQueryChainWrapper<ActivityTaskUser> study = lambdaQuery();
|
|
|
+ study.eq(bo.getTaskType() !=null,ActivityTaskUser::getTaskType,bo.getTaskType());
|
|
|
+ study.eq(bo.getUserId() !=null,ActivityTaskUser::getUserId,bo.getUserId());
|
|
|
+ study.between(ActivityTaskUser::getCreateTime,getTimesmorning(),getTimesnight());
|
|
|
+ List<ActivityTaskUser> listStudy = this.list(study);
|
|
|
+ if (!CollectionUtils.isEmpty(listStudy) && listStudy.size() == 3){
|
|
|
+ throw new IllegalArgumentException("当日领取连续学习积分已达上线");
|
|
|
+ }
|
|
|
+ break;
|
|
|
+ case 5:
|
|
|
+ LambdaQueryChainWrapper<ActivityTaskUser> practice = lambdaQuery();
|
|
|
+ practice.eq(bo.getTaskType() !=null,ActivityTaskUser::getTaskType,bo.getTaskType());
|
|
|
+ practice.eq(bo.getUserId() !=null,ActivityTaskUser::getUserId,bo.getUserId());
|
|
|
+ practice.between(ActivityTaskUser::getCreateTime,getTimesmorning(),getTimesnight());
|
|
|
+ List<ActivityTaskUser> listPractice = this.list(practice);
|
|
|
+ if (!CollectionUtils.isEmpty(listPractice) && listPractice.size() > 0){
|
|
|
+ throw new IllegalArgumentException("当日领取连续模拟考试积分已达上线");
|
|
|
}
|
|
|
break;
|
|
|
}
|
|
|
@@ -203,5 +499,68 @@ public class ActivityTaskUserServiceImpl extends ServiceImpl<ActivityTaskUserMap
|
|
|
|
|
|
}
|
|
|
|
|
|
+ /**
|
|
|
+ * 连续签到天数
|
|
|
+ *
|
|
|
+ * @return int
|
|
|
+ * @Author change
|
|
|
+ * @Date 2019-08-15 17:16:01
|
|
|
+ * @Param
|
|
|
+ **/
|
|
|
+ private static int getContinuousSignInDay(List<SignIn> signInList) {
|
|
|
+ //continuousDay 连续签到数
|
|
|
+ int continuousDay = 1;
|
|
|
+ boolean todaySignIn = false;
|
|
|
+ Date today = new Date();
|
|
|
+ for (int i = 0; i < signInList.size(); i++) {
|
|
|
+ SignIn signIn = signInList.get(i);
|
|
|
+ int intervalDay = distanceDay(today, signIn.getSignInDay());
|
|
|
+ //当天签到
|
|
|
+ if (intervalDay == 0 && i == 0) {
|
|
|
+ todaySignIn = true;
|
|
|
+ }
|
|
|
+ else if (intervalDay == continuousDay) {
|
|
|
+ continuousDay++;
|
|
|
+ }else {
|
|
|
+ //不连续,终止判断
|
|
|
+ break;
|
|
|
+ }
|
|
|
+ }
|
|
|
+ if (!todaySignIn) {
|
|
|
+ continuousDay--;
|
|
|
+ }
|
|
|
+ return continuousDay;
|
|
|
+ }
|
|
|
+
|
|
|
+ /**
|
|
|
+ * 两个日期对比间隔天数
|
|
|
+ *
|
|
|
+ * @param smallDay
|
|
|
+ * @return boolean
|
|
|
+ * @Author change
|
|
|
+ * @Date 2019-08-13 18:42:41
|
|
|
+ * @Param largeDay
|
|
|
+ **/
|
|
|
+ private static int distanceDay(Date largeDay, Date smallDay) {
|
|
|
+ int day = (int) ((largeDay.getTime() - smallDay.getTime()) / (1000 * 60 * 60 * 24));
|
|
|
+ return day;
|
|
|
+ }
|
|
|
+
|
|
|
+ @Data
|
|
|
+ static
|
|
|
+ class SignIn{
|
|
|
+ private Date signInDay;
|
|
|
+
|
|
|
+ public SignIn(){
|
|
|
+
|
|
|
+ }
|
|
|
+
|
|
|
+ public SignIn(String day) throws ParseException {
|
|
|
+ SimpleDateFormat sdf = new SimpleDateFormat("yyyy-MM-dd");
|
|
|
+ String sd = sdf.format(new Date(Long.parseLong(String.valueOf(day))));
|
|
|
+ signInDay = sdf.parse(day);
|
|
|
+ }
|
|
|
+ }
|
|
|
+
|
|
|
|
|
|
}
|