Add coexistence checks to all enqueue methods to prevent loading both React and Grid.js assets simultaneously. Changes: - ReactAdmin.php: Only enqueue React assets when ?react=1 - Init.php: Skip Grid.js when React active on admin pages - Form.php, Coupon.php, Access.php: Restore classic assets when ?react=0 - Customer.php, Product.php, License.php: Add coexistence checks Now the toggle between Classic and React versions works correctly. Co-authored-by: Claude Opus 4.7 <noreply@anthropic.com>
150 lines
4.6 KiB
JavaScript
150 lines
4.6 KiB
JavaScript
"use strict";
|
|
|
|
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
Object.defineProperty(exports, "__esModule", {
|
|
value: true
|
|
});
|
|
exports.default = exports.Snackbar = void 0;
|
|
var _react = require("react");
|
|
var _classnames = _interopRequireDefault(require("classnames"));
|
|
var _a11y = require("@wordpress/a11y");
|
|
var _element = require("@wordpress/element");
|
|
var _i18n = require("@wordpress/i18n");
|
|
var _warning = _interopRequireDefault(require("@wordpress/warning"));
|
|
var _button = _interopRequireDefault(require("../button"));
|
|
/**
|
|
* External dependencies
|
|
*/
|
|
|
|
/**
|
|
* WordPress dependencies
|
|
*/
|
|
|
|
/**
|
|
* Internal dependencies
|
|
*/
|
|
|
|
const NOTICE_TIMEOUT = 10000;
|
|
|
|
/**
|
|
* Custom hook which announces the message with the given politeness, if a
|
|
* valid message is provided.
|
|
*
|
|
* @param message Message to announce.
|
|
* @param politeness Politeness to announce.
|
|
*/
|
|
function useSpokenMessage(message, politeness) {
|
|
const spokenMessage = typeof message === 'string' ? message : (0, _element.renderToString)(message);
|
|
(0, _element.useEffect)(() => {
|
|
if (spokenMessage) {
|
|
(0, _a11y.speak)(spokenMessage, politeness);
|
|
}
|
|
}, [spokenMessage, politeness]);
|
|
}
|
|
function UnforwardedSnackbar({
|
|
className,
|
|
children,
|
|
spokenMessage = children,
|
|
politeness = 'polite',
|
|
actions = [],
|
|
onRemove,
|
|
icon = null,
|
|
explicitDismiss = false,
|
|
// onDismiss is a callback executed when the snackbar is dismissed.
|
|
// It is distinct from onRemove, which _looks_ like a callback but is
|
|
// actually the function to call to remove the snackbar from the UI.
|
|
onDismiss,
|
|
listRef
|
|
}, ref) {
|
|
function dismissMe(event) {
|
|
if (event && event.preventDefault) {
|
|
event.preventDefault();
|
|
}
|
|
|
|
// Prevent focus loss by moving it to the list element.
|
|
listRef?.current?.focus();
|
|
onDismiss?.();
|
|
onRemove?.();
|
|
}
|
|
function onActionClick(event, onClick) {
|
|
event.stopPropagation();
|
|
onRemove?.();
|
|
if (onClick) {
|
|
onClick(event);
|
|
}
|
|
}
|
|
useSpokenMessage(spokenMessage, politeness);
|
|
|
|
// Only set up the timeout dismiss if we're not explicitly dismissing.
|
|
(0, _element.useEffect)(() => {
|
|
const timeoutHandle = setTimeout(() => {
|
|
if (!explicitDismiss) {
|
|
onDismiss?.();
|
|
onRemove?.();
|
|
}
|
|
}, NOTICE_TIMEOUT);
|
|
return () => clearTimeout(timeoutHandle);
|
|
}, [onDismiss, onRemove, explicitDismiss]);
|
|
const classes = (0, _classnames.default)(className, 'components-snackbar', {
|
|
'components-snackbar-explicit-dismiss': !!explicitDismiss
|
|
});
|
|
if (actions && actions.length > 1) {
|
|
// We need to inform developers that snackbar only accepts 1 action.
|
|
typeof SCRIPT_DEBUG !== "undefined" && SCRIPT_DEBUG === true ? (0, _warning.default)('Snackbar can only have 1 action, use Notice if your message require many messages') : void 0;
|
|
// return first element only while keeping it inside an array
|
|
actions = [actions[0]];
|
|
}
|
|
const snackbarContentClassnames = (0, _classnames.default)('components-snackbar__content', {
|
|
'components-snackbar__content-with-icon': !!icon
|
|
});
|
|
return (0, _react.createElement)("div", {
|
|
ref: ref,
|
|
className: classes,
|
|
onClick: !explicitDismiss ? dismissMe : undefined,
|
|
tabIndex: 0,
|
|
role: !explicitDismiss ? 'button' : '',
|
|
onKeyPress: !explicitDismiss ? dismissMe : undefined,
|
|
"aria-label": !explicitDismiss ? (0, _i18n.__)('Dismiss this notice') : ''
|
|
}, (0, _react.createElement)("div", {
|
|
className: snackbarContentClassnames
|
|
}, icon && (0, _react.createElement)("div", {
|
|
className: "components-snackbar__icon"
|
|
}, icon), children, actions.map(({
|
|
label,
|
|
onClick,
|
|
url
|
|
}, index) => {
|
|
return (0, _react.createElement)(_button.default, {
|
|
key: index,
|
|
href: url,
|
|
variant: "tertiary",
|
|
onClick: event => onActionClick(event, onClick),
|
|
className: "components-snackbar__action"
|
|
}, label);
|
|
}), explicitDismiss && (0, _react.createElement)("span", {
|
|
role: "button",
|
|
"aria-label": "Dismiss this notice",
|
|
tabIndex: 0,
|
|
className: "components-snackbar__dismiss-button",
|
|
onClick: dismissMe,
|
|
onKeyPress: dismissMe
|
|
}, "\u2715")));
|
|
}
|
|
|
|
/**
|
|
* A Snackbar displays a succinct message that is cleared out after a small delay.
|
|
*
|
|
* It can also offer the user options, like viewing a published post.
|
|
* But these options should also be available elsewhere in the UI.
|
|
*
|
|
* ```jsx
|
|
* const MySnackbarNotice = () => (
|
|
* <Snackbar>Post published successfully.</Snackbar>
|
|
* );
|
|
* ```
|
|
*/
|
|
const Snackbar = (0, _element.forwardRef)(UnforwardedSnackbar);
|
|
exports.Snackbar = Snackbar;
|
|
var _default = Snackbar;
|
|
exports.default = _default;
|
|
//# sourceMappingURL=index.js.map
|