介绍

在文档使用案例中有一部分是导出pdf的文档,但是目前不能直接导出pdf,只能是先预览在下载pdf,实现步骤与文档套件使用案例基本一致,需要修改的地方就是代码部分。

配置功能

文档数据,数据提取方式用资源表也可以

文档模板,其中文档类型的pdf 目前不用配,这个类型不用了

文档模板预览效果

在全局脚本库编写脚本

文档表单的下载与预览脚本库(doExecDoc)代码

/*
 方法调用示例:JE.callCustomFn('编码',{ param1:1, param2:2 });
*/
/*
 方法体编写示例:
*/
// 1. 方法参数解析
// const { param1, param2 } = EventOptions;
// 2. 方法体编写
// 3. 需要返回值,直接return;
// return result;
const {docCode,params,pd,returnType,$func} = EventOptions;
var pdf="0";
var returnTypeVal="exp";
if(JE.isNotEmpty(returnType)){
    returnTypeVal=returnType;
}
var pdVal="";
if(JE.isNotEmpty(pd)){
    pdVal=pd;
}else{
    if($func && $func.getFuncData){
        pdVal=$func.getFuncData().info.productCode;
    }
}
JE.ajax({
    url:"/je/office/jeOffice/doCacheParam",
    params:params || {},
    headers:{pd:pdVal}
}).then((resObj)=>{
    if(resObj.success){
        var paramKey=resObj.data;
        if('exp'==returnType){
            window.open("/je/office/jeOffice/doExecDoc?code="+docCode+"&pdf="+pdf+"&returnType="+returnTypeVal+"&type=cache&data="+paramKey+"&pd="+pdVal);
        }else{
            window.open("/je/office/jeOffice/doExecDoc?code="+docCode+"&pdf="+pdf+"&returnType="+returnTypeVal+"&type=cache&data="+paramKey+"&pd="+pdVal);
        }
    }else{
        JE.alert(resObj.data, "error");
    }
})

文档生成后保存到文档(doExecDataDoc)代码

/*
 方法调用示例:JE.callCustomFn('编码',{ param1:1, param2:2 });
*/
/*
 方法体编写示例:
*/
// 1. 方法参数解析
// const { param1, param2 } = EventOptions;
// 2. 方法体编写
// 3. 需要返回值,直接return;
// return result;
const {docCode,params,pd,returnType,$func,pdf} = EventOptions;
const {Upload} = JE.useUi();
var pdfVal="0";
var returnTypeVal="exp";
if(JE.isNotEmpty(returnType)){
    returnTypeVal=returnType;
}
var pdVal="";
if(JE.isNotEmpty(pd)){
    pdVal=pd;
}else{
    if($func && $func.getFuncData){
        pdVal=$func.getFuncData().info.productCode;
    }
}
if(JE.isNotEmpty(pdf)){
    pdfVal=pdf;
}
JE.ajax({
    url:"/je/office/jeOffice/doCacheParam",
    params:params || {},
    headers:{pd:pdVal}
}).then((resObj)=>{
    if(resObj.success){
        var paramKey=resObj.data;
        JE.ajax({
            url:"/je/office/jeOffice/doExecDataDoc",
            params:{
                code:docCode,
                pdf:pdf,
                returnType:returnType,
                type:'cache',
                data:paramKey
            }, headers:{pd:pdVal}
        }).then((docObj)=>{
            if(!docObj.success){
                JE.alert(docObj.message,"error");
                return;
            }
            if("exp"==returnTypeVal){
                 JE.useUtils().downloadFile(docObj.data.fileKey);
            }else{
                const fileItem = {fileKey: docObj.data.fileKey,relName:docObj.data.relName,size: docObj.data.size,suffix: "docx"};
                Upload.previewFile(fileItem);
                // JE.useUtils().previewFile(docObj.data.fileKey);
            }
        });
    }else{
        JE.alert(resObj.data, "error");
    }
})

业务功能中使用

在功能中配置按钮,编写按钮事件,这里加了两个按钮,第一:下载原件,这是直接下载Word;预览文档,这是先将文档进行预览,预览之后下载pdf。

下载原件按钮事件

//获取ajax
//获得功能对象
const {$func} = EventOptions;
const funcForm=$func.getFuncForm();
const formValues=funcForm.getValues();
var pkCode=$func.getFuncData().info.pkCode;
if(!JE.isNotEmpty(formValues[pkCode])){
    JE.alert("请先保存数据!", "error");
    return;
}
var docCode="CRM002";
var params={
    pkValue:formValues[pkCode]
}
var returnType="exp";
JE.callCustomFn('doExecDoc',{docCode:docCode,params:params,returnType:returnType,$func});

下载原文件效果(word)

预览文档按钮事件

const {
    $func,  // 功能对象
    button, // 按钮对象
} = EventOptions;

// 异步事件,支持 await语法,实现同步处理。

const funcForm=$func.getFuncForm();
const formValues=funcForm.getValues();
var pkCode=$func.getFuncData().info.pkCode;
if(!JE.isNotEmpty(formValues[pkCode])){
    JE.alert("请先保存数据!", "error");
    return;
}
var docCode="CRM002";
var params={
    pkValue:formValues[pkCode]
}
var returnType="preview";
JE.callCustomFn('doExecDataDoc',{docCode:docCode,params:params,returnType:returnType,$func});

预览文档效果:单击按钮之后弹框效果,先预览在手动点击下载

下载pdf效果

最后编辑: 呼丽华  文档更新时间: 2025-01-15 16:00   作者:呼丽华