epoc32/include/hswidget.h
author William Roberts <williamr@symbian.org>
Tue, 16 Mar 2010 16:12:26 +0000
branchSymbian2
changeset 2 2fe1408b6811
permissions -rw-r--r--
Final list of Symbian^2 public API header files
williamr@2
     1
/*
williamr@2
     2
* Copyright (c) 2007 Nokia Corporation and/or its subsidiary(-ies). 
williamr@2
     3
* All rights reserved.
williamr@2
     4
* This component and the accompanying materials are made available
williamr@2
     5
* under the terms of the License "Symbian Foundation License v1.0" to Symbian Foundation members and "Symbian Foundation End User License Agreement v1.0" to non-members
williamr@2
     6
* which accompanies this distribution, and is available
williamr@2
     7
* at the URL "http://www.symbianfoundation.org/legal/licencesv10.html".
williamr@2
     8
*
williamr@2
     9
* Initial Contributors:
williamr@2
    10
* Nokia Corporation - initial contribution.
williamr@2
    11
*
williamr@2
    12
* Contributors:
williamr@2
    13
*
williamr@2
    14
* Description:  Updates applications and icons in Operator Tile.
williamr@2
    15
*
williamr@2
    16
*/
williamr@2
    17
williamr@2
    18
williamr@2
    19
#ifndef __HSWIDGET_H__
williamr@2
    20
#define __HSWIDGET_H__
williamr@2
    21
williamr@2
    22
//  Include Files
williamr@2
    23
#include <cctype>
williamr@2
    24
#include <string>
williamr@2
    25
#include <memory>
williamr@2
    26
#include <vector>
williamr@2
    27
williamr@2
    28
namespace Hs {
williamr@2
    29
williamr@2
    30
class HsWidgetItem;
williamr@2
    31
williamr@2
    32
/**
williamr@2
    33
 * Class defining a Homescreen Widget. A widget is identified by
williamr@2
    34
 * its templateName, widgetName, uniqueIdentifier.
williamr@2
    35
 * 
williamr@2
    36
 * @code
williamr@2
    37
 * @code
williamr@2
    38
 * class ObserverClass : public IHsDataObserver
williamr@2
    39
 * {
williamr@2
    40
 *      void handleEvent( std::string aWidgetName, 
williamr@2
    41
 *			IHsDataObserver::EEvent aEvent)
williamr@2
    42
 *      {
williamr@2
    43
 *      }
williamr@2
    44
 * 
williamr@2
    45
 *      void handleItemEvent( std::string aWidgetName,
williamr@2
    46
 *        	std::string aWidgetItemName,
williamr@2
    47
 *       	IHsDataObserver::EItemEvent aEvent)
williamr@2
    48
 *      {
williamr@2
    49
 *      }
williamr@2
    50
 * }
williamr@2
    51
 * 
williamr@2
    52
 * ObserverClass* dataObserver = new ObserverClass();
williamr@2
    53
 * HsWidgetPublisher* hsPublisher = new HsWidgetPublisher( dataObserver );
williamr@2
    54
 * HsWidget& widget =  hsPublisher->createHsWidget( 
williamr@2
    55
 *     "templateName", "widgetName", "uniqueIdentifier" );
williamr@2
    56
 * hsPublisher->publishHsWidget( widget ); 
williamr@2
    57
 * @endcode
williamr@2
    58
 */
williamr@2
    59
class HsWidget
williamr@2
    60
    {
williamr@2
    61
public:
williamr@2
    62
    /**
williamr@2
    63
     * Adds a new widget item to the widget if it wasn't created 
williamr@2
    64
     * previously or set a new value to the existing one.
williamr@2
    65
     * Widget item is identified by the name with the value provided. 
williamr@2
    66
     * The value is a string.
williamr@2
    67
     *
williamr@2
    68
     * @code
williamr@2
    69
     * HsWidgetPublisher* hsPublisher = new HsWidgetPublisher( dataObserver );
williamr@2
    70
     * HsWidget& widget =  hsPublisher->createHsWidget( 
williamr@2
    71
     *     "templateName", "widgetName", "uniqueIdentifier" );
williamr@2
    72
     * // assuming count and values[] are defined
williamr@2
    73
     * while ( count )
williamr@2
    74
     * {
williamr@2
    75
     *    widget->setItem("image", values[count] );
williamr@2
    76
     *    count--;
williamr@2
    77
     * }
williamr@2
    78
     * @endcode
williamr@2
    79
     * @param aItemName, Name of the widget item.
williamr@2
    80
     * @param aValue Integer value of the widget item.
williamr@2
    81
     * @exception HsException
williamr@2
    82
     */
williamr@2
    83
    IMPORT_C void setItem( std::string aItemName, std::string aValue);
williamr@2
    84
    
williamr@2
    85
    /**
williamr@2
    86
     * Adds a new widget item to the widget if it wasn't created previously 
williamr@2
    87
     * or set a new value to the existing one. Widget item is identified by 
williamr@2
    88
     * the name with the value provided. The value is a int.
williamr@2
    89
     *
williamr@2
    90
     * @code
williamr@2
    91
     * HsWidgetPublisher* hsPublisher = new HsWidgetPublisher( dataObserver );
williamr@2
    92
     * HsWidget& widget =  hsPublisher->createHsWidget( 
williamr@2
    93
     *     "templateName", "widgetName", "uniqueIdentifier" );
williamr@2
    94
     * // assuming count and values[] are defined
williamr@2
    95
     * while ( count )
williamr@2
    96
     * {
williamr@2
    97
     *    widget->setItem("image", values[count] );
williamr@2
    98
     *    count--;
williamr@2
    99
     * }
williamr@2
   100
     * @endcode
williamr@2
   101
     * @param aItemName, Name of the widget item.
williamr@2
   102
     * @param aValue Integer value of the widget item.
williamr@2
   103
     * @exception HsException
williamr@2
   104
     */
williamr@2
   105
    IMPORT_C void setItem( std::string aItemName, int aValue );
williamr@2
   106
    
williamr@2
   107
    /**
williamr@2
   108
     * Method removes widget's item.
williamr@2
   109
     * An attempt to remove not existing item causes exception with 
williamr@2
   110
     * KErrNotFound reason;
williamr@2
   111
     *
williamr@2
   112
     * @code
williamr@2
   113
     * HsWidgetPublisher* hsPublisher = new HsWidgetPublisher( dataObserver );
williamr@2
   114
     * HsWidget& widget =  hsPublisher->createHsWidget( 
williamr@2
   115
     *     "templateName", "widgetName", "uniqueIdentifier" );
williamr@2
   116
     * widget.setItem( "myItem", "value" );
williamr@2
   117
     * widget.removeItem( "myItem" );
williamr@2
   118
     * hsPublisher->removeHsWidget(
williamr@2
   119
     *     "templateName", "widgetName", "uniqueIdentifier" );
williamr@2
   120
     * @endcode
williamr@2
   121
     * @param aItemName Name of the Item.
williamr@2
   122
     * @param aWidgetName Name of the Widget
williamr@2
   123
     * @param aIdentifier Unique identification of the content.
williamr@2
   124
     * @exception HsException
williamr@2
   125
     */
williamr@2
   126
    IMPORT_C void removeItem( std::string aItemName );
williamr@2
   127
    
williamr@2
   128
public: 
williamr@2
   129
    
williamr@2
   130
    /**
williamr@2
   131
     */
williamr@2
   132
	HsWidget( std::string& aTemplateName, 
williamr@2
   133
        std::string& aWidgetName,
williamr@2
   134
        std::string& aIdentifier );
williamr@2
   135
williamr@2
   136
    /**
williamr@2
   137
     */
williamr@2
   138
    virtual ~HsWidget();
williamr@2
   139
    
williamr@2
   140
    /**
williamr@2
   141
     */
williamr@2
   142
    HsWidgetItem* getWidgetItem( std::string& aItemName );
williamr@2
   143
williamr@2
   144
    /**
williamr@2
   145
     */
williamr@2
   146
    const std::string& getWidgetName();
williamr@2
   147
    
williamr@2
   148
    /**
williamr@2
   149
     */
williamr@2
   150
    const std::string& getTemplateName();
williamr@2
   151
    
williamr@2
   152
    /**
williamr@2
   153
     */
williamr@2
   154
    const std::string& getIdentifier();
williamr@2
   155
    
williamr@2
   156
    /**
williamr@2
   157
     */
williamr@2
   158
    int itemsCount();
williamr@2
   159
    
williamr@2
   160
    /**
williamr@2
   161
     */
williamr@2
   162
    HsWidgetItem* getWidgetItem( int aIndex );
williamr@2
   163
    
williamr@2
   164
    /**
williamr@2
   165
     */
williamr@2
   166
    bool checkIfWidgetItemExist( std::string& aItemName );
williamr@2
   167
    
williamr@2
   168
private:
williamr@2
   169
    std::string mWidgetName;
williamr@2
   170
    std::string mTemplateName;
williamr@2
   171
    std::string mIdentifier;
williamr@2
   172
    std::vector<HsWidgetItem*> mItems;
williamr@2
   173
    };
williamr@2
   174
williamr@2
   175
}
williamr@2
   176
williamr@2
   177
williamr@2
   178
#endif /*__HSWIDGET_H__*/