@atlaskit/editor-common
Version:
A package that contains common classes and components for editor and renderer
85 lines (84 loc) • 3.9 kB
JavaScript
/**
* @jsxRuntime classic
* @jsx jsx
* @jsxFrag React.Fragment
*/
import React from 'react';
// eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled, @typescript-eslint/consistent-type-imports -- Ignored via go/DSP-18766; jsx required at runtime for @jsxRuntime classic
import { css, jsx } from '@emotion/react';
import classnames from 'classnames';
import { expValEquals } from '@atlaskit/tmp-editor-statsig/exp-val-equals';
import { ZERO_WIDTH_SPACE } from '../whitespace';
import { ExtensionSSRReactContextsProvider } from './ExtensionSSRReactContextsProvider';
const styles = css({
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors -- Ignored via go/DSP-18766
'&.inline-extension': {
display: 'inline-block'
},
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors -- Ignored via go/DSP-18766
'&.relative': {
position: 'relative'
}
});
const hoverStyles = css({
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors, @atlaskit/ui-styling-standard/no-unsafe-selectors
':has(.extension-label:hover) .extension-container, :has(.extension-edit-toggle-container:hover) .extension-container': {
boxShadow: `0 0 0 1px ${"var(--ds-border-input, #8C8F97)"}`
},
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors, @atlaskit/ui-styling-standard/no-unsafe-selectors
':has(.extension-container:hover) .extension-label, :has(.extension-edit-toggle-container:hover) .extension-label, .extension-label:hover': {
opacity: 1,
backgroundColor: "var(--ds-background-accent-gray-subtlest, #F0F1F2)",
boxShadow: 'none',
cursor: 'pointer',
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors
'&.always-hide-label': {
opacity: 0,
cursor: 'auto'
},
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors
'&.with-bodied-macro-live-page-styles': {
backgroundColor: "var(--ds-background-input, #FFFFFF)",
boxShadow: `0 0 0 1px ${"var(--ds-border, #0B120E24)"}`
}
},
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors, @atlaskit/ui-styling-standard/no-unsafe-selectors
':has(.extension-label:hover) .extension-icon, :has(.extension-container:hover) .extension-icon, :has(.extension-edit-toggle-container:hover) .extension-icon': {
display: 'inline'
},
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-nested-selectors, @atlaskit/ui-styling-standard/no-unsafe-selectors
':has(.extension-label:hover) .extension-edit-toggle-container, :has(.extension-container:hover) .extension-edit-toggle-container, .extension-edit-toggle-container:hover': {
opacity: 1
}
});
/**
* If inlineExtension, add zero width space to the end of the nodes and wrap with span;
* Also if showMacroInteractionDesignUpdates is true, then add the inline-block style to account for the lozenge.
* else wrap with a div (for multi bodied extensions)
*
* @param param0
* @returns
*/
export const ExtensionNodeWrapper = ({
children,
nodeType,
macroInteractionDesignFeatureFlags,
intl
}) => {
const {
showMacroInteractionDesignUpdates
} = macroInteractionDesignFeatureFlags || {};
const wrapperClassNames = classnames({
'inline-extension': nodeType === 'inlineExtension' && showMacroInteractionDesignUpdates,
relative: showMacroInteractionDesignUpdates
});
return jsx(ExtensionSSRReactContextsProvider, {
intl: intl
}, jsx("span", {
"data-testid": "extension-node-wrapper"
// eslint-disable-next-line @atlaskit/ui-styling-standard/no-classname-prop
,
className: wrapperClassNames,
css: [styles, expValEquals('cc_editor_ttvc_release_bundle_one', 'extensionHoverRefactor', true) && hoverStyles]
}, children, nodeType === 'inlineExtension' && ZERO_WIDTH_SPACE));
};