Ver código fonte

feat(marketing): 新增项目设备管理功能

hechunping 6 meses atrás
pai
commit
0f868d637d

+ 39 - 0
src/main/java/com/xynet/marketing/entity/MercProjectDevice.java

@@ -0,0 +1,39 @@
+package com.xynet.marketing.entity;
+
+import com.baomidou.mybatisplus.annotation.IdType;
+import com.baomidou.mybatisplus.annotation.TableId;
+import com.baomidou.mybatisplus.annotation.TableName;
+import lombok.Data;
+import lombok.experimental.Accessors;
+
+import java.io.Serializable;
+
+/**
+ * 项目设备表
+ * @author hechunping
+ * @date 2025/1/20
+ */
+@Data
+@Accessors(chain = true)
+@TableName("marketing_merc_project_device")
+public class MercProjectDevice implements Serializable {
+    @TableId(type = IdType.AUTO)
+    private Integer id;
+
+    /**
+     * 活动Id
+     */
+    private Integer actId;
+
+    /**
+     * 活动类型
+     */
+    private String actType;
+
+    /**
+     * 设备Id
+     */
+    private String deviceId;
+
+
+}

+ 13 - 0
src/main/java/com/xynet/marketing/mapper/MercProjectDeviceMapper.java

@@ -0,0 +1,13 @@
+package com.xynet.marketing.mapper;
+
+import com.baomidou.mybatisplus.core.mapper.BaseMapper;
+import com.xynet.marketing.entity.MercProjectDevice;
+
+/**
+ * 项目设备表-Mapper
+ *
+ * @author hechunping
+ * @date 2025/01/20
+ */
+public interface MercProjectDeviceMapper extends BaseMapper<MercProjectDevice> {
+}

+ 42 - 0
src/main/java/com/xynet/marketing/service/MercProjectDeviceService.java

@@ -0,0 +1,42 @@
+package com.xynet.marketing.service;
+
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.xynet.marketing.utils.collections.map.JMap;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 项目设备服务
+ * @author hechunping
+ * @date 2025/1/20
+ */
+public interface MercProjectDeviceService {
+    /**
+     * 对象查询
+     * @param param
+     * @return
+     */
+    Map<String,Object> obj(JMap<String,Object> param);
+
+    /**
+     * 新增或修改
+     * @param param
+     * @return
+     */
+    void saveOrUpdate(JMap<String, Object> param);
+
+    /**
+     * 列表查询
+     * @param param
+     * @return
+     */
+    List<Map<String,Object>> list(JMap<String,Object> param);
+
+    /**
+     * 分页查询
+     * @param param
+     * @return
+     */
+    Page<Map<String, Object>> page(JMap<String, Object> param);
+}

+ 65 - 0
src/main/java/com/xynet/marketing/service/impl/MercProjectDeviceServiceImpl.java

@@ -0,0 +1,65 @@
+package com.xynet.marketing.service.impl;
+
+import cn.hutool.core.bean.BeanUtil;
+import com.baomidou.mybatisplus.core.conditions.query.LambdaQueryWrapper;
+import com.baomidou.mybatisplus.extension.plugins.pagination.Page;
+import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl;
+import com.xynet.marketing.entity.MercProjectDevice;
+import com.xynet.marketing.mapper.MercProjectDeviceMapper;
+import com.xynet.marketing.service.MercProjectDeviceService;
+import com.xynet.marketing.utils.Emptys;
+import com.xynet.marketing.utils.collections.map.JHashMap;
+import com.xynet.marketing.utils.collections.map.JMap;
+import lombok.extern.slf4j.Slf4j;
+import org.springframework.stereotype.Service;
+
+import java.util.List;
+import java.util.Map;
+
+/**
+ * 项目设备服务 实现
+ * @author hechunping
+ * @date 2025/1/20
+ */
+@Service
+@Slf4j
+public class MercProjectDeviceServiceImpl extends ServiceImpl<MercProjectDeviceMapper, MercProjectDevice> implements MercProjectDeviceService {
+    private LambdaQueryWrapper<MercProjectDevice> commonQueryWrapper(JMap<String,Object> param) {
+        LambdaQueryWrapper<MercProjectDevice> lqw = new LambdaQueryWrapper<MercProjectDevice>()
+                .eq(Emptys.check(param.getInt("id")), MercProjectDevice::getId, param.getInt("id"))
+                ;
+        return lqw;
+    }
+
+    @Override
+    public Map<String, Object> obj(JMap<String, Object> param) {
+        LambdaQueryWrapper<MercProjectDevice> lqw = commonQueryWrapper(param).last("limit 1");
+        MercProjectDevice obj = getOne(lqw);
+        return JHashMap.copy(obj);
+    }
+
+    @Override
+    public void saveOrUpdate(JMap<String, Object> param) {
+        MercProjectDevice save = BeanUtil.copyProperties(param, MercProjectDevice.class);
+        if(Emptys.check(save.getId())){
+            updateById(save);
+        }else{
+            save(save);
+        }
+    }
+
+    @Override
+    public List<Map<String, Object>> list(JMap<String, Object> param) {
+        LambdaQueryWrapper<MercProjectDevice> lqw = commonQueryWrapper(param).orderByAsc(MercProjectDevice::getId);
+        List<MercProjectDevice> list = list(lqw);
+        return JHashMap.copy(list);
+    }
+
+    @Override
+    public Page<Map<String, Object>> page(JMap<String, Object> param) {
+        LambdaQueryWrapper<MercProjectDevice> lqw = commonQueryWrapper(param).orderByAsc(MercProjectDevice::getId);
+        Page<MercProjectDevice> page = new Page<>(param.getInt("pageCurrent"), param.getInt("pageSize"),true);
+        Page<MercProjectDevice> list = page(page, lqw);
+        return JHashMap.copy(list);
+    }
+}