fix
Helius
2022-08-08 a62596b736d8a6c53aefbf47e3938f0c835e7305
src/main/java/com/xcong/farmer/cms/core/handler/PageDataParserHandler.java
@@ -10,9 +10,12 @@
import com.xcong.farmer.cms.core.tag.data.PageChildData;
import com.xcong.farmer.cms.core.tag.data.PageData;
import com.xcong.farmer.cms.core.tag.model.Article;
import com.xcong.farmer.cms.core.tag.model.Column;
import com.xcong.farmer.cms.core.tag.model.Pagination;
import com.xcong.farmer.cms.modules.system.entity.ArticleEntity;
import com.xcong.farmer.cms.modules.system.entity.ColumnEntity;
import com.xcong.farmer.cms.modules.system.mapper.ArticleMapper;
import com.xcong.farmer.cms.modules.system.mapper.ColumnMapper;
import com.xcong.farmer.cms.utils.SpringContextHolder;
import lombok.extern.slf4j.Slf4j;
@@ -27,57 +30,67 @@
public class PageDataParserHandler implements DataParserHandler {
    private ArticleMapper articleMapper = SpringContextHolder.getBean(ArticleMapper.class);
    private CmsProperties cmsProperties = SpringContextHolder.getBean(CmsProperties.class);
    private ColumnMapper columnMapper = SpringContextHolder.getBean(ColumnMapper.class);
    @Override
    public void dataParser(AttrNode attrNode) {
        log.info("分页解析");
        Template.HAS_PAGING = true;
//        log.info("分页解析");
        synchronized (this) {
            Template.HAS_PAGING = true;
            String baseUrl = (String) attrNode.getSystemDataValue("baseUrl");
        Long companyId = (Long) attrNode.getSystemDataValue("companyId");
        Pagination param = (Pagination) attrNode.getParam();
            Long companyId = (Long) attrNode.getSystemDataValue("companyId");
            Pagination param = (Pagination) attrNode.getParam();
        Page<ArticleEntity> page = new Page<>(Integer.parseInt(param.getPage()), Integer.parseInt(param.getLimit()));
        ArticleEntity article = new ArticleEntity();
        article.setColumnCode(param.getCode());
        article.setCompanyId(companyId);
        IPage<ArticleEntity> pageList = articleMapper.selectArticleInPage(page, article);
            Page<ArticleEntity> page = new Page<>(Integer.parseInt(param.getPage()), Integer.parseInt(param.getLimit()));
            ArticleEntity article = new ArticleEntity();
            article.setColumnCode(param.getCode());
            article.setCompanyId(companyId);
            IPage<ArticleEntity> pageList = articleMapper.selectArticleInPage(page, article);
        PageData pageData = new PageData();
        pageData.setTotalPage((int) pageList.getPages());
        pageData.setIndex(Integer.parseInt(param.getPage()));
        pageData.setTotalCnt((int) pageList.getSize());
            PageData pageData = new PageData();
            pageData.setTotalPage((int) pageList.getPages());
            pageData.setIndex(Integer.parseInt(param.getPage()));
            pageData.setTotalCnt((int) pageList.getSize());
        if (CollUtil.isNotEmpty(pageList.getRecords())) {
            String path = cmsProperties.getBaseUrl() + "/" + param.getCode();
            String filename = "index_{}.html";
            List<PageChildData> list = new ArrayList<>();
            int pageNo = Integer.parseInt(param.getPage());
            // 计算出页面显示分页的最大和最小值
            int[] startAndEnd = pageStartAndEnd(pageNo, (int) pageList.getPages(), Integer.parseInt(param.getSize()));
            for (int i = startAndEnd[0]; i <= startAndEnd[1] ; i++) {
                PageChildData child = new PageChildData();
                child.setIndex(i);
                if (pageNo == 1) {
                    child.setPath(path + "/index.html");
            if (CollUtil.isNotEmpty(pageList.getRecords())) {
                ColumnEntity parentColumn = columnMapper.selectParentColumnByCodeAndCompanyId(param.getCode(), companyId);
                String path;
                if (parentColumn == null) {
                    path = baseUrl + "/" + param.getCode();
                } else {
                    child.setPath(path + "/" + StrUtil.format(filename, i));
                    path = baseUrl + "/" + parentColumn.getColumnCode() + "/" + param.getCode();
                }
                list.add(child);
                String filename = "index_{}.html";
                List<PageChildData> list = new ArrayList<>();
                int pageNo = Integer.parseInt(param.getPage());
                // 计算出页面显示分页的最大和最小值
                int[] startAndEnd = pageStartAndEnd(pageNo, (int) pageList.getPages(), Integer.parseInt(param.getSize()));
                for (int i = startAndEnd[0]; i <= startAndEnd[1]; i++) {
                    PageChildData child = new PageChildData();
                    child.setIndex(i);
                    if (pageNo == 1) {
                        child.setPath(path + "/index.html");
                    } else {
                        child.setPath(path + "/" + StrUtil.format(filename, i));
                    }
                    list.add(child);
                }
                pageData.setChildren(list);
            } else {
                pageData.setNext("javascript:void(0)");
                pageData.setPrev("javascript:void(0)");
            }
            pageData.setChildren(list);
        } else {
            pageData.setNext("javascript:void(0)");
            pageData.setPrev("javascript:void(0)");
        }
            if (Integer.parseInt(param.getPage()) >= pageList.getPages()) {
                Template.HAS_PAGING = false;
            }
        if (Integer.parseInt(param.getPage()) == pageList.getPages()) {
            Template.HAS_PAGING = false;
            attrNode.setData(pageData);
        }
        attrNode.setData(pageData);
    }
    /**