calendarui/views/inc/calendayviewwidget.h
branchGCC_SURGE
changeset 54 e6894b852bc6
parent 40 4b686cfad39d
parent 53 e08ac1a3ba2b
--- a/calendarui/views/inc/calendayviewwidget.h	Tue Jun 15 15:22:54 2010 +0100
+++ /dev/null	Thu Jan 01 00:00:00 1970 +0000
@@ -1,352 +0,0 @@
-/*
-* Copyright (c) 2009 Nokia Corporation and/or its subsidiary(-ies).
-* All rights reserved.
-* This component and the accompanying materials are made available
-* under the terms of "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:  CalenDayViewWidget class definition.
-*
-*/
-
-#ifndef CALENDAYVIEWWIDGET_H
-#define CALENDAYVIEWWIDGET_H
-
-// System includes
-#include <QGraphicsLinearLayout>
-#include <QDateTime>
-#include <hbwidget.h>
-
-// User includes
- 
-// Forward declarations
-class QStandardItemModel;
-class QGraphicsSceneMouseEvent; // TODO: Remove this after gestures are supported
-class HbAbstractViewItem;
-class HbGroupBox;
-class HbListView;
-class HbLabel;
-class HbAction;
-class HbDateTimePicker;
-class XQSettingsManager;
-class MCalenServices;
-class CalenDayView;
-class AgendaEntry;
-class CalenDocLoader;
-class CalenEventListViewItem;
-class NotesEditor;
-
-/**
- * @class CalenDayViewWidget
- * @brief The content widget for the day/agenda view.
- * It is responsible for showing all the events &/ to-do's
- * (if any) for a particular day selected by the user
- */
-class CalenDayViewWidget : public HbWidget
-    {
-    Q_OBJECT
-
-public:
-    
-    /**
-     * @brief Constructor
-     * @param services The reference to the MCalenServices object
-     * @param docLoader The document loader object
-     */
-	IMPORT_C CalenDayViewWidget(MCalenServices &services,
-	                                 CalenDocLoader *docLoader);
-	
-	/**
-	 * @brief Default C++ destructor
-	 */
-	IMPORT_C ~CalenDayViewWidget();
-	
-	/**
-	 * @brief Initializes the widget to show all the events/to-do's
-	 * for the selected day
-	 * @param view Pointer to the view to which this is the content
-	 */
-    void setupWidget(CalenDayView *view);
-    
-    /**
-     * @brief Prepares the widget to be shown.
-     * Initializes the widget with the day's events and other details 
-     */
-    void showWidget();
-    
-    /**
-     * @brief Called from the view whenever the orientation of the
-     * device changes
-     */
-    void orientationChanged(Qt::Orientation);
-    
-    /**
-     * @brief Callback function to handle system locale change
-     */
-    void handleLocaleChange();
-    
-    /**
-     * @brief clears the list model from the view
-     */
-    void clearListModel();
-    
-private:
-    
-    /**
-     * @brief Sets the context based on the item selected by the user
-     * @param entry The entry using which the context is deduced
-     */
-    void setContextFromHighlight(AgendaEntry entry);
-    
-    /**
-     * @brief Initializes the child widgets of this widget
-     */
-    void initChildWidgets();
-    
-    /**
-     * @brief Populates the list with the events for the current day.
-     * Does nothing if the day has no events. To be called whenever
-     * the view has to be refreshed
-     */
-    void populateListWidget();
-    
-    /**
-     * @brief Gets the instance list for day
-     */
-    void getInstanceList();
-    
-    /**
-     * @brief Sets the heading text to show the date for which this
-     * widget is being shown
-     */
-    void setHeadingText();
-    
-    /**
-     * @brief Creates and adds an item to the list at position index
-     * @param index The position in the list when the item is added
-     * @param entry The entry whose details must be shown in the item
-     */
-    void createListItem(int index, AgendaEntry entry);
-    
-    /**
-     * @brief Creates and add a list item for the event
-     * @param index The position in the list when the item is added
-     * @param entry The entry whose details must be shown in the item
-     */
-    void addTimedEventToList(int index, AgendaEntry entry);
-    
-    /**
-     * @brief Creates and add a list item for the event which is non timed
-     * @param index The position in the list when the item is added
-     * @param entry The entry whose details must be shown in the item
-     */
-    void addNonTimedEventToList(int index, AgendaEntry entry);
-    
-    /**
-     * @brief Sets strecthing to list items showing non-timed events
-     */
-    void handleListItemStretching(Qt::Orientation orientation);
-    
-    /**
-     * @brief Returns the index in the list to which scrolling must
-     * happen. For ex: After creating a new event, the list must scroll
-     * to the newly created event
-     */
-    int getIndexToScrollTo();
-    
-    /**
-     * @brief To Show and hide regional plugin label depends upon settings
-     */
-    
-    void showHideRegionalInformation();
-    
-private slots:
-
-    /**
-     * @brief Opens the editor to create a new entry
-     */
-    void createNewEvent();
-    
-    /**
-     * @brief Opens the entry at position index in the list for
-     * editing in the editor. Does nothing if the index is invalid
-     */
-    void editEntry();
-    
-    /**
-     * @brief Opens the entry at position index in the list for
-     * viewing in the viewer. Does nothing if the index is invalid
-     */
-    void viewEntry();
-	
-    /**
-     * @brief Deletes the entry at position index in the list.
-     * Does nothing if the list is empty
-     */
-    void deleteEntry();
-    
-    /**
-     * @brief Marks a to-do as done
-     */
-    void markAsDone(); 
-    
-    /**
-     * @brief Handles long press on a particular item. Presents a
-     * context menu with various operations that the user can
-     * perform
-     * @param ite, The index item which is being long pressed
-     * @param coords The (x, y) co-ordinates where the long tap has
-     * occured
-     */
-    void itemLongPressed(HbAbstractViewItem *item, const QPointF &coords);
-    
-    /**
-     * @brief Handles user selection on a particular item of a
-     * particular event in the list. Default action is to view it
-     * @param index Index of the item which was selected 
-     */
-    void itemActivated(const QModelIndex &index);
-    
-    /**
-     * @brief Called whenever a editing a to-do is completed
-     * @param status Inidcates if the editing was successful or not
-     */
-    void noteEditingCompleted(bool status);
-    
-    /**
-     * @brief Callback function for navigating to today's agenda
-     * This option must be available only if the view is showing
-     * events for some day other than the current day
-     */
-    void goToToday();
-    
-    /**
-     * @brief This slot connected to aboutToClose()signal of contextmenu
-     * To reset the flag of mLongTapEventFlag
-     */
-    void contextMenuClosed();
-    
-    /**
-     * @brief Called when contextMenu item is triggered
-     */
-    void contextManuTriggered(HbAction *action);
-
-private:
-    /**
-     * @var mDate
-     * @brief Stores the date for which this widget is being shown
-     */
-    QDateTime mDate;
-    
-    /**
-     * @var mInstanceArray
-     * @brief Holds the list of instances for the day
-     */
-    QList<AgendaEntry> mInstanceArray;
-    
-    /**
-     * @var mHeadingLabel
-     * @brief The heading widget which shows the date
-     */
-    HbGroupBox *mHeadingLabel;
-    
-    /**
-     * @var mEventsList
-     * @brief The list view which shows the list of events
-     */
-    HbListView *mEventsList;
-
-    /**
-     * @var mServices
-     * @brief The reference to the MCalenServices object
-     */
-    MCalenServices &mServices;
-    
-    /**
-     * @var mView
-     * @brief The pointer to the view
-     */
-    CalenDayView *mView;
-    
-    /**
-     * @var mDocLoader
-     * @brief The pointer to the document loader which has
-     * loaded this widget
-     */
-    CalenDocLoader *mDocLoader;
-    
-    /**
-     * @var mListViewPrototype
-     * @brief Acts as the item prototype for list view.
-     * Allows providing own layout for list items
-     */
-    CalenEventListViewItem *mListViewPrototype;
-	
-    /**
-     * @var mEmptyListLabel
-     * @brief The pointer to the empty view label
-     */
-	HbLabel *mEmptyListLabel;
-	
-	/**
-	 * @var mListModel
-	 * @brief The event list model
-	 */
-	QStandardItemModel *mListModel;
-	
-	/**
-	 * @var mSelectedIndex
-	 * @brief Stores the index of the item being acted upon
-	 * Since there is no focus, it becomes necessary to store the
-	 * index of the item on which user is performing some action
-	 */
-	int mSelectedIndex;
-	
-	/**
-	 * @var NotesEditor
-	 * @brief Pointer to the notes editor
-	 */
-	NotesEditor *mNotesEditor;
-	
-	/**
-	 * @var mDatePicker
-	 * @brief The date picker component
-	 */
-	HbDateTimePicker *mDatePicker;
-	
-	/**
-	 * @var mRegionalPluginLayout
-	 * @brief Regional Plugin layout pointer
-	 */
-	QGraphicsLinearLayout* mRegionalPluginLayout;
-	
-	/**
-	 * @var mRegionalInfoGroupBox
-	 * @brief Regional Plugin Info groupbox
-	 */
-	HbGroupBox *mRegionalInfoGroupBox;
-
-	/**
-	 * @var mSettingsManager
-	 * @brief Setting Manager pointer
-	 */
-	
-	XQSettingsManager *mSettingsManager;
-	
-	/**
-	 * @var mLongTapeventFlag
-	 * @brief Set flag true if contextmenu is opened
-	 */
-	bool mLongTapEventFlag;
-	
-};
-
-#endif //CALENDAYVIEWWIDGET_H
-
-// End of file	--Don't remove this.