Skip to content

Latest commit

 

History

History
253 lines (165 loc) · 10.5 KB

File metadata and controls

253 lines (165 loc) · 10.5 KB

Frontend notices

useStoreNotices()

The useStoreNotices() hook allows reading and manipulating notices in the frontend.

Please refer to the useStoreSnackbarNotices() section for information on handling snackbar notices.

API

Note: if the context is not specified in noticeProps or ctxt params (depending on the method), the current context is used.

addDefaultNotice( text = '', noticeProps = {} )

Create a new notice with default status.

Argument Type Description
text string Text to be displayed in the notice.
noticeProps Object Object with the notice options.

addErrorNotice( text = '', noticeProps = {} )

Create a new error notice.

Argument Type Description
text string Text to be displayed in the notice.
noticeProps Object Object with the notice options.

addWarningNotice( text = '', noticeProps = {} )

Create a new warning notice.

Argument Type Description
text string Text to be displayed in the notice.
noticeProps Object Object with the notice options.

addInfoNotice( text = '', noticeProps = {} )

Create a new info notice.

Argument Type Description
text string Text to be displayed in the notice.
noticeProps Object Object with the notice options.

addSuccessNotice( text = '', noticeProps = {} )

Create a new success notice.

Argument Type Description
text string Text to be displayed in the notice.
noticeProps Object Object with the notice options.

hasNoticesOfType( type )

Check whether there are notices of the provided type in the current context.

Argument Type Description
type string Type of the notices to check.

notices

An array of the notices in the current context.

removeNotice( id, ctx )

Remove an existing notice.

Argument Type Description
id string Id of the notice to remove.
ctx string Context where the notice to remove is stored.

removeNotices( status = null )

Remove all notices from the current context. If a status is provided, only the notices with that status are removed.

Argument Type Description
status string Status that notices must match to be removed. If not provided, all notices of any status are removed.

setIsSuppressed( val )

Whether notices are suppressed. If true, it will hide the notices from the frontend.

Argument Type Description
val boolean Id of the notice to remove.

StoreNoticesProvider

The StoreNoticesProvider allows managing notices in the frontend. Notices are rendered before React Children.

Internally, it uses the StoreNoticesContext which relies on the notices package from Gutenberg.

Actions

createNotice( status = 'default', content = '', options = {} )

This action creates a new notice. If the context is not specified in the options object, the current context is used.

Argument Type Description
status string One of the statuses listed below.
content string Text to be displayed in the notice.
options Object Object with the notice options.

createSnackbarNotice( content = '', options = {} )

This action creates a new snackbar notice. If the context is not specified in the options object, the current context is used.

Argument Type Description
content string Text to be displayed in the notice.
options Object Object with the notice options.

removeNotice( id, ctx )

This action removes an existing notice. If the context is not specified, the current context is used.

Argument Type Description
id string Id of the notice to remove.
ctx string Context where the notice to remove is stored. If the context is not specified, the current context is used.

setIsSuppressed( val )

Whether notices are suppressed. If true, it will hide the notices from the frontend.

Argument Type Description
val boolean Id of the notice to remove.

Statuses

All notices must have one of the following statuses: default, error, success, info, warning.

Notice options

Object of the form:

{
	id: 'checkout',
	type: string,
	isDismissible: false,
}

Refer to the Gutenberg docs to know the available options.

useStoreSnackbarNotices()

The useStoreNotices() hook allows reading and manipulating snackbar notices in the frontend.

The snackbar is a small toast-like notification that appears at the bottom of a user's screen.

API

addSnackbarNotice( text = '', noticeProps = {} )

Create a new snackbar notice.

Argument Type Description
text string Text to be displayed in the notice.
noticeProps Object Object with the notice options.

notices

An array of the notices in the current context.

removeNotices( status = null )

Remove all notices from the current context. If a status is provided, only the notices with that status are removed.

Argument Type Description
status string Status that notices must match to be removed. If not provided, all notices of any status are removed.

StoreSnackbarNoticesProvider

The StoreSnackbarNoticesProvider allows managing snackbar notices in the frontend. Snackbar notices are displayed in the bottom left corner and disappear after a certain time.

Internally, it uses the StoreNoticesContext which relies on the notices package from Gutenberg.

Actions

createSnackbarNotice( content = '', options = {} )

This action creates a new snackbar notice. If the context is not specified in the options object, the current context is used.

Argument Type Description
content string Text to be displayed in the notice.
options Object Object with the notice options.

removeSnackbarNotice( id, ctx )

This action removes an existing notice. If the context is not specified, the current context is used.

Argument Type Description
id string Id of the notice to remove.
ctx string Context where the notice to remove is stored. If the context is not specified, the current context is used.

setIsSuppressed( val )

Whether notices are suppressed. If true, it will hide the notices from the frontend.

Argument Type Description
val boolean Id of the notice to remove.

Example usage

The following example shows a CheckoutProcessor component that displays an error notice when the payment process fails and it removes it every time the payment is started. When the payment is completed correctly, it shows a snackbar notice.

const CheckoutProcessor = () => {
	const { addErrorNotice, removeNotice } = useStoreNotices();
	const { addSnackbarNotice } = useStoreSnackbarNotices();
	// ...
	const paymentFail = () => {
		addErrorNotice( 'Something went wrong.', { id: 'checkout' } );
	};
	const paymentStart = () => {
		removeNotice( 'checkout' );
	};
	const paymentSuccess = () => {
		addSnackbarNotice( 'Payment successfully completed.' );
	};
	// ...
};
<StoreNoticesSnackbarProvider context="wc/checkout">
  <StoreNoticesProvider context="wc/checkout">
      // ...
      <CheckoutProcessor />
  </StoreNoticesProvider>
</StoreSnackbarNoticesProvider>