Rough in support for chat sound and flash notification

This commit is contained in:
Curtis ROck 2020-09-04 21:43:14 -05:00
parent 34a575482c
commit cf93733076
7 changed files with 64 additions and 6 deletions

View file

@ -23,6 +23,8 @@ export const CHAT_READ_REQUEST = 'CHAT_READ_REQUEST';
export const CHAT_READ_SUCCESS = 'CHAT_READ_SUCCESS';
export const CHAT_READ_FAIL = 'CHAT_READ_FAIL';
export const STREAMING_CHAT_UPDATE = 'STREAMING_CHAT_UPDATE';
export function fetchChats() {
return (dispatch, getState) => {
dispatch({ type: CHATS_FETCH_REQUEST });
@ -150,3 +152,55 @@ export function markChatRead(chatId, lastReadId) {
});
};
}
export function updateChatsQueue(chat) {
return (dispatch, getState) => {
if (chat.type === 'pleroma:chat_mention') return; // Drop chat notifications, handle them per-chat
// const showAlert = getSettings(getState()).getIn(['notifications', 'alerts', chat.type]);
// const filters = getFilters(getState(), { contextType: 'notifications' });
// const playSound = getSettings(getState()).getIn(['notifications', 'sounds', chat.type]);
//
// let filtered = false;
//
// const isOnNotificationsPage = curPath === '/notifications';
//
// if (chat.type === 'mention') {
// const regex = regexFromFilters(filters);
// const searchIndex = chat.status.spoiler_text + '\n' + unescapeHTML(chat.status.content);
// filtered = regex && regex.test(searchIndex);
// }
//
// // Desktop notifications
// if (typeof window.Notification !== 'undefined' && showAlert && !filtered) {
// const title = new IntlMessageFormat(intlMessages[`notification.${chat.type}`], intlLocale).format({ name: chat.account.display_name.length > 0 ? chat.account.display_name : notification.account.username });
// const body = (chat.status && chat.status.spoiler_text.length > 0) ? chat.status.spoiler_text : unescapeHTML(chat.status ? chat.status.content : '');
//
// const notify = new Notification(title, { body, icon: chat.account.avatar, tag: chat.id });
//
// notify.addEventListener('click', () => {
// window.focus();
// notify.close();
// });
// }
// if (playSound && !filtered) {
// dispatch({
// type: CHATS_UPDATE_NOOP,
// meta: { sound: 'boop' },
// });
// }
dispatch({ type: STREAMING_CHAT_UPDATE, chat: chat, me: getState().get('me') });
// if (isOnNotificationsPage) {
// dispatch({
// type: CHATS_UPDATE_QUEUE,
// chat,
// intlMessages,
// intlLocale,
// });
// } else {
// dispatch(updateChats(chat, intlMessages, intlLocale));
// }
};
};

View file

@ -32,6 +32,8 @@ const defaultSettings = ImmutableMap({
chats: ImmutableMap({
panes: ImmutableList(),
mainWindow: 'minimized',
sound: true,
flash: true,
}),
home: ImmutableMap({

View file

@ -7,12 +7,13 @@ import {
processTimelineUpdate,
} from './timelines';
import { updateNotificationsQueue, expandNotifications } from './notifications';
import { updateChatsQueue } from './chats';
import { updateConversations } from './conversations';
import { fetchFilters } from './filters';
import { getSettings } from 'soapbox/actions/settings';
import messages from 'soapbox/locales/messages';
export const STREAMING_CHAT_UPDATE = 'STREAMING_CHAT_UPDATE';
// export const STREAMING_CHAT_UPDATE = 'STREAMING_CHAT_UPDATE';
const validLocale = locale => Object.keys(messages).includes(locale);
@ -55,7 +56,8 @@ export function connectTimelineStream(timelineId, path, pollingRefresh = null, a
dispatch(fetchFilters());
break;
case 'pleroma:chat_update':
dispatch({ type: STREAMING_CHAT_UPDATE, chat: JSON.parse(data.payload), me: getState().get('me') });
dispatch(updateChatsQueue(JSON.parse(data.payload)));
// dispatch({ type: STREAMING_CHAT_UPDATE, chat: JSON.parse(data.payload), me: getState().get('me') });
break;
}
},

View file

@ -4,7 +4,7 @@ import {
ACCOUNT_FETCH_FAIL_FOR_USERNAME_LOOKUP,
} from '../actions/importer';
import { CHATS_FETCH_SUCCESS, CHAT_FETCH_SUCCESS } from 'soapbox/actions/chats';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/streaming';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/chats';
import { normalizeAccount as normalizeAccount2 } from 'soapbox/actions/importer/normalizer';
import { Map as ImmutableMap, fromJS } from 'immutable';

View file

@ -4,7 +4,7 @@ import {
CHAT_MESSAGE_SEND_REQUEST,
CHAT_MESSAGE_SEND_SUCCESS,
} from 'soapbox/actions/chats';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/streaming';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/chats';
import { Map as ImmutableMap, OrderedSet as ImmutableOrderedSet } from 'immutable';
const initialState = ImmutableMap();

View file

@ -4,7 +4,7 @@ import {
CHAT_MESSAGE_SEND_REQUEST,
CHAT_MESSAGE_SEND_SUCCESS,
} from 'soapbox/actions/chats';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/streaming';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/chats';
import { Map as ImmutableMap, fromJS } from 'immutable';
const initialState = ImmutableMap();

View file

@ -4,7 +4,7 @@ import {
CHAT_READ_SUCCESS,
CHAT_READ_REQUEST,
} from 'soapbox/actions/chats';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/streaming';
import { STREAMING_CHAT_UPDATE } from 'soapbox/actions/chats';
import { normalizeChat } from 'soapbox/actions/importer/normalizer';
import { Map as ImmutableMap, fromJS } from 'immutable';