- Register an account or login before using any feature
- Can use this user: email: dev@mailit.com, pwd: zxcvbn12
- When attempting to upload recipients using CSV, you might need to refresh the page in order to get the request to be formatted properly.
- In order for views to be properly incremented for an email, you must view the email in a web browser.
Template
- Create a template by clicking on the “Create A Template” button on the
/
page or/templates
page. - Fill in the Name and Markdown for the Template. Click “Create” button to create the template.
- You should be redirected to the
/
page and see your newly created template. - Click the Name of the template to update it.
- Click “Trash” icon to delete the template.
Real-time Collaboration for Template Editing
- To add collaborators for a template, go to the template update page.
- Search users by user emails to add collaborators one at a time. The email must be an exact match.
- Log in as two users and land on the same template editing page.
- You should be able to see others’ cursors in the editor with their names on it
- Start typing and changes will be synced across users.
- Known issue: when a new user joins the editor, the content gets duplicated. We are looking into this issue.
Predefined Templates & Analytics
- Click “Predefined templates” on the navigation bar.
- Choose the template that you want.
- Edit it and save your own copy.
- The analytics about predefined templates are shown on the predefined templates when there is data.
Create A Campaign
- Create a campaign by clicking the “Campaigns” on the sidebar.
- Choose a template on the left side.
- Download the CSV template by pressing the link at the bottom of the page.
- Follow the example in the CSV template and put in first name, last name, email address, and tags for all the recipients. Tags are separated by “|”.
- Fill in the name and subject and add tags for this campaign. Tags are required. Make sure the target recipients and the campaign have the same tags
- Click the “Create Campaign” button at the bottom.
Recipients
- Navigate to the Recipients page.
- Click “Upload Recipients”.
- Manually create a single recipient by filling in the fields on the right side of the page. Tags are required.
- Create bulk recipients by uploading a csv with the following headers: firstname,lastname,email,tags. If you want more than one tag, you must separate them with “|” (ie test|beauty).
- Navigate back to the Recipients page and see all your recipients.
- Click the “Delete” button to delete any recipient.
Edit A Campaign
- On the Dashboard page, choose a campaign by clicking the name.
- Choose a template on the left side.
- You can also add recipients to your campaign using a CSV like the one mentioned in Recipients 4. Download the CSV template by pressing the link at the bottom of the page, to get access to it.
- Fill in the name and subject and add tags for this campaign. Tags are required. Make sure the target recipients and the campaign are having the same tag.
- Click the “Save Campaign” button at the bottom.
Campaign Analytics
- On the Dashboard page, click the “analytics” button for the campaign you want.
Reset User Password
- Go to your login page and click “Forget your password?”.
- Input your email address and submit.
- Check your mailbox and follow the link.
- Input your new password.
- Installed Postgres, Ruby, Rails, Node, NPM/Yarn
- Postgres is running
- Create a terminal window,
cd backend
- Run
bundle
to install all dependencies - Run
rake db:create
to create databases - Run
bin/rails db:migrate
to sync up database - Run
rails server
to start the Rails server. Backend application should be running at http://127.0.0.1:3000 - Seed your db:
rails db:seed
- Reset your db:
rake db:drop db:create db:migrate
- Run
bundle exec figaro install
- Navigate to
/config/application.yml
- Add the following to the file:
development:
frontend_url: "http://localhost:8080"
backend_url: "http://localhost:3000"
production:
frontend_url: "https://mailit-app.herokuapp.com"
backend_url: "https://mailit-api.herokuapp.com"
test:
frontend_url: "http://localhost:8080"
backend_url: "http://localhost:3000"
- Create a terminal window,
cd frontend
- Run
yarn install
to install all dependencies - Run
yarn start
to start the React server. Frontend application should be running at http://localhost:8080 - Create an
.env
file in/frontend
contains:
ESLINT_NO_DEV_ERRORS=true
REACT_APP_BASE_URL=http://localhost:3000
- Ruby on Rails API mode:
- All controllers are under Api/V1
- Only contains controllers and models
- React:
- Fetching data via HTTP requests
We use cucumber.js to test our frontend. Make sure you have the Firefox browser installed
- When running cucumber tests, make sure both the frontend and the backend of the app is running!
- Required packages:
@cucumber/cucumber
,selenium-webdriver
. Install them withyarn install
- Create two terminal windows and navigate to the /frontend folder
- In one terminal, run
./geckodriver
. This will run the Firefox test window - In the other terminal:
- Run
yarn run cucumber
to run cucumber tests - Run
yarn run coverage
to generate cucumber coverage report
cd backend
bundle exec rspec spec
We choose to deploy the frontend and the backend separately
cd backend
git push heroku main
heroku run rake db:migrate
heroku run rake db:seed
cd frontend
git push heroku-frontend main