ServiceWorker: click toast to install update (dirty)

This commit is contained in:
Alex Gleason 2022-06-23 15:20:41 -05:00
parent 638fc35f77
commit 3e205a9610
No known key found for this signature in database
GPG key ID: 7211D1F99744FBB7
5 changed files with 24 additions and 10 deletions

View file

@ -2,24 +2,32 @@ import { ALERT_SHOW } from './alerts';
import type { MessageDescriptor } from 'react-intl';
export type SnackbarActionSeverity = 'info' | 'success' | 'error'
export type SnackbarActionSeverity = 'info' | 'success' | 'error';
type SnackbarMessage = string | MessageDescriptor
type SnackbarMessage = string | MessageDescriptor;
export type SnackbarAction = {
type: typeof ALERT_SHOW
message: SnackbarMessage
actionLabel?: SnackbarMessage
actionLink?: string
severity: SnackbarActionSeverity
}
type: typeof ALERT_SHOW,
message: SnackbarMessage,
actionLabel?: SnackbarMessage,
actionLink?: string,
action?: () => void,
severity: SnackbarActionSeverity,
};
export const show = (severity: SnackbarActionSeverity, message: SnackbarMessage, actionLabel?: SnackbarMessage, actionLink?: string): SnackbarAction => ({
export const show = (
severity: SnackbarActionSeverity,
message: SnackbarMessage,
actionLabel?: SnackbarMessage,
actionLink?: string,
action?: () => void,
): SnackbarAction => ({
type: ALERT_SHOW,
message,
actionLabel,
actionLink,
severity,
action,
});
export const info = (message: SnackbarMessage, actionLabel?: SnackbarMessage, actionLink?: string) =>

View file

@ -5,7 +5,9 @@ import * as OfflinePluginRuntime from '@lcdp/offline-plugin/runtime';
import React from 'react';
import ReactDOM from 'react-dom';
import snackbar from 'soapbox/actions/snackbar';
import * as BuildConfig from 'soapbox/build_config';
import { store } from 'soapbox/store';
import { printConsoleWarning } from 'soapbox/utils/console';
import { default as Soapbox } from './containers/soapbox';
@ -34,7 +36,9 @@ function main() {
// https://github.com/NekR/offline-plugin/pull/201#issuecomment-285133572
OfflinePluginRuntime.install({
onUpdateReady: function() {
OfflinePluginRuntime.applyUpdate();
store.dispatch(snackbar.show('info', 'An update is available.', 'Update', undefined, () => {
OfflinePluginRuntime.applyUpdate();
}));
},
onUpdated: function() {
window.location.reload();

View file

@ -13,6 +13,7 @@ const AlertRecord = ImmutableRecord({
severity: 'info',
actionLabel: '',
actionLink: '',
action: () => {},
});
import type { AnyAction } from 'redux';

View file

@ -186,6 +186,7 @@ const buildAlert = (item: any) => {
title: item.title,
actionLabel: item.actionLabel,
actionLink: item.actionLink,
action: item.action,
key: item.key,
className: `notification-bar-${item.severity}`,
activeClassName: 'snackbar--active',