Part 1
- Add following models to plugin basic:
- resource with fields
- number - string identifier of resource
- quantity - quantity of resource
- product - related product from plugin basic
- transfer with fields
- resource - related resource
- quantity - quantity of product in transfer
- type - type of transfer (incoming or outgoing)
- status - status of transfer (planned or done)
- request date,
- the worker who filled the request
- confirmation date/worker.
- resource with fields
- Create views with list of resources and transfers
- Create view with resource details:
- form will contains three inputs
- number
- product's lookup
- quantity - disabled, because it is set using custom action
- expression will be used to generate window header
- window header will be displayed
- form will contains three inputs
- Create view with transfer details:
- form will contains eight inputs
- resource's lookup
- quantity
- type
- status
- requestWorker - disabled, because it is set using custom action
- requestDate - disabled, because it is set using custom action
- confirmWorker - disabled, because it is set using custom action
- confirmDate - disabled, because it is set using custom action
- expression will be used to generate window header
- window header will be displayed
- form will contains eight inputs
- Add custom action on save for transfer model - it should automatically set the transfer's workers and dates. Workers will be set using the current logged user - the one who create request will be put into requestWorker, Afterwards the one who changes the status to done will be put into confirmWorker. If transfer has not been saved (id is null) it should set requests worker and date, if transfer's status is done it should set confirmation worker and date. This action should also change quantity of the related resources, when the transfer is done.
- Add custom validation for transfer model - it should check if a resource has enough quantity for delivery transfer.
Part 2
...
Table of Contents |
---|
Useful links
- Installation manual
- Building MES from source code - tutorial
- Plugin developement
- Our coding conventions
- Javadoc
- Github repository
Before you start
- Fork https://github.com/qcadoo/mes/
create branch from master
git checkout -b recruitment - Change hotDeploy=false in file: mes/mes-application/conf/tomcat/app.properties
- Read the comments below
Assignment
- Add new model purchase to plugin basic with fields:
- product - product from basic plugin,
- quantity - quantity of product,
- price - price of product,
- date - date with time.
- Add validator which would check if product price is > 0.
- Add validator which would check if product quantity is > 0.
- Add validator which would check if there is no product purchase with the same name product and price.
- Add views for that model list with list and add/edit details.
- Add hooks which would set default system currency in field next to price (locale chosen in framework).
- (OPTIONAL) Add hooks which would set product unit in
- add disabled input field next to quantity
- field in purchase details view
- when product changes, this field also should be updated.
- Add button to ribbon in purchases list or details which will count average price of all purchases or average price of product. The result can be presented in any way (for example as a simple popup or field on the view).
Useful links
...
- (OPTIONAL) Prepare additional functionality with simple dictionary and two fields: input and output. While the user enters input text, the application rewrites it, and mark words found in the dictionary.Requirements:* prepare a separate subpage (you can use component: staticPage)* allowed words can be stored in an external file or served by the controller in any format* use pure java script or jQuery