@elastic/eui
Version:
Elastic UI Component Library
91 lines (89 loc) • 6.88 kB
JavaScript
import _defineProperty from "@babel/runtime/helpers/defineProperty";
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { _defineProperty(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; }
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
/*
* Copyright Elasticsearch B.V. and/or licensed to Elasticsearch B.V. under one
* or more contributor license agreements. Licensed under the Elastic License
* 2.0 and the Server Side Public License, v 1; you may not use this file except
* in compliance with, at your election, the Elastic License 2.0 or the Server
* Side Public License, v 1.
*/
import { css } from '@emotion/react';
import { mathWithUnits, logicalCSS, euiFontSizeFromScale, euiCanAnimate, euiAnimScale, logicalSizeCSS } from '../../global_styling';
import { highContrastModeStyles, preventForcedColors } from '../../global_styling/functions/high_contrast';
import { euiStepVariables } from './step.styles';
import { euiButtonFillColor } from '../../global_styling/mixins';
var _ref = process.env.NODE_ENV === "production" ? {
name: "1ru1jeq-euiStepNumber",
styles: "flex-shrink:0;label:euiStepNumber;"
} : {
name: "1ru1jeq-euiStepNumber",
styles: "flex-shrink:0;label:euiStepNumber;",
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
};
export var euiStepNumberStyles = function euiStepNumberStyles(euiThemeContext) {
var euiTheme = euiThemeContext.euiTheme;
var euiStep = euiStepVariables(euiTheme);
var createStepsNumber = function createStepsNumber(size, fontSize) {
return "\n display: flex;\n justify-content: center;\n align-items: center;\n ".concat(logicalCSS('width', size), ";\n ").concat(logicalCSS('height', size), ";\n font-size: ").concat(fontSize, ";\n font-weight: ").concat(euiTheme.font.weight.medium, ";\n color: ").concat(euiTheme.colors.emptyShade, ";\n background-color: ").concat(euiTheme.colors.primary, ";\n border-radius: 50%;\n ").concat(highContrastModeStyles(euiThemeContext, {
preferred: "border: ".concat(euiTheme.border.thick, ";")
}), "\n ");
};
// euiButtonColor utils add colored borders in high contrast mode, but
// we want to set our own standardized border instead
var unsetButtonBorder = function unsetButtonBorder(buttonStyles) {
return _objectSpread(_objectSpread({}, buttonStyles), {}, {
border: undefined
});
};
return {
euiStepNumber: _ref,
// sizes
m: /*#__PURE__*/css(createStepsNumber(euiStep.numberSize, euiFontSizeFromScale('s', euiTheme)), ";;label:m;"),
s: /*#__PURE__*/css(createStepsNumber(euiStep.numberSize, euiFontSizeFromScale('s', euiTheme)), ";;label:s;"),
xs: /*#__PURE__*/css(createStepsNumber(euiStep.numberXSSize, euiFontSizeFromScale('xs', euiTheme)), ";;label:xs;"),
none: /*#__PURE__*/css(createStepsNumber(euiStep.numberXXSSize, euiFontSizeFromScale('xs', euiTheme)), ";;label:none;"),
// status
incomplete: /*#__PURE__*/css("background-color:transparent;color:", euiTheme.colors.textParagraph, ";border:", euiTheme.border.thick, ";;label:incomplete;"),
disabled: /*#__PURE__*/css(euiButtonFillColor(euiThemeContext, 'disabled'), " ", highContrastModeStyles(euiThemeContext, {
forced: 'opacity: 0.5;'
}), ";;label:disabled;"),
loading: /*#__PURE__*/css("background:transparent;", highContrastModeStyles(euiThemeContext, {
preferred: 'border: none;'
}), ";;label:loading;"),
warning: /*#__PURE__*/css(unsetButtonBorder(euiButtonFillColor(euiThemeContext, 'warning')), " ", euiCanAnimate, "{animation:", euiAnimScale, " ", euiTheme.animation.fast, " ", euiTheme.animation.bounce, ";};label:warning;"),
danger: /*#__PURE__*/css(unsetButtonBorder(euiButtonFillColor(euiThemeContext, 'danger')), " ", euiCanAnimate, "{animation:", euiAnimScale, " ", euiTheme.animation.fast, " ", euiTheme.animation.bounce, ";};label:danger;"),
complete: /*#__PURE__*/css(unsetButtonBorder(euiButtonFillColor(euiThemeContext, 'success')), " ", euiCanAnimate, "{animation:", euiAnimScale, " ", euiTheme.animation.fast, " ", euiTheme.animation.bounce, ";};label:complete;"),
current: /*#__PURE__*/css("transform:scale(1.1);box-shadow:inset 0 0 0 ", euiTheme.border.width.thick, " ", euiTheme.colors.emptyShade, ";", highContrastModeStyles(euiThemeContext, {
none: "\n border: ".concat(euiTheme.border.width.thick, " solid ").concat(euiTheme.colors.primary, ";\n "),
// !important overrides horizontal steps' euiOutline usage. The extra offset
// is here to helps reduce subpixel gaps between the outline and the border
preferred: "\n border-width: ".concat(euiTheme.border.width.thick, ";\n outline-offset: -").concat(euiTheme.border.width.thin, " !important;\n "),
// For Windows forced color themes, just invert the background/foreground colors
forced: "\n color: ".concat(euiTheme.colors.emptyShade, ";\n background-color: ").concat(euiTheme.colors.fullShade, ";\n ").concat(preventForcedColors(euiThemeContext), "\n ")
}), ";;label:current;")
};
};
export var euiStepNumberContentStyles = function euiStepNumberContentStyles(_ref2) {
var euiTheme = _ref2.euiTheme;
return {
// Statuses with icon content
euiStepNumber__icon: /*#__PURE__*/css(";label:euiStepNumber__icon;"),
complete: /*#__PURE__*/css("stroke:currentColor;stroke-width:", mathWithUnits(euiTheme.border.width.thin, function (x) {
return x / 2;
}), ";;label:complete;"),
danger: /*#__PURE__*/css("stroke:currentColor;stroke-width:", mathWithUnits(euiTheme.border.width.thin, function (x) {
return x / 2;
}), ";;label:danger;"),
warning: {
// Slight extra offset for visual balance. Intentionally uses static px and not tokens
m: "margin-block-start: -2px;",
s: "margin-block-start: -2px;",
xs: "margin-block-start: -1px;",
none: "margin-block-start: -0.5px;"
},
// Title sizes
none: /*#__PURE__*/css(logicalSizeCSS(euiTheme.size.s), ";label:none;")
};
};