2018-05-02 22:03:26 +00:00
|
|
|
interface Environment {
|
|
|
|
isAppFocused: boolean;
|
|
|
|
isAudioNotificationEnabled: boolean;
|
|
|
|
isEnabled: boolean;
|
2020-09-04 23:07:24 +00:00
|
|
|
hasNotifications: boolean;
|
2018-05-02 22:03:26 +00:00
|
|
|
userSetting: UserSetting;
|
|
|
|
}
|
|
|
|
|
|
|
|
interface Status {
|
|
|
|
shouldClearNotifications: boolean;
|
|
|
|
shouldPlayNotificationSound: boolean;
|
|
|
|
shouldShowNotifications: boolean;
|
|
|
|
type: Type;
|
|
|
|
}
|
|
|
|
|
|
|
|
type UserSetting = 'off' | 'count' | 'name' | 'message';
|
|
|
|
|
|
|
|
type Type =
|
|
|
|
| 'ok'
|
|
|
|
| 'disabled'
|
|
|
|
| 'appIsFocused'
|
|
|
|
| 'noNotifications'
|
|
|
|
| 'userSetting';
|
|
|
|
|
2018-05-02 22:33:58 +00:00
|
|
|
export const getStatus = ({
|
|
|
|
isAppFocused,
|
|
|
|
isAudioNotificationEnabled,
|
|
|
|
isEnabled,
|
2020-09-04 23:07:24 +00:00
|
|
|
hasNotifications,
|
2018-05-02 22:33:58 +00:00
|
|
|
userSetting,
|
|
|
|
}: Environment): Status => {
|
2018-05-02 22:03:26 +00:00
|
|
|
const type = ((): Type => {
|
2018-05-02 22:33:58 +00:00
|
|
|
if (!isEnabled) {
|
2018-05-02 22:03:26 +00:00
|
|
|
return 'disabled';
|
|
|
|
}
|
|
|
|
|
|
|
|
if (!hasNotifications) {
|
|
|
|
return 'noNotifications';
|
|
|
|
}
|
|
|
|
|
2018-05-02 22:33:58 +00:00
|
|
|
if (isAppFocused) {
|
2018-05-02 22:03:26 +00:00
|
|
|
return 'appIsFocused';
|
|
|
|
}
|
|
|
|
|
2018-05-02 22:33:58 +00:00
|
|
|
if (userSetting === 'off') {
|
2018-05-02 22:03:26 +00:00
|
|
|
return 'userSetting';
|
|
|
|
}
|
|
|
|
|
|
|
|
return 'ok';
|
|
|
|
})();
|
|
|
|
|
|
|
|
return {
|
2020-09-11 21:23:11 +00:00
|
|
|
shouldClearNotifications: type === 'appIsFocused',
|
|
|
|
shouldPlayNotificationSound: isAudioNotificationEnabled,
|
|
|
|
shouldShowNotifications: type === 'ok',
|
2018-05-02 22:03:26 +00:00
|
|
|
type,
|
|
|
|
};
|
|
|
|
};
|