mirror of
https://github.com/wasp-lang/wasp.git
synced 2025-01-04 07:15:01 +03:00
103 lines
2.7 KiB
JavaScript
103 lines
2.7 KiB
JavaScript
import classNames from 'classnames'
|
|
import { Terminal, Layers, Coffee, Code } from 'react-feather'
|
|
|
|
import SectionContainer from './Layouts/SectionContainer'
|
|
|
|
import styles from '../styles/index.module.css'
|
|
|
|
const Lang = () => (
|
|
<>
|
|
<span className='underline decoration-yellow-500 font-bold'>
|
|
language
|
|
</span>
|
|
</>
|
|
)
|
|
|
|
const Benefit = ({ Icon, title, description }) => (
|
|
<div className='mb-10 md:mb-0 space-y-4'>
|
|
<div className='flex items-center'>
|
|
<div
|
|
className={`
|
|
inline-flex h-8 w-8 rounded-md
|
|
items-center justify-center
|
|
text-yellow-500 bg-neutral-700
|
|
`}
|
|
>
|
|
<Icon size={20} />
|
|
</div>
|
|
<dt className='ml-4'>
|
|
{ title }
|
|
</dt>
|
|
</div>
|
|
<p className=''>
|
|
{ description }
|
|
</p>
|
|
</div>
|
|
)
|
|
|
|
const Benefits = () => {
|
|
return (
|
|
<SectionContainer className='space-y-16'>
|
|
<div className='grid grid-cols-12'>
|
|
<div className='col-span-12 text-center'>
|
|
<h2 className='text-xl lg:text-2xl text-neutral-700 mb-4'>
|
|
Yet another web framework. Except it is
|
|
a <Lang />.
|
|
</h2>
|
|
<p className='text-neutral-500'>
|
|
Don't worry, it takes less than 30 minutes to learn.
|
|
</p>
|
|
</div>
|
|
</div>
|
|
|
|
<dl className='grid grid-cols-1 lg:grid-cols-3 md:gap-16 lg:gap-x-8 xl:gap-x-24'>
|
|
<Benefit
|
|
Icon={Layers}
|
|
title='Truly full-stack'
|
|
description={`
|
|
When we say full-stack, we really mean it. Wasp has you covered from front-end,
|
|
back-end and database to deployment. Zero config required to get started.
|
|
`}
|
|
/>
|
|
|
|
<Benefit
|
|
Icon={Coffee}
|
|
title='The wheel can take a break'
|
|
description={`
|
|
No reinventing the wheel here. Write your code in React & Node.js as you are used to,
|
|
along with your favourite NPM packages.
|
|
`}
|
|
/>
|
|
|
|
<Benefit
|
|
Icon={Code}
|
|
title='Less boilerplate'
|
|
description={`
|
|
The language approach allows us to immensely improve developer experience.
|
|
E.g., full-stack auth takes only 5 lines of code.
|
|
`}
|
|
/>
|
|
</dl>
|
|
</SectionContainer>
|
|
)
|
|
}
|
|
|
|
const BenefitsWithSkewedBorder = () => (
|
|
<div className='relative'>
|
|
<div className={classNames(styles.sectionSkewedContainer)}>
|
|
<div
|
|
className={classNames(
|
|
styles.sectionSkewed,
|
|
'border-t border-b border-yellow-500/25 bg-neutral-100/50'
|
|
)}
|
|
>
|
|
</div>
|
|
</div>
|
|
<div className='relative'>
|
|
<Benefits />
|
|
</div>
|
|
</div>
|
|
)
|
|
|
|
export default BenefitsWithSkewedBorder
|