import React from 'react'
import PropTypes from 'prop-types'
import { IconClose } from '../../../assets'
import { getGlobalStyle } from '../../../utils'
import { CardOrder, EmptyData } from '../../molecules'
import type { IstoreOrder } from '../OrderCard'
import style from './Orders.module.css'

interface IOrder {
  isOpen?: boolean
  deliveryTimeMinutes?: number | null
  orders?: IstoreOrder[]
  handleSetIsOpenOrder?: () => void
  handleViewOrder?: (pCodeRef: string) => string
}

export const Orders: React.FC<IOrder> = ({
  isOpen = false,
  deliveryTimeMinutes = null,
  orders = [],
  handleSetIsOpenOrder = () => {

  },
  handleViewOrder = (pCodeRef: string) => {
    return pCodeRef
  }
}) => {
  return (
    <div className={`${style.wrapper_order} ${isOpen ? style.slideIn : ''}`}>
      <div className={style.button_cancel}>
        <button
          onClick={() => {
            handleSetIsOpenOrder()
          }}
        >
          <IconClose color={getGlobalStyle('--color-primary-red')} size={30} />
        </button>

      </div>

      {(Array.isArray(orders) && orders.length > 0)
        ? orders?.map((order, index) => {
          return (
          <CardOrder
            key={index}
            {...order}
            deliveryTimeMinutes={deliveryTimeMinutes}
            handleViewOrder={handleViewOrder}
          />
          )
        })
        : <EmptyData height={300} width={300} />}
    </div>
  )
}
Orders.propTypes = {
  isOpen: PropTypes.bool,
  handleSetIsOpenOrder: PropTypes.func,
  deliveryTimeMinutes: PropTypes.oneOfType([
    PropTypes.number,
    PropTypes.oneOf([null])
  ]),
  orders: PropTypes.array,
  handleViewOrder: PropTypes.func
}
