2004-10-26 04:34:03 +04:00
|
|
|
/* -*- Mode: IDL; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
|
|
|
|
/* ***** BEGIN LICENSE BLOCK *****
|
|
|
|
* Version: MPL 1.1/GPL 2.0/LGPL 2.1
|
|
|
|
*
|
|
|
|
* The contents of this file are subject to the Mozilla Public License Version
|
|
|
|
* 1.1 (the "License"); you may not use this file except in compliance with
|
|
|
|
* the License. You may obtain a copy of the License at
|
|
|
|
* http://www.mozilla.org/MPL/
|
|
|
|
*
|
|
|
|
* Software distributed under the License is distributed on an "AS IS" basis,
|
|
|
|
* WITHOUT WARRANTY OF ANY KIND, either express or implied. See the License
|
|
|
|
* for the specific language governing rights and limitations under the
|
|
|
|
* License.
|
|
|
|
*
|
|
|
|
* The Original Code is Mozilla XForms support.
|
|
|
|
*
|
|
|
|
* The Initial Developer of the Original Code is
|
|
|
|
* IBM Corporation.
|
|
|
|
* Portions created by the Initial Developer are Copyright (C) 2004
|
|
|
|
* the Initial Developer. All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Contributor(s):
|
|
|
|
* Brian Ryner <bryner@brianryner.com>
|
|
|
|
*
|
|
|
|
* Alternatively, the contents of this file may be used under the terms of
|
|
|
|
* either the GNU General Public License Version 2 or later (the "GPL"), or
|
|
|
|
* the GNU Lesser General Public License Version 2.1 or later (the "LGPL"),
|
|
|
|
* in which case the provisions of the GPL or the LGPL are applicable instead
|
|
|
|
* of those above. If you wish to allow use of your version of this file only
|
|
|
|
* under the terms of either the GPL or the LGPL, and not to allow others to
|
|
|
|
* use your version of this file under the terms of the MPL, indicate your
|
|
|
|
* decision by deleting the provisions above and replace them with the notice
|
|
|
|
* and other provisions required by the GPL or the LGPL. If you do not delete
|
|
|
|
* the provisions above, a recipient may use your version of this file under
|
|
|
|
* the terms of any one of the MPL, the GPL or the LGPL.
|
|
|
|
*
|
|
|
|
* ***** END LICENSE BLOCK ***** */
|
|
|
|
|
|
|
|
#include "nsIXFormsModelElement.idl"
|
|
|
|
|
|
|
|
interface nsIXFormsControl;
|
|
|
|
interface nsISchemaType;
|
|
|
|
interface nsIInstanceElementPrivate;
|
2005-01-29 23:36:09 +03:00
|
|
|
interface nsIDOMNode;
|
2004-10-26 04:34:03 +04:00
|
|
|
|
2004-11-05 00:12:22 +03:00
|
|
|
/**
|
|
|
|
* Private interface implemented by the model element for other
|
|
|
|
* elements to use.
|
|
|
|
*/
|
2006-05-24 11:29:53 +04:00
|
|
|
[uuid(74238f22-d112-4bed-a8dc-cc228df52c2e)]
|
2004-10-26 04:34:03 +04:00
|
|
|
interface nsIModelElementPrivate : nsIXFormsModelElement
|
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Called by form control elements when they are bound to or unbound from
|
|
|
|
* this model. These form controls will be refreshed when refresh() is
|
|
|
|
* called on the model.
|
|
|
|
*/
|
2006-03-29 14:49:28 +04:00
|
|
|
void addFormControl(in nsIXFormsControl control, in nsIXFormsControl parent);
|
2004-10-26 04:34:03 +04:00
|
|
|
void removeFormControl(in nsIXFormsControl control);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Determine the type for a form control based on the schema included by
|
|
|
|
* this model.
|
|
|
|
*/
|
|
|
|
nsISchemaType getTypeForControl(in nsIXFormsControl control);
|
|
|
|
|
2005-02-26 00:52:59 +03:00
|
|
|
/**
|
|
|
|
* This function takes an instance data node, finds the type bound to it, and
|
|
|
|
* returns the seperated out type and namespace URI. If no type is set for
|
|
|
|
* the node, then it returns the defaults: "http://www.w3.org/2001/XMLSchema"
|
|
|
|
* and "string"
|
|
|
|
*/
|
|
|
|
void getTypeAndNSFromNode(in nsIDOMNode instancenode, out AString type,
|
|
|
|
out AString namespaceURI);
|
|
|
|
|
2004-10-26 04:34:03 +04:00
|
|
|
/**
|
|
|
|
* Notification that an instance element has started or finished loading
|
2006-03-22 21:05:49 +03:00
|
|
|
* its instance data. Model construction cannot complete until all of
|
2004-10-26 04:34:03 +04:00
|
|
|
* the instances have loaded their data.
|
|
|
|
*/
|
|
|
|
void instanceLoadStarted();
|
|
|
|
void instanceLoadFinished(in boolean success);
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Locate the instance element child with the given id.
|
|
|
|
*/
|
|
|
|
nsIInstanceElementPrivate findInstanceElement(in AString id);
|
2005-01-19 19:05:31 +03:00
|
|
|
|
|
|
|
/**
|
2005-01-29 23:36:09 +03:00
|
|
|
* Set the value of an instance node.
|
2006-05-22 12:51:06 +04:00
|
|
|
*
|
|
|
|
* If doRefresh is true, the function will request xforms-recalculate,
|
|
|
|
* xforms-revalidate, and xforms-refresh to be dispatched to the model.
|
|
|
|
*
|
|
|
|
* @param instanceNode The node to set the value for
|
|
|
|
* @param nodeValue The value to set
|
|
|
|
* @param doRefresh Request value-changed event sequence
|
|
|
|
* @param nodeChanged Return whether the node was actually changed
|
2005-01-19 19:05:31 +03:00
|
|
|
*/
|
2006-05-22 12:51:06 +04:00
|
|
|
void setNodeValue(in nsIDOMNode instanceNode,
|
2005-01-29 23:36:09 +03:00
|
|
|
in AString nodeValue,
|
2006-05-22 12:51:06 +04:00
|
|
|
in boolean doRefresh,
|
2005-01-29 23:36:09 +03:00
|
|
|
out boolean nodeChanged);
|
|
|
|
|
2005-11-18 01:00:27 +03:00
|
|
|
/**
|
2006-02-24 02:53:23 +03:00
|
|
|
* Insert a set of nodes underneath an instance node.
|
2006-05-22 12:51:06 +04:00
|
|
|
*
|
|
|
|
* If doRebuild is true, the function will request
|
|
|
|
* xforms-rebuild, xforms-recalculate, xforms-revalidate, and
|
|
|
|
* xforms-refresh to be dispatched to the model.
|
|
|
|
*
|
|
|
|
* @param node The instance node
|
|
|
|
* @param content Node that holds the contents to insert under
|
2006-02-24 02:53:23 +03:00
|
|
|
* the instance node
|
2006-05-22 12:51:06 +04:00
|
|
|
* @param doRebuild Request rebuild event sequence
|
2005-11-18 01:00:27 +03:00
|
|
|
*/
|
2006-05-22 12:51:06 +04:00
|
|
|
void setNodeContent(in nsIDOMNode node,
|
|
|
|
in nsIDOMNode content,
|
|
|
|
in boolean doRebuild);
|
2005-11-18 01:00:27 +03:00
|
|
|
|
2005-01-20 14:11:41 +03:00
|
|
|
/**
|
|
|
|
* Validates the instance node against the schemas loaded by the model.
|
|
|
|
*/
|
2005-01-27 21:22:58 +03:00
|
|
|
PRBool validateNode(in nsIDOMNode aInstanceNode);
|
2005-01-31 19:13:24 +03:00
|
|
|
|
2005-02-18 22:48:46 +03:00
|
|
|
const unsigned short SUBMIT_SERIALIZE_NODE = 1;
|
|
|
|
const unsigned short SUBMIT_SKIP_NODE = 2;
|
|
|
|
const unsigned short SUBMIT_ABORT_SUBMISSION = 3;
|
|
|
|
|
2005-01-31 19:13:24 +03:00
|
|
|
/**
|
2005-02-18 22:48:46 +03:00
|
|
|
* Handles an instance data node and returns one of the above 3 values.
|
2005-01-31 19:13:24 +03:00
|
|
|
*/
|
2005-02-18 22:48:46 +03:00
|
|
|
unsigned short handleInstanceDataNode(in nsIDOMNode aInstanceDataNode);
|
|
|
|
|
2005-05-05 11:09:40 +04:00
|
|
|
/**
|
|
|
|
* Set MIP states for given control bound to the given bound node.
|
|
|
|
* @param aControl The control
|
|
|
|
* @param aBoundNode The node the control is bound to
|
|
|
|
*/
|
|
|
|
void setStates(in nsIXFormsControl aControl, in nsIDOMNode aBoundNode);
|
2005-06-29 22:14:43 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add an instance element to the model's instance list
|
|
|
|
* @param aInstanceElement The instance element to add to the list
|
|
|
|
*/
|
|
|
|
void addInstanceElement(in nsIInstanceElementPrivate aInstanceElement);
|
|
|
|
|
2006-02-08 14:03:27 +03:00
|
|
|
/**
|
|
|
|
* Remove an instance element from the model's instance list
|
|
|
|
* @param aInstanceElement The instance element to remove from the list
|
|
|
|
*/
|
|
|
|
void removeInstanceElement(in nsIInstanceElementPrivate aInstanceElement);
|
|
|
|
|
2005-06-29 22:14:43 +04:00
|
|
|
/**
|
|
|
|
* This attribute is set when the model's instance was lazy authored
|
|
|
|
*/
|
|
|
|
readonly attribute boolean lazyAuthored;
|
2006-02-08 14:03:27 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* This attribute is set when the model handled xforms-ready event
|
|
|
|
*/
|
|
|
|
readonly attribute boolean isReady;
|
2006-02-17 13:14:10 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieves the type for an instance data node
|
|
|
|
*
|
|
|
|
* @param aInstanceData The instance data node
|
|
|
|
* @param aType The type of the node
|
|
|
|
* @param aNSURI The namespace of the type
|
|
|
|
*/
|
2006-05-22 12:51:06 +04:00
|
|
|
void getTypeFromNode(in nsIDOMNode aInstanceData, out AString aType,
|
2006-02-17 13:14:10 +03:00
|
|
|
out AString aNSUri);
|
2006-03-22 21:05:49 +03:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Notification that all of the external message loads have finished loading.
|
|
|
|
* Model contstruction cannot complete until all of the external messages
|
|
|
|
* have loaded their data.
|
|
|
|
*/
|
|
|
|
void messageLoadFinished();
|
2006-05-17 23:30:36 +04:00
|
|
|
|
2006-05-22 12:51:06 +04:00
|
|
|
/**
|
|
|
|
* Request an xforms-rebuild.
|
|
|
|
*
|
|
|
|
* If a previous request (of this or one of the 3 following events) is
|
|
|
|
* already being handled, the event will be queued, and sent after that. If
|
|
|
|
* multiple events are queued, they will be dispatched FIFO order.
|
|
|
|
*/
|
|
|
|
void requestRebuild();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Request an xforms-recalculate
|
|
|
|
*/
|
|
|
|
void requestRecalculate();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Request an xforms-revalidate
|
|
|
|
*/
|
|
|
|
void requestRevalidate();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Request an xforms-refresh
|
|
|
|
*/
|
|
|
|
void requestRefresh();
|
|
|
|
|
2006-05-17 23:30:36 +04:00
|
|
|
/**
|
|
|
|
* Returns true when the model has been notified that the DOMContentLoaded
|
|
|
|
* event has been fired on the XForms document.
|
|
|
|
*/
|
|
|
|
readonly attribute boolean hasDOMContentFired;
|
2006-05-24 11:29:53 +04:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Force rebinding (and refreshing) of a control. Also handles rebinding and
|
|
|
|
* refreshing of child controls, if necessary.
|
|
|
|
*
|
|
|
|
* @param control The control to rebind.
|
|
|
|
*/
|
|
|
|
void forceRebind(in nsIXFormsControl control);
|
2004-10-26 04:34:03 +04:00
|
|
|
};
|