/** * External dependencies */ import { uniqueId } from 'lodash'; /** * WordPress dependencies */ import { select as selectData, dispatch as dispatchData, subscribe } from '@wordpress/data'; import { default as triggerApiFetch } from '@wordpress/api-fetch'; /** * Internal dependencies */ import { responseToError } from '@ithemes/security-utils'; /** * Utility for returning a promise that handles a selector with a resolver. * * @param {Object} options * @param {string} options.storeKey The store the selector belongs to * @param {string} options.selectorName The selector name * @param {Array} options.args The arguments fed to the selector * * @return {Promise} A promise for resolving the given selector. */ const resolveSelect = ( { storeKey, selectorName, args } ) => { return new Promise( ( resolve ) => { const hasFinished = () => selectData( 'core/data' ).hasFinishedResolution( storeKey, selectorName, args ); const getResult = () => selectData( storeKey )[ selectorName ].apply( null, args ); // trigger the selector (to trigger the resolver) const result = getResult(); if ( hasFinished() ) { return resolve( result ); } const unsubscribe = subscribe( () => { if ( hasFinished() ) { unsubscribe(); resolve( getResult() ); } } ); } ); }; /** * Trigger an API Fetch request. * * @param {Object} request API Fetch Request Object. * @return {Object} control descriptor. */ export function apiFetch( request ) { return { type: 'API_FETCH', request, }; } /** * Calls a selector using the current state. * @param {string} storeKey Store key. * @param {string} selectorName Selector name. * @param {Array} args Selector arguments. * * @return {Object} control descriptor. */ export function select( storeKey, selectorName, ...args ) { return { type: 'SELECT', storeKey, selectorName, args, }; } /** * Dispatches a control action for triggering a registry dispatch. * * @param {string} storeKey The key for the store the action belongs to * @param {string} actionName The name of the action to dispatch * @param {...*} args Arguments for the dispatch action. * * @example * ```js * import { dispatch } from '@wordpress/data-controls'; * * // Action generator using dispatch * export function* myAction() { * yield dispatch( 'core/edit-post', 'togglePublishSidebar' ); * // do some other things. * } * ``` * * @return {Object} The control descriptor. */ export function dispatch( storeKey, actionName, ...args ) { return { type: 'DISPATCH', storeKey, actionName, args, }; } /** * Parses the fetch response. * * @param {Response} response The response object from apiFetch. * @return {{response: *, type: string}} Data control. */ export function parseFetchResponse( response ) { return { type: 'PARSE_FETCH_RESPONSE', response, }; } /** * Parse the fetch response into an object with data and headers. * * @param {Response} response The response object from apiFetch. * @return {Promise<*>} Parsed response object. */ async function PARSE_FETCH_RESPONSE( { response } ) { return await response.json(); } /** * Yields action objects used in signalling that a notice is to be created. * * @see @wordpress/notices#createNotice() * * @param {?string} status Notice status. * Defaults to `info`. * @param {string} content Notice message. * @param {?Object} options Notice options. * @param {?string} options.context Context under which to * group notice. * @param {?string} options.id Identifier for notice. * Automatically assigned * if not specified. * @param {?boolean} options.isDismissible Whether the notice can * be dismissed by user. * Defaults to `true`. * @param {?number} options.autoDismiss Whether the notice should * by automatically dismissed * after x milliseconds. * Defaults to `false`. * @param {?string} options.type Notice type. Either 'default' or 'snackbar'. * @param {?Array} options.actions User actions to be * presented with notice. * * @return {Object} control descriptor. */ export function createNotice( status = 'info', content, options = {} ) { return { type: 'CREATE_NOTICE', status, content, options: { context: 'ithemes-security', ...options, }, }; } const controls = { API_FETCH( { request } ) { return triggerApiFetch( request ).catch( responseToError ); }, SELECT( { storeKey, selectorName, args } ) { const selector = selectData( storeKey )[ selectorName ]; if ( selector.hasResolver ) { return resolveSelect( { storeKey, selectorName, args } ); } return selector( ...args ); }, DISPATCH( { storeKey, actionName, args } ) { return dispatchData( storeKey )[ actionName ]( ...args ); }, PARSE_FETCH_RESPONSE, CREATE_NOTICE( { status, content, options } ) { if ( options.autoDismiss ) { options.id = options.id || uniqueId( 'itsec-auto-dismiss-' ); setTimeout( () => dispatchData( 'core/notices' ).removeNotice( options.id, options.context ), options.autoDismiss ); } dispatchData( 'core/notices' ).createNotice( status, content, options ); }, }; export default controls; x

Windows NT KPTV 6.2 build 9200 (Windows Server 2012 Datacenter Edition) i586