Sha256: e1ca2a6ec2aeb505566e8eeba5d3294c2534de0439a2235d3db685f632e08a15

Contents?: true

Size: 1.78 KB

Versions: 44

Compression:

Stored size: 1.78 KB

Contents

/* @flow */

import React from 'react'
import classnames from 'classnames'

import { spacing } from '../utilities/spacing.js'
import { Body, Caption, Title } from '../'
import { buildAriaProps, buildCss, buildDataProps } from '../utilities/props'

type CurrencyProps = {
  align?: 'center' | 'left' | 'right',
  amount: String,
  aria?: object,
  className?: String,
  dark?: Boolean,
  data?: object,
  id?: String,
  label?: String,
  size?: 'sm' | 'md' | 'lg',
  symbol?: String,
  unit?: String,
}

const sizes = {
  lg: 1,
  md: 3,
  sm: 4,
}

const Currency = (props: CurrencyProps) => {
  const {
    align = 'left',
    aria = {},
    amount,
    data = {},
    id,
    unit,
    className,
    label = '',
    size = 'sm',
    symbol = '$',
    dark = false,
  } = props

  const [whole, decimal = '00'] = amount.split('.')
  const ariaProps = buildAriaProps(aria)
  const dataProps = buildDataProps(data)
  const classes = classnames(buildCss('pb_currency_kit', align, size, { dark: dark }), className, spacing(props))

  return (
    <div
        {...ariaProps}
        {...dataProps}
        className={classes}
        id={id}
    >
      <Caption>{label}</Caption>

      <div className="pb_currency_wrapper">
        <Body
            className="dollar_sign"
            color="light"
            dark={dark}
        >
          {symbol}
        </Body>

        <Title
            className="pb_currency_value"
            dark={dark}
            size={sizes[size]}
        >
          {`${whole}`}
        </Title>

        <Body
            className="unit"
            color="light"
            dark={dark}
        >
          <If condition={unit}>
            {unit}
            <Else />
            {`.${decimal}`}
          </If>
        </Body>
      </div>
    </div>
  )
}

export default Currency

Version data entries

44 entries across 44 versions & 1 rubygems

Version Path
playbook_ui-6.0.1.pre.alpha5 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-6.0.1.pre.alpha4 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-6.0.1.pre.alpha3 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-6.0.1.pre.alpha2 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.2.0.pre.alpha15 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.2.0.pre.alpha14 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.2.0.pre.alpha13 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-6.0.1 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.2.0.pre.alpha12 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-6.0.0 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.2.0.pre.alpha11 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.5.1.pre.alpha4 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.5.1.pre.alpha3 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.5.1.pre.alpha2 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.5.1.pre.alpha1 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.2.0.pre.alpha10 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.5.1 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.5.0 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.5.0.pre.alpha1 app/pb_kits/playbook/pb_currency/_currency.jsx
playbook_ui-5.2.0.pre.alpha9 app/pb_kits/playbook/pb_currency/_currency.jsx