/****************************************************************************** * Product: Adempiere ERP & CRM Smart Business Solution * * Copyright (C) 1999-2006 ComPiere, Inc. All Rights Reserved. * * This program is free software; you can redistribute it and/or modify it * * under the terms version 2 of the GNU General Public License as published * * by the Free Software Foundation. This program is distributed in the hope * * that it will be useful, but WITHOUT ANY WARRANTY; without even the implied * * warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. * * See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along * * with this program; if not, write to the Free Software Foundation, Inc., * * 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. * * For the text or an alternative of this public license, you may reach us * * ComPiere, Inc., 2620 Augustine Dr. #245, Santa Clara, CA 95054, USA * * or via info@compiere.org or http://www.compiere.org/license.html * *****************************************************************************/ package org.compiere.model; import java.util.Properties; import org.adempiere.base.IColumnCallout; /** * Callout Interface for column/field. * Used in MTab and ImpFormatRow. * @see CalloutEngine * @see IColumnCallout * @see org.adempiere.base.annotation.Callout * * @author Jorg Janke * @version $Id: Callout.java,v 1.2 2006/07/30 00:51:05 jjanke Exp $ */ public interface Callout { /** * Start Callout. *

* Callout's are used for field validation, cross field validation and setting values in other fields. * When returning a non empty (error message) string, an exception is raised. *

* When invoked, the Tab model has the new value! * * @param ctx Context * @param method Method name * @param WindowNo current Window No * @param mTab Model Tab * @param mField Model Field * @param value The new value * @param oldValue The old value * @return Error message or "" */ public String start (Properties ctx, String method, int WindowNo, GridTab mTab, GridField mField, Object value, Object oldValue); /** * Conversion Rules. * Use by ImpFormatRow to convert an input value. * * @param method in notation User_Function * @param value the value * @return converted String or Null if no method found */ public String convert (String method, String value); } // callout