Skip to content

Latest commit

 

History

History
115 lines (87 loc) · 5.05 KB

README.md

File metadata and controls

115 lines (87 loc) · 5.05 KB

Vessels Management Tool

What's this?

This is a small tiny webapp to manage Vessels, its purpose is to show a sample implementation with these 4 technologies together:

  • Scala in backend, using Play framework
  • AngularJS in the browser, using a REST api provided by the server to manage the vessels.
  • Mongodb as database to store the vessels

It also shows the vessels in google maps. The UI is based on bootstrap.

How to run it

To run the tests you don't need db because I used a embedded mongodb. To run the website you need to have a mongodb running in the port 27017 without any authentication.

I used the activator play-scala seed at starting point, so you can run the tests with: ./activator test

Or use this one to run the app: ./activator run

After that you can go to http://localhost:9000/ to view the web.

Focus

Code readability

  • In server side, separation between controller and persistence layer make the classes/objects/methods shorter.
  • In client side, separate files by view, javascript and template
  • Partial RESTful api. POST and CREATE methods don't return the object as well, because we don't need it, with that the code in the controller is nicer without any lack of functionality.

Website usability

  • Keeping in mind the user most of the times will want to create or update a Vessel, the main entry point is the screen to create a Vessel, but the user can always search or choose a vessel to edit in that page as well.
  • Delete operation probably is less needed, that is why the user has to do it through the edit screen instead of having it in the vessel list.
  • Search box. The user can filter by vessel name to find easily which one he wants to edit, this list is updated automatically every time the user modify/create/delete a vessel.
  • Google maps for location. It is pretty handy for adding or modifying a location just clicking the map.
  • Error/Info messages. The user gets information about if every operation has been done right or with failures.
  • Validation error messages. User can know and learn how the form should be filled with the right information.
  • The website is responsive to different screen sizes. It uses internally twitter bootstrap as base.

Technical Decisions

  • Avoid to merge the controller with mongo. Even if I have not done any Dependency Injection I have prepared the separation of controller and persistence layer. So we could mock the persistence layer for testing or use another different database without change the controller.
  • IE8 and below are not fully supported by JQuery version used and angular version.
  • The app manages its own id, instead of using the mongodb one (_id). The id in this case is the resource id of the API, instead of the id of a record in one database. You can migrate to another database easily.

Future improvements

Due to the time restrictions we could go further with some improvements for following versions:

  • Add tests for javascript code and fully tests browser with rest service
  • Avoid double submit of the form if the user presses twice the button
  • Remove info/error messages after few seconds
  • Reuse vessel html form common parts
  • Give more feedback of the actions to the user: loadings, disabling buttons, etc
  • Add server validations
  • Manage exceptions. It is only developed the "happy path"
  • Add log traces to make the life easier for production support
  • Use nicer ids instead of hexadecimal
  • Use GeoJson for longitude/latitude data, so that later we could apply spacial queries over it.
  • Add Dependency Injection if needed (cake pattern, scaldi, guice, ...)

Useful Information

Angular

API

Getting Started

Promises

Seeds

Play

Seeds

MongoDB