๐ Embrace design. Own the stack.
Destack Build landing pages visually right in your React or Next.js projects. Deploy them zero further configuration!
Announcements
You can check it out at destack-starter-beta. More info at #62 and #22.
What's Destack?
It's a tool to build landing pages within your React or Next.js projects. Destack includes multiple components from Tailblocks, Meraki UI, Hyper UI, Preline, Flow Bite and Flow Rift.. It also supports image uploads and form submissions.
Destack helps you stop worrying about marketing pages so you can focus on your project.
Themes
Destack now supports theme selection.
Theme selection | Meraki UI (Components) |
Hyper UI (Components) | Tailblocks (Components) |
Preline (Components) | Flow Rift (Components) |
Flow Bite (Components) |
Contribute (add a new theme)
There are many open source Tailwind themes that Destack can support. If you want to help adding a new theme create a new topic in discussions or reach out to me on twitter.
Features
๐งฑ Powerful Blocks
There are hundreds of well designed and heavily functional blocks from Tailblocks, Meraki UI, Hyper UI, Preline, Flow Bite and Flow Rift.. Supports Tailwind's theme colors ie. Red, Yellow, Green, Blue, Indigo, Purple & Pink.
๐ Delightful Builder
Powered by Craft.js, a minimal page-builder framework. The builder was created with simplicity in mind and aims to be quickest way to build a landing page for a side-project.
๐น Data Ownership
Destack stores all your assets on Github, Bitbucket etc through the editor. There are no external dependencies to manage or worry about.
๐ Assets & Forms Support
Stores the images uploaded in the editor in your repository & displays them when needed on production. Also supports HTML and API form submission out of the box.
๐ฉ๐ปโ๐ป Easy Setup & Deployment
Works existing & new React and Next.js projects. Requires minimal setup and no extra configuration to deploy your landing pages to production.
Getting Started
With a new Next.js project:
-
Fork the destack-starter project
With an existing Next.js project:
1. Install Destack on your Next.js project
npm i destack
2. Setup the builder endpoint
Create pages/api/builder/handle.js
and add the following:
export { handleEditor as default, config } from 'destack/build/server'
3. Then create a new page
On any Next.js page you want to setup Destack:
export { getStaticProps } from 'destack/build/server'
export { ContentProvider as default } from 'destack'
How to use the legacy page-builder (Grapesjs)
import { ContentProviderGrapes } from 'destack'
import 'grapesjs/dist/css/grapes.min.css'
export { getStaticProps } from 'destack/build/server'
export default function Page(props) {
return (
<div style={{height: '100%'}}>
<span>Hello world</span>
<ContentProviderGrapes {...props}/>
</div>)
}
With a new React.js project:
-
Fork the destack-react-starter project
With an existing React.js project:
1. Install Destack on your React.js project
npm i destack
2. Setup the builder endpoint
In package.json
:
- Replace the "start" script with
destack -d \"react-scripts start\"
- Then, replace the "build" script with
destack -b \"react-scripts build\"
3. Then create a new page
In any React.js component you want to setup Destack:
export { ContentProviderReact as default } from 'destack'
How to use the legacy page-builder (Grapesjs)
import 'grapesjs/dist/css/grapes.min.css'
import { ContentProviderReact } from 'destack'
const App = () => {
return (
<div style={{ height: '100%' }}>
<span>Hello world</span>
<ContentProviderReact />
</div>
)
}
export default App
How it works
development
(ie. with npm run dev
) the React component understands it from the NODE_ENV
environment variable and shows you the editor where you can create your landing page visually.
default.json
file. That file contains the HTML for your landing page and it remembers how you structure your page so you can come back later to update it.
production
(ie. do npm run build
or deploy to Vercel) the React component reads NODE_ENV
again and statically generates the HTML version of the page you build in the editor from the default.json
file Destack created for you earlier.
Note: The above description is for Next.js. In React.js, the
destack -b
script creates an API route similar to the one described above that handles template changes and file uploads in development. In production thedestack -d
script copiesdefault.json
to thepublic
folder and builds a static version of the page.
How to's & guides
Adding an HTML form
- Drop a block that contains a form
- Click on the form & head to components settings
- Add form URL & check
async
if don't want a redirection - To handle a
async
forms you can create an API route- Next.js: Create a file in api/submit.js
- React.js: You will need a seperate Node.js server listening on
/api/submit
Uploading images
- Drop a block that contains an image or use image block
- Click on an image to open the upload modal
- Select the image you want to update and click on it to add it to the page
- Note: Images are uploaded to
public/uploaded
with their original filenames
Multi-page Support
Next.js
Create a new page file in pages
folder of the Next.js project and import destack
as described in #with-an-existing-nextjs-project to various pages.
React.js
Install a routing library such as react-router-dom
or router-tutorial
in the React.js project and import destack
as described in #with-a-new-reactjs-project to various routes. For more info check out destack-react-starter.
Contributing to the project
See CONTRIBUTING.md
How this project came to existence
This project was nothing that was planned and design in depth in advance. Instead it was evolved out of the need and enjoyment of using some amazing tools and prototype quickly. These projects heavily improved my developer life and a few of my friends'.
Next.js ๐ ง
โ Tailwind CSS๐ โ Craft.js๐งถ =๐ฃ ๐ฃ
Please go and show these projects some love (
Don't forget to check out Tailblocks, Meraki UI, Hyper UI, Preline, Flow Bite and Flow Rift., without their amazing open sourced components none of this would have been possible.
Contributors
Made with contributors-img.
Upcoming Tasks
- Add admin UI as a Next.js route