src/hbcore/utils/hbwidgetloaderactions_p.cpp
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 04 Oct 2010 00:38:12 +0300
changeset 30 80e4d18b72f5
parent 28 b7da29130b0e
permissions -rw-r--r--
Revision: 201037 Kit: 201039

/****************************************************************************
**
** Copyright (C) 2008-2010 Nokia Corporation and/or its subsidiary(-ies).
** All rights reserved.
** Contact: Nokia Corporation (developer.feedback@nokia.com)
**
** This file is part of the HbCore module of the UI Extensions for Mobile.
**
** GNU Lesser General Public License Usage
** This file may be used under the terms of the GNU Lesser General Public
** License version 2.1 as published by the Free Software Foundation and
** appearing in the file LICENSE.LGPL included in the packaging of this file.
** Please review the following information to ensure the GNU Lesser General
** Public License version 2.1 requirements will be met:
** http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html.
**
** In addition, as a special exception, Nokia gives you certain additional
** rights.  These rights are described in the Nokia Qt LGPL Exception
** version 1.1, included in the file LGPL_EXCEPTION.txt in this package.
**
** If you have questions regarding the use of this file, please contact
** Nokia at developer.feedback@nokia.com.
**
****************************************************************************/

#include "hbwidgetloaderactions_p.h"
#include "hbwidgetloadersyntax_p.h"
#include "hbwidget_p.h"
#include "hbwidgetbase_p.h"
#include <QDebug>

/*
    \class HbWidgetLoaderActions
    \internal
    \proto
*/

/*!
    \internal
*/
HbWidgetLoaderActions::HbWidgetLoaderActions()
    : HbXmlLoaderBaseActions(), mWidget(0), mLayout(0)
{
}

/*!
    \internal
*/
HbWidgetLoaderActions::~HbWidgetLoaderActions()
{
}

#ifndef HB_BIN_CSS
/*!
    \internal
*/
bool HbWidgetLoaderActions::createAnchorLayout( const QString &widget, bool modify )
{
    Q_UNUSED( widget );
    Q_UNUSED( modify );
    HbAnchorLayout *layout = static_cast<HbAnchorLayout*>(mWidget->layout());
    if (!layout) {
        layout = new HbAnchorLayout();
        mWidget->setLayout(layout);
    } else {
        // Reset layout's state
        while (layout->count()) {
            layout->removeAt(0);
        }
        layout->removeAnchors();
        layout->removeMappings();
    }
    mLayout = layout;
    return true;
}

/*!
    \internal
*/
bool HbWidgetLoaderActions::addAnchorLayoutItem(
    const QString &src,
    const QString &srcId,
    Hb::Edge srcEdge, 
    const QString &dst,
    const QString &dstId,
    Hb::Edge dstEdge,
    const HbXmlLengthValue &minLength,
    const HbXmlLengthValue &prefLength,
    const HbXmlLengthValue &maxLength,
    QSizePolicy::Policy *policy, 
    HbAnchor::Direction *dir,
    const QString &anchorId )
{
    // widgetml is purely id based.
    Q_UNUSED(src); 
    Q_UNUSED(dst);

    HbAnchor* anchor = new HbAnchor( srcId, srcEdge, dstId, dstEdge );

    if ( minLength.mValues.count() ) {
        qreal minVal(0);
        if ( !toPixels(minLength, minVal) ) {
            delete anchor;
            return false;
        } else {
            anchor->setMinimumLength( minVal );
        }
    }

    if ( prefLength.mValues.count() ) {
        qreal prefVal(0);
        if ( !toPixels(prefLength, prefVal) ) {
            delete anchor;
            return false;
        } else {
            // if the expression resulted a negative result, we must reverse the direction
            if ( prefVal < 0 && dir ) {
                *dir = (*dir==HbAnchor::Positive) ? HbAnchor::Negative : HbAnchor::Positive;
            }
            anchor->setPreferredLength( qAbs(prefVal) );         
        }
    }

    if ( maxLength.mValues.count() ) {
        qreal maxVal(0);
        if ( !toPixels(maxLength, maxVal) ) {
            delete anchor;
            return false;
        } else {
            anchor->setMaximumLength( maxVal );
        }
    }

    if ( policy ) {
        anchor->setSizePolicy( *policy );
    }

    if ( dir ) {
        anchor->setDirection( *dir );
    }

    if ( !anchorId.isEmpty() ) {
        anchor->setAnchorId( anchorId );
    }

    return mLayout->setAnchor( anchor );
}
#endif
/*
    \class HbWidgetLoaderMemoryActions
    \internal
    \proto
*/

/*!
    \internal
*/
HbWidgetLoaderMemoryActions::HbWidgetLoaderMemoryActions() : HbXmlLoaderAbstractActions(), mLayoutDef(0)
{
}

/*!
    \internal
*/
HbWidgetLoaderMemoryActions::~HbWidgetLoaderMemoryActions()
{
}

/*!
    \internal
*/
bool HbWidgetLoaderMemoryActions::createAnchorLayout( const QString &widget, bool modify )
{
    Q_UNUSED(widget);
    Q_UNUSED(modify);
    mLayoutDef->anchorItems.clear();
    return true;
}

/*!
    \internal
*/
bool HbWidgetLoaderMemoryActions::addAnchorLayoutItem(
    const QString &src,
    const QString &srcId,
    Hb::Edge srcEdge, 
    const QString &dst,
    const QString &dstId,
    Hb::Edge dstEdge,
    const HbXmlLengthValue &minLength,
    const HbXmlLengthValue &prefLength,
    const HbXmlLengthValue &maxLength,
    QSizePolicy::Policy *policy, 
    HbAnchor::Direction *dir,
    const QString &anchorId )
{
    // widgetml is purely id based.
    Q_UNUSED(src); 
    Q_UNUSED(dst);

    HbWidgetLoader::AnchorItem item(mLayoutDef->type);
    item.srcId = srcId;
    item.dstId = dstId;
    item.srcEdge = srcEdge;
    item.dstEdge = dstEdge;

    for (int i=0; i<minLength.mValues.count(); i++) {
        item.minVal.append(minLength.mValues.at(i));
    }
    for (int j=0; j<prefLength.mValues.count(); j++) {
        item.prefVal.append(prefLength.mValues.at(j));
    }
    for (int k=0; k<maxLength.mValues.count(); k++) {
        item.maxVal.append(maxLength.mValues.at(k));
    }

    item.sizepolicy = policy ? *policy : -1;
    item.direction = dir ? *dir : -1;
    item.anchorId = anchorId;

    mLayoutDef->anchorItems.append(item);
    return true;
}