/* * Copyright (C) 2013 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package com.android.deskclock.provider; import android.net.Uri; import android.provider.BaseColumns; import com.android.deskclock.BuildConfig; /** *
* The contract between the clock provider and desk clock. Contains * definitions for the supported URIs and data columns. *
** ClockContract defines the data model of clock related information. * This data is stored in a number of tables: *
*Type: BOOLEAN
*/ String VIBRATE = "vibrate"; /** * Alarm label. * *Type: STRING
*/ String LABEL = "label"; /** * Audio alert to play when alarm triggers. Null entry * means use system default and entry that equal * Uri.EMPTY.toString() means no ringtone. * *Type: STRING
*/ String RINGTONE = "ringtone"; } /** * Constants for the Alarms table, which contains the user created alarms. */ protected interface AlarmsColumns extends AlarmSettingColumns, BaseColumns { /** * The content:// style URL for this table. */ Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/alarms"); /** * The content:// style URL for the alarms with instance tables, which is used to get the * next firing instance and the current state of an alarm. */ Uri ALARMS_WITH_INSTANCES_URI = Uri.parse("content://" + AUTHORITY + "/alarms_with_instances"); /** * Hour in 24-hour localtime 0 - 23. *Type: INTEGER
*/ String HOUR = "hour"; /** * Minutes in localtime 0 - 59. *Type: INTEGER
*/ String MINUTES = "minutes"; /** * Days of the week encoded as a bit set. *Type: INTEGER
* * {@link com.android.deskclock.data.Weekdays} */ String DAYS_OF_WEEK = "daysofweek"; /** * True if alarm is active. *Type: BOOLEAN
*/ String ENABLED = "enabled"; /** * Determine if alarm is deleted after it has been used. *Type: INTEGER
*/ String DELETE_AFTER_USE = "delete_after_use"; } /** * Constants for the Instance table, which contains the state of each alarm. */ protected interface InstancesColumns extends AlarmSettingColumns, BaseColumns { /** * The content:// style URL for this table. */ Uri CONTENT_URI = Uri.parse("content://" + AUTHORITY + "/instances"); /** * Alarm state when to show no notification. * * Can transitions to: * LOW_NOTIFICATION_STATE */ int SILENT_STATE = 0; /** * Alarm state to show low priority alarm notification. * * Can transitions to: * HIDE_NOTIFICATION_STATE * HIGH_NOTIFICATION_STATE * DISMISSED_STATE */ int LOW_NOTIFICATION_STATE = 1; /** * Alarm state to hide low priority alarm notification. * * Can transitions to: * HIGH_NOTIFICATION_STATE */ int HIDE_NOTIFICATION_STATE = 2; /** * Alarm state to show high priority alarm notification. * * Can transitions to: * DISMISSED_STATE * FIRED_STATE */ int HIGH_NOTIFICATION_STATE = 3; /** * Alarm state when alarm is in snooze. * * Can transitions to: * DISMISSED_STATE * FIRED_STATE */ int SNOOZE_STATE = 4; /** * Alarm state when alarm is being fired. * * Can transitions to: * DISMISSED_STATE * SNOOZED_STATE * MISSED_STATE */ int FIRED_STATE = 5; /** * Alarm state when alarm has been missed. * * Can transitions to: * DISMISSED_STATE */ int MISSED_STATE = 6; /** * Alarm state when alarm is done. */ int DISMISSED_STATE = 7; /** * Alarm state when alarm has been dismissed before its intended firing time. */ int PREDISMISSED_STATE = 8; /** * Alarm year. * *Type: INTEGER
*/ String YEAR = "year"; /** * Alarm month in year. * *Type: INTEGER
*/ String MONTH = "month"; /** * Alarm day in month. * *Type: INTEGER
*/ String DAY = "day"; /** * Alarm hour in 24-hour localtime 0 - 23. *Type: INTEGER
*/ String HOUR = "hour"; /** * Alarm minutes in localtime 0 - 59 *Type: INTEGER
*/ String MINUTES = "minutes"; /** * Foreign key to Alarms table *Type: INTEGER (long)
*/ String ALARM_ID = "alarm_id"; /** * Alarm state *Type: INTEGER
*/ String ALARM_STATE = "alarm_state"; } }