The open-source LaunchRock alternative. Build beautiful splash pages to collect emails & more – primarily focused on performance and rapid development. This project is sponsored by Clevertech.
This project is bundled with the following default components and services in mind:
- Node.js
- Eskimo
- Jade
- LESS
- Gulp
- Bower
- Bootstrap
- FontAwesome
- jQuery
- Modernizr
- HTML5 Boilerplate
- Amazon CloudFront
- Amazon S3
- MailChimp
- CircleCI
* Note that you can swap out many of these components and services with your preferred alternatives.
Development (and Deployment) is made simple thanks to Gulp. Follow these simple instructions for setting up this project locally:
-
Make sure you are using Node.js version
>= 0.12. -
Either clone this repository (recommended) or download a ZIP locally:
To clone locally (preferred approach):
git clone [email protected]:niftylettuce/gulp-aws-splash.gitOr, to download a ZIP locally:
curl -o ~/gulp-aws-splash.zip https://github.com/niftylettuce/gulp-aws-splash/archive/master.zipIf you downloaded the ZIP, then you'll need to extract it first of course.
-
Change your working directory in terminal to the project's (e.g.
cd ~/gulp-aws-splash/). -
Install NPM dependencies required for developing locally and deploying the project:
npm installAlso install gulp and bower globally if you have not yet already:
npm install -g gulp bower- Configure
boot/config.jswith your Google Analytics, MailChimp, and Amazon Web Services credentials.
For Google Analytics:
-
Go to https://www.google.com/analytics/web/ → Admin → Create New Account.
-
Complete required fields in order to create a new account.
-
Copy/paste the generated "Tracking ID" as the value of
googleAnalyticsinboot/config.js:
```diff
- googleAnalytics: env.GA || 'TODO',
+ googleAnalytics: env.GA || '12345678',
```
For MailChimp:
-
Go to http://mailchimp.com/ → Log in (or Sign up) → Create List.
-
Complete required fields in order to create a new list.
-
Go to the Lists → Select (select your newly created list) → Signup forms → Embedded forms.
-
Copy/paste the generated
<form>action attribute value as the value ofmailChimp.actionUrlinboot/config.js:
```diff
mailChimp: {
- actionUrl: env.MC_AU || 'TODO',
+ actionUrl: env.MC_AU || '//johndoe.us0.list-manage.com/subscribe/post?u=123456789abcdefghijklmno&id=1234567890',
```
- Copy/paste the generated
<input>name attribute value as the value ofmailChimp.hiddenInputNameinboot/config.js(note that this<input>is inside of an<div>withabsoluteCSS positioning):
```diff
- hiddenInputName: env.MC_HIN || 'TODO'
+ hiddenInputName: env.MC_HIN || 'm_4co51234b92a65zb2a52z0221_154363e5def'
},
```
For Amazon Web Services:
-
Go to https://console.aws.amazon.com/s3/home → Create New Bucket.
-
Click on the newly created bucket → Static Website Hosting → Enable Website Hosting.
-
Set the value of Index Document to
index.htmland Error Document to404.html, then click Save. -
Modify
boot/config.jswith your newly created bucket name:
```diff
params: {
- Bucket: env.AWS_BUCKET || 'TODO'
+ Bucket: env.AWS_BUCKET || 'gulp-aws-splash'
}
```
-
Go to https://console.aws.amazon.com/iam/home#security_credential → Access Keys (Access Key ID and Secret Access Key) → Create New Access Key.
-
Copy/paste the values of Access Key ID and Secret Access Key to
boot/config.js(note that you will repeat yourself below, sincegulp-awspublishandgulp-cloudfrontcall for different configurations):
```diff
aws: {
- key: env.AWS_KEY || 'TODO',
+ key: env.AWS_KEY || 'ZFIKXOJ1MKTNVTQ4VPAD',
- accessKeyId: env.AWS_KEY || 'TODO',
+ accessKeyId: env.AWS_KEY || 'ZFIKXOJ1MKTNVTQ4VPAD',
- secret: env.AWS_SECRET || 'TODO',
+ secret: env.AWS_SECRET || 'j4nIT6KSuuuk01g3q4y+eYsuxtIUvMuoyWTfGV86W',
- secretAccessKey: env.AWS_KEY || 'TODO',
+ secretAccessKey: env.AWS_SECRET || 'j4nIT6KSuuuk01g3q4y+eYsuxtIUvMuoyWTfGV86W',
```
-
Go to https://console.aws.amazon.com/cloudfront/home → Web → Get Started → Create Distribution.
-
Complete required fields in order to create a new distribution * If you want to use your own domain name, then please fill out the value of Alternate Domain Names).
-
Copy/paste the Distribution ID as the value for
aws.distributionIdinboot/config.js:
```diff
- distributionId: env.AWS_DI || 'TODO',
+ distributionId: env.AWS_DI || 'UXCY8BV5VXPSL',
```
- Start
gulp watchto start watching changes you make locally to the project. It should automatically open up http://localhost:3000/ in your default browser for you as well (which is the default development URL).
To manually publish changes to your project, simply run gulp publish. That's all you have to do!
If you'd like your project to automatically be built and published to Amazon when you git push to GitHub, then configure CircleCI for continuous integration:
- Create a new repo on GitHub for your
gulp-aws-splashproject and push to it your locally checked out copy (ensure that the defaultcircle.ymlstill exists in your project's root folder). - Log in to CircleCI and add the newly created repository
- Create custom environment variables based off your configuration in
boot/config.js. Here is a list of all the required variables:
GA- Google Analytics IDMC_AU- MailChimp Form Action URLMC_HIN- MailChimp Hidden Input NameAWS_KEY- AWS keyAWS_SECRET- AWS secretAWS_BUCKET- AWS bucketAWS_DI- AWS distribution ID