杜洪波
2024-08-26 a518ef8df36abe8d80733797d4e1322af79a4c34
src/main/java/com/product/file/service/DocumentService.java
@@ -81,15 +81,15 @@
            fseDocument.setValue(CmnConst.FILE_TYPE, file_type);
            //保存数据
            String documentUUID = baseDao.add(fseDocument);
            //创建文档版本数据容器
            FieldSetEntity fseDocumentHistory = new FieldSetEntity(CmnConst.PRODUCT_OA_DOCUMENT_HISTORY);
            BaseUtil.createCreatorAndCreationTime(fseDocumentHistory);
            fseDocument.setValue("document_uuid", documentUUID);
            fseDocument.setValue("attachment_uuid", attachment.getUUID());
            fseDocument.setValue("version_number", "v1");
            fseDocumentHistory.setValue("document_uuid", documentUUID);
            fseDocumentHistory.setValue("attachment_uuid", attachment.getUUID());
            fseDocumentHistory.setValue("version_number", "v1");
            baseDao.add(fseDocumentHistory);
            uuidList.add(documentUUID);
            fileNameList.add(file_name);
        }
@@ -481,7 +481,7 @@
        return baseDao.listTable("SELECT CONCAT(b.show_name, a.state) log,a.created_utc_datetime FROM PRODUCT_OA_document_log a LEFT JOIN product_sys_staffs b on a.created_by = b.user_id WHERE document_uuid = ? ORDER BY a.created_utc_datetime DESC",
                new String[]{fieldSetEntity.getString(CmnConst.DOCUMENT_UUID)}, fieldSetEntity.getInteger(CmnConst.PAGESIZE), fieldSetEntity.getInteger(CmnConst.CPAGE));
    }
    /**
     *    文档收藏
     * @param fse
@@ -492,7 +492,7 @@
       fse.setValue("document_collector", SpringMVCContextHolder.getCurrentUserId());
       return baseDao.add(fse);
    }
    /**
     *    文档取消收藏
     * @param documentUUID
@@ -501,7 +501,7 @@
    public boolean documentCancelCollection(String documentUUID) {
       return baseDao.delete(CmnConst.PRODUCT_OA_DOCUMENT_COLLECTION, "document_uuid = ? AND document_collector = ?", new Object[] {documentUUID, SpringMVCContextHolder.getCurrentUserId()});
    }
    /**
     *    查询文档历史版本
     * @param documentUUID
@@ -516,7 +516,7 @@
       sql.append("ORDER BY A.version_number");
       return baseDao.listTable(sql.toString(), new Object[] {documentUUID});
    }
    /**
     *    文档最新版本保存
     * @param fse
@@ -541,40 +541,48 @@
       }
       fseDocument.setValue("attachments_uuid", fse.getString("attachment_uuid"));
       baseDao.saveFieldSetEntity(fseDocument);
       fse.setValue("version_number", versionNUmberAddne(fseDocument.getString("max_version_number")));
       return baseDao.saveFieldSetEntity(fse);
    }
    /**
     *    文档版本+1
     * @param originNumber
     * @return
     */
    public String versionNUmberAddne(String originNumber) {
       String numberStr = originNumber.substring(1); // 去掉前缀"v"
       String numberStr = originNumber.substring(1); // 去掉前缀"v"
       int number = Integer.parseInt(numberStr); // 将字符串转
        // 数字加一
        number += 1;
        // 重新构建字符串(这里我们假设前缀总是"v")
        return "v" + number;
        // 数字加一
        number += 1;
        // 重新构建字符串(这里我们假设前缀总是"v")
        return "v" + number;
    }
    @Override
    public DataTableEntity getApplyDocument(FieldSetEntity fse) throws BaseException {
        DataTableEntity product_oa_document;
        if(ObjectUtil.isNotEmpty(fse.getString("document_name"))){
            String document_name = fse.getString("document_name");
            String filter="file_name like '%"+document_name+"'%";
            product_oa_document = baseDao.listTable("product_oa_document",filter);
        DataTableEntity product_oa_document = new DataTableEntity();
        StringBuilder sb=new StringBuilder();
        List<String> param=new ArrayList<>();
        if(!ObjectUtil.isNotEmpty(fse.getString("document_name"))){
            sb.append(" select  d.*,f.show_name ");
            sb.append(" from product_oa_document d ");
            sb.append(" left join  product_sys_staffs f ");
            sb.append(" on d.created_by=f.user_id ");
            product_oa_document = baseDao.listTable(sb.toString(),param.toArray());
        }else {
            product_oa_document = baseDao.listTable("product_oa_document");
            String document_name = fse.getString("document_name");
            sb.append(" where d.file_name like '%"+document_name+"%'");
           product_oa_document = baseDao.listTable(sb.toString());
        }
        return product_oa_document;
        return  product_oa_document;
    }
    @Override
@@ -625,8 +633,9 @@
    }
    @Override
    public DataTableEntity getApplayFileSort() throws BaseException {
    public DataTableEntity getApplyFileSort() throws BaseException {
        StringBuilder sb=new StringBuilder();
        List<String> param=new ArrayList<>();
        sb.append(" SELECT b.* FROM (");
        sb.append(" SELECT t.uuid,t.file_name,s.show_name,t.created_utc_datetime,count(t.uuid) as applyCount");
        sb.append(" FROM product_oa_document_borrow_sub b");
@@ -636,16 +645,17 @@
        sb.append(" on t.created_by=s.user_id");
        sb.append(" group by t.file_name,t.uuid,s.show_name,t.created_utc_datetime");
        sb.append(" )b order by  b.applyCount asc");
        DataTableEntity dataTableEntity = baseDao.listTable(sb.toString());
        DataTableEntity dataTableEntity = baseDao.listTable(sb.toString(),param.toArray());
        return dataTableEntity;
    }
    @Override
    public DataTableEntity getApplayUserSort() throws BaseException {
    public DataTableEntity getApplyUserSort() throws BaseException {
        StringBuilder sb=new StringBuilder();
        List<String> param=new ArrayList<>();
        sb.append(" SELECT a.borrower,a.show_name,a.applayCount,a.applayFileCount ");
        sb.append(" FROM (");
        sb.append(" SELECT w.borrower,");
        sb.append(" SELECT w.borrower,s.show_name,");
        sb.append(" (select   count(borrower)  from  product_oa_document_borrow group by borrower ) as  applayCount,");
        sb.append(" count(sub_uuid) as applayFileCount ");
        sb.append(" FROM product_oa_document_borrow  w ");
@@ -658,12 +668,12 @@
        sb.append(" GROUP BY w.borrower,s.show_name");
        sb.append(" )a");
        sb.append(" order by a.applayCount,a.applayFileCount asc");
        DataTableEntity dataTableEntity = baseDao.listTable(sb.toString());
        DataTableEntity dataTableEntity = baseDao.listTable(sb.toString(),param.toArray());
        return dataTableEntity;
    }
    @Override
    public FieldSetEntity getApplayInfo(FieldSetEntity fes) throws BaseException {
    public FieldSetEntity getApplyInfo(FieldSetEntity fes) throws BaseException {
        String uuid = fes.getString("uuid");
        FieldSetEntity product_oa_document_borrow = baseDao.getFieldSetEntity("product_oa_document_borrow", uuid, false);
        return product_oa_document_borrow;