| | |
| | | import com.baomidou.mybatisplus.extension.plugins.pagination.Page; |
| | | import com.baomidou.mybatisplus.extension.service.impl.ServiceImpl; |
| | | import com.ruoyi.approve.utils.StartAndEndDateDto; |
| | | import com.ruoyi.common.utils.excel.ExcelUtils; |
| | | import com.ruoyi.lavorissue.dto.StatisticsLaborIssue; |
| | | import com.ruoyi.lavorissue.mapper.LavorIssueMapper; |
| | | import com.ruoyi.lavorissue.pojo.LaborIssue; |
| | | import com.ruoyi.lavorissue.service.LavorIssueService; |
| | | import com.ruoyi.project.system.domain.SysDictData; |
| | | import com.ruoyi.project.system.domain.SysDictType; |
| | | import com.ruoyi.project.system.mapper.SysDictDataMapper; |
| | | import lombok.extern.slf4j.Slf4j; |
| | | import org.springframework.beans.factory.annotation.Autowired; |
| | | import org.springframework.stereotype.Service; |
| | | import org.springframework.util.CollectionUtils; |
| | | |
| | | import javax.servlet.http.HttpServletResponse; |
| | | import java.text.SimpleDateFormat; |
| | | import java.util.ArrayList; |
| | | import java.util.Calendar; |
| | | import java.util.Date; |
| | | import java.util.List; |
| | |
| | | return statisticsLaborIssue; |
| | | } |
| | | |
| | | @Autowired |
| | | private SysDictDataMapper sysDictDataMapper; |
| | | |
| | | @Override |
| | | public void exportCopy(HttpServletResponse response) { |
| | | List<SysDictData> sys_lavor_issue = sysDictDataMapper.selectDictDataByType("sys_lavor_issue"); |
| | | if(CollectionUtils.isEmpty(sys_lavor_issue)){ |
| | | throw new RuntimeException("字典数据为空"); |
| | | } |
| | | List<Object> head = new ArrayList<>(); |
| | | head.add("部门"); |
| | | head.add(ExcelUtils.COLUMN_MERGE); |
| | | head.add("企业管理科"); |
| | | head.add(ExcelUtils.COLUMN_MERGE); |
| | | head.add("企业管理科2025年1月-2025年3月劳保发放计划表"); |
| | | for (int i = 0; i < sys_lavor_issue.size(); i++) { |
| | | if (i == 0) { |
| | | head.add(ExcelUtils.COLUMN_MERGE); |
| | | } else { |
| | | head.add(ExcelUtils.COLUMN_MERGE); |
| | | } |
| | | } |
| | | List<Object> head1 = new ArrayList<>(); |
| | | head1.add("开始年/月"); |
| | | head1.add(ExcelUtils.COLUMN_MERGE); |
| | | head1.add("结束年/月"); |
| | | head1.add(ExcelUtils.COLUMN_MERGE); |
| | | for (int i = 0; i < sys_lavor_issue.size(); i++) { |
| | | head1.add(""); |
| | | } |
| | | |
| | | List<Object> head2 = new ArrayList<>(); |
| | | head2.add("2025"); |
| | | head2.add("1"); |
| | | head2.add("2025"); |
| | | head2.add("3"); |
| | | for (int i = 0; i < sys_lavor_issue.size(); i++) { |
| | | head2.add(""); |
| | | } |
| | | List<Object> head3 = new ArrayList<>(); |
| | | head3.add("部门名称"); |
| | | head3.add(ExcelUtils.COLUMN_MERGE); |
| | | head3.add("姓名"); |
| | | head3.add("工号"); |
| | | for (SysDictData sysDictData : sys_lavor_issue) { |
| | | head3.add(sysDictData.getDictLabel()); |
| | | } |
| | | |
| | | List<List<Object>> sheetDataList = new ArrayList<>(); |
| | | sheetDataList.add(head); |
| | | sheetDataList.add(head1); |
| | | sheetDataList.add(head2); |
| | | sheetDataList.add(head3); |
| | | ExcelUtils.export(response, "劳保发放计划表", sheetDataList); |
| | | } |
| | | |
| | | public Date getLastDayOfMonth(Date date) { |
| | | Calendar calendar = Calendar.getInstance(); |
| | | calendar.setTime(date); // 设置传入的Date |