CPD Log I built this app as a management tool to help myself (or other leaders) to track their continuous professional development. Previous logs I had maintained were fully manual in either gsheets or written in markdown - I wanted something database related, powerful but simple in presentation that I could adapt for quick access and day to day use.
Link to project: https://cpdeasy.azurewebsites.net/
Middleware: EJS, Mongoose, passport.js, bcrypt, validator, express-session, body-parser, flash, morgan,
I built this as a simple CRUD app that grabs your data from a form sent to the back-end then uploads it to mongodb. I used a combination of EJS and Bootstrap for the front-end which worked extremely well, bootstrap is lightweight and totally compatible, it was possible to make a simple, clean UI quickly and effectively.
bootstrap supports a "Mobile-first" view which works from the ground up. If you build from mobile as a starting point with bootstrap it's generally quite easy to tailor the site with inline css to fit phones/tablets and then move on to desktops. I actually had the most trouble with high resolution monitors > 1400 where I had to implement media queries manually because bootstrap breakpoints cap off at 1400px.
After writing the simple app and getting it working, I realised that I could make it better by installing passport.js for authentication and researched google oauth functionality - that required a named domain which is something I did look into.
I started out by having a verbose and unwieldy entry-log format, but after researching more about bootstrap - I realised I could make an accordion/collapsible UI that hides the details of logs. This allows the user to browse headings by date/title and only expand the ones they wanted to read.
I added in passport.js for authentication and used bcrypt to salt and hash passwords.
Having previously only used older versions of mongoose, I wanted to use the latest on this app so I could test-drive a few of the features. That meant having to update legacy code for compatibility using mongoose documentation to bring it up to date.
Bootstrap was a really nice lightweight framework to use, but there is a learning curve. Taking it from "working" to "ok" and "ok" to good was just a question of how much time I wanted to spend going over the documentation. That's all good and I could probably spend a bit more time making it better - but getting authentication set up was more important so I resisted the urge to fiddle with it too much - til later. - I will go back and make it look nicer when I get more time. Generally I prioritise functionality over form. Edit: I did exactly that and the overall look and feel of the site is looking much better!
I deep dived quite a bit on express-session for this one. After installing a logout button that only appears if you're logged in and on the entries page, It correctly logged you out but crashed the server each time instead of redirecting! The problem was in the syntax of the session termination request. req.session.destroy()
and delete req.user
are both cited as ways to end the session. But in combination with passport.js they kept throwing errors like req.session is not a function. This got ironed out after quite a bit of trial, error and thorough testing.
I learned that versioning can be really important as successive versions can add/remove features and functionalities, sometimes completely changing their syntax in the process. Removing the redundant syntax fixed the problem. Finally, I found a way to implement the conditional appearance of buttons depending on state by getting advice from another developer, each route now passes the user state back to the view, so if the user is logged in - they'll see a slightly different version of the site.
Bootstrap is highly versatile, which is perhaps unsurprising given it's age and widespread use. I was able to make the app fully mobile responsive with dynamic forms, buttons and navigation systems without touching front-end javascript or css.
Take a look at these other examples that I have in my own portfolio:
Tab-Safe: https://github.com/HoldUpFjord/Link-Manager This was the first app where I helped implement authentication, the work we did there forms the foundation for password/logins for this app.
Behavioural Recruitment RESTful API: https://github.com/TheWoodenMan/behavioural-recruitment This RESTful API was my most detailed exploration of CRUD functions and my first real implementation of mongoose, both of which feature heavily in this app