omads/omadsextensions/adapters/sms/inc/snapshotitem.h
author hgs
Tue, 13 Jul 2010 03:39:25 +0530
changeset 40 b63e67867dcd
permissions -rw-r--r--
201025
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
40
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2005-2007 Nokia Corporation and/or its subsidiary(-ies). 
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  Private snapshot item header
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef __SNAPSHOTITEM_H__
hgs
parents:
diff changeset
    20
#define __SNAPSHOTITEM_H__
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// INCLUDES
hgs
parents:
diff changeset
    23
#include <msvids.h>
hgs
parents:
diff changeset
    24
#include <nsmlsnapshotitem.h>
hgs
parents:
diff changeset
    25
#include "smsdataproviderdefs.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
typedef TBuf<KMaxFolderNameLength> TFolderName;
hgs
parents:
diff changeset
    28
hgs
parents:
diff changeset
    29
// CLASS DECLARATION
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
/**
hgs
parents:
diff changeset
    32
* @brief TSnapshotItem
hgs
parents:
diff changeset
    33
* This class represents a single item in the ChangeFinder snapshot.
hgs
parents:
diff changeset
    34
* It's derived from the generic snapshot item and extended
hgs
parents:
diff changeset
    35
* to contain the read/unread information, which is mandatory when 
hgs
parents:
diff changeset
    36
* partial update of the messages is required.
hgs
parents:
diff changeset
    37
*/
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
class TSnapshotItem : public TNSmlSnapshotItem
hgs
parents:
diff changeset
    40
	{ 
hgs
parents:
diff changeset
    41
public:
hgs
parents:
diff changeset
    42
	
hgs
parents:
diff changeset
    43
	/**
hgs
parents:
diff changeset
    44
    * Constructor
hgs
parents:
diff changeset
    45
    */
hgs
parents:
diff changeset
    46
	TSnapshotItem();
hgs
parents:
diff changeset
    47
hgs
parents:
diff changeset
    48
	/**
hgs
parents:
diff changeset
    49
    * Constructor
hgs
parents:
diff changeset
    50
    * 
hgs
parents:
diff changeset
    51
    * @param aItemId   IN: id of the item.
hgs
parents:
diff changeset
    52
    * @param aParent   IN: parent item, 0 as default.
hgs
parents:
diff changeset
    53
    * @param aUnread   IN: read/unread information, the default is read.
hgs
parents:
diff changeset
    54
    */
hgs
parents:
diff changeset
    55
	TSnapshotItem( const TSmlDbItemUid& aItemId, const TSmlDbItemUid& aParent = 0, TBool aUnread = EFalse );
hgs
parents:
diff changeset
    56
	
hgs
parents:
diff changeset
    57
	/**
hgs
parents:
diff changeset
    58
    * Writes the item to a stream.
hgs
parents:
diff changeset
    59
    * 
hgs
parents:
diff changeset
    60
    * @param aStream   IN: a reference to a stream, where this item is to be written.
hgs
parents:
diff changeset
    61
    */
hgs
parents:
diff changeset
    62
	void ExternalizeL( RWriteStream& aStream ) const;
hgs
parents:
diff changeset
    63
hgs
parents:
diff changeset
    64
	/**
hgs
parents:
diff changeset
    65
    * Reads item from a stream.
hgs
parents:
diff changeset
    66
    * 
hgs
parents:
diff changeset
    67
    * @param aStream   IN: a reference to a stream, where this item is read from.
hgs
parents:
diff changeset
    68
    */
hgs
parents:
diff changeset
    69
	void InternalizeL( RReadStream& aStream );	
hgs
parents:
diff changeset
    70
	
hgs
parents:
diff changeset
    71
	/**
hgs
parents:
diff changeset
    72
    * Sets the read flag
hgs
parents:
diff changeset
    73
    * 
hgs
parents:
diff changeset
    74
    * @param aState   IN: a new state.
hgs
parents:
diff changeset
    75
    */
hgs
parents:
diff changeset
    76
	void SetUnread( TBool aState ); 
hgs
parents:
diff changeset
    77
	
hgs
parents:
diff changeset
    78
	/**
hgs
parents:
diff changeset
    79
    * Sets the read flag
hgs
parents:
diff changeset
    80
    * 
hgs
parents:
diff changeset
    81
    * @return TBool, ETrue if the item is not read and EFalse if it has been read.
hgs
parents:
diff changeset
    82
    */
hgs
parents:
diff changeset
    83
	TBool Unread() const;	
hgs
parents:
diff changeset
    84
	
hgs
parents:
diff changeset
    85
	void SetFolderNameL( const TDesC& aFolderName );
hgs
parents:
diff changeset
    86
	
hgs
parents:
diff changeset
    87
	const TDesC& FolderName() const;
hgs
parents:
diff changeset
    88
	
hgs
parents:
diff changeset
    89
private:
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
    /**
hgs
parents:
diff changeset
    92
    * Read / Unread information
hgs
parents:
diff changeset
    93
    */
hgs
parents:
diff changeset
    94
	TBool       iUnread;
hgs
parents:
diff changeset
    95
	
hgs
parents:
diff changeset
    96
	TFolderName iFolderName;
hgs
parents:
diff changeset
    97
    };
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
#endif