~cytrogen/masto-fe

ref: 7cfcd23dadc97a0ef287a2a542e3eb21c88eb70f masto-fe/app/javascript/mastodon/features/onboarding/components/progress_indicator.jsx -rw-r--r-- 792 bytes
7cfcd23d — Cytrogen Convert 17 SCSS files to CSS custom properties (Phase 3-4) a month ago
                                                                                
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
import PropTypes from "prop-types";
import { Fragment } from "react";

import classNames from "classnames";

import { Check } from "mastodon/components/check";

const ProgressIndicator = ({ steps, completed }) => (
  <div className='onboarding__progress-indicator'>
    {(new Array(steps)).fill().map((_, i) => (
      <Fragment key={i}>
        {i > 0 && <div className={classNames("onboarding__progress-indicator__line", { active: completed > i })} />}

        <div className={classNames("onboarding__progress-indicator__step", { active: completed > i })}>
          {completed > i && <Check />}
        </div>
      </Fragment>
    ))}
  </div>
);

ProgressIndicator.propTypes = {
  steps: PropTypes.number.isRequired,
  completed: PropTypes.number,
};

export default ProgressIndicator;