2018-02-09 17:00:03 +00:00
|
|
|
/**
|
|
|
|
* @flow
|
|
|
|
* AndroidNotification representation wrapper
|
|
|
|
*/
|
2018-02-22 15:52:24 +00:00
|
|
|
import { Category } from './types';
|
2018-02-09 17:00:03 +00:00
|
|
|
import type Notification from './Notification';
|
2018-02-22 15:52:24 +00:00
|
|
|
import type {
|
|
|
|
BadgeIconTypeType,
|
|
|
|
CategoryType,
|
|
|
|
DefaultsType,
|
|
|
|
GroupAlertType,
|
|
|
|
Lights,
|
|
|
|
NativeAndroidNotification,
|
|
|
|
PriorityType,
|
|
|
|
Progress,
|
|
|
|
SmallIcon,
|
|
|
|
VisibilityType,
|
|
|
|
} from './types';
|
2018-02-09 17:00:03 +00:00
|
|
|
|
|
|
|
export default class AndroidNotification {
|
2018-02-22 15:52:24 +00:00
|
|
|
// TODO optional fields
|
2018-02-09 17:00:03 +00:00
|
|
|
// TODO actions: Action[]; // icon, title, ??pendingIntent??, allowGeneratedReplies, extender, extras, remoteinput (ugh)
|
|
|
|
_autoCancel: boolean;
|
|
|
|
_badgeIconType: BadgeIconTypeType;
|
|
|
|
_category: CategoryType;
|
|
|
|
_channelId: string;
|
2018-02-22 15:52:24 +00:00
|
|
|
_clickAction: string | void;
|
2018-02-15 14:59:21 +00:00
|
|
|
_color: string;
|
2018-02-09 17:00:03 +00:00
|
|
|
_colorized: boolean;
|
|
|
|
_contentInfo: string;
|
|
|
|
_defaults: DefaultsType[];
|
|
|
|
_group: string;
|
|
|
|
_groupAlertBehaviour: GroupAlertType;
|
|
|
|
_groupSummary: boolean;
|
|
|
|
_largeIcon: string;
|
|
|
|
_lights: Lights;
|
|
|
|
_localOnly: boolean;
|
|
|
|
_notification: Notification;
|
|
|
|
_number: number;
|
|
|
|
_ongoing: boolean;
|
|
|
|
_onlyAlertOnce: boolean;
|
|
|
|
_people: string[];
|
|
|
|
_priority: PriorityType;
|
|
|
|
_progress: Progress;
|
2018-02-15 14:59:21 +00:00
|
|
|
// _publicVersion: Notification;
|
2018-02-09 17:00:03 +00:00
|
|
|
_remoteInputHistory: string[];
|
|
|
|
_shortcutId: string;
|
|
|
|
_showWhen: boolean;
|
2018-02-22 15:52:24 +00:00
|
|
|
_smallIcon: SmallIcon;
|
2018-02-09 17:00:03 +00:00
|
|
|
_sortKey: string;
|
|
|
|
// TODO: style: Style; // Need to figure out if this can work
|
|
|
|
_ticker: string;
|
|
|
|
_timeoutAfter: number;
|
|
|
|
_usesChronometer: boolean;
|
|
|
|
_vibrate: number[];
|
|
|
|
_visibility: VisibilityType;
|
|
|
|
_when: number;
|
|
|
|
|
|
|
|
// android unsupported
|
|
|
|
// content: RemoteViews
|
|
|
|
// contentIntent: PendingIntent - need to look at what this is
|
|
|
|
// customBigContentView: RemoteViews
|
|
|
|
// customContentView: RemoteViews
|
|
|
|
// customHeadsUpContentView: RemoteViews
|
|
|
|
// deleteIntent: PendingIntent
|
|
|
|
// fullScreenIntent: PendingIntent
|
|
|
|
// sound.streamType
|
|
|
|
|
2018-02-22 15:52:24 +00:00
|
|
|
constructor(notification: Notification, data?: NativeAndroidNotification) {
|
2018-02-09 17:00:03 +00:00
|
|
|
this._notification = notification;
|
2018-02-22 15:52:24 +00:00
|
|
|
|
|
|
|
if (data) {
|
|
|
|
this._autoCancel = data.autoCancel;
|
|
|
|
this._badgeIconType = data.badgeIconType;
|
|
|
|
this._category = data.category;
|
|
|
|
this._channelId = data.channelId;
|
|
|
|
this._clickAction = data.clickAction;
|
|
|
|
this._color = data.color;
|
|
|
|
this._colorized = data.colorized;
|
|
|
|
this._contentInfo = data.contentInfo;
|
|
|
|
this._defaults = data.defaults;
|
|
|
|
this._group = data.group;
|
|
|
|
this._groupAlertBehaviour = data.groupAlertBehaviour;
|
|
|
|
this._groupSummary = data.groupSummary;
|
|
|
|
this._largeIcon = data.largeIcon;
|
|
|
|
this._lights = data.lights;
|
|
|
|
this._localOnly = data.localOnly;
|
|
|
|
this._number = data.number;
|
|
|
|
this._ongoing = data.ongoing;
|
|
|
|
this._onlyAlertOnce = data.onlyAlertOnce;
|
|
|
|
this._people = data.people;
|
|
|
|
this._priority = data.priority;
|
|
|
|
this._progress = data.progress;
|
|
|
|
// _publicVersion: Notification;
|
|
|
|
this._remoteInputHistory = data.remoteInputHistory;
|
|
|
|
this._shortcutId = data.shortcutId;
|
|
|
|
this._showWhen = data.showWhen;
|
|
|
|
this._smallIcon = data.smallIcon;
|
|
|
|
this._sortKey = data.sortKey;
|
|
|
|
this._ticker = data.ticker;
|
|
|
|
this._timeoutAfter = data.timeoutAfter;
|
|
|
|
this._usesChronometer = data.usesChronometer;
|
|
|
|
this._vibrate = data.vibrate;
|
|
|
|
this._visibility = data.visibility;
|
|
|
|
this._when = data.when;
|
|
|
|
}
|
|
|
|
|
|
|
|
// Defaults
|
|
|
|
this._people = this._people || [];
|
|
|
|
this._smallIcon = this._smallIcon || {
|
|
|
|
icon: 'ic_launcher',
|
|
|
|
};
|
2018-02-09 17:00:03 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
2018-02-15 14:59:21 +00:00
|
|
|
* @param person
|
2018-02-09 17:00:03 +00:00
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
addPerson(person: string): Notification {
|
|
|
|
this._people.push(person);
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param autoCancel
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setAutoCancel(autoCancel: boolean): Notification {
|
|
|
|
this._autoCancel = autoCancel;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param badgeIconType
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setBadgeIconType(badgeIconType: BadgeIconTypeType): Notification {
|
|
|
|
this._badgeIconType = badgeIconType;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param category
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setCategory(category: CategoryType): Notification {
|
|
|
|
if (!Object.values(Category).includes(category)) {
|
|
|
|
throw new Error(`AndroidNotification: Invalid Category: ${category}`);
|
|
|
|
}
|
|
|
|
this._category = category;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param channelId
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setChannelId(channelId: string): Notification {
|
|
|
|
this._channelId = channelId;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param color
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
2018-02-15 14:59:21 +00:00
|
|
|
setColor(color: string): Notification {
|
2018-02-09 17:00:03 +00:00
|
|
|
this._color = color;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param colorized
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setColorized(colorized: boolean): Notification {
|
|
|
|
this._colorized = colorized;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param contentInfo
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setContentInfo(contentInfo: string): Notification {
|
|
|
|
this._contentInfo = contentInfo;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param defaults
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setDefaults(defaults: DefaultsType[]): Notification {
|
|
|
|
this._defaults = defaults;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param group
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setGroup(group: string): Notification {
|
|
|
|
this._group = group;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param groupAlertBehaviour
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setGroupAlertBehaviour(groupAlertBehaviour: GroupAlertType): Notification {
|
|
|
|
this._groupAlertBehaviour = groupAlertBehaviour;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param groupSummary
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setGroupSummary(groupSummary: boolean): Notification {
|
|
|
|
this._groupSummary = groupSummary;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param largeIcon
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setLargeIcon(largeIcon: string): Notification {
|
|
|
|
this._largeIcon = largeIcon;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param argb
|
|
|
|
* @param onMs
|
|
|
|
* @param offMs
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setLights(argb: number, onMs: number, offMs: number): Notification {
|
|
|
|
this._lights = {
|
|
|
|
argb,
|
|
|
|
onMs,
|
|
|
|
offMs,
|
|
|
|
};
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param localOnly
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setLocalOnly(localOnly: boolean): Notification {
|
|
|
|
this._localOnly = localOnly;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param number
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setNumber(number: number): Notification {
|
|
|
|
this._number = number;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param ongoing
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setOngoing(ongoing: boolean): Notification {
|
|
|
|
this._ongoing = ongoing;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param onlyAlertOnce
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setOnlyAlertOnce(onlyAlertOnce: boolean): Notification {
|
|
|
|
this._onlyAlertOnce = onlyAlertOnce;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param priority
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setPriority(priority: PriorityType): Notification {
|
|
|
|
this._priority = priority;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param max
|
|
|
|
* @param progress
|
|
|
|
* @param indeterminate
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setProgress(
|
|
|
|
max: number,
|
|
|
|
progress: number,
|
|
|
|
indeterminate: boolean
|
|
|
|
): Notification {
|
|
|
|
this._progress = {
|
|
|
|
max,
|
|
|
|
progress,
|
|
|
|
indeterminate,
|
|
|
|
};
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param publicVersion
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
2018-02-15 14:59:21 +00:00
|
|
|
/* setPublicVersion(publicVersion: Notification): Notification {
|
2018-02-09 17:00:03 +00:00
|
|
|
this._publicVersion = publicVersion;
|
|
|
|
return this._notification;
|
2018-02-15 14:59:21 +00:00
|
|
|
} */
|
2018-02-09 17:00:03 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param remoteInputHistory
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setRemoteInputHistory(remoteInputHistory: string[]): Notification {
|
|
|
|
this._remoteInputHistory = remoteInputHistory;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param shortcutId
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setShortcutId(shortcutId: string): Notification {
|
|
|
|
this._shortcutId = shortcutId;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param showWhen
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setShowWhen(showWhen: boolean): Notification {
|
|
|
|
this._showWhen = showWhen;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param icon
|
|
|
|
* @param level
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
2018-02-15 14:59:21 +00:00
|
|
|
setSmallIcon(icon: string, level?: number): Notification {
|
2018-02-09 17:00:03 +00:00
|
|
|
this._smallIcon = {
|
|
|
|
icon,
|
|
|
|
level,
|
|
|
|
};
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param sortKey
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setSortKey(sortKey: string): Notification {
|
|
|
|
this._sortKey = sortKey;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param ticker
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setTicker(ticker: string): Notification {
|
|
|
|
this._ticker = ticker;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param timeoutAfter
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setTimeoutAfter(timeoutAfter: number): Notification {
|
|
|
|
this._timeoutAfter = timeoutAfter;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param usesChronometer
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setUsesChronometer(usesChronometer: boolean): Notification {
|
|
|
|
this._usesChronometer = usesChronometer;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param vibrate
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setVibrate(vibrate: number[]): Notification {
|
|
|
|
this._vibrate = vibrate;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @param when
|
|
|
|
* @returns {Notification}
|
|
|
|
*/
|
|
|
|
setWhen(when: number): Notification {
|
|
|
|
this._when = when;
|
|
|
|
return this._notification;
|
|
|
|
}
|
|
|
|
|
|
|
|
build(): NativeAndroidNotification {
|
2018-02-22 15:52:24 +00:00
|
|
|
// TODO: Validation of required fields
|
2018-02-15 08:11:17 +00:00
|
|
|
if (!this._channelId) {
|
|
|
|
throw new Error(
|
|
|
|
'AndroidNotification: Missing required `channelId` property'
|
|
|
|
);
|
|
|
|
}
|
2018-02-09 17:00:03 +00:00
|
|
|
|
|
|
|
return {
|
|
|
|
// TODO actions: Action[],
|
|
|
|
autoCancel: this._autoCancel,
|
|
|
|
badgeIconType: this._badgeIconType,
|
|
|
|
category: this._category,
|
|
|
|
channelId: this._channelId,
|
2018-02-15 14:59:21 +00:00
|
|
|
clickAction: this._clickAction,
|
2018-02-09 17:00:03 +00:00
|
|
|
color: this._color,
|
|
|
|
colorized: this._colorized,
|
|
|
|
contentInfo: this._contentInfo,
|
|
|
|
defaults: this._defaults,
|
|
|
|
group: this._group,
|
|
|
|
groupAlertBehaviour: this._groupAlertBehaviour,
|
|
|
|
groupSummary: this._groupSummary,
|
|
|
|
largeIcon: this._largeIcon,
|
|
|
|
lights: this._lights,
|
|
|
|
localOnly: this._localOnly,
|
|
|
|
number: this._number,
|
|
|
|
ongoing: this._ongoing,
|
|
|
|
onlyAlertOnce: this._onlyAlertOnce,
|
|
|
|
people: this._people,
|
|
|
|
priority: this._priority,
|
|
|
|
progress: this._progress,
|
2018-02-15 14:59:21 +00:00
|
|
|
// publicVersion: this._publicVersion,
|
2018-02-09 17:00:03 +00:00
|
|
|
remoteInputHistory: this._remoteInputHistory,
|
|
|
|
shortcutId: this._shortcutId,
|
|
|
|
showWhen: this._showWhen,
|
|
|
|
smallIcon: this._smallIcon,
|
|
|
|
sortKey: this._sortKey,
|
|
|
|
// TODO: style: Style,
|
|
|
|
ticker: this._ticker,
|
|
|
|
timeoutAfter: this._timeoutAfter,
|
|
|
|
usesChronometer: this._usesChronometer,
|
|
|
|
vibrate: this._vibrate,
|
|
|
|
visibility: this._visibility,
|
|
|
|
when: this._when,
|
|
|
|
};
|
|
|
|
}
|
|
|
|
}
|