Commit 0a25cc98 authored by niminmin's avatar niminmin

Merge branch 'feature/发票功能优化' into develop

parents 2458810c b70ee121
Pipeline #3869 canceled with stages
package leaf.plugin.export.word;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.InputStream;
import java.io.StringReader;
import java.io.UnsupportedEncodingException;
import java.math.BigInteger;
import java.net.URL;
import java.security.InvalidKeyException;
import java.security.NoSuchAlgorithmException;
import java.util.ArrayList;
import java.util.HashMap;
import java.util.Iterator;
import java.util.List;
import java.util.Map;
import java.util.UUID;
import javax.crypto.BadPaddingException;
import javax.crypto.Cipher;
import javax.crypto.IllegalBlockSizeException;
import javax.crypto.KeyGenerator;
import javax.crypto.NoSuchPaddingException;
import javax.crypto.SecretKey;
import javax.crypto.spec.SecretKeySpec;
import javax.xml.bind.JAXBContext;
import javax.xml.bind.JAXBElement;
import javax.xml.bind.JAXBException;
import javax.xml.bind.Marshaller;
import javax.xml.bind.Unmarshaller;
import javax.xml.namespace.QName;
import org.apache.commons.io.FileUtils;
import org.docx4j.UnitsOfMeasurement;
import org.docx4j.XmlUtils;
import org.docx4j.dml.wordprocessingDrawing.Inline;
import org.docx4j.jaxb.Context;
import org.docx4j.model.structure.PageSizePaper;
import org.docx4j.model.structure.SectionWrapper;
import org.docx4j.openpackaging.packages.WordprocessingMLPackage;
import org.docx4j.openpackaging.parts.Part;
import org.docx4j.openpackaging.parts.WordprocessingML.AltChunkType;
import org.docx4j.openpackaging.parts.WordprocessingML.BinaryPartAbstractImage;
import org.docx4j.openpackaging.parts.WordprocessingML.DocumentSettingsPart;
import org.docx4j.openpackaging.parts.WordprocessingML.FooterPart;
import org.docx4j.openpackaging.parts.WordprocessingML.HeaderPart;
import org.docx4j.openpackaging.parts.WordprocessingML.MainDocumentPart;
import org.docx4j.openpackaging.parts.WordprocessingML.NumberingDefinitionsPart;
import org.docx4j.openpackaging.parts.relationships.Namespaces;
import org.docx4j.relationships.Relationship;
import org.docx4j.wml.*;
import org.docx4j.wml.CTSettings.DisplayHorizontalDrawingGridEvery;
import org.docx4j.wml.CTSettings.DisplayVerticalDrawingGridEvery;
import org.docx4j.wml.CTTblPrBase.TblStyle;
import org.docx4j.wml.P.Hyperlink;
import org.docx4j.wml.PPrBase.NumPr;
import org.docx4j.wml.PPrBase.NumPr.Ilvl;
import org.docx4j.wml.PPrBase.NumPr.NumId;
import org.docx4j.wml.R.Ptab;
import org.docx4j.wml.SectPr.PgMar;
import org.docx4j.wml.TcPrInner.GridSpan;
import org.docx4j.wml.TcPrInner.TcBorders;
import org.docx4j.wml.TcPrInner.VMerge;
import leaf.plugin.export.word.wml.AltChunk;
import leaf.plugin.export.word.wml.Body;
import leaf.plugin.export.word.wml.Break;
import leaf.plugin.export.word.wml.Document;
import leaf.plugin.export.word.wml.Footer;
import leaf.plugin.export.word.wml.Header;
import leaf.plugin.export.word.wml.Image;
import leaf.plugin.export.word.wml.NumberingChunk;
import leaf.plugin.export.word.wml.PBdr;
import leaf.plugin.export.word.wml.PTab;
import leaf.plugin.export.word.wml.Paragraph;
import leaf.plugin.export.word.wml.PermEnd;
import leaf.plugin.export.word.wml.PermStart;
import leaf.plugin.export.word.wml.QRCode;
import leaf.plugin.export.word.wml.Settings;
import leaf.plugin.export.word.wml.Table;
import leaf.plugin.export.word.wml.TableTc;
import leaf.plugin.export.word.wml.TableTcBorder;
import leaf.plugin.export.word.wml.TableTr;
import leaf.plugin.export.word.wml.Text;
import leaf.plugin.export.word.wml.Toc;
import com.google.zxing.BarcodeFormat;
import com.google.zxing.EncodeHintType;
import com.google.zxing.MultiFormatWriter;
import com.google.zxing.common.BitMatrix;
import com.google.zxing.qrcode.decoder.ErrorCorrectionLevel;
@SuppressWarnings("unchecked")
public class WordUtils {
// public static final int TWIP_CENTIMETER = 567;
public static final String TYPE_WORD = "word";
public static final String TYPE_PDF = "pdf";
public static final String EXPORT_TYPE = "KEY_EXPORT_TYPE";
private static final String KEY_RUN_NUMID = "KEY_RUN_NUMID";
private static final String KEY_TEMPLATE_FILE = "KEY_TEMPLATE_FILE";
private static final String KEY_NUMBERING_DEFINITION_PART = "KEY_NUMBERING_DEFINITION_PART";
private static final ThreadLocal threadLocal = new ThreadLocal();
private static int permId = new java.util.Random().nextInt();
public static Object getObject(String key){
Map map = (Map)threadLocal.get();
return map.get(key);
}
public static void putObject(String key,Object value){
Map map = (Map)threadLocal.get();
if(map==null){
map = new HashMap();
threadLocal.set(map);
}
map.put(key, value);
}
public static WordprocessingMLPackage createWord(Document doc,File templateFile) throws Exception{
if(doc.getDebugger()){
JAXBContext jaxbContext = JAXBContext.newInstance(Document.class);
Marshaller marshaller = jaxbContext.createMarshaller();
marshaller.setProperty(Marshaller.JAXB_FORMATTED_OUTPUT, true);
marshaller.setProperty(Marshaller.JAXB_ENCODING, "gbk");
marshaller.marshal(doc, System.out);
System.out.println("");
}
// threadLocal.set(new HashMap());
putObject(KEY_TEMPLATE_FILE,templateFile);
WordprocessingMLPackage wordMLPackage = WordUtils.createWordprocessingMLPackage(doc);
MainDocumentPart mdp = wordMLPackage.getMainDocumentPart();
ObjectFactory factory = Context.getWmlObjectFactory();
SectPr docSectPr = wordMLPackage.getMainDocumentPart().getContents().getBody().getSectPr();
// PgSz pgSz = factory.createSectPrPgSz();
// BigInteger w = doc.getPgSzW();
// if(w!=null) pgSz.setW(w);
// BigInteger h = doc.getPgSzH();
// if(h!=null) pgSz.setH(h);
// BigInteger code = doc.getPgSzCode();
// if(code!=null) pgSz.setCode(code);
// docSectPr.setPgSz(pgSz);
PgMar pg = factory.createSectPrPgMar();
pg.setTop(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(doc.getTop()*10)));
pg.setBottom(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(doc.getBottom()*10)));
pg.setLeft(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(doc.getLeft()*10)));
pg.setRight(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(doc.getRight()*10)));
pg.setHeader(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(doc.getHeaderSize()*10)));
pg.setFooter(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(doc.getFooterSize()*10)));
docSectPr.setPgMar(pg);
docSectPr.setCols(factory.createCTColumns());
SectPr.Type st = new SectPr.Type();
st.setVal("continuous");
docSectPr.setType(st);
String docGridType = doc.getDocGridType();
if(docGridType!=null){
CTDocGrid docGrid = factory.createCTDocGrid();
docGrid.setType(STDocGrid.fromValue(docGridType));
docSectPr.setDocGrid(docGrid);
BigInteger linePitch = doc.getDocGridLinePitch();
if(linePitch!=null)docGrid.setLinePitch(linePitch);
}
Settings sts = doc.getSettings();
if(sts!=null){
CTSettings settings = WordUtils.createSettings(factory, wordMLPackage, sts);
DocumentSettingsPart dsp = new DocumentSettingsPart();
dsp.setJaxbElement(settings);
mdp.addTargetPart(dsp);
}
HeaderPart hp = null;
Header hd = doc.getHeader();
if(hd!=null && hd.getPara()!=null){
hp = WordUtils.addHeader(factory, wordMLPackage, hd.getPara());
}
Footer ft = doc.getFooter();
if(ft!=null){
WordUtils.addFooter(factory, wordMLPackage, ft.getPara());
}
String watermark = doc.getWatermark();
if(watermark!=null){
WordUtils.addWaterMark(hp,factory, wordMLPackage, watermark);
}
Body body = doc.getBody();
List<Object> paras = body.getParas();
int indexOfToc = WordUtils.findToc(paras);
List<Map> tocs = new ArrayList();
// int permId = new java.util.Random().nextInt();
for (Object obj : paras) {
Object p = null;
if(obj instanceof Paragraph) {
Paragraph paragraph = (Paragraph)obj;
Boolean toc = paragraph.getToc();
if(toc){
String tocTitle = "untitle";
List objs = paragraph.getObjects();
if(objs!=null && objs.size() > 0) {
Object t = objs.get(0);
if(t instanceof Text){
tocTitle = ((Text)t).getText();
}
}
Map bmk = new HashMap();
String bookmark = UUID.randomUUID().toString();
paragraph.setTocBookMark(bookmark);
bmk.put(Toc.TOC_TITLE, tocTitle);
bmk.put(Toc.TOC_BOOKMARK, bookmark);
tocs.add(bmk);
}
p = WordUtils.createPara(wordMLPackage,factory,(Paragraph)obj);
} else if(obj instanceof Break){
p = WordUtils.createPageBreak(factory);
}else if(obj instanceof Table){
Table table = (Table)obj;
p = WordUtils.createTable(wordMLPackage, factory, table);
}else if(obj instanceof AltChunk){
AltChunk chunk = (AltChunk)obj;
WordUtils.createChunk(mdp,chunk);
}else if(obj instanceof PermStart){
permId = new java.util.Random().nextInt();
RangePermissionStart start = factory.createRangePermissionStart();
start.setId(String.valueOf(permId));
start.setEdGrp("everyone");
mdp.getContents().getBody().getContent().add(start);
}else if(obj instanceof PermEnd){
CTPerm end = factory.createCTPerm();
end.setId(String.valueOf(permId));
mdp.getContents().getBody().getContent().add(end);
}
if(p!=null) mdp.getContents().getBody().getContent().add(p);
}
//create TOC
if(indexOfToc!= -1 && !tocs.isEmpty()){
mdp.getContents().getBody().getContent().add(indexOfToc++,WordUtils.createTOCHead(factory));
mdp.getContents().getBody().getContent().add(indexOfToc++,WordUtils.createTOCStart(factory));
for (Map toc : tocs) {
mdp.getContents().getBody().getContent().add(indexOfToc++,WordUtils.createTOC(factory,toc));
}
mdp.getContents().getBody().getContent().add(indexOfToc++,WordUtils.createTOCEnd(factory));
mdp.getContents().getBody().getContent().add(indexOfToc++,WordUtils.createPageBreak(factory));
}
// WordUtils.hideSpellAndGrammaticalErrors(wordMLPackage, factory);
if(doc.getReadOnly()) {
setReadOnly(wordMLPackage, factory);
}
if(doc.getDebugger()){
System.out.println(XmlUtils.marshaltoString(wordMLPackage.getMainDocumentPart().getContents(), true, true));
}
return wordMLPackage;
}
/**
*
* @param xml
* @param templateFile
* @return
* @throws Exception
*/
public static WordprocessingMLPackage createWord(String xml,File templateFile) throws Exception{
Document doc = unmarshalXML(xml);
return createWord(doc,templateFile);
}
private static Document unmarshalXML(String xml) throws JAXBException,FileNotFoundException {
JAXBContext jaxbContext = JAXBContext.newInstance(Document.class);
Unmarshaller unmarshaller = jaxbContext.createUnmarshaller();
Document doc = (Document) unmarshaller.unmarshal(new StringReader(xml));
return doc;
}
/**
* 功能描述:创建chunk对象
* @throws Exception
*/
public static void createChunk(MainDocumentPart mdp, AltChunk chunk) throws Exception{
String html = chunk.getText(),type = chunk.getType();
if(html!=null&&type!=null){
StringBuilder sb = new StringBuilder();
sb.append("<html><body>").append(html).append("</body></html>");
AltChunkType altType = null;
if("html".equals(type)){
altType = AltChunkType.Html;
}
if(altType!=null) mdp.addAltChunk(altType, sb.toString().getBytes());
}
}
/**
* 功能描述:创建文档处理包对象
* @return 返回值:返回文档处理包对象
* @throws Exception
*/
public static WordprocessingMLPackage createWordprocessingMLPackage(Document doc) throws Exception {
WordprocessingMLPackage wordMLPackage = WordprocessingMLPackage.createPackage(PageSizePaper.valueOf(doc.getPageSize()),doc.getLandscape());
NumberingDefinitionsPart ndp = new NumberingDefinitionsPart();
wordMLPackage.getMainDocumentPart().addTargetPart(ndp);
String numbering = initialNumbering;
NumberingChunk nc = doc.getNumberingChunk();
if(nc!=null){
if(nc.getText()!=null) numbering = nc.getText();
}
ndp.setJaxbElement( (Numbering) XmlUtils.unmarshalString(numbering));
putObject(KEY_NUMBERING_DEFINITION_PART, ndp);
return wordMLPackage;
}
/**
* 功能描述:获取文档的可用宽度
* @param wordPackage 文档处理包对象
* @return 返回值:返回值文档的可用宽度
* @throws Exception
*/
public static int getWritableWidth(WordprocessingMLPackage wordPackage)throws Exception{
return wordPackage.getDocumentModel().getSections().get(0).getPageDimensions().getWritableWidthTwips();
}
/**
* createTable
*
* @param wordMLPackage
* @param factory
* @param table
* @return
* @throws Exception
*/
public static Tbl createTable(WordprocessingMLPackage wordMLPackage, ObjectFactory factory, Table table) throws Exception{
// SectPr docSectPr = wordMLPackage.getMainDocumentPart().getContents().getBody().getSectPr();
// int pageWidth = docSectPr.getPgSz().getW().intValue();
Tbl tbl = factory.createTbl();
TblPr tblPr = factory.createTblPr();
tbl.setTblPr(tblPr);
if(table.getIndLeft()!=null){
TblWidth w = factory.createTblWidth();
w.setType("dxa");
w.setW(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(table.getIndLeft()*10)));
tblPr.setTblInd(w);
}
if(table.getWidth()!=null){
TblWidth w = factory.createTblWidth();
w.setType("dxa");
w.setW(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(table.getWidth()*10)));
tblPr.setTblW(w);
}
Jc jc = factory.createJc();
jc.setVal(JcEnumeration.fromValue(table.getAlign()));
tblPr.setJc(jc);
Boolean isBorder = table.getBorder();
if(isBorder) {
TblStyle tblStyle = factory.createCTTblPrBaseTblStyle();
tblStyle.setVal("TableGrid");
tblPr.setTblStyle(tblStyle);
}
int columnSize = 0;
List list = null;
for (TableTr tblTr : table.getTrs()) {
Tr tr = factory.createTr();
tbl.getContent().add(tr);
TrPr trPr = factory.createTrPr();
CTHeight ctHeight = new CTHeight();
ctHeight.setVal(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(tblTr.getHeight()*10)));
ctHeight.setHRule(STHeightRule.AT_LEAST);
JAXBElement<CTHeight> trHeightElement = factory.createCTTrPrBaseTrHeight(ctHeight);
trPr.getCnfStyleOrDivIdOrGridBefore().add(trHeightElement);
tr.setTrPr(trPr);
if(tblTr.getTcs().size()>columnSize) {
columnSize = tblTr.getTcs().size();
list = tblTr.getTcs();
}
for (TableTc tblTc : tblTr.getTcs()) {
Tc tc = factory.createTc();
tr.getContent().add(tc);
TcPr tcPr = factory.createTcPr();
if(tblTc.getBorders().size()>0){
TcBorders tcB = factory.createTcPrInnerTcBorders();
tcPr.setTcBorders(tcB);
for (TableTcBorder border : tblTc.getBorders()) {
CTBorder ctborder = factory.createCTBorder();
ctborder.setVal(STBorder.fromValue(border.getStyle()));
ctborder.setSz(new BigInteger(border.getSize()));
ctborder.setColor(border.getColor());
String type = border.getType();
if("top".equalsIgnoreCase(type)){
tcB.setTop(ctborder);
}else if("bottom".equalsIgnoreCase(type)){
tcB.setBottom(ctborder);
}else if("left".equalsIgnoreCase(type)){
tcB.setLeft(ctborder);
}else if("right".equalsIgnoreCase(type)){
tcB.setRight(ctborder);
}else if("tl2br".equalsIgnoreCase(type)){
tcB.setTl2Br(ctborder);
}else if("tr2bl".equalsIgnoreCase(type)){
tcB.setTr2Bl(ctborder);
}
}
}
if(tblTc.getWidth()!=null){
tc.setTcPr(tcPr);
TblWidth cellWidth = factory.createTblWidth();
tcPr.setTcW(cellWidth);
cellWidth.setType("dxa");
cellWidth.setW(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(tblTc.getWidth()*10)));
}
String fill = tblTc.getFill();
if(fill!=null){
CTShd shd = factory.createCTShd();
shd.setVal(STShd.CLEAR);
shd.setColor("auto");
shd.setFill(fill);
tcPr.setShd(shd);
}
Integer span = tblTc.getSpan();
if(span!=null){
GridSpan gs = factory.createTcPrInnerGridSpan();
gs.setVal(new BigInteger(span.toString()));
tcPr.setGridSpan(gs);
}
String vMerge = tblTc.getVMerge();
if(vMerge!=null){
VMerge vm = factory.createTcPrInnerVMerge();
vm.setVal(vMerge);
tcPr.setVMerge(vm);
}
String vAlign = tblTc.getVAlign();
if(vAlign!=null){
CTVerticalJc vjc = factory.createCTVerticalJc();
vjc.setVal(STVerticalJc.fromValue(vAlign));
tcPr.setVAlign(vjc);
}
tc.setTcPr(tcPr);
for (Object obj : tblTc.getParas()) {
if(obj instanceof Paragraph) {
tc.getContent().add(WordUtils.createPara(wordMLPackage,factory,(Paragraph)obj));
}else if(obj instanceof PermStart){
permId = new java.util.Random().nextInt();
RangePermissionStart start = factory.createRangePermissionStart();
start.setId(String.valueOf(permId));
start.setEdGrp("everyone");
tc.getContent().add(start);
}else if(obj instanceof PermEnd){
CTPerm end = factory.createCTPerm();
end.setId(String.valueOf(permId));
tc.getContent().add(end);
}
}
}
}
if(list!=null){
TblGrid tblGrid = factory.createTblGrid();
Iterator it = list.iterator();
while(it.hasNext()){
TableTc tblTc = (TableTc)it.next();
TblGridCol col = factory.createTblGridCol();
if(tblTc.getWidth()!=null){
col.setW(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(tblTc.getWidth()*10)));
}
tblGrid.getGridCol().add(col);
}
tbl.setTblGrid(tblGrid);
}
return tbl;
}
public static int findToc(List<Object> paras) {
int i = 0;
for (Object obj : paras) {
if(obj instanceof Toc) {
return i;
}
i++;
}
return -1;
}
public static R createImage(WordprocessingMLPackage wordprocessingMLPackage, ObjectFactory factory, Part part, byte[] bytes) throws Exception {
BinaryPartAbstractImage imagePart;
if(part!=null) {
imagePart = BinaryPartAbstractImage.createImagePart(wordprocessingMLPackage,part, bytes);
}else {
imagePart = BinaryPartAbstractImage.createImagePart(wordprocessingMLPackage, bytes);
}
Inline inline = imagePart.createImageInline(null, null, 0, 1, false);
// Now add the inline in w:p/w:r/w:drawing
R run = factory.createR();
Drawing drawing = factory.createDrawing();
run.getContent().add(drawing);
drawing.getAnchorOrInline().add(inline);
return run;
}
public static R createImage(WordprocessingMLPackage wordprocessingMLPackage, ObjectFactory factory, Part part, File file) throws Exception {
if(file == null || !file.exists()){
R run = factory.createR();
RPr rpr = factory.createRPr();
run.setRPr(rpr);
Color color = new Color();
color.setVal("#ff0000");
rpr.setColor(color);
org.docx4j.wml.Text t = factory.createText();
t.setValue("("+file.getAbsolutePath()+")该链接地址图片文件已丢失!");
run.getContent().add(t);
return run;
}
InputStream is = null;
long length = file.length();
if (length > Integer.MAX_VALUE) {
System.out.println("File too large!!");
}
byte[] bytes = new byte[(int)length];
int offset = 0,numRead = 0;
try {
is = new FileInputStream(file);
while (offset < bytes.length && (numRead=is.read(bytes, offset, bytes.length-offset)) >= 0) {
offset += numRead;
}
// Ensure all the bytes have been read in
if (offset < bytes.length) {
System.out.println("Could not completely read file "+file.getName());
}
} finally{
if(is!=null) is.close();
}
return createImage(wordprocessingMLPackage,factory,part,bytes);
}
public static JAXBElement getWrappedFldChar(FldChar fldchar) {
return new JAXBElement(new QName(Namespaces.NS_WORD12, "fldChar"),FldChar.class, fldchar);
}
public static Hyperlink createHyperlink(String name, String anchor) throws JAXBException {
String hpl = "<w:hyperlink xmlns:w=\"http://schemas.openxmlformats.org/wordprocessingml/2006/main\" w:anchor=\""+anchor+"\"><w:r><w:rPr><w:rFonts w:hint=\"eastAsia\" w:ascii=\"SimSun\" w:hAnsi=\"SimSun\"/><w:color w:val=\"000000\"/><w:sz w:val=\"24\"/><w:szCs w:val=\"24\"/></w:rPr><w:t>"+name+"</w:t></w:r><w:r> <w:tab /> </w:r><w:fldSimple w:instr=\"PAGEREF "+anchor+"\"> <w:r> <w:t></w:t> </w:r> </w:fldSimple> </w:hyperlink>";
return (Hyperlink)XmlUtils.unmarshalString(hpl);
}
public static P createTOCHead(ObjectFactory factory){
P p = factory.createP();
org.docx4j.wml.Text t = factory.createText();
t.setValue("目 录");
R run = factory.createR();
run.getContent().add(t);
Jc jc = factory.createJc();
jc.setVal(JcEnumeration.CENTER);
PPr ppr = factory.createPPr();
ppr.setJc(jc);
p.setPPr(ppr);
RPr rPr = factory.createRPr();
RFonts rf = new RFonts();
rf.setHint(STHint.EAST_ASIA);
rf.setAscii("SimSun");
rf.setHAnsi("SimSun");
rPr.setRFonts(rf);
HpsMeasure sz = new HpsMeasure();
sz.setVal(new BigInteger("36"));
rPr.setSz(sz);
rPr.setSzCs(sz);
BooleanDefaultTrue bdt = Context.getWmlObjectFactory().createBooleanDefaultTrue();
rPr.setBCs(bdt);
rPr.setB(bdt);
run.setRPr(rPr);
p.getContent().add(run);
return p;
}
public static P createTOCStart(ObjectFactory factory){
P p1 = factory.createP();
R r11 = factory.createR();
FldChar fldchar = factory.createFldChar();
fldchar.setFldCharType(STFldCharType.BEGIN);
r11.getContent().add(WordUtils.getWrappedFldChar(fldchar));
p1.getContent().add(r11);
R r12 = factory.createR();
org.docx4j.wml.Text txt = new org.docx4j.wml.Text();
txt.setSpace("preserve");
txt.setValue("TOC \\o \"1-3\" \\h \\z \\u \\n");
r12.getContent().add(factory.createRInstrText(txt));
p1.getContent().add(r12);
R r13 = factory.createR();
FldChar fldchar2 = factory.createFldChar();
fldchar2.setFldCharType(STFldCharType.SEPARATE);
r13.getContent().add(WordUtils.getWrappedFldChar(fldchar2));
p1.getContent().add(r13);
return p1;
}
public static P createTOCEnd(ObjectFactory factory){
P p3 = factory.createP();
R r3 = factory.createR();
FldChar fldchar3 = factory.createFldChar();
fldchar3.setFldCharType(STFldCharType.END);
r3.getContent().add(WordUtils.getWrappedFldChar(fldchar3));
p3.getContent().add(r3);
return p3;
}
public static P createTOC(ObjectFactory factory, Map<String,String> map) throws JAXBException {
P p = factory.createP();
PPr ppr = factory.createPPr();
Tabs tabs = factory.createTabs();
CTTabStop cttab = factory.createCTTabStop();
cttab.setVal(STTabJc.RIGHT);
cttab.setLeader(STTabTlc.DOT);
cttab.setPos(new BigInteger("9350"));//TODO:page width ?
tabs.getTab().add(cttab);
ppr.setTabs(tabs);
p.setPPr(ppr);
String title = map.get(Toc.TOC_TITLE);
String bookmark = map.get(Toc.TOC_BOOKMARK);
Hyperlink link = createHyperlink(title,bookmark);
p.getContent().add(link);
return p;
}
public static P createPageBreak(ObjectFactory factory){
Br breakObj = new Br();
breakObj.setType(STBrType.PAGE);
P p = factory.createP();
R run = factory.createR();
run.getContent().add(breakObj);
p.getContent().add(run);
return p;
}
/**
* Surround the specified r in the specified p with a bookmark (with specified name and id)
*/
private static void bookmarkRun(P p, R r, String name, int id) {
// Find the index
int index = p.getContent().indexOf(r);
if (index < 0) {
System.out.println("P does not contain R!");
return;
}
ObjectFactory factory = Context.getWmlObjectFactory();
BigInteger ID = BigInteger.valueOf(id);
// Add bookmark end first
CTMarkupRange mr = factory.createCTMarkupRange();
mr.setId(ID);
JAXBElement<CTMarkupRange> bmEnd = factory.createBodyBookmarkEnd(mr);
p.getContent().add(index + 1, bmEnd);
// Next, bookmark start
CTBookmark bm = factory.createCTBookmark();
bm.setId(ID);
bm.setName(name);
JAXBElement<CTBookmark> bmStart = factory.createBodyBookmarkStart(bm);
p.getContent().add(index, bmStart);
}
public static P createPara(WordprocessingMLPackage wordprocessingMLPackage, ObjectFactory factory, Paragraph para) throws Exception{
return createPara(wordprocessingMLPackage,factory,null,para);
}
public static P createPara(WordprocessingMLPackage wordprocessingMLPackage, ObjectFactory factory, Part part, Paragraph para) throws Exception{
P p = factory.createP();
Float indfirstLineChars = para.getIndFirstLineChars();
Float indFirstLine = para.getIndFirstLine();
Float indLeft = para.getIndLeft();
String align = para.getAlign();
PPr ppr = factory.createPPr();
PPrBase.Spacing spacing = factory.createPPrBaseSpacing();
spacing.setAfter(new BigInteger(para.getAfter()));
ppr.setSpacing(spacing);
String pageBreakBefore = para.getPageBreakBefore();
if("true".equals(pageBreakBefore)){
BooleanDefaultTrue pageBreakBeforeOn = factory.createBooleanDefaultTrue();
pageBreakBeforeOn.setVal(Boolean.TRUE);
ppr.setPageBreakBefore(pageBreakBeforeOn);
}
//左悬挂 首行悬挂
if(indFirstLine!=null || indLeft !=null || indfirstLineChars!=null){
PPrBase.Ind ind = factory.createPPrBaseInd();
if(indLeft != null ) {
ind.setLeft(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(indLeft*10)));
}
if(indFirstLine != null ) {
ind.setFirstLine(BigInteger.valueOf(UnitsOfMeasurement.mmToTwip(indFirstLine*10)));
}
if(indfirstLineChars != null ) {
// indfirstLineChars = indfirstLineChars;//字符
ind.setFirstLineChars(BigInteger.valueOf(indfirstLineChars.intValue()));
}
ppr.setInd(ind);
}
SectPr docSectPr = wordprocessingMLPackage.getMainDocumentPart().getContents().getBody().getSectPr();
BigInteger pageWidth = docSectPr.getPgSz().getW();
BigInteger pageHeight = docSectPr.getPgSz().getH();
String orientation = para.getOrientation();
SectPr sectPr = null;
if(orientation!=null){
sectPr = factory.createSectPr();
SectPr.PgSz pgSz = factory.createSectPrPgSz();
if("portrait".equals(orientation)){
pgSz.setW(pageWidth);
pgSz.setH(pageHeight);
pgSz.setOrient(STPageOrientation.fromValue("portrait"));
sectPr.setPgSz(pgSz);
}else if("landscape".equals(orientation)){
pgSz.setW(pageHeight);
pgSz.setH(pageWidth);
pgSz.setOrient(STPageOrientation.fromValue("landscape"));
sectPr.setPgSz(pgSz);
}
//TODO:pageMargin
}
BigInteger colsNum = para.getColsNum();
if(colsNum!=null){
if(sectPr == null) sectPr = factory.createSectPr();
CTColumns ctc = factory.createCTColumns();
ctc.setNum(colsNum);
Double colsSpace = para.getColsSpace();
if(colsSpace!=null) {
//colsSpace *= TWIP_CENTIMETER;
ctc.setSpace(BigInteger.valueOf(colsSpace.intValue()));
}
sectPr.setPgSz(docSectPr.getPgSz());
sectPr.setPgMar(docSectPr.getPgMar());
sectPr.setDocGrid(docSectPr.getDocGrid());
sectPr.setCols(ctc);
String type = para.getSectPrType();
if(type!=null){
SectPr.Type t = new SectPr.Type();
t.setVal(type);
sectPr.setType(t);
}
}
if(sectPr!=null){
sectPr.getEGHdrFtrReferences().addAll(docSectPr.getEGHdrFtrReferences());
ppr.setSectPr(sectPr);
}
Long numId = para.getNumId();
Long ilvl = para.getIlvl();
if(numId!=null && ilvl !=null){
Long runNumId = (Long)getObject(KEY_RUN_NUMID);
if(runNumId==null){
runNumId = numId;
putObject(KEY_RUN_NUMID, new Long(1));
}
if(numId > runNumId){
NumberingDefinitionsPart ndp = (NumberingDefinitionsPart)getObject(KEY_NUMBERING_DEFINITION_PART);
long rid =0;
for(;rid<numId;){
rid=ndp.restart(runNumId, 0, 1);
}
putObject(KEY_RUN_NUMID, numId);
}
// Create and add <w:numPr>
NumPr numPr = factory.createPPrBaseNumPr();
ppr.setNumPr(numPr);
// The <w:ilvl> element
Ilvl ilvlElement = factory.createPPrBaseNumPrIlvl();
numPr.setIlvl(ilvlElement);
ilvlElement.setVal(BigInteger.valueOf(ilvl));
// The <w:numId> element
NumId numIdElement = factory.createPPrBaseNumPrNumId();
numPr.setNumId(numIdElement);
numIdElement.setVal(BigInteger.valueOf(numId));
}
//align
if(align!=null){
Jc jc = factory.createJc();
jc.setVal(JcEnumeration.fromValue(align));
ppr.setJc(jc);
}
p.setPPr(ppr);
List<Object> objs = para.getObjects();
int i = 0;
boolean hasImg = false;
for(Object obj:objs){
if(obj instanceof Text){
Text text = (Text)obj;
if(text.getFldCharType()){
addFieldBegin(factory,p);
}
R run = createRun(factory,text);
p.getContent().add(run);
if(text.getFldCharType()){
addFieldEnd(factory,p);
}
if(para.getToc()){
bookmarkRun(p,run,para.getTocBookMark(),1);
}
}else if(obj instanceof PTab) {
PTab ptab = (PTab)obj;
R run = factory.createR();
Ptab pt = factory.createRPtab();
pt.setRelativeTo(STPTabRelativeTo.fromValue(ptab.getRelativeTo()));
pt.setAlignment(STPTabAlignment.fromValue(ptab.getAlignment()));
pt.setLeader(STPTabLeader.fromValue(ptab.getLeader()));
run.getContent().add(pt);
p.getContent().add(run);
}else if(obj instanceof PBdr) {
PBdr pbdr = (PBdr)obj;
PPrBase.PBdr pdr = factory.createPPrBasePBdr();
ppr.setPBdr(pdr);
createPDBorder(factory,pdr,pbdr.getTop());
createPDBorder(factory,pdr,pbdr.getBottom());
createPDBorder(factory,pdr,pbdr.getRight());
createPDBorder(factory,pdr,pbdr.getLeft());
}else if(obj instanceof Image){
hasImg = true;
Image img = (Image)obj;
File file = null;
if(Image.PATH_TYPE_RELATIVE.equals(img.getType())){
File folder = (File)getObject(KEY_TEMPLATE_FILE);
file = folder == null ? new File(img.getSrc()) : new File(folder.getParent(),img.getSrc());
p.getContent().add(WordUtils.createImage(wordprocessingMLPackage, factory,part, file));
} else if(Image.PATH_TYPE_ABSOLUTE.equals(img.getType())) {
file = new File(img.getSrc());
p.getContent().add(WordUtils.createImage(wordprocessingMLPackage, factory,part, file));
} else if(Image.PATH_TYPE_URL.equals(img.getType())) {
file = File.createTempFile("url_img", ".tmp");
try{
FileUtils.copyURLToFile(new URL(img.getSrc()), file);
p.getContent().add(WordUtils.createImage(wordprocessingMLPackage, factory,part, file));
}finally {
FileUtils.forceDelete(file);
}
}
}else if(obj instanceof QRCode){
hasImg = true;
QRCode qrcode = (QRCode)obj;
String format = "jpg";
HashMap hints = new HashMap();
hints.put(EncodeHintType.CHARACTER_SET, "UTF-8");
hints.put(EncodeHintType.ERROR_CORRECTION, ErrorCorrectionLevel.valueOf(qrcode.getErrorCorrection()));
hints.put(EncodeHintType.MARGIN,1);
BitMatrix bitMatrix = new MultiFormatWriter().encode(qrcode.getText(), BarcodeFormat.QR_CODE, qrcode.getWidth(), qrcode.getHeight(), hints);
File file = File.createTempFile("qrcode", ".tmp");
try{
QRCodeWriter.writeToFile(bitMatrix, format, file);
p.getContent().add(WordUtils.createImage(wordprocessingMLPackage, factory, part, file));
}finally {
FileUtils.forceDelete(file);
}
}else if(obj instanceof PermStart){
permId = new java.util.Random().nextInt();
RangePermissionStart start = factory.createRangePermissionStart();
start.setId(String.valueOf(permId));
start.setEdGrp("everyone");
p.getContent().add(start);
}else if(obj instanceof PermEnd){
CTPerm end = factory.createCTPerm();
end.setId(String.valueOf(permId));
p.getContent().add(end);
}
i++;
}
if(!hasImg){
String line = para.getLine();
String lineRule = para.getLineRule();
if(line!=null){
spacing.setLine(new BigInteger(line));
spacing.setLineRule(STLineSpacingRule.fromValue(lineRule));
}
BigInteger beforeLines = para.getBeforeLines();
if(beforeLines!=null){
spacing.setBeforeLines(beforeLines);
}
BigInteger afterLines = para.getAfterLines();
if(afterLines!=null){
spacing.setAfterLines(afterLines);
}
}
return p;
}
private static void createPDBorder(ObjectFactory factory,PPrBase.PBdr pdr, Object obj){
if(obj==null)return;
CTBorder ctborder = factory.createCTBorder();
PBdr.Border border = (PBdr.Border)obj;
ctborder.setVal(STBorder.fromValue(border.getValue()));
ctborder.setColor(border.getColor());
ctborder.setSz(new BigInteger(border.getSz()));
ctborder.setSpace(new BigInteger(border.getSpace()));
if(border instanceof PBdr.Top){
pdr.setTop(ctborder);
}else if(border instanceof PBdr.Left) {
pdr.setLeft(ctborder);
}else if(border instanceof PBdr.Right) {
pdr.setRight(ctborder);
}else if(border instanceof PBdr.Bottom) {
pdr.setBottom(ctborder);
}
}
public static R createRun(ObjectFactory factory, Text text){
R run = factory.createR();
RPr rpr = factory.createRPr();;
Boolean isBold = text.isBold();
if(isBold){
BooleanDefaultTrue bdt = Context.getWmlObjectFactory().createBooleanDefaultTrue();
rpr.setBCs(bdt);
rpr.setB(bdt);
}
String fontFamily = text.getFontFamily();
RFonts rf = new RFonts();
rf.setHint(STHint.EAST_ASIA);
rf.setEastAsia(fontFamily);
rf.setAscii(fontFamily);
rf.setHAnsi(fontFamily);
rpr.setRFonts(rf);
Boolean italic = text.isItalic();
if(italic){
BooleanDefaultTrue bdt = Context.getWmlObjectFactory().createBooleanDefaultTrue();
rpr.setI(bdt);
}
Color color = new Color();
color.setVal(text.getFontColor());
rpr.setColor(color);
HpsMeasure sz = new HpsMeasure();
sz.setVal(new BigInteger(text.getFontSize()));
rpr.setSz(sz);
rpr.setSzCs(sz);
String underline = text.getUnderline();
if(underline!=null){
U u = factory.createU();
u.setVal(UnderlineEnumeration.fromValue(underline));
rpr.setU(u);
}
run.setRPr(rpr);
org.docx4j.wml.Text t = factory.createText();
String space = text.getSpace();
if(space != null){
t.setSpace(space);
}
t.setValue(text.getText());
run.getContent().add(t);
return run;
}
// private static PPr createPPr(ObjectFactory factory,PPr ppr){
// if(ppr == null){
// ppr = factory.createPPr();
// }
// return ppr;
// }
public static CTSettings createSettings(ObjectFactory factory,WordprocessingMLPackage wordprocessingMLPackage, Settings st) throws Exception{
CTSettings settings = factory.createCTSettings();
String characterSpacingControl = st.getCharacterSpacingControl();
if(characterSpacingControl!=null){
CTCharacterSpacing characterspacing = factory.createCTCharacterSpacing();
settings.setCharacterSpacingControl(characterspacing);
characterspacing.setVal(STCharacterSpacing.fromValue(characterSpacingControl));
}
Boolean hideSpellingErrors = st.getHideSpellingErrors();
if(hideSpellingErrors == true) settings.setHideSpellingErrors(Context.getWmlObjectFactory().createBooleanDefaultTrue());
Boolean hideGrammaticalErrors = st.getHideGrammaticalErrors();
if(hideGrammaticalErrors == true) settings.setHideGrammaticalErrors(Context.getWmlObjectFactory().createBooleanDefaultTrue());
BigInteger drawingGridHorizontalSpacing = st.getDrawingGridHorizontalSpacing();
if(drawingGridHorizontalSpacing!=null) {
CTTwipsMeasure dghs = factory.createCTTwipsMeasure();
dghs.setVal(drawingGridHorizontalSpacing);
settings.setDrawingGridHorizontalSpacing(dghs);
}
BigInteger drawingGridVerticalSpacing = st.getDrawingGridVerticalSpacing();
if(drawingGridVerticalSpacing!=null) {
CTTwipsMeasure dgvs = factory.createCTTwipsMeasure();
dgvs.setVal(drawingGridVerticalSpacing);
settings.setDrawingGridVerticalSpacing(dgvs);
}
BigInteger displayHorizontalDrawingGridEvery = st.getDisplayHorizontalDrawingGridEvery();
if(displayHorizontalDrawingGridEvery!=null) {
DisplayHorizontalDrawingGridEvery dhdge = factory.createCTSettingsDisplayHorizontalDrawingGridEvery();
dhdge.setVal(displayHorizontalDrawingGridEvery);
settings.setDisplayHorizontalDrawingGridEvery(dhdge);
}
BigInteger displayVerticalDrawingGridEvery = st.getDisplayVerticalDrawingGridEvery();
if(displayVerticalDrawingGridEvery!=null) {
DisplayVerticalDrawingGridEvery dvdge = factory.createCTSettingsDisplayVerticalDrawingGridEvery();
dvdge.setVal(displayVerticalDrawingGridEvery);
settings.setDisplayVerticalDrawingGridEvery(dvdge);
}
return settings;
}
/**
* add Header
*
* @param factory
* @param wordprocessingMLPackage
* @param para
* @throws Exception
*/
public static HeaderPart addHeader(ObjectFactory factory,WordprocessingMLPackage wordprocessingMLPackage, Paragraph para) throws Exception{
HeaderPart headerPart = new HeaderPart();
headerPart.setPackage(wordprocessingMLPackage);
Hdr hdr = factory.createHdr();
hdr.getContent().add(createPara(wordprocessingMLPackage,factory,headerPart,para));
headerPart.setJaxbElement(hdr);
Relationship relationship = wordprocessingMLPackage.getMainDocumentPart().addTargetPart(headerPart);
List<SectionWrapper> sections = wordprocessingMLPackage.getDocumentModel().getSections();
SectPr sectPr = sections.get(sections.size() - 1).getSectPr();
if (sectPr==null ) {
sectPr = factory.createSectPr();
wordprocessingMLPackage.getMainDocumentPart().addObject(sectPr);
sections.get(sections.size() - 1).setSectPr(sectPr);
}
HeaderReference headerReference = factory.createHeaderReference();
headerReference.setId(relationship.getId());
headerReference.setType(HdrFtrRef.DEFAULT);
sectPr.getEGHdrFtrReferences().add(headerReference);
return headerPart;
}
/**
* add Footer
*
* @param factory
* @param wordprocessingMLPackage
* @param para
* @throws Exception
*/
public static void addFooter(ObjectFactory factory,WordprocessingMLPackage wordprocessingMLPackage, Paragraph para) throws Exception{
FooterPart footer = new FooterPart();
footer.setPackage(wordprocessingMLPackage);
Ftr ftr = factory.createFtr();
P p = null;
if(para!=null){
p = createPara(wordprocessingMLPackage,factory,footer,para);
}else {
p = factory.createP();
addFieldBegin(factory,p);
Jc jc = factory.createJc();
jc.setVal(JcEnumeration.CENTER);
PPr ppr = factory.createPPr();
ppr.setJc(jc);
p.setPPr(ppr);
R run = factory.createR();
org.docx4j.wml.Text txt = new org.docx4j.wml.Text();
txt.setSpace("preserve");
txt.setValue(" PAGE \\* MERGEFORMAT ");
run.getContent().add(factory.createRInstrText(txt));
p.getContent().add(run);
addFieldEnd(factory,p);
}
ftr.getContent().add(p);
footer.setJaxbElement(ftr);
Relationship relationship = wordprocessingMLPackage.getMainDocumentPart().addTargetPart(footer);
List<SectionWrapper> sections = wordprocessingMLPackage.getDocumentModel().getSections();
SectPr sectPr = sections.get(sections.size() - 1).getSectPr();
if (sectPr==null ) {
sectPr = factory.createSectPr();
wordprocessingMLPackage.getMainDocumentPart().addObject(sectPr);
sections.get(sections.size() - 1).setSectPr(sectPr);
}
FooterReference footerReference = factory.createFooterReference();
footerReference.setId(relationship.getId());
footerReference.setType(HdrFtrRef.DEFAULT);
sectPr.getEGHdrFtrReferences().add(footerReference);
}
// /**
// * add Footer
// *
// * @param factory
// * @param wordprocessingMLPackage
// * @param para
// * @throws Exception
// */
// public static void addFooter(ObjectFactory factory,WordprocessingMLPackage wordprocessingMLPackage) throws Exception{
// FooterPart footer = new FooterPart(new PartName("/word/myfooter.xml"));
// footer.setPackage(wordprocessingMLPackage);
// Ftr ftr = factory.createFtr();
//
// P p = factory.createP();
// addFieldBegin(factory,p);
//
//
// org.docx4j.wml.Jc jc = factory.createJc();
// jc.setVal(JcEnumeration.CENTER);
// PPr ppr = factory.createPPr();
// ppr.setJc(jc);
// p.setPPr(ppr);
//
// R run = factory.createR();
// org.docx4j.wml.Text txt = new org.docx4j.wml.Text();
// txt.setSpace("preserve");
// txt.setValue(" PAGE \\* MERGEFORMAT ");
// run.getContent().add(factory.createRInstrText(txt));
// p.getContent().add(run);
// addFieldEnd(factory,p);
//
// ftr.getContent().add(p);
// footer.setJaxbElement(ftr);
//
// Relationship relationship = wordprocessingMLPackage.getMainDocumentPart().addTargetPart(footer);
// List<SectionWrapper> sections = wordprocessingMLPackage.getDocumentModel().getSections();
//
// SectPr sectPr = sections.get(sections.size() - 1).getSectPr();
// if (sectPr==null ) {
// sectPr = factory.createSectPr();
// wordprocessingMLPackage.getMainDocumentPart().addObject(sectPr);
// sections.get(sections.size() - 1).setSectPr(sectPr);
// }
//
// FooterReference footerReference = factory.createFooterReference();
// footerReference.setId(relationship.getId());
// footerReference.setType(HdrFtrRef.DEFAULT);
// sectPr.getEGHdrFtrReferences().add(footerReference);
// }
/**
* Every fields needs to be delimited by complex field characters. This method
* adds the delimiter that precedes the actual field to the given paragraph.
* @param paragraph
*/
private static void addFieldBegin(ObjectFactory factory,P paragraph) {
R run = factory.createR();
FldChar fldchar = factory.createFldChar();
fldchar.setFldCharType(STFldCharType.BEGIN);
run.getContent().add(fldchar);
paragraph.getContent().add(run);
}
/**
* Every fields needs to be delimited by complex field characters. This method
* adds the delimiter that follows the actual field to the given paragraph.
* @param paragraph
*/
private static void addFieldEnd(ObjectFactory factory,P paragraph) {
FldChar fldcharend = factory.createFldChar();
fldcharend.setFldCharType(STFldCharType.END);
R run3 = factory.createR();
run3.getContent().add(fldcharend);
paragraph.getContent().add(run3);
}
/**
* Add watermark
* @param factory
* @param wordprocessingMLPackage
* @param watermark
* @throws Exception
*/
public static void addWaterMark(HeaderPart headerPart, ObjectFactory factory,WordprocessingMLPackage wordprocessingMLPackage,String watermark) throws Exception{
boolean createHeaderPart = headerPart == null;
Relationship relationship = null;
Hdr hdr = null;
if(createHeaderPart){
headerPart = new HeaderPart();
hdr = factory.createHdr();
headerPart.setJaxbElement(hdr);
relationship = wordprocessingMLPackage.getMainDocumentPart().addTargetPart(headerPart);
}else {
hdr = headerPart.getContents();
}
addWaterMarkToP(hdr,factory,wordprocessingMLPackage, headerPart,watermark);
List<SectionWrapper> sections = wordprocessingMLPackage.getDocumentModel().getSections();
SectPr sectPr = sections.get(sections.size() - 1).getSectPr();
// There is always a section wrapper, but it might not contain a sectPr
if (sectPr==null ) {
sectPr = factory.createSectPr();
wordprocessingMLPackage.getMainDocumentPart().addObject(sectPr);
sections.get(sections.size() - 1).setSectPr(sectPr);
}
if(createHeaderPart){
HeaderReference headerReference = factory.createHeaderReference();
headerReference.setId(relationship.getId());
headerReference.setType(HdrFtrRef.DEFAULT);
sectPr.getEGHdrFtrReferences().add(headerReference);
}
}
public static byte[] encrypt(String content, String password) {
try {
KeyGenerator kgen = KeyGenerator.getInstance("AES");
kgen.init(128);
// kgen.init(128, new SecureRandom(password.getBytes()));
SecretKey secretKey = kgen.generateKey();
byte[] enCodeFormat = secretKey.getEncoded();
SecretKeySpec key = new SecretKeySpec(enCodeFormat, "AES");
Cipher cipher = Cipher.getInstance("AES");// 创建密码器
byte[] byteContent = content.getBytes("utf-8");
cipher.init(Cipher.ENCRYPT_MODE, key);// 初始化
byte[] result = cipher.doFinal(byteContent);
return result; // 加密
} catch (NoSuchAlgorithmException e) {
e.printStackTrace();
} catch (NoSuchPaddingException e) {
e.printStackTrace();
} catch (InvalidKeyException e) {
e.printStackTrace();
} catch (UnsupportedEncodingException e) {
e.printStackTrace();
} catch (IllegalBlockSizeException e) {
e.printStackTrace();
} catch (BadPaddingException e) {
e.printStackTrace();
}
return null;
}
/**
* 功能描述:设置文档是否只读,包括内容和样式
* @param wordPackage 文档处理包对象
* @param isReadOnly 是否只读
* @throws Exception
*
*/
public static void setReadOnly(WordprocessingMLPackage wordPackage , ObjectFactory factory)throws Exception{
byte[] bt = "handhand".getBytes();
//创建设置文档对象
//创建文档保护对象
CTDocProtect cp = factory.createCTDocProtect();
//设置加密方式
cp.setCryptProviderType(STCryptProv.RSA_AES);
cp.setCryptAlgorithmClass(STAlgClass.HASH);
//设置任何用户
cp.setCryptAlgorithmType(STAlgType.TYPE_ANY);
cp.setCryptAlgorithmSid(new BigInteger("4"));
cp.setCryptSpinCount(new BigInteger("50000"));
//只读
cp.setEdit(STDocProtect.READ_ONLY);
cp.setHash(bt);
cp.setSalt(bt);
//设置内容不可编辑
cp.setEnforcement(true);
//设置格式不可编辑
cp.setFormatting(false);
DocumentSettingsPart dsp = wordPackage.getMainDocumentPart().getDocumentSettingsPart();
CTSettings settings = null;
if(dsp == null){
dsp = new DocumentSettingsPart();
settings = factory.createCTSettings();
settings.setDocumentProtection(cp);
dsp.setJaxbElement(settings);
wordPackage.getMainDocumentPart().addTargetPart(dsp);
}else {
settings = dsp.getContents();
settings.setDocumentProtection(cp);
}
}
private static void addWaterMarkToP(Hdr hdr, ObjectFactory factory, WordprocessingMLPackage wordprocessingMLPackage,Part sourcePart,String watermark) throws Exception {
String openXML = "<w:p xmlns:v=\"urn:schemas-microsoft-com:vml\" xmlns:w=\"http://schemas.openxmlformats.org/wordprocessingml/2006/main\" xmlns:o=\"urn:schemas-microsoft-com:office:office\" xmlns:w10=\"urn:schemas-microsoft-com:office:word\">"
// + "<w:pPr>"
// + "<w:pStyle w:val=\"Header\"/>"
// +"</w:pPr>"
+ "<w:sdt>"
+ "<w:sdtPr>"
+ "<w:id w:val=\"-1589924921\"/>"
+ "<w:lock w:val=\"sdtContentLocked\"/>"
+ "<w:docPartObj>"
+ "<w:docPartGallery w:val=\"Watermarks\"/>"
+ "<w:docPartUnique/>"
+"</w:docPartObj>"
+"</w:sdtPr>"
+ "<w:sdtEndPr/>"
+ "<w:sdtContent>"
+ "<w:r>"
+ "<w:rPr>"
+ "<w:noProof/>"
+ "<w:lang w:eastAsia=\"zh-TW\"/>"
+"</w:rPr>"
+ "<w:pict>"
+ "<v:shapetype adj=\"10800\" coordsize=\"21600,21600\" id=\"_x0000_t136\" o:spt=\"136\" path=\"m@7,l@8,m@5,21600l@6,21600e\">"
+ "<v:formulas>"
+ "<v:f eqn=\"sum #0 0 10800\"/>"
+ "<v:f eqn=\"prod #0 2 1\"/>"
+ "<v:f eqn=\"sum 21600 0 @1\"/>"
+ "<v:f eqn=\"sum 0 0 @2\"/>"
+ "<v:f eqn=\"sum 21600 0 @3\"/>"
+ "<v:f eqn=\"if @0 @3 0\"/>"
+ "<v:f eqn=\"if @0 21600 @1\"/>"
+ "<v:f eqn=\"if @0 0 @2\"/>"
+ "<v:f eqn=\"if @0 @4 21600\"/>"
+ "<v:f eqn=\"mid @5 @6\"/>"
+ "<v:f eqn=\"mid @8 @5\"/>"
+ "<v:f eqn=\"mid @7 @8\"/>"
+ "<v:f eqn=\"mid @6 @7\"/>"
+ "<v:f eqn=\"sum @6 0 @5\"/>"
+"</v:formulas>"
+ "<v:path o:connectangles=\"270,180,90,0\" o:connectlocs=\"@9,0;@10,10800;@11,21600;@12,10800\" o:connecttype=\"custom\" textpathok=\"t\"/>"
+ "<v:textpath fitshape=\"t\" on=\"t\"/>"
+ "<v:handles>"
+ "<v:h position=\"#0,bottomRight\" xrange=\"6629,14971\"/>"
+"</v:handles>"
+ "<o:lock shapetype=\"t\" text=\"t\" v:ext=\"edit\"/>"
+"</v:shapetype>"
+ "<v:shape fillcolor=\"silver\" id=\"PowerPlusWaterMarkObject357476642\" o:allowincell=\"f\" o:spid=\"_x0000_s2049\" stroked=\"f\" style=\"position:absolute;margin-left:0;margin-top:0;width:527.85pt;height:131.95pt;rotation:315;z-index:-251658752;mso-position-horizontal:center;mso-position-horizontal-relative:margin;mso-position-vertical:center;mso-position-vertical-relative:margin\" type=\"#_x0000_t136\">"
+ "<v:fill opacity=\".5\"/>"
+ "<v:textpath string=\""+watermark+"\" style=\"font-family:&quot;Calibri&quot;;font-size:1pt\"/>"
+ "<w10:wrap anchorx=\"margin\" anchory=\"margin\"/>"
+"</v:shape>"
+"</w:pict>"
+"</w:r>"
+"</w:sdtContent>"
+"</w:sdt>"
+ "</w:p>";
P wp = (P) XmlUtils.unmarshalString(openXML);
List list = hdr.getContent();
P p = null;
if(list!=null && list.size()>0){
p = (P)list.get(0);
}else {
p = factory.createP();
hdr.getContent().add(p);
}
if(p!=null) p.getContent().add(wp.getContent().get(0));
}
static final String initialNumbering = "<w:numbering xmlns:ve=\"http://schemas.openxmlformats.org/markup-compatibility/2006\" xmlns:o=\"urn:schemas-microsoft-com:office:office\" xmlns:r=\"http://schemas.openxmlformats.org/officeDocument/2006/relationships\" xmlns:m=\"http://schemas.openxmlformats.org/officeDocument/2006/math\" xmlns:v=\"urn:schemas-microsoft-com:vml\" xmlns:wp=\"http://schemas.openxmlformats.org/drawingml/2006/wordprocessingDrawing\" xmlns:w10=\"urn:schemas-microsoft-com:office:word\" xmlns:w=\"http://schemas.openxmlformats.org/wordprocessingml/2006/main\" xmlns:wne=\"http://schemas.microsoft.com/office/word/2006/wordml\">"
+ "<w:abstractNum w:abstractNumId=\"0\">"
+ "<w:nsid w:val=\"2DD860C0\"/>"
+ "<w:multiLevelType w:val=\"multilevel\"/>"
+ "<w:tmpl w:val=\"0409001D\"/>"
+ "<w:lvl w:ilvl=\"0\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"decimal\"/>"
+ "<w:lvlText w:val=\"%1\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"420\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"420\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "<w:rPr>"
+ "<w:b/>"
+ "<w:rFonts w:hint=\"eastAsia\" w:ascii=\"SimSun\" w:hAnsi=\"SimSun\"/>"
+ "<w:color w:val=\"auto\"/>"
+ "<w:sz w:val=\"24\"/>"
+ "<w:szCs w:val=\"24\"/>"
+ "</w:rPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"1\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"decimal\"/>"
+ "<w:lvlText w:val=\"%1.%2\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"840\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"840\" w:hanging=\"840\"/>"
+ "</w:pPr>"
+ "<w:rPr>"
+ "<w:b/>"
+ "<w:rFonts w:hint=\"eastAsia\" w:ascii=\"SimSun\" w:hAnsi=\"SimSun\"/>"
+ "<w:color w:val=\"auto\"/>"
+ "<w:sz w:val=\"24\"/>"
+ "<w:szCs w:val=\"24\"/>"
+ "</w:rPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"2\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"decimal\"/>"
+ "<w:lvlText w:val=\"(%3)\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"1260\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"1260\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"3\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"lowerLetter\"/>"
+ "<w:lvlText w:val=\"(%4)\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"1680\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"1680\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"4\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"lowerRoman\"/>"
+ "<w:lvlText w:val=\"%5)\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"2100\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"2100\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"5\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"lowerRoman\"/>"
+ "<w:lvlText w:val=\"(%6)\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"2520\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"2520\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"6\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"decimal\"/>"
+ "<w:lvlText w:val=\"%7.\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"2940\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"2940\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"7\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"lowerLetter\"/>"
+ "<w:lvlText w:val=\"%8.\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"3360\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"3360\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "</w:lvl>"
+ "<w:lvl w:ilvl=\"8\">"
+ "<w:start w:val=\"1\"/>"
+ "<w:numFmt w:val=\"lowerRoman\"/>"
+ "<w:lvlText w:val=\"%9.\"/>"
+ "<w:lvlJc w:val=\"left\"/>"
+ "<w:pPr>"
+ "<w:tabs>"
+ "<w:tab w:val=\"num\" w:pos=\"3780\"/>"
+ "</w:tabs>"
+ "<w:ind w:left=\"3780\" w:hanging=\"420\"/>"
+ "</w:pPr>"
+ "</w:lvl>"
+ "</w:abstractNum>"
+ "<w:num w:numId=\"1\">"
+ "<w:abstractNumId w:val=\"0\"/>"
+ "</w:num>"
+ "</w:numbering>";
}
...@@ -15,27 +15,27 @@ ...@@ -15,27 +15,27 @@
t1.contract_status_desc, t1.contract_status_desc,
t1.billing_method, t1.billing_method,
t1.billing_method_desc, t1.billing_method_desc,
decode(t2.cf_item,'912',t1.inv_billing_object_id,t1.billing_object_id) billing_object_id, decode(t2.cf_item,'250',t1.inv_billing_object_id,t1.billing_object_id) billing_object_id,
decode(t2.cf_item,'912',t1.inv_billing_object_code,t1.billing_object_code) billing_object_code, decode(t2.cf_item,'250',t1.inv_billing_object_code,t1.billing_object_code) billing_object_code,
decode(t2.cf_item,'912',t1.inv_billing_object_name,t1.billing_object_name) billing_object_name, decode(t2.cf_item,'250',t1.inv_billing_object_name,t1.billing_object_name) billing_object_name,
decode(t2.cf_item,'912',t1.inv_object_taxpayer_type,t1.object_taxpayer_type) object_taxpayer_type, decode(t2.cf_item,'250',t1.inv_object_taxpayer_type,t1.object_taxpayer_type) object_taxpayer_type,
decode(t2.cf_item,'912',t1.inv_object_taxpayer_type_desc,t1.object_taxpayer_type_desc) object_taxpayer_type_desc, decode(t2.cf_item,'250',t1.inv_object_taxpayer_type_desc,t1.object_taxpayer_type_desc) object_taxpayer_type_desc,
decode(t2.cf_item,'912',t1.inv_object_tax_registry_num,t1.object_tax_registry_num) object_tax_registry_num, decode(t2.cf_item,'250',t1.inv_object_tax_registry_num,t1.object_tax_registry_num) object_tax_registry_num,
decode(t2.cf_item,'912',t1.inv_bill_object_bp_class,t1.bill_object_bp_class) bill_object_bp_class, decode(t2.cf_item,'250',t1.inv_bill_object_bp_class,t1.bill_object_bp_class) bill_object_bp_class,
decode(t2.cf_item,'912',t1.inv_bill_object_bp_class_desc,t1.bill_object_bp_class_desc) bill_object_bp_class_desc, decode(t2.cf_item,'250',t1.inv_bill_object_bp_class_desc,t1.bill_object_bp_class_desc) bill_object_bp_class_desc,
t1.tax_type_vat, t1.tax_type_vat,
t1.description, t1.description,
decode(t2.cf_item,'912',t1.inv_invoice_title,t1.invoice_title) invoice_title, decode(t2.cf_item,'250',t1.inv_invoice_title,t1.invoice_title) invoice_title,
decode(t2.cf_item,'912',t1.inv_bp_address_phone_num,t1.invoice_bp_address_phone_num) invoice_bp_address_phone_num, decode(t2.cf_item,'250',t1.inv_bp_address_phone_num,t1.invoice_bp_address_phone_num) invoice_bp_address_phone_num,
decode(t2.cf_item,'912',t1.inv_invoice_bp_bank_account,t1.invoice_bp_bank_account) invoice_bp_bank_account, decode(t2.cf_item,'250',t1.inv_invoice_bp_bank_account,t1.invoice_bp_bank_account) invoice_bp_bank_account,
decode(t2.cf_item,'912',t1.inv_tax_registry_num,t1.tax_registry_num) tax_registry_num, decode(t2.cf_item,'250',t1.inv_tax_registry_num,t1.tax_registry_num) tax_registry_num,
t1.prj_search_term_1, t1.prj_search_term_1,
t1.prj_search_term_2, t1.prj_search_term_2,
t1.con_search_term_1, t1.con_search_term_1,
t1.con_search_term_2, t1.con_search_term_2,
t1.document_type, t1.document_type,
t1.bp_name, t1.bp_name,
decode(t2.cf_item,'912',t1.inv_invoice_type_desc,t1.invoice_type_desc) invoice_type_desc, decode(t2.cf_item,'250',t1.inv_invoice_type_desc,t1.invoice_type_desc) invoice_type_desc,
t2.cashflow_id, t2.cashflow_id,
t2.cf_item, t2.cf_item,
t2.cf_item_desc, t2.cf_item_desc,
......
...@@ -53,7 +53,32 @@ ...@@ -53,7 +53,32 @@
from hls_division hd from hls_division hd
where hd.enabled_flag = 'Y' where hd.enabled_flag = 'Y'
and hd.division = cc.division) division_n, and hd.division = cc.division) division_n,
cc.division cc.division,
con_contract_pkg.get_cus_column(p_contract_id => cc.contract_id,
p_type => 'times') account_due_times, --会计逾期总期数
con_contract_pkg.get_cus_column(p_contract_id => cc.contract_id,
p_type => 'days') account_due_days, --会计逾期总天数
con_contract_pkg.get_cus_column(p_contract_id => cc.contract_id,
p_type => 'amounts') account_due_amount, --会计逾期总金额
(select count(1)
from con_contract_cashflow ccc
where ccc.contract_id = cc.contract_id
and ccc.overdue_status = 'Y'
and ccc.cf_item = 1
and ccc.write_off_flag <> 'FULL') business_due_times, --营业逾期总期数
(select sum(ccc.overdue_max_days)
from con_contract_cashflow ccc
where ccc.contract_id = cc.contract_id
and ccc.overdue_status = 'Y'
and ccc.cf_item = 1
and ccc.write_off_flag <> 'FULL') business_due_days, --营业逾期总天数
(select sum(ccc.due_amount - nvl(ccc.received_amount, 0))
from con_contract_cashflow ccc
where ccc.contract_id = cc.contract_id
and ccc.overdue_status = 'Y'
and ccc.cf_item = 1
and ccc.write_off_flag <> 'FULL') business_due_amount --营业逾期总金额
FROM con_contract cc FROM con_contract cc
where exists (select 1 where exists (select 1
from con_contract_cashflow ccw from con_contract_cashflow ccw
...@@ -71,10 +96,12 @@ ...@@ -71,10 +96,12 @@
<bm:query-field name="bp_id_tenant" queryExpression="t1.bp_id_tenant = ${@bp_id_tenant}"/> <bm:query-field name="bp_id_tenant" queryExpression="t1.bp_id_tenant = ${@bp_id_tenant}"/>
<bm:query-field name="contract_name" queryExpression="t1.contract_name = ${@contract_name}"/> <bm:query-field name="contract_name" queryExpression="t1.contract_name = ${@contract_name}"/>
<bm:query-field name="project_number" queryExpression="t1.project_number = ${@project_number}"/> <bm:query-field name="project_number" queryExpression="t1.project_number = ${@project_number}"/>
<bm:query-field name="bp_id_tenant_desc" queryExpression="t1.bp_id_tenant_desc = ${@bp_id_tenant_desc}"/> <!--<bm:query-field name="bp_id_tenant_desc" queryExpression="t1.bp_id_tenant_desc like ${@bp_id_tenant_desc}"/>-->
<bm:query-field name="bp_id_agent_desc" queryExpression="t1.bp_id_agent_desc like ${@bp_id_agent_desc}"/>
<!-- <bm:query-field name="lease_start_date_from" queryExpression="t1.inception_of_lease &gt;=to_date(${@lease_start_date_from},&apos;yyyy-mm-dd&apos;)"/> <!-- <bm:query-field name="lease_start_date_from" queryExpression="t1.inception_of_lease &gt;=to_date(${@lease_start_date_from},&apos;yyyy-mm-dd&apos;)"/>
<bm:query-field name="lease_start_date_to" queryExpression="t1.inception_of_lease &lt;=to_date(${@lease_start_date_to},&apos;yyyy-mm-dd&apos;)"/> <bm:query-field name="lease_start_date_to" queryExpression="t1.inception_of_lease &lt;=to_date(${@lease_start_date_to},&apos;yyyy-mm-dd&apos;)"/>
--> -->
<bm:query-field name="division" queryExpression="t1.division = ${@division}"/>
<bm:query-field name="lease_start_date_from" <bm:query-field name="lease_start_date_from"
queryExpression="t1.inception_of_lease &gt;=${@lease_start_date_from}"/> queryExpression="t1.inception_of_lease &gt;=${@lease_start_date_from}"/>
<bm:query-field name="lease_start_date_to" <bm:query-field name="lease_start_date_to"
...@@ -88,11 +115,18 @@ ...@@ -88,11 +115,18 @@
queryExpression="t1.promised_return_date &gt;= to_date(${@promised_return_date_from},&apos;yyyy-mm-dd&apos;)"/> queryExpression="t1.promised_return_date &gt;= to_date(${@promised_return_date_from},&apos;yyyy-mm-dd&apos;)"/>
<bm:query-field name="promised_return_date_to" <bm:query-field name="promised_return_date_to"
queryExpression="t1.promised_return_date &lt;= to_date(${@promised_return_date_to},&apos;yyyy-mm-dd&apos;)"/> queryExpression="t1.promised_return_date &lt;= to_date(${@promised_return_date_to},&apos;yyyy-mm-dd&apos;)"/>
<bm:query-field name="overdue_times" queryExpression="t1.overdue_times = ${@overdue_times}"/> <bm:query-field name="account_due_times_from" queryExpression="t1.account_due_times &gt;= ${@account_due_times_from}"/>
<bm:query-field name="overdue_days_from" queryExpression="overdue_days &gt;= ${@overdue_days_from}"/> <bm:query-field name="account_due_times_to" queryExpression="t1.account_due_times &lt;= ${@account_due_times_to}"/>
<bm:query-field name="overdue_days_to" queryExpression="overdue_days &lt;= ${@overdue_days_to}"/> <bm:query-field name="account_due_days_from" queryExpression="t1.account_due_days &gt;= ${@account_due_days_from}"/>
<bm:query-field name="due_amount_from" queryExpression="t1.pmt &gt;= ${@due_amount_from}"/> <bm:query-field name="account_due_days_to" queryExpression="t1.account_due_days &lt;= ${@account_due_days_to}"/>
<bm:query-field name="due_amount_to" queryExpression="t1.pmt &lt;= ${@due_amount_to}"/> <bm:query-field name="account_due_amount_from" queryExpression="t1.account_due_amount &gt;= ${@account_due_amount_from}"/>
<bm:query-field name="account_due_amount_to" queryExpression="t1.account_due_amount &lt;= ${@account_due_amount_to}"/>
<bm:query-field name="business_due_times_from" queryExpression="t1.business_due_times &gt;= ${@business_due_times_from}"/>
<bm:query-field name="business_due_times_to" queryExpression="t1.business_due_times &lt;= ${@business_due_times_to}"/>
<bm:query-field name="business_due_days_from" queryExpression="t1.business_due_days &gt;= ${@business_due_days_from}"/>
<bm:query-field name="business_due_days_to" queryExpression="t1.business_due_days &lt;= ${@business_due_days_to}"/>
<bm:query-field name="business_due_amount_from" queryExpression="t1.business_due_amount &gt;= ${@business_due_amount_from}"/>
<bm:query-field name="business_due_amount_to" queryExpression="t1.business_due_amount &lt;= ${@business_due_amount_to}"/>
<bm:query-field name="owner_user_id" queryExpression="t1.owner_user_id = ${@owner_user_id}"/> <bm:query-field name="owner_user_id" queryExpression="t1.owner_user_id = ${@owner_user_id}"/>
<bm:query-field name="lease_organization" queryExpression="t1.lease_organization = ${@lease_organization}"/> <bm:query-field name="lease_organization" queryExpression="t1.lease_organization = ${@lease_organization}"/>
</bm:query-fields> </bm:query-fields>
......
...@@ -175,17 +175,17 @@ ...@@ -175,17 +175,17 @@
} }
} }
function onIndexChange(ds, record, name, value, oldvalue) { // function onIndexChange(ds, record, name, value, oldvalue) {
$('bgt_contract_payment_detail_line_ds').setQueryParameter('contract_id', record.get('contract_id')); // $('bgt_contract_payment_detail_line_ds').setQueryParameter('contract_id', record.get('contract_id'));
$('bgt_contract_payment_detail_line_ds').query(); // $('bgt_contract_payment_detail_line_ds').query();
} // }
function ds_query(ds) { // function ds_query(ds) {
if (ds.getAll().length == 0) { // if (ds.getAll().length == 0) {
$('bgt_contract_payment_detail_line_ds').setQueryParameter('contract_id', null); // $('bgt_contract_payment_detail_line_ds').setQueryParameter('contract_id', null);
$('bgt_contract_payment_detail_line_ds').query(); // $('bgt_contract_payment_detail_line_ds').query();
} // }
} // }
]]></script> ]]></script>
<a:screen-include screen="modules/cont/CON500/con_contract_get_layout_code.lview"/> <a:screen-include screen="modules/cont/CON500/con_contract_get_layout_code.lview"/>
...@@ -209,6 +209,8 @@ ...@@ -209,6 +209,8 @@
</a:mapping> </a:mapping>
</a:field> </a:field>
<a:field name="bp_id_tenant"/> <a:field name="bp_id_tenant"/>
<a:field name="bp_id_agent_desc"/>
<a:field name="division"/>
<a:field name="contract_number" typeCase="Upper"/> <a:field name="contract_number" typeCase="Upper"/>
<a:field name="overdue_times"/> <a:field name="overdue_times"/>
<a:field name="owner_user_id_desc" lovGridHeight="350" lovHeight="475" <a:field name="owner_user_id_desc" lovGridHeight="350" lovHeight="475"
...@@ -234,7 +236,7 @@ ...@@ -234,7 +236,7 @@
</a:fields> </a:fields>
<a:events> <a:events>
<!--<a:event name="indexChange" handler="onIndexChange"/>--> <!--<a:event name="indexChange" handler="onIndexChange"/>-->
<a:event name="load" handler="ds_query"/> <!--<a:event name="load" handler="ds_query"/>-->
</a:events> </a:events>
</a:dataSet> </a:dataSet>
<!--<a:dataSet id="bgt_contract_payment_detail_line_ds" fetchAll="true" model="cont.CON620.bgt_contract_payment_detail_line"/>--> <!--<a:dataSet id="bgt_contract_payment_detail_line_ds" fetchAll="true" model="cont.CON620.bgt_contract_payment_detail_line"/>-->
...@@ -278,15 +280,15 @@ ...@@ -278,15 +280,15 @@
<a:column name="bp_id_agent_desc" align="center" prompt="代理店" width="200"/> <a:column name="bp_id_agent_desc" align="center" prompt="代理店" width="200"/>
<a:column name="business_type_n" align="center" prompt="业务类型" width="60"/> <a:column name="business_type_n" align="center" prompt="业务类型" width="60"/>
<a:column name="division_n" align="center" prompt="租赁物" width="60"/> <a:column name="division_n" align="center" prompt="租赁物" width="60"/>
<a:column name="account_due_times" align="right" prompt="会计逾期总期数" renderer="Leaf.formatMoney" <a:column name="account_due_times" align="center" prompt="会计逾期总期数"
width="100"/> width="100"/>
<a:column name="account_due_days" align="right" prompt="会计逾期总天数" renderer="Leaf.formatMoney" <a:column name="account_due_days" align="center" prompt="会计逾期总天数"
width="100"/> width="100"/>
<a:column name="account_due_amount" align="right" prompt="会计逾期总金额" renderer="Leaf.formatMoney" <a:column name="account_due_amount" align="right" prompt="会计逾期总金额" renderer="Leaf.formatMoney"
width="100"/> width="100"/>
<a:column name="business_due_times" align="right" prompt="营业逾期总期数" renderer="Leaf.formatMoney" <a:column name="business_due_times" align="center" prompt="营业逾期总期数"
width="100"/> width="100"/>
<a:column name="business_due_days" align="right" prompt="营业逾期总天数" renderer="Leaf.formatMoney" <a:column name="business_due_days" align="center" prompt="营业逾期总天数"
width="100"/> width="100"/>
<a:column name="business_due_amount" align="right" prompt="营业逾期总金额" renderer="Leaf.formatMoney" <a:column name="business_due_amount" align="right" prompt="营业逾期总金额" renderer="Leaf.formatMoney"
width="100"/> width="100"/>
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment