diff -r 96907930389d -r 12af337248b1 alarmui/alarmalertwidget/alarmalertplugin/src/alarmalertplugin.cpp --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/alarmui/alarmalertwidget/alarmalertplugin/src/alarmalertplugin.cpp Tue Aug 31 15:13:43 2010 +0300 @@ -0,0 +1,181 @@ +/* +* Copyright (c) 2010 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: +* +*/ +// alarmalertplugin.h + +// System includes +#include +#include +#include + +// User includes +#include "alarmalertplugin.h" +#include "alarmalertwidget_p.h" +#include "alarmalert.h" +#include "alarmalertdocloader.h" +#include "OstTraceDefinitions.h" +#ifdef OST_TRACE_COMPILER_IN_USE +#include "alarmalertpluginTraces.h" +#endif + +// Plugin export +Q_EXPORT_PLUGIN2(alarmalertplugin, AlarmAlertPlugin); + +// --------------------------------------------------------- +// AlarmAlertPlugin::AlarmAlertPlugin +// rest of the details are commented in the header +// --------------------------------------------------------- +// +AlarmAlertPlugin::AlarmAlertPlugin() +{ + OstTraceFunctionEntry0( ALARMALERTPLUGIN_ALARMALERTPLUGIN_ENTRY ); + // No implementation yet + OstTraceFunctionExit0( ALARMALERTPLUGIN_ALARMALERTPLUGIN_EXIT ); +} + +// --------------------------------------------------------- +// AlarmAlertPlugin::~AlarmAlertPlugin +// rest of the details are commented in the header +// --------------------------------------------------------- +// +AlarmAlertPlugin::~AlarmAlertPlugin() +{ + OstTraceFunctionEntry0( DUP1_ALARMALERTPLUGIN_ALARMALERTPLUGIN_ENTRY ); + // No implementation yet + OstTraceFunctionExit0( DUP1_ALARMALERTPLUGIN_ALARMALERTPLUGIN_EXIT ); +} + +// --------------------------------------------------------- +// AlarmAlertPlugin::accessAllowed +// rest of the details are commented in the header +// --------------------------------------------------------- +// +bool AlarmAlertPlugin::accessAllowed(const QString &deviceDialogType, + const QVariantMap ¶meters, + const QVariantMap &securityInfo) const +{ + OstTraceFunctionEntry0( ALARMALERTPLUGIN_ACCESSALLOWED_ENTRY ); + Q_UNUSED(securityInfo); + Q_UNUSED(parameters); + Q_UNUSED(deviceDialogType); + + // No implementation yet + OstTraceFunctionExit0( ALARMALERTPLUGIN_ACCESSALLOWED_EXIT ); + return true; +} + +// --------------------------------------------------------- +// AlarmAlertPlugin::deviceDialogInfo +// rest of the details are commented in the header +// --------------------------------------------------------- +// +bool AlarmAlertPlugin::deviceDialogInfo(const QString &deviceDialogType, + const QVariantMap ¶meters, + DeviceDialogInfo *info) const +{ + OstTraceFunctionEntry0( ALARMALERTPLUGIN_DEVICEDIALOGINFO_ENTRY ); + Q_UNUSED(deviceDialogType); + Q_UNUSED(parameters); + + info->group = CriticalGroup; + info->priority = DefaultPriority; + info->flags = NoDeviceDialogFlags; + OstTraceFunctionExit0( ALARMALERTPLUGIN_DEVICEDIALOGINFO_EXIT ); + return true; +} + +// --------------------------------------------------------- +// AlarmAlertPlugin::deviceDialogTypes +// rest of the details are commented in the header +// --------------------------------------------------------- +// +QStringList AlarmAlertPlugin::deviceDialogTypes() const +{ + OstTraceFunctionEntry0( ALARMALERTPLUGIN_DEVICEDIALOGTYPES_ENTRY ); + // Return the device dialog type this plugin supports + QStringList dialogType; + dialogType.append(ALARM_ALERT_PLUGIN); + OstTraceFunctionExit0( ALARMALERTPLUGIN_DEVICEDIALOGTYPES_EXIT ); + return dialogType; +} + +// --------------------------------------------------------- +// AlarmAlertPlugin::pluginFlags +// rest of the details are commented in the header +// --------------------------------------------------------- +// +HbDeviceDialogPlugin::PluginFlags AlarmAlertPlugin::pluginFlags() const +{ + OstTraceFunctionEntry0( ALARMALERTPLUGIN_PLUGINFLAGS_ENTRY ); + OstTraceFunctionExit0( ALARMALERTPLUGIN_PLUGINFLAGS_EXIT ); + return NoPluginFlags; +} + +// --------------------------------------------------------- +// AlarmAlertPlugin::error +// rest of the details are commented in the header +// --------------------------------------------------------- +// +int AlarmAlertPlugin::error() const +{ + OstTraceFunctionEntry0( ALARMALERTPLUGIN_ERROR_ENTRY ); + // TODO: Need to handle any error that might occur + OstTraceFunctionExit0( ALARMALERTPLUGIN_ERROR_EXIT ); + return 0; +} + +// --------------------------------------------------------- +// AlarmAlertPlugin::createDeviceDialog +// rest of the details are commented in the header +// --------------------------------------------------------- +// +HbDeviceDialogInterface *AlarmAlertPlugin::createDeviceDialog(const QString &deviceDialogType, + const QVariantMap ¶meters) +{ + OstTraceFunctionEntry0( ALARMALERTPLUGIN_CREATEDEVICEDIALOG_ENTRY ); + Q_UNUSED(deviceDialogType); + + // Create and return the alarm alert dialog + HbDeviceDialogInterface *ret(0); + AlarmAlertDocLoader *alertDocLoader = new AlarmAlertDocLoader(parameters); + // Get the type of alarm to load the proper docml + QVariantMap::const_iterator iter = parameters.constBegin(); + int count = parameters.size(); + AlarmType alertType = OtherAlarm; + while (iter != parameters.constEnd()) { + QString key(iter.key()); + if (alarmType == key) { + alertType = static_cast (iter.value().toInt()); + } + iter++; + } + bool loadSuccess = false; + if (alertType == ClockAlarm) { + alertDocLoader->load(alarmNormalUIClockDocml, &loadSuccess); + }else if (alertType == TodoAlarm) { + alertDocLoader->load(alarmNormalUITodoDocml, &loadSuccess); + }else if(alertType == CalendarAlarm) { + alertDocLoader->load(alarmNormalUICalendarDocml, &loadSuccess); + } + if(!loadSuccess) { + qFatal("Unable to load the docml"); + } + AlarmAlertDialogPrivate *alertDialog = qobject_cast (alertDocLoader->findWidget("dialog")); + alertDialog->setupNormalUI(alertDocLoader); + ret = alertDialog; + OstTraceFunctionExit0( ALARMALERTPLUGIN_CREATEDEVICEDIALOG_EXIT ); + return ret; +}