--- a/src/hbwidgets/widgets/hbdatetimepicker.cpp Mon Oct 04 17:49:30 2010 +0300
+++ b/src/hbwidgets/widgets/hbdatetimepicker.cpp Mon Oct 18 18:23:13 2010 +0300
@@ -26,66 +26,164 @@
#include "hbdatetimepicker.h"
#include "hbdatetimepicker_p.h"
#include "hbstyleoption_p.h"
+#include "hbframeitem.h"
+#include "hbstyleprimitivedata.h"
+#include <hbstyleframeprimitivedata.h>
/*!
@beta
\class HbDateTimePicker
- \brief HbDateTimePicker class provides a widget for picking the date, time, date and time. <br>
+ \brief The HbDateTimePicker class provides a widget that has multiple vertical tumblers
+ for selecting a date, time, or date and time by flick, drag and tap gestures.
+
+ The number of tumblers depends on the display format. The default constructor creates
+ a widget for selecting a date by internally setting the display format to the default
+ locale's short date format. Other constructors enable you to create a widget
+ for selecting a time or date and time by passing a QTime or QDateTime variable as an
+ argument. Internally these constructors set the display format to the default locale's
+ short time or date and time format, respectively.
+
+ Use setDisplayFormat() to set the display format. Be aware that changing the display format
+ can change the widget from one for selecting the date to one for selecting the time, for
+ example.
+
+ Looping is enabled in the tumblers. The general appearance of the widget depends on the
+ theme that is in use.
+
+ <TABLE border="0">
+ <TR><TD>\image html hbdatetimepicker_date.png "Display format: d.MMMM"</TD>
+ <TD></TD>
+ <TD>\image html hbdatetimepicker_time.png "Display format: h.m.AP"</TD></TR>
+ </TABLE>
- By default date picker will be created, with date functionality only.
- For exclusive time or datetime picker creation, use QTime or QDateTime variable as parameter for the constructor.
- \li Date and Time
- \li Date
- \li Time
+ You can set the range of values available in the tumblers by defining minimum and maximum
+ values or using convenience range functions. If you change the range, if necessary
+ the widget changes the displayed values so that they are within the new range. Users
+ cannot select a value outside the range. One effect of this is that if you set,
+ for example, an afternoon time range, users cannot scroll to the AM value when the
+ display format includes an AM/PM tumbler. The date range is currently independent of the
+ time range.
+
+ You can use setInterval() to define the increments for the minute tumbler. This is
+ useful when you want users to be able to set the time in 15 minute increments, for example.
+
+ The number of rows displayed depends on how much space is available. To change the number
+ of rows shown when the widget is is in a layout, for example, use
+ QGraphicsLayoutItem::setPreferredHeight() to increase the space available. The widget then
+ increases the number of rows to occupy the available space.
- Below is a sample code snippet for datetime picker creation:
- \snippet{ultimatecodesnippet/ultimatecodesnippet.cpp,51}
+ %HbDateTimePicker emits a dateChanged(), timeChanged() or dateTimeChanged() signal when
+ the user selects a new value. The selected date, time, or date and time value is passed
+ in a QDate, QTime, or QDateTime argument.
+
+ \section _usecases_hbdatetimepicker Using HbDateTimePicker
+
+ The following example demonstrates creating a widget for selecting a date:
+
+ \code
+ // Use the default constructor to create a widget for selecting a date.
+ HbDateTimePicker *datePicker = new HbDateTimePicker();
+
+ // Set the minumum and maximum dates to display.
+ datePicker->setMinimumDate(QDate::currentDate());
+ datePicker->setMaximumDate(QDate::currentDate().addDays(365));
- By default, display format is from HbExtendedLocale. User can set the format using setDisplayFormat API. \sa setDisplayFormat.<br>
- Based on the display format the tumblers or sections will be rearranged.<br>
- For each tumbler(TumbleView) in datetime picker, loopingEnabled property is always true.<br>
+ // Specify the display format.
+ datePicker->setDisplayFormat("dd.MMMM.yyyy");
+ \endcode
+
+ The following example demonstrates connecting the dateChanged() signal to a slot
+ on an object, \a d, of a class (not shown). This has a \c setMeetingDate() function
+ that takes a QDate argument.
+
+ \code
+ QObject::connect(datePicker, SIGNAL(dateChanged(const QDate&)),
+ d, SLOT(setMeetingDate(const QDate&)));
+ \endcode
+
+ The following example demonstrates creating a widget for selecting a time:
+
+ \code
+ // Create a widget for selecting a time.
+ HbDateTimePicker *timePicker = new HbDateTimePicker(QTime());
+
+ // Set the minimum and maximum times using the convenience range method.
+ timePicker->setTimeRange(QTime::currentTime(),
+ QTime::currentTime().addSecs(10*60*60));
+
+ // Set the time interval to be 15 minutes.
+ timePicker->setInterval(QDateTimeEdit::MinuteSection, 15);
+
+ // Specify the display format.
+ timePicker->setDisplayFormat("hh:mm.ap");
+ \endcode
+
+ The following example demonstrates creating a widget for selecting a date and time:
- HbDateTimePicker provides various date and time range functionalities.<br>
- Currently the date range is independent of the time range.
- \sa setDateRange \sa setTimeRange \sa setDateTimeRange
- \sa setMinimumTime \sa setMaximumTime \sa setMinimumDate \sa setMaximumDate
- \sa setMinimumDateTime \sa setMaximumDateTime
+ \code
+ // Create a widget for selecting a date and time.
+ HbDateTimePicker *dateTimePicker =
+ new HbDateTimePicker(QDateTime::currentDateTime());
- \image html hbdatetimepicker_date.png "Datetime picker with date functionalities, in d/MMMM format"
- \image html hbdatetimepicker_time.png "Datetime picker with time functionalities, in h.m.AP format"
-
- <b>Note:</b>Graphics in the above images varies depending on theme.
+ // Specify the display format.
+ dateTimePicker->setDisplayFormat("dd.MM.yyyy.hh.mm.ap");
+ \endcode
+
+ The properties that hold the minimum and maximum values take a QDate, QTime
+ or QDateTime object as an argument. DocML does not directly support properties that
+ use QDate, QTime or QDateTime as a parameter. This means that when you add an \b %HbDateTimePicker
+ widget in Application Designer, you must pass the date, time and date and time to these
+ properties as a string in a valid ISO 8601 extended format. For example, YYYY-MM-DD for dates,
+ hh:mm:ss for times, and YYYY-MM-DDTHH:MM:SS for combined dates and times.
+
+ Here is an example of the \c maximumTime property defined in DocML:
+
+ \code
+ <widget name="t:dtp" type="HbDateTimePicker">
+ <!-- 'maximumTime' is a QTime property of HbDateTimePicker. -->
+ <string name ="displayFormat" value="hh:mm:ss" />
+ <string name="maximumTime" value="08:30:00" />
+ </widget>
+ \endcode
+
+ \section _methodgroups_HbDateTimePicker Function groups
+
+ \li \b Range: setDateRange(), setTimeRange(), setDateTimeRange()
+ \li \b Minimum \b value: setMinimumDate(), setMinimumTime(), setMinimumDateTime()
+ \li \b Maximum \b value: setMaximumDate(), setMaximumTime(), setMaximumDateTime()
+ \li \b Time \b interval: setInterval()
+
+ \sa HbTumbleView, HbExtendedLocale
*/
/*!
- \fn void dateChanged(const QDate &date)
+ \fn void HbDateTimePicker::dateChanged(const QDate &date);
- This signal is emitted when item selection changes in any of the date pickers(day, month, year) in the datetimepicker widget.
-
- \param date selected by the user.
+ This signal is emitted when there is a change in the day, month or year selected.
+ The new date is passed in \a date.
*/
/*!
- \fn void timeChanged(const QTime &time)
+ \fn void HbDateTimePicker::timeChanged(const QTime &time);
- This signal is emitted when item selection changes in any of the time pickers(hour, minute, second, am/pm) in the datetimepicker widget.
- \param time selected by the user.
+ This signal is emitted when there is a change in the hour, minute, second, or AM/PM
+ selected. The new time is passed in \a time.
*/
/*!
- \fn void dateTimeChanged(const QDateTime &datetime)
+ \fn void HbDateTimePicker::dateTimeChanged(const QDateTime &datetime);
- This signal is emitted when item selection changes in any of the date and time pickers in the datetimepicker widget.
- \param datetime selected by the user.
+ This signal is emitted when there is a change in the value selected in any of the
+ tumblers in a date and time picker. The new date and time are passed in \a dateTime.
*/
/*!
- Constructs date picker widget by default.
+ Constructs an %HbDateTimePicker object with the locale's default short date display format
+ and with parent \a parent.
- \param parent parent item for datetime picker widget.
*/
HbDateTimePicker::HbDateTimePicker( QGraphicsItem *parent ):
HbWidget(*new HbDateTimePickerPrivate, parent)
@@ -99,8 +197,9 @@
}
/*!
- Constructs datetime picker widget with both date and time functionalities and with default locale's datetime format.
- \param datetime Value to be set on datetime picker widget, which has both date and time related tumblers.
+ Constructs an %HbDateTimePicker object with the locale's default short date and time
+ display format and with parent \a parent.
+
*/
HbDateTimePicker::HbDateTimePicker(const QDateTime &datetime, QGraphicsItem *parent ):
HbWidget(*new HbDateTimePickerPrivate, parent)
@@ -112,9 +211,9 @@
}
/*!
- Constructs datetime picker widget with only date functionalities and with default locale's date format.
-
- \param date QDate value.
+ Constructs an %HbDateTimePicker object with the locale's default short date
+ display format and with parent \a parent.
+
*/
HbDateTimePicker::HbDateTimePicker(const QDate &date, QGraphicsItem *parent ):
HbWidget(*new HbDateTimePickerPrivate, parent)
@@ -126,9 +225,9 @@
}
/*!
- Constructs datetime picker widget with only time functionalities and with with default locale's time format.
+ Constructs an %HbDateTimePicker object with the locale's default time
+ display format and with parent \a parent.
- \param time QTime value.
*/
HbDateTimePicker::HbDateTimePicker(const QTime &time, QGraphicsItem *pParent ):
HbWidget(*new HbDateTimePickerPrivate, pParent)
@@ -140,12 +239,13 @@
}
/*!
- \internal
Protected constructor for derivations.
- the default mode is DateTimeMode, if other mode is required, set the mDateTimeMode variable.
- this does not set any default datetime, needs to be explicitly done in the derived constructor.
+
+ The default mode is date and time. If another mode is required, set the mDateTimeMode
+ variable explicitly in the constructor of the class derived from HbDateTimePicker. This
+ does not set the default date and time value.
- \sa setDateTime, setTime, setDate
+ \sa setDateTime(), setTime(), setDate()
*/
HbDateTimePicker::HbDateTimePicker(HbDateTimePickerPrivate &dd, QGraphicsItem *parent):
HbWidget(dd, parent)
@@ -155,18 +255,22 @@
d->init(QVariant::DateTime);
}
-/*!
- \reimp
-*/
+
bool HbDateTimePicker::event(QEvent *e)
-{
+{
+ Q_D(HbDateTimePicker);
+
bool result = HbWidget::event(e);
- if (e->type()==QEvent::LayoutRequest) {
+ if(e->type() == d->mFormatEventType){
+ d->processFormatEvent();
+ }
+ else if (e->type()==QEvent::LayoutRequest) {
updatePrimitives();
}
return result;
}
+
/*!
Destructor.
*/
@@ -175,9 +279,7 @@
}
/*!
- Returns current display format as QString value.
-
- \return display format of datetime picker widget.
+ Returns the current display format as a QString value.
\sa setDisplayFormat()
*/
@@ -188,37 +290,48 @@
}
/*!
- Sets the display \a format . eg: DDMMYY, MMDDYY
+ Sets the display format using a suitable combination of the following expressions
+ in QString format.
- These expressions may be used for the format:
+ These expressions may be used for the date:
<TABLE>
- <TR><TD><b><i> Expression </TD><TD> Output </TD></i></b></TR>
- <TR><TD> d </TD><TD><i> The day as a number without a leading zero (1 to 31)</i></TD></TR>
- <TR><TD> dd </TD><TD><i> The day as a number with a leading zero (01 to 31) </i></TD></TR>
- <TR><TD> ddd </TD><TD><i>
- The abbreviated localized day name (e.g. 'Mon' to 'Sun').
- Uses QDate::shortDayName().</i></TD></TR>
- <TR><TD> dddd </TD><TD><i>
- The long localized day name (e.g. 'Monday' to 'Sunday').
- Uses QDate::longDayName().</i></TD></TR>
- <TR><TD> M </TD><TD><i> The month as a number without a leading zero (1 to 12)</i></TD></TR>
- <TR><TD> MM </TD><TD><i> The month as a number with a leading zero (01 to 12)</i></TD></TR>
- <TR><TD> MMM </TD><TD><i>
- The abbreviated localized month name (e.g. 'Jan' to 'Dec').
- Uses QDate::shortMonthName().</i></TD></TR>
- <TR><TD> MMMM </TD><TD><i>
- The long localized month name (e.g. 'January' to 'December').
- Uses QDate::longMonthName().</i></TD></TR>
- <TR><TD> yy </TD><TD><i> The year as two digit number (00 to 99)</i></TD></TR>
- <TR><TD> yyyy </TD><TD><i> The year as four digit number. If the year is negative,
- a minus sign is prepended in addition.</i></TD></TR>
+ <TR><TD><b><b>Expression </b></TD><TD><b>Output</b> </TD></b></TR>
+ <TR><TD> d </TD><TD> The day as a number without a leading zero (1 to 31).</TD></TR>
+ <TR><TD> dd </TD><TD> The day as a number with a leading zero (01 to 31). </TD></TR>
+ <TR><TD> ddd </TD><TD>The abbreviated localized day name (such as <i>Mon</i> to <i>Sun</i>).
+ Uses QDate::shortDayName().</TD></TR>
+ <TR><TD> dddd </TD><TD>The long localized day name (such as <i>Monday</i> to <i>Sunday</i>).
+ Uses QDate::longDayName().</TD></TR>
+ <TR><TD> M </TD><TD> The month as a number without a leading zero (1 to 12).</TD></TR>
+ <TR><TD> MM </TD><TD> The month as a number with a leading zero (01 to 12).</TD></TR>
+ <TR><TD> MMM </TD><TD>The abbreviated localized month name (such as <i>Jan</i> to <i>Dec</i>).
+ Uses QDate::shortMonthName().</TD></TR>
+ <TR><TD> MMMM </TD><TD>The long localized month name (such as <i>January</i> to <i>December</i>).
+ Uses QDate::longMonthName().</TD></TR>
+ <TR><TD> yy </TD><TD>The year as a two digit number (00 to 99).</TD></TR>
+ <TR><TD> yyyy </TD><TD>The year as a four digit number. If the year is negative,
+ a minus sign is prepended.</TD></TR>
+ </TABLE>
+
+ These expressions may be used for the time:
+
+ <TABLE>
+ <TR><TD><b><b>Expression </b></TD><TD><b>Output</b> </TD></b></TR>
+ <TR><TD> h </TD><TD>The hour without a leading zero (0 to 23 or 1 to 12).</TD></TR>
+ <TR><TD> hh </TD><TD>The hour with a leading zero (00 to 23 or 01 to 12). </TD></TR>
+ <TR><TD>H </TD><TD>The hour without a leading zero (0 to 23, even with AM/PM display).</TD></TR>
+ <TR><TD>HH </TD><TD>The hour with a leading zero (00 to 23, even with AM/PM display).</TD></TR>
+ <TR><TD> m </TD><TD>The minute without a leading zero (0 to 59).</TD></TR>
+ <TR><TD> mm </TD><TD>The minute with a leading zero (00 to 59).</TD></TR>
+ <TR><TD> s </TD><TD>The second without a leading zero (0 to 59).</TD></TR>
+ <TR><TD> ss </TD><TD>The second with a leading zero (00 to 59).</TD></TR>
+ <TR><TD>AP or A </TD><TD>Displays AM and PM.</i></TD></TR>
+ <TR><TD>ap or a </TD><TD>Displays am and pm.</TD></TR>
</TABLE>
- NOTE:setDisplayFormat works only when the separators are mentioned in the format like 'dd.mm.yy' or 'dd mm yy', this
- will be fixed in the future versions.
-
- \param format is the display format, for datetime picker widget, in QString format.
+ \note Currently you must include separators in the format; for example, 'dd.mm.yy'.
+ \note Use max upto 4 fields like hh:mm:ss:ap in the format. More than 4 fields will not be usable on typical mobile display.
\sa displayFormat()
*/
@@ -226,34 +339,27 @@
{
Q_D(HbDateTimePicker);
- if(d->isFormatValid(format)){
+ if(d->isFormatValid(format)){
d->mFormat = format;
- d->parseDisplayFormat(format);
- d->rearrangeTumbleViews();
- d->emitDateTimeChange();
- }//End If format is valid
+ d->postFormatEvent();
+ }
}
/*!
- Returns the current date in QDate format.
-
- \return current selected date in datetime picker.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the currently selected date in QDate format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QDate as a parameter. For these
+ properties, pass the date as a string in a valid ISO 8601 extended format,
+ such as YYYY-MM-DD.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'date' is a QDate property of HbDateTimePicker. -->
<string name="date" value="02-02-15" />
</widget>
- ...
\endcode
- \sa setDate
+ \sa setDate()
*/
QDate HbDateTimePicker::date() const
{
@@ -263,11 +369,11 @@
}
/*!
- Sets the current \a date in the form of QDate.
+ Sets the current date to \a date.
- \param date date to be set on the datetime picker in QDate format
+ \param date The date in QDate format.
- \sa date
+ \sa date()
*/
void HbDateTimePicker::setDate(const QDate& date)
{
@@ -276,25 +382,19 @@
}
/*!
- Returns minimum date in QDate format.
-
- \return Minimum date set on datetime picker in QDate format.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the minimum date in QDate format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QDate as a parameter. For these
+ properties, pass the date as a string in a valid ISO 8601 extended format, such as YYYY-MM-DD.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'minimumDate' is a QDate property of HbDateTimePicker. -->
<string name="minimumDate" value="02-02-15" />
</widget>
- ...
\endcode
-
- \sa setMinimumDate
+
+ \sa setMinimumDate()
*/
QDate HbDateTimePicker::minimumDate()const
{
@@ -303,11 +403,11 @@
}
/*!
- Sets minimum \a date in QDate format.
+ Sets the minimum date to \a date.
- \param Minimum date to be set on datetime picker in QDate format.
+ \param date The minimum date in QDate format.
- \sa minimumDate
+ \sa minimumDate(), setDateRange()
*/
void HbDateTimePicker::setMinimumDate(const QDate& date)
{
@@ -316,25 +416,19 @@
}
/*!
- Returns maximum date in QDate format.
-
- \return Maximum Date set on datetime picker in QDate format.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the maximum date in QDate format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QDate as a parameter. For these
+ properties, pass the date as a string in a valid ISO 8601 extended format, such as YYYY-MM-DD.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'maximumDate' is a QDate property of HbDateTimePicker. -->
<string name="maximumDate" value="02-02-15" />
</widget>
- ...
\endcode
- \sa setMaximumDate
+ \sa setMaximumDate()
*/
QDate HbDateTimePicker::maximumDate()const
{
@@ -343,11 +437,11 @@
}
/*!
- Sets maximum \a date in QDate format.
+ Sets the maximum date to \a date.
- \param date Maximum date to be set on datetime picker in QDate format.
+ \param date The maximum date in QDate format.
- \sa maximumDate
+ \sa maximumDate(), setDateRange()
*/
void HbDateTimePicker::setMaximumDate(const QDate& date)
{
@@ -356,12 +450,12 @@
}
/*!
- Sets minimum \a minDate and maximum \a maxDate dates in QDate format. This will allow user to set date range on datetime picker.
+ Sets the minimum and maximum dates.
- \param minDate Minimum date in QDate format.
- \param maxDate Maximum date in QDate format.
+ \param minDate The minimum date in QDate format.
+ \param maxDate The maximum date in QDate format.
- \sa setMinimumDate \sa setMaximumDate
+ \sa setMinimumDate(), setMaximumDate()
*/
void HbDateTimePicker::setDateRange(const QDate &minDate, const QDate &maxDate)
{
@@ -371,25 +465,21 @@
}
/*!
- Returns the current date and time value, selected in datetime picker, in QDateTime format.
-
- \return date and time value in QDateTime format.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the currently selected date and time in QDateTime format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QDate, QTime or QDateTime as a
+ parameter. For these properties, pass the date, time or date and time as a string in a
+ valid ISO 8601 extended format. For example, YYYY-MM-DD for dates and YYYY-MM-DDTHH:MM:SS
+ for combined dates and times.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'dateTime' is a QDateTime property of HbDateTimePicker. -->
<string name="dateTime" value="02-02-15T02-15-30" />
</widget>
- ...
\endcode
- \sa setDateTime
+ \sa setDateTime()
*/
QDateTime HbDateTimePicker::dateTime()const
{
@@ -398,11 +488,11 @@
}
/*!
- Sets the current \a datetime value to be set on datetime picker in QDateTime format.
+ Sets the current date and time.
- \param datetime in QDateTime format.
+ \param datetime The date and time in QDateTime format.
- \sa dateTime
+ \sa dateTime()
*/
void HbDateTimePicker::setDateTime(const QDateTime &datetime)
{
@@ -411,25 +501,21 @@
}
/*!
- Returns minimum date time value set on datetime picker in QDateTime format.
-
- \return Minimum date and minimum time in QDateTime format.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the minimum date and time in QDateTime format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QDate, QTime or QDateTime as a
+ parameter. For these properties, pass the date, time or date and time as a string in a
+ valid ISO 8601 extended format. For example, YYYY-MM-DD for dates and YYYY-MM-DDTHH:MM:SS
+ for combined dates and times.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'minimumDateTime' is a QDateTime property of HbDateTimePicker. -->
<string name="minimumDateTime" value="02-02-15T02-15-30" />
</widget>
- ...
\endcode
- \sa setMinimumDateTime
+ \sa setMinimumDateTime()
*/
QDateTime HbDateTimePicker::minimumDateTime()const
{
@@ -438,14 +524,14 @@
}
/*!
- Sets minimum \a datetime for datetime picker in QDateTime format.
+ Sets the minimum date and time.
- <b>Note:</b> There's no link between Date functionality and time functionality in this API. Using this API, for now,
- would be similar to using a combination of setMinimumDate and setMinimumTime APIs.
+ \note The date and time are not linked in this API. This means that
+ calling this function is similar to calling setMinimumDate() and setMinimumTime().
- \param datetime minimum date and minimum time in QDateTime format.
+ \param datetime The minimum date and time in QDateTime format.
- \sa minimumDateTime \sa setMinimumDate \sa setMinimumTime
+ \sa minimumDateTime(), setDateTimeRange()
*/
void HbDateTimePicker::setMinimumDateTime(const QDateTime& datetime)
{
@@ -454,25 +540,21 @@
}
/*!
- Returns maximum date time, set on datetime picker, in QDateTime format.
-
- \return Maximum date and maximum time in QDateTime format.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the maximum date and time in QDateTime format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QDate, QTime or
+ QDateTime as parameters. For these properties, pass the date, time, or date and time
+ as a string in a valid ISO 8601 extended format. For example, YYYY-MM-DD for dates
+ or YYYY-MM-DDTHH:MM:SS for combined dates and times.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'maximumDateTime' is a QDateTime property of HbDateTimePicker. -->
<string name="maximumDateTime" value="02-02-15T02-15-30" />
</widget>
- ...
\endcode
- \sa setMaximumDateTime
+ \sa setMaximumDateTime()
*/
QDateTime HbDateTimePicker::maximumDateTime()const
{
@@ -481,14 +563,14 @@
}
/*!
- Sets maximum \a datetime, to be set on datetime picker, in QDateTime format.
+ Sets the maximum date and time.
- <b>Note:</b> There's no link between Date functionality and time functionality in this API, using this API for now
- would be similar to using a combination of setMaximumDate and setMaximumTime APIs.
+ \note The date and time are not linked in this API. This means that
+ calling this function is similar to calling setMaximumDate() and setMaximumTime().
- \param date Maximum date and maximum time in QDateTime format.
+ \param date The maximum date and time in QDateTime format.
- \sa maximumDateTime \sa setMaximumDate \sa setMaximumTime
+ \sa maximumDateTime(), setDateTimeRange()
*/
void HbDateTimePicker::setMaximumDateTime(const QDateTime& date)
{
@@ -497,18 +579,16 @@
}
/*!
- Sets minimum \a minDatetime and maximum \a maxDatetime date and time values, to be set on datetime picker, in QDateTime format.
- This will allow the user to set date and time range on datetime picker.
+ Sets the minimum and maximum date and time.
+
+ \note The date and time are not linked in this API. This means that calling
+ this function is equivalent to calling setMinimumDate(), setMaximumDate(),
+ setMinimumTime(), and setMaximumTime().
- <b>Note:</b> There's no link between Date and time in this API, using this API for now
- would be similar to using a combination of setMinimumDate, setMaximumTime and
- setMinimumTime, setMaximumTime APIs.
+ \param minDateTime The minimum date and time in QDateTime format.
+ \param maxDateTime The maximum date and time in QDateTime format.
- \param minDateTime minimum date and time in QDateTime format.
- \param maxDateTime maximum date and time in QDateTime format.
-
- \sa setMinimumDateTime \sa setMaximumDateTime \sa setMinimumDate \sa setMaximumDate
- \sa setMinimumTime \sa setMaximumTime
+ \sa setMinimumDateTime(), setMaximumDateTime()
*/
void HbDateTimePicker::setDateTimeRange(const QDateTime &minDateTime, const QDateTime &maxDateTime)
{
@@ -517,25 +597,20 @@
}
/*!
- Returns the current time, selected in datetime picker widget, in QTime format.
-
- \return time in QTime format.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the currently selected time in QTime format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QTime as a parameter.
+ For these properties, pass the time as a string in a valid ISO 8601 extended format;
+ for example, HH:MM:SS.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'time' is a QTime property of HbDateTimePicker. -->
<string name="time" value="02-15-30" />
</widget>
- ...
\endcode
- \sa setTime
+ \sa setTime()
*/
QTime HbDateTimePicker::time() const
{
@@ -544,11 +619,11 @@
}
/*!
- Sets the current \a time, to be set on datetime picker widget, in QTime format.
+ Sets the current time to \a time.
- \param time in QTime format.
+ \param time The time in QTime format.
- \sa time
+ \sa time()
*/
void HbDateTimePicker::setTime(const QTime &time)
{
@@ -557,25 +632,20 @@
}
/*!
- Returns minimum time, set on datetime picker, in QTime format.
-
- \return Minimum time in QTime format.
-
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
+ Returns the minimum time in QTime format.
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QTime as a parameter.
+ For these properties, pass the time as a string in a valid ISO 8601 extended format;
+ for example, HH:MM:SS.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'minimumTime' is a QTime property of HbDateTimePicker. -->
- <string name="minimumTime" value="02-15-30" />
+ <string name="minimumTime" value="08-00-00" />
</widget>
- ...
\endcode
- \sa setMinimumTime
+ \sa setMinimumTime()
*/
QTime HbDateTimePicker::minimumTime()const
{
@@ -584,11 +654,11 @@
}
/*!
- Sets minimum \a time, to be set on datetime picker, in QTime format.
+ Sets the minimum time to \a time.
- \param time minimum time in QTime format.
+ \param time The minimum time in QTime format.
- \sa minimumTime
+ \sa minimumTime(), setTimeRange()
*/
void HbDateTimePicker::setMinimumTime(const QTime& time)
{
@@ -597,25 +667,20 @@
}
/*!
- Returns maximum time, set on datetime picker, in QTime format.
-
- \return maximum time in QTime format.
+ Returns the maximum time in QTime format.
- <b>Note:</b> The DocML does not support directly the properties which uses QDate/QTime/QDateTime as parameters. For the properties to work user has to pass date, time or datetime
- as a string, in a valid ISO date format.
-
- ISO 8601 extended format: either YYYY-MM-DD for dates or YYYY-MM-DDTHH:MM:SS for combined dates and times.
+ \note DocML does not directly support properties that use QTime as a parameter.
+ For these properties, pass the time as a string in a valid ISO 8601 extended format;
+ for example, HH:MM:SS.
\code
- ...
<widget name="t:dtp" type="HbDateTimePicker">
<!-- 'maximumTime' is a QTime property of HbDateTimePicker. -->
- <string name="maximumTime" value="02-15-30" />
+ <string name="maximumTime" value="18-30-00" />
</widget>
- ...
\endcode
- \sa setMaximumTime
+ \sa setMaximumTime()
*/
QTime HbDateTimePicker::maximumTime()const
{
@@ -624,11 +689,11 @@
}
/*!
- Sets maximum \a time, to be set on datetime picker, in QTime format.
+ Sets the maximum time to \a time.
- \param time maximum time in QTime format
+ \param time The maximum time in QTime format.
- \sa maximumTime
+ \sa maximumTime(), setTimeRange()
*/
void HbDateTimePicker::setMaximumTime(const QTime& time)
{
@@ -637,12 +702,12 @@
}
/*!
- Sets minimum \a minTime and maximum \a maxTime in QTime format. This will allow the user to set a time range on datetime picker.
+ Sets the minimum and maximum time.
- \param minTime minimum time in QTime format.
- \param maxTime maximum time in QTime format.
+ \param minTime The minimum time in QTime format.
+ \param maxTime The maximum time in QTime format.
- \sa setMinimumTime \sa setMaximumTime
+ \sa setMinimumTime(), setMaximumTime()
*/
void HbDateTimePicker::setTimeRange(const QTime &minTime, const QTime &maxTime)
{
@@ -652,13 +717,14 @@
}
/*!
- Sets the \a interval or periodic gap for the corresponding \a section.
+ Sets the interval or periodic gap for a tumbler. Currently this is
+ supported for minute tumblers only.
- <b>Note</b>: Only MinuteSection is supported at this time.<br>
- <b>Note</b>: Minute interval must be a divisor of 60. Divisors of 60 are 1, 2, 3, 4, 5, 6, 10, 12, 15, 20, 30
-
- \param section can be a MinuteSection.
- \param interval to be set on each picker.
+ \param section This identifies the tumbler. This must be QDateTimeEdit::MinuteSection.
+ \param interval The interval to set on the tumbler. This must be a divisor of 60; that
+ is, 1, 2, 3, 4, 5, 6, 10, 12, 15, 20, or 30.
+
+ \sa interval()
*/
void HbDateTimePicker::setInterval(QDateTimeEdit::Section section,int interval)
{
@@ -703,11 +769,12 @@
}
/*!
- returns the \a interval for the corresponding \a section.
+ Returns the interval set for a tumbler. Currently this is supported for
+ minute tumblers only.
- Note: Only MinuteSection is supported at this time.
+ \param section Identifies the tumbler. This must be QDateTimeEdit::MinuteSection.
- \return interval or duration set on a particular \a section.
+ \sa setInterval()
*/
int HbDateTimePicker::interval(QDateTimeEdit::Section section) const
{
@@ -717,56 +784,156 @@
}
/*!
- \deprecated HbDateTimePicker::primitive(HbStyle::Primitive)
- is deprecated.
-
- \reimp
-*/
-QGraphicsItem *HbDateTimePicker::primitive(HbStyle::Primitive primitive) const
-{
- Q_D(const HbDateTimePicker);
- switch(primitive) {
- case HbStyle::P_DateTimePicker_background:
- return d->mBackground;
-
- case HbStyle::P_DateTimePicker_frame:
- return d->mFrame;
-
- case HbStyle::P_TumbleView_highlight:
- return d->mHighlight;
-
- default:
- return HbWidget::primitive(primitive);
- }
-}
-
-/*!
- \reimp
+ Reimplemented from QGraphicsWidget::setGeometry().
*/
void HbDateTimePicker::setGeometry(const QRectF &rect)
{
HbWidget::setGeometry(rect);
updatePrimitives();
+ Q_D(HbDateTimePicker);
+
+ for(int i=0;i<d->mParser.mSectionNodes.count();i++) {
+ switch(d->mParser.mSectionNodes[i].type) {
+ case HbDateTimeParser::AmPmSection:
+ if(!d->mAmPmPicker){
+ break;
+ }
+ break;
+
+ case HbDateTimeParser::DaySection:
+ case HbDateTimeParser::DayOfWeekSection:
+ if(!d->mDayPicker){
+ break;
+ }
+ d->mLabelDay->setPreferredWidth(d->mDayPicker->preferredSize().width());
+ break;
+
+ case HbDateTimeParser::MonthSection:
+ if(!d->mMonthPicker){
+ break;
+ }
+ d->mLabelMonth->setPreferredWidth(d->mMonthPicker->preferredSize().width());
+ break;
+
+ case HbDateTimeParser::YearSection:
+ case HbDateTimeParser::YearSection2Digits:
+ if(!d->mYearPicker){
+ break;
+ }
+
+ d->mLabelYear->setPreferredWidth(d->mYearPicker->preferredSize().width());
+ break;
+
+ case HbDateTimeParser::SecondSection:
+ if(!d->mSecondPicker){
+ break;
+ }
+
+ d->mLabelSecond->setPreferredWidth(d->mSecondPicker->preferredSize().width());
+ break;
+
+ case HbDateTimeParser::MinuteSection:
+ if(!d->mMinutePicker){
+ break;
+ }
+ d->mLabelMinute->setPreferredWidth(d->mMinutePicker->preferredSize().width());
+ break;
+
+ case HbDateTimeParser::Hour12Section:
+ case HbDateTimeParser::Hour24Section:
+ if(!d->mHourPicker){
+ break;
+ }
+ d->mLabelHour->setPreferredWidth(d->mHourPicker->preferredSize().width());
+ break;
+
+ default:
+ break;
+ }
+ }
+
}
-/*!
- \reimp
-*/
+void HbDateTimePicker::initPrimitiveData(HbStylePrimitiveData *primitiveData, const QGraphicsObject *primitive)
+{
+ HbWidget::initPrimitiveData(primitiveData, primitive);
+ QString itemName = HbStyle::itemName(primitive);
+ if(itemName == QLatin1String("background")) {
+ HbStyleFramePrimitiveData *frameItem = hbstyleprimitivedata_cast<HbStyleFramePrimitiveData*>(primitiveData);
+ frameItem->frameGraphicsName= QLatin1String("qtg_fr_tumbler_bg");
+ frameItem->frameType = HbFrameDrawer::NinePieces;
+ (const_cast<QGraphicsObject *> (primitive))->setZValue(-5);
+ }
+
+ if(itemName == QLatin1String("frame")) {
+ HbStyleFramePrimitiveData *frameItem = hbstyleprimitivedata_cast<HbStyleFramePrimitiveData*>(primitiveData);
+ frameItem->frameGraphicsName= QLatin1String("qtg_fr_tumbler_overlay");
+ frameItem->frameType = HbFrameDrawer::NinePieces;
+ (const_cast<QGraphicsObject *> (primitive))->setZValue(1);
+
+ }
+ if(itemName == QLatin1String("highlight")) {
+ HbStyleFramePrimitiveData *frameItem = hbstyleprimitivedata_cast<HbStyleFramePrimitiveData*>(primitiveData);
+ frameItem->frameGraphicsName= QLatin1String("qtg_fr_tumbler_highlight_pri");
+ frameItem->frameType = HbFrameDrawer::ThreePiecesHorizontal;
+ (const_cast<QGraphicsObject *> (primitive))->setZValue(-1);
+
+ }
+
+}
+
void HbDateTimePicker::updatePrimitives()
{
Q_D(HbDateTimePicker);
- HbStyleOption option;
- initStyleOption(&option);
+ HbWidget::updatePrimitives();
+
if(d->mBackground) {
- style()->updatePrimitive(d->mBackground,HbStyle::P_DateTimePicker_background,&option);
+ HbStyleFramePrimitiveData data;
+ initPrimitiveData(&data,d->mBackground);
+ style()->updatePrimitive(d->mBackground,&data,this);
+ if(!d->mLastAdded.isNull()){
+ QRectF geom = ((HbFrameItem*)d->mBackground)->geometry();
+ ((HbFrameItem*)d->mBackground)->setGeometry(geom.x(), d->mLastAdded->pos().y(), geom.width(), d->mLastAdded->size().height());
+ }
}
+
if(d->mFrame) {
- style()->updatePrimitive(d->mFrame,HbStyle::P_DateTimePicker_frame,&option);
+ HbStyleFramePrimitiveData data;
+ initPrimitiveData(&data,d->mFrame);
+ style()->updatePrimitive(d->mFrame,&data,this);
+ if(!d->mLastAdded.isNull()){
+ QRectF geom = ((HbFrameItem*)d->mFrame)->geometry();
+ ((HbFrameItem*)d->mFrame)->setGeometry(geom.x(), d->mLastAdded->pos().y(), geom.width(), d->mLastAdded->size().height());
+ }
}
if(d->mHighlight) {
- style()->updatePrimitive(d->mHighlight,HbStyle::P_TumbleView_highlight,&option);
+ HbStyleFramePrimitiveData data;
+ initPrimitiveData (&data,d->mHighlight);
+ style()->updatePrimitive(d->mHighlight,&data,this);
+ if(!d->mLastAdded.isNull()){
+ qreal top = d->mLastAdded->pos().y() + d->mLastAdded->size().height()/2 - ((HbFrameItem*)d->mHighlight)->geometry().height()/2;
+ d->mHighlight->setPos(d->mHighlight->pos().x(), top);
+ }
+
}
}
+QGraphicsItem *HbDateTimePicker::primitive(const QString &itemName) const
+{
+ Q_D(const HbDateTimePicker);
+
+ if(!itemName.compare(QString("background"))){
+ return d->mBackground;
+ }
+ if(!itemName.compare(QString("frame"))){
+ return d->mFrame;
+ }
+ if(!itemName.compare(QString("highlight"))){
+ return d->mHighlight;
+ }
+
+ return HbWidget::primitive(itemName);
+}
+
#include "moc_hbdatetimepicker.cpp"