UNPKG

@atlaskit/atlassian-navigation

Version:

A horizontal navigation component for Atlassian apps.

159 lines (156 loc) 7.1 kB
/** * @jsxRuntime classic * @jsx jsx */ import React, { Fragment } from 'react'; // eslint-disable-next-line @atlaskit/ui-styling-standard/use-compiled -- Ignored via go/DSP-18766 import { css, jsx } from '@emotion/react'; import { PRODUCT_HOME_BREAKPOINT } from '../../common/constants'; import { useTheme } from '../../theme'; import { stripEmptyProperties } from '../../utils'; const VAR_PRODUCT_HOME_COLOR_ACTIVE = '--product-home-color-active'; const VAR_PRODUCT_HOME_BACKGROUND_COLOR_ACTIVE = '--product-home-bg-color-active'; const VAR_PRODUCT_HOME_BOX_SHADOW_ACTIVE = '--product-home-box-shadow-active'; const VAR_PRODUCT_HOME_COLOR_FOCUS = '--product-home-color-focus'; const VAR_PRODUCT_HOME_BACKGROUND_COLOR_FOCUS = '--product-home-bg-color-focus'; const VAR_PRODUCT_HOME_BOX_SHADOW_FOCUS = '--product-home-box-shadow-focus'; const VAR_PRODUCT_HOME_COLOR_HOVER = '--product-home-color-hover'; const VAR_PRODUCT_HOME_BACKGROUND_COLOR_HOVER = '--product-home-bg-color-hover'; const VAR_PRODUCT_HOME_BOX_SHADOW_HOVER = '--product-home-box-shadow-hover'; const VAR_SITE_TITLE_BG_COLOR_AFTER = '--site-title-bg-color-after'; const productHomeButtonStyles = css({ display: 'flex', padding: "var(--ds-space-050, 4px)", alignItems: 'center', background: 'none', border: 0, borderRadius: "var(--ds-radius-small, 3px)", color: 'inherit', cursor: 'pointer', // eslint-disable-next-line @atlaskit/ui-styling-standard/no-unsafe-selectors -- Ignored via go/DSP-18766 '&::-moz-focus-inner': { border: 0 }, // eslint-disable-next-line @atlaskit/ui-styling-standard/no-unsafe-selectors -- Ignored via go/DSP-18766 '&:first-of-type': { marginInlineStart: 0 }, '&:active': { backgroundColor: `var(${VAR_PRODUCT_HOME_BACKGROUND_COLOR_ACTIVE})`, boxShadow: `var(${VAR_PRODUCT_HOME_BOX_SHADOW_ACTIVE})`, color: `var(${VAR_PRODUCT_HOME_COLOR_ACTIVE})` }, '&:focus': { backgroundColor: `var(${VAR_PRODUCT_HOME_BACKGROUND_COLOR_FOCUS})`, boxShadow: `var(${VAR_PRODUCT_HOME_BOX_SHADOW_FOCUS})`, color: `var(${VAR_PRODUCT_HOME_COLOR_FOCUS})`, outline: 0 }, '&:hover': { backgroundColor: `var(${VAR_PRODUCT_HOME_BACKGROUND_COLOR_HOVER})`, boxShadow: `var(${VAR_PRODUCT_HOME_BOX_SHADOW_HOVER})`, color: `var(${VAR_PRODUCT_HOME_COLOR_HOVER})` }, // eslint-disable-next-line @atlaskit/design-system/no-nested-styles, @atlaskit/ui-styling-standard/no-nested-selectors, @atlaskit/ui-styling-standard/no-unsafe-selectors -- Ignored via go/DSP-18766 'div&': { pointerEvents: 'none' }, // eslint-disable-next-line @atlaskit/design-system/no-nested-styles, @atlaskit/ui-styling-standard/no-unsafe-values, @atlaskit/ui-styling-standard/no-imported-style-values -- Ignored via go/DSP-18766 [`@media (max-width: ${PRODUCT_HOME_BREAKPOINT - 0.1}px)`]: { margin: `0 ${"var(--ds-space-100, 8px)"}` }, // eslint-disable-next-line @atlaskit/design-system/no-nested-styles, @atlaskit/ui-styling-standard/no-unsafe-values, @atlaskit/ui-styling-standard/no-imported-style-values -- Ignored via go/DSP-18766 [`@media (min-width: ${PRODUCT_HOME_BREAKPOINT}px)`]: { margin: `0 ${"var(--ds-space-200, 16px)"}` } }); const productLogoStyles = css({ display: 'flex', width: 120, maxWidth: 120, height: 24, maxHeight: 28, opacity: 0.15, // eslint-disable-next-line @atlaskit/design-system/no-nested-styles, @atlaskit/ui-styling-standard/no-nested-selectors -- Ignored via go/DSP-18766 '& > *': { maxHeight: 24 }, // eslint-disable-next-line @atlaskit/design-system/no-nested-styles, @atlaskit/ui-styling-standard/no-unsafe-values, @atlaskit/ui-styling-standard/no-imported-style-values -- Ignored via go/DSP-18766 [`@media (max-width: ${PRODUCT_HOME_BREAKPOINT - 0.1}px)`]: { display: 'none' } }); const productIconStyles = css({ display: 'flex', width: 28, height: 28, borderRadius: "var(--ds-radius-full, 50%)", opacity: 0.15, // eslint-disable-next-line @atlaskit/design-system/no-nested-styles, @atlaskit/ui-styling-standard/no-nested-selectors -- Ignored via go/DSP-18766 '& > *': { maxHeight: 24 }, // eslint-disable-next-line @atlaskit/design-system/no-nested-styles, @atlaskit/ui-styling-standard/no-unsafe-values, @atlaskit/ui-styling-standard/no-imported-style-values -- Ignored via go/DSP-18766 [`@media (min-width: ${PRODUCT_HOME_BREAKPOINT}px)`]: { display: 'none' } }); const siteTitleStyles = css({ display: 'flex', width: "var(--ds-space-500, 40px)", alignItems: 'center', backgroundColor: 'transparent', marginInlineEnd: "var(--ds-space-050, 4px)", marginInlineStart: "var(--ds-space-050, 4px)", paddingInlineEnd: "var(--ds-space-200, 16px)", // eslint-disable-next-line @atlaskit/ui-styling-standard/no-unsafe-selectors -- Ignored via go/DSP-18766 '&:after': { width: '100%', height: 14, backgroundColor: `var(${VAR_SITE_TITLE_BG_COLOR_AFTER})`, borderRadius: "var(--ds-radius-small, 4px)", content: '""' } }); // Not exported to consumers, only used in NavigationSkeleton // eslint-disable-next-line @repo/internal/react/require-jsdoc export const ProductHomeSkeleton = ({ showSiteName }) => { const theme = useTheme(); const primaryButton = theme.mode.primaryButton; const productHomeButtonDynamicStyles = stripEmptyProperties({ [VAR_PRODUCT_HOME_COLOR_ACTIVE]: primaryButton.active.color, [VAR_PRODUCT_HOME_BACKGROUND_COLOR_ACTIVE]: primaryButton.active.backgroundColor, [VAR_PRODUCT_HOME_BOX_SHADOW_ACTIVE]: primaryButton.active.boxShadow, [VAR_PRODUCT_HOME_COLOR_FOCUS]: primaryButton.focus.color, [VAR_PRODUCT_HOME_BACKGROUND_COLOR_FOCUS]: primaryButton.focus.backgroundColor, [VAR_PRODUCT_HOME_BOX_SHADOW_FOCUS]: primaryButton.focus.boxShadow, [VAR_PRODUCT_HOME_COLOR_HOVER]: primaryButton.hover.color, [VAR_PRODUCT_HOME_BACKGROUND_COLOR_HOVER]: primaryButton.hover.backgroundColor, [VAR_PRODUCT_HOME_BOX_SHADOW_HOVER]: primaryButton.hover.boxShadow, [VAR_SITE_TITLE_BG_COLOR_AFTER]: theme.mode.skeleton.backgroundColor }); const siteTitleDynamicStyles = { borderRight: theme.mode.productHome.borderRight, opacity: theme.mode.skeleton.opacity, [VAR_SITE_TITLE_BG_COLOR_AFTER]: theme.mode.skeleton.backgroundColor }; return jsx(Fragment, null, jsx("div", { // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop -- Ignored via go/DSP-18766 style: productHomeButtonDynamicStyles, css: productHomeButtonStyles }, jsx("div", { // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop -- Ignored via go/DSP-18766 style: theme.mode.skeleton, css: productLogoStyles }), jsx("div", { // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop -- Ignored via go/DSP-18766 style: theme.mode.skeleton, css: productIconStyles })), showSiteName && jsx("div", { // eslint-disable-next-line @atlaskit/ui-styling-standard/enforce-style-prop -- Ignored via go/DSP-18766 style: siteTitleDynamicStyles, css: siteTitleStyles })); };