stacker.news/components/invoice-status.js

42 lines
1.2 KiB
JavaScript
Raw Normal View History

2021-05-13 08:28:38 -05:00
import Moon from '../svgs/moon-fill.svg'
import Check from '../svgs/check-double-line.svg'
2021-05-13 16:19:51 -05:00
import ThumbDown from '../svgs/thumb-down-fill.svg'
2021-05-13 08:28:38 -05:00
function InvoiceDefaultStatus ({ status }) {
return (
2023-01-10 12:55:17 -06:00
<div className='d-flex mt-2 justify-content-center'>
2021-05-13 08:28:38 -05:00
<Moon className='spin fill-grey' />
2023-07-24 13:35:05 -05:00
<div className='ms-3 text-muted' style={{ fontWeight: '600' }}>{status}</div>
2021-05-13 08:28:38 -05:00
</div>
)
}
function InvoiceConfirmedStatus ({ status }) {
return (
2023-01-10 12:55:17 -06:00
<div className='d-flex mt-2 justify-content-center'>
2021-05-13 08:28:38 -05:00
<Check className='fill-success' />
2023-07-24 13:35:05 -05:00
<div className='ms-3 text-success' style={{ fontWeight: '600' }}>{status}</div>
2021-05-13 08:28:38 -05:00
</div>
)
}
function InvoiceFailedStatus ({ status }) {
return (
2023-01-10 12:55:17 -06:00
<div className='d-flex mt-2 justify-content-center'>
2021-05-13 16:19:51 -05:00
<ThumbDown className='fill-danger' />
2023-07-24 13:35:05 -05:00
<div className='ms-3 text-danger' style={{ fontWeight: '600' }}>{status}</div>
2021-05-13 08:28:38 -05:00
</div>
)
}
export default function InvoiceStatus ({ variant, status }) {
switch (variant) {
case 'confirmed':
return <InvoiceConfirmedStatus status={status} />
case 'failed':
return <InvoiceFailedStatus status={status} />
default:
return <InvoiceDefaultStatus status={status} />
}
}