/* * Copyright (c) 2021-2022 Huawei Device Co., Ltd. * 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. */ /** * @file * @kit BackgroundTasksKit */ import { AsyncCallback } from './@ohos.base'; import notification from './@ohos.notification'; import { NotificationSlot } from './notification/notificationSlot'; /** * Providers static methods for managing reminders, including publishing or canceling a reminder. * adding or removing a notification slot, and obtaining or cancelling all reminders of the current application. * * @namespace reminderAgent * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager */ declare namespace reminderAgent { /** * Publishes a scheduled reminder. * * @permission ohos.permission.PUBLISH_AGENT_REMINDER * @param { ReminderRequest } reminderReq Indicates the reminder instance to publish. * @param { AsyncCallback } callback Indicates the callback function. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.publishReminder */ function publishReminder(reminderReq: ReminderRequest, callback: AsyncCallback): void; /** * Publishes a scheduled reminder. * * @permission ohos.permission.PUBLISH_AGENT_REMINDER * @param { ReminderRequest } reminderReq Indicates the reminder instance to publish. * @returns { Promise } reminder id. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.publishReminder */ function publishReminder(reminderReq: ReminderRequest): Promise; /** * Cancels a reminder. * * @param { number } reminderId Indicates the reminder id. * @param { AsyncCallback } callback Indicates the callback function. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.cancelReminder */ function cancelReminder(reminderId: number, callback: AsyncCallback): void; /** * Cancels a reminder. * * @param { number } reminderId Indicates the reminder id. * @returns { Promise } * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.cancelReminder */ function cancelReminder(reminderId: number): Promise; /** * Obtains all the valid reminders of current application. * * @param { AsyncCallback> } callback Indicates the callback function. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.getValidReminders */ function getValidReminders(callback: AsyncCallback>): void; /** * Obtains all the valid reminders of current application. * * @returns { Promise> } Reminder Common information. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.getValidReminders */ function getValidReminders(): Promise>; /** * Cancels all the reminders of current application. * * @param { AsyncCallback } callback Indicates the callback function. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.cancelAllReminders */ function cancelAllReminders(callback: AsyncCallback): void; /** * Cancels all the reminders of current application. * * @returns { Promise } * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.cancelAllReminders */ function cancelAllReminders(): Promise; /** * Add notification slot. * * @param { NotificationSlot } slot Indicates the slot. * @param { AsyncCallback } callback Indicates the callback function. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.addNotificationSlot */ function addNotificationSlot(slot: NotificationSlot, callback: AsyncCallback): void; /** * Add notification slot. * * @param { NotificationSlot } slot Indicates the slot. * @returns { Promise } * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.addNotificationSlot */ function addNotificationSlot(slot: NotificationSlot): Promise; /** * Deletes a created notification slot based on the slot type. * * @param { notification.SlotType } slotType Indicates the type of the slot. * @param { AsyncCallback } callback Indicates the callback function. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.removeNotificationSlot */ function removeNotificationSlot(slotType: notification.SlotType, callback: AsyncCallback): void; /** * Deletes a created notification slot based on the slot type. * * @param { notification.SlotType } slotType Indicates the type of the slot. * @returns { Promise } * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.removeNotificationSlot */ function removeNotificationSlot(slotType: notification.SlotType): Promise; /** * Declares action button type. * * @enum { number } * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ActionButtonType */ export enum ActionButtonType { /** * Button for closing the reminder. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ActionButtonType.ACTION_BUTTON_TYPE_CLOSE */ ACTION_BUTTON_TYPE_CLOSE = 0, /** * Button for snoozing the reminder. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ActionButtonType.ACTION_BUTTON_TYPE_SNOOZE */ ACTION_BUTTON_TYPE_SNOOZE = 1 } /** * Declares reminder type. * * @enum { number } * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderType */ export enum ReminderType { /** * Countdown reminder. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderType.REMINDER_TYPE_TIMER */ REMINDER_TYPE_TIMER = 0, /** * Calendar reminder. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderType.REMINDER_TYPE_CALENDAR */ REMINDER_TYPE_CALENDAR = 1, /** * Alarm reminder. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderType.REMINDER_TYPE_ALARM */ REMINDER_TYPE_ALARM = 2 } /** * Action button information. The button will show on displayed reminder. * * @interface ActionButton * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ActionButton */ interface ActionButton { /** * Text on the button. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ActionButton.title */ title: string; /** * Button type. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ActionButton.type */ type: ActionButtonType; } /** * Want agent information. * It will switch to target ability when you click the displayed reminder. * * @interface WantAgent * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.WantAgent */ interface WantAgent { /** * Name of the package redirected to when the reminder notification is clicked. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.WantAgent.pkgName */ pkgName: string; /** * Name of the ability that is redirected to when the reminder notification is clicked. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.WantAgent.abilityName */ abilityName: string; } /** * Max screen want agent information. * * @interface MaxScreenWantAgent * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.MaxScreenWantAgent */ interface MaxScreenWantAgent { /** * Name of the package that is automatically started when the reminder arrives and the device is not in use. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.MaxScreenWantAgent.pkgName */ pkgName: string; /** * Name of the ability that is automatically started when the reminder arrives and the device is not in use. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.MaxScreenWantAgent.abilityName */ abilityName: string; } /** * Reminder Common information. * * @interface ReminderRequest * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest */ interface ReminderRequest { /** * Type of the reminder. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.reminderType */ reminderType: ReminderType; /** * Action button displayed on the reminder notification. * (The parameter is optional. Up to two buttons are supported). * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.actionButton */ actionButton?: [ActionButton?, ActionButton?]; /** * Information about the ability that is redirected to when the notification is clicked. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.wantAgent */ wantAgent?: WantAgent; /** * Information about the ability that is automatically started when the reminder arrives. * If the device is in use, a notification will be displayed. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.maxScreenWantAgent */ maxScreenWantAgent?: MaxScreenWantAgent; /** * Ringing duration. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.ringDuration */ ringDuration?: number; /** * Number of reminder snooze times. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.snoozeTimes */ snoozeTimes?: number; /** * Reminder snooze interval. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.timeInterval */ timeInterval?: number; /** * Reminder title. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.title */ title?: string; /** * Reminder content. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.content */ content?: string; /** * Content to be displayed when the reminder is expired. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.expiredContent */ expiredContent?: string; /** * Content to be displayed when the reminder is snoozing. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.snoozeContent */ snoozeContent?: string; /** * notification id. If there are reminders with the same ID, the later one will overwrite the earlier one. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.notificationId */ notificationId?: number; /** * Type of the slot used by the reminder. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequest.slotType */ slotType?: notification.SlotType; } /** * @interface ReminderRequestCalendar * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestCalendar */ interface ReminderRequestCalendar extends ReminderRequest { /** * Reminder time. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestCalendar.dateTime */ dateTime: LocalDateTime; /** * Month in which the reminder repeats. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestCalendar.repeatMonths */ repeatMonths?: Array; /** * Date on which the reminder repeats. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestCalendar.repeatDays */ repeatDays?: Array; } /** * Alarm reminder information. * * @interface ReminderRequestAlarm * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestAlarm */ interface ReminderRequestAlarm extends ReminderRequest { /** * Hour portion of the reminder time. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestAlarm.hour */ hour: number; /** * minute portion of the remidner time. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestAlarm.minute */ minute: number; /** * Days of a week when the reminder repeates. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestAlarm.daysOfWeek */ daysOfWeek?: Array; } /** * CountDown reminder information. * * @interface ReminderRequestTimer * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer */ interface ReminderRequestTimer extends ReminderRequest { /** * value of triggerTimeInSeconds. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer.triggerTimeInSeconds */ triggerTimeInSeconds: number; } /** * Local DateTime information. * * @interface LocalDateTime * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer */ interface LocalDateTime { /** * value of year. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer.year */ year: number; /** * value of month. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer.month */ month: number; /** * value of day. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer.day */ day: number; /** * value of hour. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer.hour */ hour: number; /** * value of minute. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer.minute */ minute: number; /** * value of second. * @syscap SystemCapability.Notification.ReminderAgent * @since 7 * @deprecated since 9 * @useinstead reminderAgentManager.ReminderRequestTimer.second */ second?: number; } } export default reminderAgent;