Search in sources :

Example 21 with MQuery

use of org.compiere.model.MQuery in project adempiere by adempiere.

the class TableElement method getDrillDown.

//	getPageYCount
/**************************************************************************
	 * 	Get Drill Down value
	 * 	@param relativePoint relative Point
	 *  @param pageNo page number
	 * 	@return if found Qyery or null
	 */
public MQuery getDrillDown(Point relativePoint, int pageNo) {
    if (m_rowColDrillDown.size() == 0)
        return null;
    if (!getBounds(pageNo).contains(relativePoint))
        return null;
    int row = getRow(relativePoint.y, pageNo);
    if (row == -1)
        return null;
    int col = getCol(relativePoint.x, pageNo);
    if (col == -1)
        return null;
    log.fine("Row=" + row + ", Col=" + col + ", PageNo=" + pageNo);
    //
    NamePair pp = (NamePair) m_rowColDrillDown.get(new Point(row, col));
    if (pp == null)
        return null;
    String columnName = MQuery.getZoomColumnName(m_columnHeader[col].getID());
    String tableName = MQuery.getZoomTableName(columnName);
    Object code = pp.getID();
    if (pp instanceof KeyNamePair)
        code = new Integer(((KeyNamePair) pp).getKey());
    //
    MQuery query = new MQuery(tableName);
    query.addRestriction(columnName, MQuery.EQUAL, code, null, pp.toString());
    return query;
}
Also used : NamePair(org.compiere.util.NamePair) ValueNamePair(org.compiere.util.ValueNamePair) KeyNamePair(org.compiere.util.KeyNamePair) MQuery(org.compiere.model.MQuery) Point(java.awt.Point) AttributedString(java.text.AttributedString) KeyNamePair(org.compiere.util.KeyNamePair) Point(java.awt.Point)

Example 22 with MQuery

use of org.compiere.model.MQuery in project adempiere by adempiere.

the class LayoutEngine method includeFormat.

//	layoutForm
/**
	 * 	Include Table Format
	 *	@param item print format item
	 *	@param data print data
	 *	@return Print Element
	 */
private PrintElement includeFormat(MPrintFormatItem item, PrintData data) {
    newLine();
    PrintElement element = null;
    //
    MPrintFormat format = MPrintFormat.get(getCtx(), item.getAD_PrintFormatChild_ID(), false);
    format.setLanguage(m_format.getLanguage());
    if (m_format.isTranslationView())
        format.setTranslationLanguage(m_format.getLanguage());
    int AD_Column_ID = item.getAD_Column_ID();
    log.info(format + " - Item=" + item.getName() + " (" + AD_Column_ID + ")");
    //
    Object obj = data.getNode(new Integer(AD_Column_ID));
    //	Object obj = data.getNode(item.getColumnName());	//	slower
    if (obj == null) {
        data.dumpHeader();
        data.dumpCurrentRow();
        log.log(Level.SEVERE, "No Node - AD_Column_ID=" + AD_Column_ID + " - " + item + " - " + data);
        return null;
    }
    PrintDataElement dataElement = (PrintDataElement) obj;
    String recordString = dataElement.getValueKey();
    if (recordString == null || recordString.length() == 0) {
        data.dumpHeader();
        data.dumpCurrentRow();
        log.log(Level.SEVERE, "No Record Key - " + dataElement + " - AD_Column_ID=" + AD_Column_ID + " - " + item);
        return null;
    }
    int Record_ID = 0;
    try {
        Record_ID = Integer.parseInt(recordString);
    } catch (Exception e) {
        data.dumpCurrentRow();
        log.log(Level.SEVERE, "Invalid Record Key - " + recordString + " (" + e.getMessage() + ") - AD_Column_ID=" + AD_Column_ID + " - " + item);
        return null;
    }
    MQuery query = new MQuery(format.getAD_Table_ID());
    query.addRestriction(item.getColumnName(), MQuery.EQUAL, new Integer(Record_ID));
    format.setTranslationViewQuery(query);
    log.fine(query.toString());
    //
    DataEngine de = new DataEngine(format.getLanguage(), m_TrxName);
    PrintData includedData = de.getPrintData(data.getCtx(), format, query);
    if (includedData == null)
        return null;
    data.addNode(includedData);
    log.fine(includedData.toString());
    //
    element = layoutTable(format, includedData, item.getXSpace());
    //	handle multi page tables
    if (element.getPageCount() > 1) {
        Point2D.Double loc = m_position[m_area];
        element.setLocation(loc);
        for (//	don't add last one
        int p = 1; //	don't add last one
        p < element.getPageCount(); //	don't add last one
        p++) {
            m_currPage.addElement(element);
            newPage(true, false);
        }
        m_position[m_area] = loc;
        ((TableElement) element).setHeightToLastPage();
    }
    m_lastWidth[m_area] = element.getWidth();
    m_lastHeight[m_area] = element.getHeight();
    if (!isXspaceFor(m_lastWidth[m_area])) {
        log.finest("Not enough X space for " + m_lastWidth[m_area] + " - remaining " + getXspace() + " - Area=" + m_area);
        newLine();
    }
    if (m_area == AREA_CONTENT && !isYspaceFor(m_lastHeight[m_area])) {
        log.finest("Not enough Y space " + m_lastHeight[m_area] + " - remaining " + getYspace() + " - Area=" + m_area);
        newPage(true, false);
    }
    //
    return element;
}
Also used : MQuery(org.compiere.model.MQuery) Point(java.awt.Point) PrinterException(java.awt.print.PrinterException) IOException(java.io.IOException) MPrintFormat(org.compiere.print.MPrintFormat) PrintDataElement(org.compiere.print.PrintDataElement) Point2D(java.awt.geom.Point2D) PrintData(org.compiere.print.PrintData) DataEngine(org.compiere.print.DataEngine)

Example 23 with MQuery

use of org.compiere.model.MQuery in project adempiere by adempiere.

the class Page method getDrillAcross.

//	getDrillDown
/**
	 * 	Get DrillAcross value
	 * 	@param relativePoint relative Point
	 * 	@return if found Query or null
	 */
public MQuery getDrillAcross(Point relativePoint) {
    MQuery retValue = null;
    for (int i = 0; i < m_elements.size() && retValue == null; i++) {
        PrintElement element = (PrintElement) m_elements.get(i);
        retValue = element.getDrillAcross(relativePoint, m_pageNo);
    }
    return retValue;
}
Also used : MQuery(org.compiere.model.MQuery) Point(java.awt.Point)

Example 24 with MQuery

use of org.compiere.model.MQuery in project adempiere by adempiere.

the class HeaderFooter method getDrillDown.

//	paint
/**
	 * 	Get DrillDown value
	 * 	@param relativePoint relative Point
	 * 	@return if found NamePait or null
	 */
public MQuery getDrillDown(Point relativePoint) {
    MQuery retValue = null;
    for (int i = 0; i < m_elements.size() && retValue == null; i++) {
        PrintElement element = (PrintElement) m_elements.get(i);
        retValue = element.getDrillDown(relativePoint, 1);
    }
    return retValue;
}
Also used : MQuery(org.compiere.model.MQuery) Point(java.awt.Point)

Example 25 with MQuery

use of org.compiere.model.MQuery in project adempiere by adempiere.

the class ReportEngineEx method createEXCEL_HTML.

//	createHTML
/**
	 * 	Write EXCEL HTML to writer
	 * 	@param writer writer
	 *  @param onlyTable if false create complete HTML document
	 *  @param language optional language - if null nubers/dates are not formatted
	 * 	@return true if success
	 */
public static boolean createEXCEL_HTML(ReportEngine re, Properties m_ctx, Writer writer, boolean onlyTable, Language language) {
    PrintData m_printData = re.getPrintData();
    MPrintFormat m_printFormat = re.getPrintFormat();
    ///Properties m_ctx = new Properties();
    MQuery m_query = re.getQuery();
    try {
        table table = new table();
        //	for all rows (-1 = header row)
        for (int row = -1; row < m_printData.getRowCount(); row++) {
            tr tr = new tr();
            table.addElement(tr);
            if (row != -1)
                m_printData.setRowIndex(row);
            //	for all columns
            for (int col = 0; col < m_printFormat.getItemCount(); col++) {
                MPrintFormatItem item = m_printFormat.getItem(col);
                if (item.isPrinted()) {
                    //	header row
                    if (row == -1) {
                        th th = new th();
                        tr.addElement(th);
                        th.addElement(Util.maskHTML(item.getPrintName(language)));
                        th.setClass("xl_head");
                    } else {
                        td td = new td();
                        tr.addElement(td);
                        Object obj = m_printData.getNode(new Integer(item.getAD_Column_ID()));
                        if (obj == null)
                            td.addElement("&nbsp;");
                        else if (obj instanceof PrintDataElement) {
                            //	formatted
                            String value = ((PrintDataElement) obj).getValueDisplay(null);
                            int displayType = ((PrintDataElement) obj).getDisplayType();
                            if (((PrintDataElement) obj).isNumeric()) {
                                if (displayType == DisplayType.Integer) {
                                    td.addAttribute("x:num", value);
                                    td.addElement(Util.maskHTML(value));
                                } else if (displayType == DisplayType.Quantity) {
                                    td.addAttribute("x:num", value);
                                    td.addElement(Util.maskHTML(value));
                                } else if (displayType == DisplayType.Amount) {
                                    td.addAttribute("x:num", value);
                                    td.addElement(Util.maskHTML(value));
                                } else if (displayType == DisplayType.CostPrice) {
                                    td.addAttribute("x:num", "");
                                    td.addAttribute("u1:num", value);
                                    td.setClass("xl25");
                                    td.addElement(Util.maskHTML(value));
                                } else //else if (displayType == DisplayType.YesNo)
                                //{
                                //}
                                //	if (displayType == Number)										
                                {
                                    td.addElement(Util.maskHTML(value));
                                }
                            } else if (((PrintDataElement) obj).isDate()) {
                                if (displayType == DisplayType.Date) {
                                    td.setClass("xl24");
                                    td.addElement(Util.maskHTML(value));
                                } else if (displayType == DisplayType.DateTime) {
                                    td.setClass("xl26");
                                    td.addElement(Util.maskHTML(value));
                                } else {
                                    td.addElement(Util.maskHTML(value));
                                }
                            } else
                                td.addElement(Util.maskHTML(value));
                        } else if (obj instanceof PrintData) {
                        //	ignore contained Data
                        } else
                            log.log(Level.SEVERE, "createHTML - Element not PrintData(Element) " + obj.getClass());
                    }
                }
            //	printed
            }
        //	for all columns
        }
        //	for all rows
        table table1 = new table();
        table1.setBorder(0).setCols(10).setCellPadding(0).setCellSpacing(2);
        table1.addElement(new tr().addElement(new td().setColSpan(10).addElement(new h1(re.getName())).setStyle("border:none;")));
        tr tr1;
        String tmp = "Jednostka: ";
        MOrg o = MOrg.get(m_ctx, Env.getAD_Org_ID(m_ctx));
        tmp += o.getName();
        tr1 = new tr();
        tr1.addElement(new td().addElement(tmp).setColSpan(10).setStyle("border:none;"));
        table1.addElement(tr1);
        java.text.DateFormat dateFormat = java.text.DateFormat.getDateInstance(java.text.DateFormat.FULL, new Locale("pl_PL"));
        String dateData = "Czas wygenerowania: " + dateFormat.format(new java.util.Date());
        tr1 = new tr();
        tr1.addElement(new td().addElement(dateData).setColSpan(10).setStyle("border:none;"));
        table1.addElement(tr1);
        for (int r = 0; r < m_query.getRestrictionCount(); r++) {
            tr1 = new tr();
            td td1 = new td().addElement(new i(m_query.getInfoName(r)));
            td1.addElement("   " + m_query.getInfoOperator(r) + "   " + m_query.getInfoDisplayAll(r)).setColSpan(10);
            td1.setStyle("border:none;");
            tr1.addElement(td1);
            table1.addElement(tr1);
        }
        tr1 = new tr();
        tr1.addElement(new td().addElement("&nbsp;").setColSpan(10).setStyle("border:none;height:20px;"));
        table1.addElement(tr1);
        //
        PrintWriter w = new PrintWriter(writer);
        if (onlyTable)
            table.output(w);
        else {
            XhtmlDocument doc = new XhtmlDocument();
            String st = "<!--table " + "	{mso-displayed-decimal-separator:\".\"; " + "	mso-displayed-thousand-separator:\" \";} " + "@page " + "	{margin:.98in .79in .98in .79in; " + "	mso-header-margin:.5in; " + "	mso-footer-margin:.5in;} " + "tr " + "	{mso-height-source:auto;} " + "col " + "	{mso-width-source:auto;} " + "br " + "	{mso-data-placement:same-cell;} " + ".style0 " + "	{mso-number-format:General; " + "	text-align:general; " + "	vertical-align:bottom; " + "	white-space:nowrap; " + "	mso-rotate:0; " + "	mso-background-source:auto; " + "	mso-pattern:auto; " + "	color:windowtext; " + "	font-size:10.0pt; " + "	font-weight:400; " + "	font-style:normal; " + "	text-decoration:none; " + "	font-family:Arial; " + "	mso-generic-font-family:auto; " + "	mso-font-charset:238; " + "	border:none; " + "	mso-protection:locked visible; " + "	mso-style-name:Normalny; " + "	mso-style-id:0;} " + "td " + "	{mso-style-parent:style0; " + "	padding-top:1px; " + "	padding-right:1px; " + "	padding-left:1px; " + "	mso-ignore:padding; " + "	color:windowtext; " + "	font-size:10.0pt; " + "	font-weight:400; " + "	font-style:normal; " + "	text-decoration:none; " + "	font-family:Arial; " + "	mso-generic-font-family:auto; " + "	mso-font-charset:238; " + "	mso-number-format:General; " + "	text-align:general; " + "	vertical-align:bottom; " + //"	border:none; "+
            "border:.5pt solid #a0a0a0; " + //windowtext
            "	mso-background-source:auto; " + "	mso-pattern:auto; " + "	mso-protection:locked visible; " + "	white-space:nowrap; " + "	mso-rotate:0;} " + ".xl24 " + "{mso-style-parent:style0; " + "mso-number-format:\"Short Date\";} " + ".xl25 " + "{mso-style-parent:style0; " + "mso-number-format:Fixed;} " + ".xl26 " + "{mso-style-parent:style0; " + "mso-number-format:\"yy\\/mm\\/dd\\ h\\:mm\\;\\@\";} " + ".xl_head " + "{text-align:center; mso-style-parent:style0; " + "font-weight:700; " + "font-family:Arial, sans-serif; " + "mso-font-charset:238; " + "border:.5pt solid windowtext; " + "background:silver; " + "mso-pattern:auto none;} " + "-->  ";
            doc.appendHead(new style().addElement(st));
            doc.appendBody(table1);
            doc.appendBody(table);
            doc.output(w);
        }
        w.flush();
        w.close();
    } catch (Exception e) {
        log.log(Level.SEVERE, "createHTML(w)", e);
    }
    return false;
}
Also used : Locale(java.util.Locale) org.apache.ecs.xhtml.h1(org.apache.ecs.xhtml.h1) XhtmlDocument(org.apache.ecs.XhtmlDocument) PrintData(org.compiere.print.PrintData) org.apache.ecs.xhtml.table(org.apache.ecs.xhtml.table) PrintWriter(java.io.PrintWriter) MPrintFormatItem(org.compiere.print.MPrintFormatItem) org.apache.ecs.xhtml.i(org.apache.ecs.xhtml.i) MQuery(org.compiere.model.MQuery) FileNotFoundException(java.io.FileNotFoundException) org.apache.ecs.xhtml.td(org.apache.ecs.xhtml.td) MPrintFormat(org.compiere.print.MPrintFormat) MOrg(org.compiere.model.MOrg) org.apache.ecs.xhtml.th(org.apache.ecs.xhtml.th) PrintDataElement(org.compiere.print.PrintDataElement) org.apache.ecs.xhtml.style(org.apache.ecs.xhtml.style) org.apache.ecs.xhtml.tr(org.apache.ecs.xhtml.tr)

Aggregations

MQuery (org.compiere.model.MQuery)109 PrintInfo (org.compiere.model.PrintInfo)19 GridField (org.compiere.model.GridField)15 MPrintFormat (org.compiere.print.MPrintFormat)14 ReportEngine (org.compiere.print.ReportEngine)12 Point (java.awt.Point)11 ALayoutConstraint (org.compiere.apps.ALayoutConstraint)9 GridWindowVO (org.compiere.model.GridWindowVO)9 SQLException (java.sql.SQLException)8 GridTab (org.compiere.model.GridTab)8 GridWindow (org.compiere.model.GridWindow)7 PreparedStatement (java.sql.PreparedStatement)6 ResultSet (java.sql.ResultSet)6 AWindow (org.compiere.apps.AWindow)6 File (java.io.File)5 IOException (java.io.IOException)5 Language (org.compiere.util.Language)4 AdempiereException (org.adempiere.exceptions.AdempiereException)3 MClient (org.compiere.model.MClient)3 MLookup (org.compiere.model.MLookup)3