Sha256: 50cafff58ca615527e43f563dffe07c5f42bd2970d02a44faa5d8f8a88467f45

Contents?: true

Size: 1.7 KB

Versions: 4

Compression:

Stored size: 1.7 KB

Contents

/* @flow */

import React from 'react'
import classnames from 'classnames'
import DateTime from '../pb_kit/dateTime.js'

import {
  Title,
  Caption
} from '../'

type DateStackedProps = {
  align?: 'center' | 'right',
  className?: String | Array<String>,
  dark?: Boolean,
  data?: String,
  date: String,
  size?: 'sm' | 'md',
  id?: String,
  reverse?: Boolean,
}

const kitClasses = ({
  align='left',
  size='sm',
  dark=false,
  reverse=false,

}: DateStackedProps) => {
  const alignStyle = align !== '' ? `_${align}` : ''
  const sizeStyle = size !== '' ? `_${size}` : ''
  const themeStyle = dark === true ? '_dark' : ''
  const reverseStyle = reverse === true ? '_reverse' : ''
  return 'pb_date_stacked_kit' + alignStyle + sizeStyle + themeStyle + reverseStyle
}

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

const DateStacked = (props: DateStackedProps) => {
  const {
    align='left',
    className,
    dark=false,
    reverse=false,
    date,
    size='sm'
  } = props

  const dateTimestamp = new DateTime({ value: date })
  const css = classnames(kitClasses(props), className)

  const current_year = new Date().getFullYear().toString()
  const input_year = dateTimestamp.toYear().toString()

  const print_year = dateTimestamp => {
    if (current_year != input_year) {
      return (
        <Caption size='xs'>{input_year}</Caption>
      )
    }
  }

  return (
    <div className={css}>
      <div class="pb_date_stacked_day_month">
        <Caption
          text={`${dateTimestamp.toMonth().toUpperCase()}`}
        />
        <Title
          dark={dark}
          size={sizes[size]}
          text={`${dateTimestamp.toDay()}`}
        />
      </div>
        {print_year(date)}
    </div>
  )
}

export default DateStacked

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
playbook_ui-3.1.0 app/pb_kits/playbook/pb_date_stacked/_date_stacked.jsx
playbook_ui-3.0.1 app/pb_kits/playbook/pb_date_stacked/_date_stacked.jsx
playbook_ui-3.0.0 app/pb_kits/playbook/pb_date_stacked/_date_stacked.jsx
playbook_ui-2.9.9 app/pb_kits/playbook/pb_date_stacked/_date_stacked.jsx