one-click-accessibility/modules/scanner/assets/js/index.js
VasylD 97e5c1241b
[APP-945] add column for tables (#282)
* [APP-945] add column for tables

* [APP-945] add column for tables

* [APP-945] add column for tables

* [APP-945] add column for tables
2025-05-29 11:44:48 +02:00

94 lines
2.7 KiB
JavaScript

import DirectionProvider from '@elementor/ui/DirectionProvider';
import { createTheme, ThemeProvider } from '@elementor/ui/styles';
import createCache from '@emotion/cache';
import { CacheProvider } from '@emotion/react';
import { prefixer } from 'stylis';
import rtlPlugin from 'stylis-plugin-rtl';
import { NotificationsProvider } from '@ea11y-apps/global/hooks/use-notifications';
import App from '@ea11y-apps/scanner/app';
import {
isRTL,
ROOT_ID,
SCANNER_URL_PARAM,
TOP_BAR_LINK,
} from '@ea11y-apps/scanner/constants';
import { ScannerWizardContextProvider } from '@ea11y-apps/scanner/context/scanner-wizard-context';
import { closeWidget } from '@ea11y-apps/scanner/utils/close-widget';
import { createRoot, Fragment, StrictMode } from '@wordpress/element';
import { __ } from '@wordpress/i18n';
document.addEventListener('DOMContentLoaded', function () {
const params = new URLSearchParams(window.location.search);
if (params.get(SCANNER_URL_PARAM) === '1') {
initApp();
}
});
TOP_BAR_LINK.addEventListener('click', (event) => {
event.preventDefault();
const rootNode = document.getElementById(ROOT_ID);
if (rootNode) {
closeWidget(rootNode);
} else {
initApp();
}
});
const initApp = () => {
const adminBar = document.querySelector('#wpadminbar');
window.ea11yScannerData = {
...window.ea11yScannerData,
adminBar,
};
adminBar.remove();
const rootNode = document.createElement('aside');
rootNode.id = ROOT_ID;
rootNode.setAttribute(
'aria-label',
__('Accessibility Assistant', 'pojo-accessibility'),
);
if (isRTL) {
rootNode.setAttribute('dir', 'rtl');
}
document.body.style[isRTL ? 'marginLeft' : 'marginRight'] = '425px';
document.body.appendChild(rootNode);
const shadowContainer = rootNode.attachShadow({ mode: 'open' });
const shadowRootElement = document.createElement('div');
shadowContainer.appendChild(shadowRootElement);
// Can't use the settings hook in the global scope so accessing directly
const isDevelopment = window?.ea11ySettingsData?.isDevelopment;
const AppWrapper = Boolean(isDevelopment) ? StrictMode : Fragment;
const cache = createCache({
key: 'css',
prepend: true,
container: shadowContainer,
stylisPlugins: isRTL ? [prefixer, rtlPlugin] : [],
});
const theme = createTheme({
direction: isRTL ? 'rtl' : 'ltr',
});
createRoot(shadowRootElement).render(
<AppWrapper>
<CacheProvider value={cache}>
<DirectionProvider rtl={isRTL}>
<ThemeProvider colorScheme="light" theme={theme}>
<NotificationsProvider>
<ScannerWizardContextProvider>
<App />
</ScannerWizardContextProvider>
</NotificationsProvider>
</ThemeProvider>
</DirectionProvider>
</CacheProvider>
</AppWrapper>,
);
};