You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							99 lines
						
					
					
						
							3.3 KiB
						
					
					
				
			
		
		
	
	
							99 lines
						
					
					
						
							3.3 KiB
						
					
					
				"use strict";
 | 
						|
var __importDefault = (this && this.__importDefault) || function (mod) {
 | 
						|
    return (mod && mod.__esModule) ? mod : { "default": mod };
 | 
						|
};
 | 
						|
Object.defineProperty(exports, "__esModule", { value: true });
 | 
						|
exports.Step = void 0;
 | 
						|
const react_1 = __importDefault(require("react"));
 | 
						|
const styled_components_1 = __importDefault(require("styled-components"));
 | 
						|
const styled_system_1 = require("styled-system");
 | 
						|
const icon_1 = __importDefault(require("../../atoms/icon"));
 | 
						|
const text_1 = __importDefault(require("../../atoms/text"));
 | 
						|
const box_1 = __importDefault(require("../../atoms/box"));
 | 
						|
const css_class_1 = require("../../utils/css-class");
 | 
						|
const Circle = styled_components_1.default(box_1.default) `
 | 
						|
  border-width: 1px;
 | 
						|
  border-style: solid;
 | 
						|
  border-radius: 9999px;
 | 
						|
  text-align: center;
 | 
						|
`;
 | 
						|
Circle.defaultProps = {
 | 
						|
    py: 'default',
 | 
						|
    px: 'default',
 | 
						|
    minWidth: '34px',
 | 
						|
    height: '34px',
 | 
						|
};
 | 
						|
const StyledStep = styled_components_1.default.div `
 | 
						|
  flex: 1 1 0px;
 | 
						|
  display: flex;
 | 
						|
  flex-direction: row;
 | 
						|
 | 
						|
  & > ${box_1.default} {
 | 
						|
    ${({ disabled }) => (!disabled ? 'cursor: pointer' : '')};
 | 
						|
    border-bottom: 2px solid ${({ active, theme }) => (active ? theme.colors.primary100 : 'transparent')};
 | 
						|
  }
 | 
						|
  
 | 
						|
  ${styled_system_1.space};
 | 
						|
`;
 | 
						|
/**
 | 
						|
 * @classdesc
 | 
						|
 *
 | 
						|
 * <img src="components/step.png" />
 | 
						|
 *
 | 
						|
 * Step represents one of the tab in placed inside {@link Stepper} component.
 | 
						|
 * You can use it alone or with before-mentioned {@link Stepper}.
 | 
						|
 *
 | 
						|
 * ### Usage
 | 
						|
 *
 | 
						|
 * ```javascript
 | 
						|
 * import { Step, StepProps } from '@adminjs/design-system'
 | 
						|
 * ```
 | 
						|
 *
 | 
						|
 *
 | 
						|
 * @hideconstructor
 | 
						|
 * @see Stepper
 | 
						|
 * @see StepProps
 | 
						|
 * @see OnStepClickHandler
 | 
						|
 * @subcategory Molecules
 | 
						|
 * @component
 | 
						|
 * @example <caption>Regular step</caption>
 | 
						|
 * return (
 | 
						|
 *   <Box p="default">
 | 
						|
 *     <Step number="1">Normal Step</Step>
 | 
						|
 *  </Box>
 | 
						|
 * )
 | 
						|
 *
 | 
						|
 * @example <caption>Active steps</caption>
 | 
						|
 * return (
 | 
						|
 *   <Box p="default">
 | 
						|
 *     <Step number="1" active>I am active</Step>
 | 
						|
 *  </Box>
 | 
						|
 * )
 | 
						|
 *
 | 
						|
 * @example <caption>Active steps</caption>
 | 
						|
 * return (
 | 
						|
 *   <Box p="default">
 | 
						|
 *     <Step number="1" completed>This was done !!!</Step>
 | 
						|
 *  </Box>
 | 
						|
 * )
 | 
						|
 *
 | 
						|
 * @example <caption>Clickable step</caption>
 | 
						|
 * const onClick = () => alert('Why did you click me?')
 | 
						|
 *
 | 
						|
 * return (
 | 
						|
 *   <Box p="default">
 | 
						|
 *     <Step number="1" onClick={onClick}>Click me if you dare</Step>
 | 
						|
 *  </Box>
 | 
						|
 * )
 | 
						|
 * @section design-system
 | 
						|
 */
 | 
						|
const Step = (props) => {
 | 
						|
    const { number, completed, children, active, disabled, onClick, className } = props;
 | 
						|
    return (react_1.default.createElement(StyledStep, { active: active, disabled: disabled || !onClick, className: css_class_1.cssClass('Step', className) },
 | 
						|
        react_1.default.createElement(box_1.default, { flexShrink: 1, flexGrow: 0, flex: true, flexDirection: "row", pt: "lg", pb: "default", onClick: () => !disabled && onClick && onClick(number) },
 | 
						|
            react_1.default.createElement(Circle, { bg: completed ? 'grey40' : 'transparent', borderColor: active ? 'primary100' : 'grey40', color: active ? 'primary100' : 'grey40' }, completed ? (react_1.default.createElement(icon_1.default, { icon: "Checkmark", color: "white" })) : number),
 | 
						|
            react_1.default.createElement(text_1.default, { my: "sm", pl: "default", py: "sm", color: active || completed ? 'grey100' : 'grey40' }, children))));
 | 
						|
};
 | 
						|
exports.Step = Step;
 | 
						|
exports.default = Step;
 |