/* eslint-disable max-len */
/**
 * @interface Theme
 * @load ./theme.doc.md
 * @section design-system
 */
/**
 * Color palette.
 *
 * @memberof Theme
 * @alias colors
 * @property {string} primary100=#4268F6      
 * @property {string} primary80=#6483F8     
 * @property {string} primary60=#879FFA     
 * @property {string} primary40=#A9BAFA     
 * @property {string} primary20=#CBD5FD     
 * @property {string} accent=#38CAF1      
 * @property {string} love=#e6282b      
 * @property {string} grey100=#1C1C38     
 * @property {string} grey80=#454655      
 * @property {string} grey60=#898A9A      
 * @property {string} grey40=#C0C0CA      
 * @property {string} grey20=#F6F7FB      
 * @property {string} white=#fff      
 * @property {string} errorDark=#DE405D     
 * @property {string} error=#FF4567     
 * @property {string} errorLight=#FFA5B5      
 * @property {string} successDark=#32A887     
 * @property {string} success=#70C9B0     
 * @property {string} successLight=#DBF0F1      
 * @property {string} infoDark=#4268F6      
 * @property {string} info=#879FFA      
 * @property {string} infoLight=#CBD5FD     
 * @property {string} filterBg=#343F87      
 * @property {string} hoverBg=#535B8E     
 * @property {string} inputBorder=#898A9A     
 * @property {string} border=#DDE1E5,     
 * @property {string} separator=#C0C0CA     
 * @property {string} highlight=#F6F7FB     
 * @property {string} filterInputBorder=rgba(255,255,255,0.15)      
 * @property {string} filterDisabled=rgba(83,91,142,0.05)      
 * @property {string} bg=#F6F7FB      
 */
const colors = {
  // Primary
  primary100: '#4268F6',
  primary80: '#6483F8',
  primary60: '#879FFA',
  primary40: '#A9BAFA',
  primary20: '#CBD5FD',
  // accent
  accent: '#38CAF1',
  love: '#4D70EB', // Main AdminJS logo color
  // grey
  grey100: '#1C1C38',
  grey80: '#454655',
  grey60: '#898A9A',
  grey40: '#C0C0CA',
  grey20: '#F6F7FB',
  white: '#fff',
  // Alerts
  errorDark: '#DE405D',
  error: '#FF4567',
  errorLight: '#FFA5B5',
  successDark: '#32A887',
  success: '#70C9B0',
  successLight: '#DBF0F1',
  infoDark: '#4268F6',
  info: '#879FFA',
  infoLight: '#CBD5FD',
  // Backgrounds
  filterBg: '#343F87',
  hoverBg: '#535B8E',
  // global
  border: '#DDE1E5',
  // Elements
  inputBorder: '#C0C0CA',
  separator: '#C0C0CA',
  highlight: '#F6F7FB',
  filterInputBorder: 'rgba(255,255,255,0.15)',
  filterDisabled: 'rgba(83,91,142,0.05)',
  bg: '#F6F7FB',
}
/**
 * Sizes can be used with paddings, margins etc.
 *
 * This is the example of using responsive margin with Box component
 *
 * ```javascript
 * some content
 * ```
 *
 * This component will have 8px padding for lowest breakpoint and 24px above
 * this breakpoint.
 *
 * @memberof Theme
 * @alias space
 * @property {string} xs=2px        2px - 
 * @property {string} sm=4px        4px - 
 * @property {string} default=8px   8px -  (alias md)
 * @property {string} lg=16px       16px - 
 * @property {string} xl=24px       24px - 
 * @property {string} xxl=32px      32px - 
 * @property {string} x3=48px       48px - 
 * @property {string} x4=64px       64px - 
 * @property {string} x5=80px       80px - 
 * @property {string} x6=128px      128px - 
 */
const space = {
  xs: '2px',
  sm: '4px',
  default: '8px',
  md: '8px',
  lg: '16px',
  xl: '24px',
  xxl: '32px',
  x3: '48px',
  x4: '64px',
  x5: '80px',
  x6: '128px',
}
/**
 * @memberof Theme
 * @alias sizes
 * @property {string} navbarHeight=64px
 * @property {string} sidebarWidth=300px
 * @property {string} maxFormWidth=740px
 */
const sizes = {
  navbarHeight: '64px',
  sidebarWidth: '300px',
  maxFormWidth: '740px',
}
/**
 * @memberof Theme
 * @alias fontSizes
 * @property {string} xs=10px      'xs' font size
 * @property {string} sm=12px      'sm' font size
 * @property {string} default=14px (alias md) 'default' font size
 * @property {string} lg=16px      'lg' font size
 * @property {string} xl=18px      'xl' font size
 * @property {string} h4=24px      'h4' font size
 * @property {string} h3=28px      'h3' font size
 * @property {string} h2=32px      'h2' font size
 * @property {string} h1=40px      'h1' font size
 */
const fontSizes = {
  xs: '10px',
  sm: '12px',
  default: '14px',
  md: '14px',
  lg: '16px',
  xl: '18px',
  h4: '24px',
  h3: '28px',
  h2: '32px',
  h1: '40px',
}
/**
 * @memberof Theme
 * @alias fontWeights
 * @property {string} lighter=200
 * @property {string} lighter=300
 * @property {string} normal=400
 * @property {string} normal=500
 * @property {string} bolder=900
 */
const fontWeights = {
  lighter: 200,
  light: 300,
  normal: 400,
  bold: 500,
  bolder: 900,
}
/**
 * @memberof Theme
 * @alias lineHeights
 * @property {string} xs=10px
 * @property {string} sm=12px
 * @property {string} default=16px (alias md)
 * @property {string} lg=24px
 * @property {string} xl=32px
 * @property {string} xxl=40px
 */
const lineHeights = {
  xs: '10px',
  sm: '12px',
  default: '16px',
  md: '16px',
  lg: '24px',
  xl: '32px',
  xxl: '40px',
}
/**
 * This dimension can be used with `testShadow` and `boxShadow` props provided
 * by {@link ShadowProps}
 *
 * ```javascript
 * Some content...
 * ```
 *
 * @alias shadows
 * @memberof Theme
 * @property {string} login              
 * @property {string} cardHover          
 * @property {string} drawer             
 * @property {string} card               
 * @property {string} inputFocus         
 * @property {string} buttonFocus        
 */
const shadows = {
  login: '0 15px 24px 0 rgba(137,138,154,0.15)',
  cardHover: '0 4px 12px 0 rgba(137,138,154,0.4)',
  drawer: '-2px 0 8px 0 rgba(137,138,154,0.2)',
  card: '0 1px 6px 0 rgba(137,138,154,0.4)',
  inputFocus: '0 2px 4px 0 rgba(135,159,250,0.4)',
  buttonFocus: '0 4px 6px 0 rgba(56,202,241,0.3)',
}
/**
 * Responsive breakpoints
 *
 * How to use them - simply pass an array to given prop:
 *
 * ```javascript
 * // Showing box on mobile devices
 * ...
 *
 * // responsive width
 * ...
 * ```
 *
 * @memberof Theme
 * @alias breakpoints
 * @property {string} 0=577px
 * @property {string} 1=769px
 * @property {string} 2=1024px
 * @property {string} 3=1324px
 */
const breakpoints = [
  '577px',
  '769px',
  '1024px',
  '1324px', // 1024 + sidebarWidth
]
const font = '\'Roboto\', sans-serif' as string
/**
 * Border styles
 *
 * @memberof Theme
 * @alias borders
 * @property {string} input
 * @property {string} filterInput
 * @property {string} bg
 * @property {string} default
 */
const borders = {
  input: '1px solid #C0C0CA',
  filterInput: ' 1px rgba(255,255,255,0. solid15)',
  bg: '1px solid #F6F7FB',
  default: '1px solid #DDE1E5',
}
/**
 * Border widths set for an entire layout. If you like to have border radius in Button's and Box'es
 * Then set default property.
 *
 * @memberof Theme
 * @alias borderWidths
 * @property {string} default - default border with
 */
const borderWidths = {
  default: '0px',
}
export type VariantType = 'primary'
  | 'danger'
  | 'success'
  | 'info'
  | 'secondary'
  | 'default'
  | 'light'
export const VariantValues: Array = [
  'primary', 'danger', 'success', 'info', 'secondary', 'default', 'light',
]
// TODO: add transitions
export {
  colors,
  lineHeights,
  fontWeights,
  fontSizes,
  sizes,
  space,
  font,
  shadows,
  borders,
  breakpoints,
  borderWidths,
}
/**
 * The color utility parses a component's color and bg props and converts them into CSS
 * declarations. By default the raw value of the prop is returned. But most often you
 * would use one of the color from the [color palette]{@link colors}.
 *
 * @typedef {object} ColorProps
 * @alias ColorProps
 * @memberof Theme
 * @property {string} [color]                 Text color. It could be either a #hash or
 *                                            {@link colors} from css theme name like
 *                                            `grey80`
 * @property {string} [backgroundColor, bg]   Background color. Similar as above could be a
 *                                            #hash or one of {@link colors}.
 */
/**
 * The space utility converts shorthand margin and padding props to margin and padding
 * CSS declarations.
 *
 * You can use as a value raw dimensions in "px" or one of the value from the
 * [space scale]{@link space}.
 *
 * @typedef {object} SpaceProps
 * @alias SpaceProps
 * @memberof Theme
 * @property {string} [margin, m]             margin
 * @property {string} [marginTop, mt]         margin-top
 * @property {string} [marginRight, mr]       margin-right
 * @property {string} [marginBottom, mb]      margin-bottom
 * @property {string} [marginLeft, ml]        margin-left
 * @property {string} [marginX, mx]           margin-left and margin-right
 * @property {string} [marginY, my]           margin-top and margin-bottom
 * @property {string} [padding, p]            padding
 * @property {string} [paddingTop, pt]        padding-top
 * @property {string} [paddingRight, pr]      padding-right
 * @property {string} [paddingBottom, pb]     padding-bottom
 * @property {string} [paddingLeft, pl]       padding-left
 * @property {string} [paddingX, px]          padding-left and padding-right
 * @property {string} [paddingY, py]          padding-top and padding-bottom
 *
 * Set of props related to {@link space}. You can put there either string with 'px' or
 * one of `space` properties like `sm`, `default`, `xl` etc.
 */
/**
 * Typography props include _fontFamily_, _fontSize_, _fontWeight_, _lineHeight_, _letterSpacing_,
 * _textAlign_, and _fontStyle_.
 *
 * @typedef {object} TypographyProps
 * @alias TypographyProps
 * @memberof Theme
 * @property {string} [fontSize]    font-size. Could be either actual css value or key taken from
 *                                  {@link fontSizes}
 * @property {string} [fontWeight]  font-weight. Could be either actual css value or key taken from
 *                                  {@link fontWeights}
 * @property {string} [lineHeight]  line-height. Could be either actual css value or key taken from
 *                                  {@link lineHeights}
 * @property {string} [textAlign]   text-align
 * @property {string} [fontFamily]  font-family
 * @property {string} [fontStyle]   font-style
 * @property {string} [letterSpacing]  letter-spacing
 */
/**
 * The layout utility includes style props for width, height, display, minWidth,
 * minHeight, maxWidth, maxHeight, size, verticalAlign, overflow, overflowX, and overflowY.
 *
 * The width prop is transformed based on the following:
 *
 * - Numbers from 0-1 are converted to percentage widths.
 * - Numbers greater than 1 are converted to pixel values.
 * - String values are passed as raw CSS values.
 * - And arrays are converted to responsive width styles.
 * - the width prop will attempt to pick up values from the {@link sizes}
 *
 * @example
 * // width `50%`
 * 
 *
 * // width `256px`
 * 
 *
 * // width `'2em'`
 * 
 *
 * // width `100%` on all viewport and `50%` from the smallest breakpoint and up
 * 
 *
 * // width from `sizes`
 * 
 *
 * @typedef {object} LayoutProps
 * @alias LayoutProps
 * @memberof Theme
 * @property {string} [width]         width
 * @property {string} [height]        height
 * @property {string} [display]       display
 * @property {string} [minWidth]      min-width
 * @property {string} [minHeight]     min-height
 * @property {string} [maxWidth]      max-width
 * @property {string} [maxHeight]     max-height
 * @property {string} [size]          size
 * @property {string} [verticalAlign] vertical-align
 * @property {string} [overflow]      overflow
 * @property {string} [overflowX]     overflow-x
 * @property {string} [overflowY]     overflow-y
 */
/**
 * The flexbox utility includes style props for alignItems, alignContent, justifyItems,
 * justifyContent, flexWrap, flexDirection, flex, flexGrow, flexShrink, flexBasis,
 * justifySelf, alignSelf, and order.
 *
 * The width prop is transformed based on the following:
 *
 * - Numbers from 0-1 are converted to percentage widths.
 * - Numbers greater than 1 are converted to pixel values.
 * - String values are passed as raw CSS values.
 * - And arrays are converted to responsive width styles.
 * - the width prop will attempt to pick up values from the {@link sizes}
 *
 * @example
 * // alignItems
 * 
 *
 * // alignContent
 * 
 *
 * // justifyContent
 * 
 *
 * // flexWrap
 * 
 *
 * // flexBasis
 * 
 *
 * // flexDirection
 * 
 *
 * // flex
 * 
 *
 * // justifySelf
 * 
 *
 * // alignSelf
 * 
 *
 * // order
 * 
 *
 * @typedef {object} FlexboxProps
 * @alias FlexboxProps
 * @memberof Theme
 * @property {string} [alignItems]         align-items
 * @property {string} [alignContent]       align-content
 * @property {string} [justifyItems]       justify-items
 * @property {string} [justifyContent]     justify-content
 * @property {string} [flexWrap]           flex-wrap
 * @property {string} [flexDirection]      flex-direction
 * @property {boolean} [flex]               flex
 * @property {number|string} [flexGrow]           flex-grow
 * @property {number} [flexShrink]         flex-shrink
 * @property {string} [flexBasis]          flex-basis
 * @property {string} [justifySelf]        justify-self
 * @property {string} [alignSelf]          align-self
 * @property {number|string} [order]              order
 */
/**
 * Reused Variant Enum: `primary` | `danger` | `success` | `info` | `secondary` | `default`
 *
 * @typedef {Enum} VariantType
 * @alias VariantType
 * @memberof Theme
 */
/**
 * The border utility includes all style props related to border
 *
 * @typedef {object} BorderProps
 * @alias BorderProps
 * @memberof Theme
 * @property {string | number} [borderWidth]
 * @property {string} [borderStyle]
 * @property {string} [borderColor] It could be either a #hash or {@link colors}
 * @property {string | number} [borderRadius]
 * @property {string | number} [borderTop]
 * @property {string | number} [borderTopWidth]
 * @property {string} [borderTopStyle]
 * @property {string} [borderTopColor] It could be either a #hash or {@link colors}
 * @property {string | number} [borderTopLeftRadius]
 * @property {string | number} [borderTopRightRadius]
 * @property {string | number} [borderRight]
 * @property {string | number} [borderRightWidth]
 * @property {string} [borderRightStyle]
 * @property {string} [borderRightColor] It could be either a #hash or {@link colors}
 * @property {string | number} [borderBottom]
 * @property {string | number} [borderBottomWidth]
 * @property {string} [borderBottomStyle]
 * @property {string} [borderBottomColor] It could be either a #hash or {@link colors}
 * @property {string | number} [borderBottomLeftRadius]
 * @property {string | number} [borderBottomRightRadius]
 * @property {string | number} [borderLeft]
 * @property {string | number} [borderLeftWidth]
 * @property {string} [borderLeftStyle]
 * @property {string} [borderLeftColor] It could be either a #hash or {@link colors}
 * @property {string | number} [borderX]
 * @property {string | number} [borderY]
 */
/**
 * The position utility includes style props for position, zIndex, top, right, bottom, and left.
 *
 * @typedef {object} PositionProps
 * @alias PositionProps
 * @memberof Theme
 * property {string | number} [position]
 * property {string | number} [zIndex]
 * property {string | number} [top]
 * property {string | number} [right]
 * property {string | number} [bottom]
 * property {string | number} [left]
 */
/**
 * The shadow utility includes style props for textShadow and boxShadow.
 *
 * @typedef {object} ShadowProps
 * @alias ShadowProps
 * @memberof Theme
 * property {string} [boxShadow]
 * property {string} [textShadow]
 */