uidesigner/com.nokia.carbide.cpp.uiq.components/components/layoutDataLibrary.js
author dadubrow
Fri, 12 Mar 2010 14:59:20 -0600
branchRCL_2_4
changeset 1106 cfd24c7f99b4
parent 0 fb279309251b
permissions -rw-r--r--
merge

/*
* Copyright (c) 2008 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "Eclipse Public License v1.0"
* which accompanies this distribution, and is available
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
*
* Initial Contributors:
* Nokia Corporation - initial contribution.
*
* Contributors:
*
* Description: 
*
*/


include("containerLibrary.js")

/**
 *	Get the layout data.
 *
 *  If Layout Data is different than "Inherit", then the layout data is returned,
 *	if not, iterate over all parent relationship.
 *
 *	@param instance the instance where look in the layout data.
 *	@param propertyPath the name of the property to analize.
 *	@param propertyDefaultValue the default value of propertyPath which will 
 *	determine if the parent layout data should be reviewed or not.
 *	@return the layout data.
 */
function getLayoutData ( instance, propertyPath, propertyDefaultValue ) {

	var container = "com.nokia.carbide.uiq.CQikContainer";
	var sbb = "com.nokia.carbide.uiq.SystemBuildingBlock";
	var slot = "com.nokia.carbide.uiq.ItemSlot";
	var viewPage = "com.nokia.carbide.uiq.ViewPage";
	var containersGroup = "com.nokia.carbide.uiq.ContainersGroup";

	var parentInstance = instance.parent;
	var parentID = instance.parent.component.id;
	var properties = instance.properties;
	var layoutManagerInstance = null; 
	var layoutData = null;

	while ((parentInstance != null) && (parentID != viewPage) && (parentID != containersGroup)) {
		if (parentID == container) {
			//println("**************** parent: container");
			layoutManagerInstance = findImmediateChildByAttributeValue( parentInstance.children, "is-layout-manager", "true");
			if ( layoutManagerInstance == null ) {
				return propertyDefaultValue;
			}
			layoutData = instance.properties.layoutData[propertyPath];
			if ( layoutData != propertyDefaultValue ) {
				return layoutData
			}
			return getLayoutData ( parentInstance, propertyPath, propertyDefaultValue );
		}
		if (parentID == slot) {
			//println("**************** parent: slot");
			return getLayoutData ( parentInstance, propertyPath, propertyDefaultValue );
		}
		if (parentID == sbb) {
			//println("**************** parent: SBB");
			layoutManagerInstance = findImmediateChildByAttributeValue( parentInstance.parent.children, "is-layout-manager", "true");
			if ( layoutManagerInstance == null ) {
				return propertyDefaultValue;
			}
			layoutData = parentInstance.properties.layoutData[propertyPath];
			if ( layoutData != propertyDefaultValue ) {
				return layoutData
			}
			return getLayoutData ( parentInstance, propertyPath, propertyDefaultValue );
		}
		return propertyDefaultValue;
	}

	return getLayoutManagerLayoutData( instance.children, propertyPath, propertyDefaultValue );
}


/**
 *	Get the layout data of LayoutManager.
 *
 *  If Layout Manager is null, then the default value of the property will be
 *	returned.
 *
 *	@param children the children where look in the layout data.
 *	@param propertyPath the name of the property to analize.
 *	@param propertyDefaultValue the default value of propertyPath.
 *	@return the layout data of LayoutManager or propertyDefaultValue if 
 *	LayoutManager is null .
 */
function getLayoutManagerLayoutData( children, propertyPath, propertyDefaultValue ) {
	var layoutManager = findImmediateChildByAttributeValue( children, "is-layout-manager", "true");
	if (layoutManager != null) {
		//println("**************** sister: layout Manager");
		return layoutManager.properties.defaultLayoutData[propertyPath];
	}
	return propertyDefaultValue;
}