Your Intelligent Note-taking Helper
QuickNote is a cross-platform scientific note-taking application, which supports a number of distinct features, including integration of multimedia, dragging and dropping, cloud storgae, and embeded web searching. It is currently being deployed at University of Notitngham, either for pratical and research usage.
.
├── public
│ ├── html files
│ ├── assests
│ │ ├───── css
│ │ │ └── css files
│ │ ├───── js
│ │ │ └── js files
│ │ └───── images
│ │ └── images
│ ├── homepage_assets
│ │ ├───── css
│ │ │ └── css files
│ │ ├───── js
│ │ │ └── js files
│ │ └───── images
│ │ └── images
│ └── package.json
├── app.js
└── node_modules
- logIn.html is the log in/register interface of Quick Note.
- qnote.html is the main interface of Quick Note.
- All related js and css files are put in the assets directory.
- css directory includes all css style sheets for the application.
- images directory includes all related images used in the application.
- js directory includes all js files.
Express.js + Passport.js
HTTPS + bcrypt.js
- Files in notes: PanFS (custom Facebook Haystack based distributed file storage system)
- Cloud storage: disk based file system
- The useless(redundant) code needs to be cleaned.
- The media insertion mechanism needs to be improved: Media files should not be saved as blob within the note; instead, they should be uploaded to the server and saved as a url to this file on the server.
- Security isses need to be addressed: Anything should be encoded when transmitting through https protocol.
- Synchronization mechanism needs to be improved: Each time, only the changed note/notebook should be synchronized rather than "alldata".
- For the Windows version:
- The recorded audio cannot be downloaded.
- For both Mac and Windows versions:
- The file management part cannot fit the screen perfectly.
- There is an unknown scroll bar outside the note.
- Online video cannot be inserted, showing as image.
- It should allow the user to choose the camera, rather than only use the default one.
- Note context menu needs to be improved: export to pdf, information.
- Save uploaded files to haystack storage system rather than hard encoding them as blob.
- When inserting an image into editor, UI needs to be improved - progress bar perhaps.
- Server error code needs to be regulated.
- Session authentication mechanism.
- Hash passwords before storing to db.
- HTTPS over koa server.
- Figure out why localstorage would be problematic if requesting webpage from server rather than load local one.
- Session/Cookies seems not working for desktop version because they can not be set for local html files.
- Set up a notification area in the top middle of the interface:
- Bootstrap Notify seems difficult to customize
- Re-login when authentication failed
- Add gulp.js
- Refactor front-end structure
- Refactor back-end structure
- Robust file deletion
- Debounce the event listeners a little bit to around 100ms
- When copying the shared note to user's own notebook.
- In notebook hierarchy, the number of notes in the child-notebook is incorrect after first refreshing.
- tinymce.js cannot be compressed - media insertion fails.
- The paragraph mechanism is useless - it is always inserted into the end of the note and it cannot be exchanged with other elements in the note.
npm install nw-builder
sh build.sh
- Fork it (https://github.com/PAN001/QuickNote/fork)
- Create your feature branch (git checkout -b feature/fooBar)
- Commit your changes (git commit -am 'Add some fooBar')
- Push to the branch (git push origin feature/fooBar)
- Create a new Pull Request