Jot is a streamlined note taking app for the scatterbrained, frequent note taker built as my Back End Capstone for Nashville Software School.
- About
- Auto Organization
- Technologies Used
- How to Contribute
- Api Endpoints
- Users
- POST /login
- POST /register
POST /logout
- Notes
- GET /notes
- GET /notes/:id
- DELETE /notes/:id
- PUT /notes/:id
- Users
The application is designed to remove the obstacles in modern note taking (having to input excess information when all you want to do is remember a tiny note) and organize your notes to help you find related notes. The user is not required to add a title, date, or tag to the note. Start typing and Jot (using IBM Watson) will highlight important words and phrases. Don't like them? No sweet. Double tap / click a word and it will override Watson's keywords. You may add as many as you want.
Jot automatically organizes your note in three seperate ways. The first, by note, is your traditional organization method. The other two, by everey edit date, and by week, are more in depth to help you find related notes.
- Sort by Edit Date: Every time you edit a note, Jot remmembers when you edited it. You may sort notes by these edit dates, allowing you to see other notes created around the same time, which may be related.
- Sort by Week: You may sort by week and see a list of keywords in that week with all notes pertaining to those keywords grouped together beneath them.
- Sort by Note: You may sort by note to see notes sorted by their last edit date which is the traditional way to look at your notes.
When you load Jot after logging in, Jot defaults to the note taking page with your cursor already in the textbox to allow you to start typing without any hinderance. If you have logged in previously, it automatically will remember you giving you the quickest route to jotting down a thought.
Jot is designed with an easy-going user interface and a desire to clutter the user's life as little as possible. With each user's visual needs varying slightly, on top of the default simple styling, the user can change the font style and size, and how Jot highlights keywords.
- React / Redux
- Material UI
- Sequelize
- PostgreSQL
- Axios
- Watson Natural Language Understanding
- Passport (with JSON Web Tokens)
- Bcrypt
- Fork the project to your GitHub
- Clone the project
- Create
server/config/watsonConfig.js
- Provide your own credentials in it in the below pattern
module.exports = {
"username": "[your username]",
"password": "[your password]",
"version": '[your version]',
"url": 'https://gateway.watsonplatform.net/natural-language-understanding/api/'
};
- Create a new PostgreSQL database.
- Create the file
/sequelize/config/config.json
. - In that file, provide the credentials to the PostgreSQL database you made.
{
"development": {
"username": "Tim",
"password": "postgres",
"database": "jot",
"host": "127.0.0.1",
"dialect": "postgres"
},
"test": {
"username": "Tim",
"password": "postgres",
"database": "jot",
"host": "127.0.0.1",
"dialect": "postgres"
},
"production": {
"username": "Tim",
"password": "postgres",
"database": "jot",
"host": "127.0.0.1",
"dialect": "postgres"
}
}
- Run
npm run buildDb
- In another window, run
nodemon server/server.js
to start the node server. - In the same window, run
npm start
to start the react development server. - You're ready to start modifying the project! Running npm start should open up a browser window. If not, navigate to
http://localhost:3000/
.
This api is consumed via the Jot front end and is only meant to be used with Jot.
- Authorization
- Users
- POST /login
- POST /register
POST /logout
- Notes
- GET /notes
- GET /notes/:id
- DELETE /notes/:id
- PUT /notes/:id
Endpoints denoted with '*' require you to be logged in require a JSON Web Token Authorization header with a body of Bearer {your_token}
.
If successful, returns the user information and a json web token that when attached to the header of other requests will allow the user to access the endpoints. See the Authorization section.
{
"email": [your email],
"password": [your password]
}
{
"user": {
"id": 1,
"display_name": "Tim",
"password": "$2a$08$PUYDqcuQWeFO771NSuJHkOmzpjXrvzRW6XaOK9WvFtT9MNxOqmvNi",
"email": "[email protected]",
"creation_date": "1970-01-18T15:38:40.916Z",
"Option": {
"id": 1,
"font_size": "small",
"font_style": "sans-serif",
"auto_keyword_style": "bold",
"user_keyword_style": "italic",
"user_id": 1
}
},
"token": [your json web token]
}
Registers a new user, and if successful, returns the new user's information and web token to be used as their future authentication.
{
"email": "[email protected]",
"password": "password123",
"display_name": "Joe",
"confirm": "password123"
}
{
"user": {
"id": 3,
"display_name": "Joe",
"email": "[email protected]",
"creation_date": "2018-05-17T19:25:15.635Z",
"Option": {
"id": 3,
"font_size": "small",
"font_style": "sans-serif",
"auto_keyword_style": "italic",
"user_keyword_style": "bold",
"user_id": 3
}
},
"token": [your json web token]
}
Depricated.
Returns the user's basic information and their options.
{
"id": 1,
"display_name": "Tim",
"email": "[email protected]",
"creation_date": "1970-01-18T15:38:40.916Z",
"Option": {
"font_size": "small",
"font_style": "sans-serif",
"auto_keyword_style": "italic",
"user_keyword_style": "bold"
}
}
Updates the user's settings. One or all four options may be sent in a patch.
{
"font_size": "small",
"font_style": "sans-serif",
"auto_keyword_style": "italic",
"user_keyword_style": "bold"
}
{
"id": 1,
"display_name": "Tim",
"email": "[email protected]",
"creation_date": "1970-01-18T15:38:40.916Z",
"Option": {
[ "font_size": "small",
"font_style": "sans-serif",
"auto_keyword_style": "bold",
"user_keyword_style": "italic"]
}
}
Returns all given user's notes with all keywords and each note's most recent edit date.
To group by keywords by week add ?weekView=true
To sort by all edit dates add ?dateView=true
[
{
"id": 1,
"text": "This is an example note.",
"user_id": 1,
"Keywords": [
{
"id": 1,
"keyword": "example",
"user_selected": true,
"note_id": 1
},
{
"id": 2,
"keyword": "note",
"user_selected": true,
"note_id": 1
}
],
"Note_Dates": [
{
"id": 1,
"edit_date": "2018-04-30T21:27:14.209Z",
"note_id": 1
}
]
}
]
Returns given note with all keywords and its most recent edit date.
[
{
"id": 1,
"text": "This is an example note.",
"user_id": 1,
"Keywords": [
{
"id": 1,
"keyword": "example",
"user_selected": true,
"note_id": 1
},
{
"id": 2,
"keyword": "note",
"user_selected": true,
"note_id": 1
}
],
"Note_Dates": [
{
"id": 1,
"edit_date": "2018-04-30T21:27:14.209Z",
"note_id": 1
}
]
}
]
Deletes the specified note. Returns the number of rows deleted. If none were deleted, 0 is returned.
1
Creates or edits the note at the given id, escaping single quotes in the note; creates the keywords from the keyword array, or if no keyword array is sent, it uses IBM Watson to generate them; and finally adds a new date_edit entry if it has not been edited within the last 24 hours.
{
"text": "This is a note",
"keywords": ['this', 'note']
}
Returns 200 if successful.