The FoodEx2 Smart Coding Application is designed and developed internally in the European Food Safety Authority (DATA and AMU units). This project aims to simplify the FoodEx2 coding process of food starting from a given free text description. The FoodEx2 Smart Coding Application's front-end is composed of several web components which allow interfacing with the APIs available on the back-end. Please note that the components can also be extracted and hence used outside the scope of the application itself (e.g. in another web platform).
Clone the project locally in your workspace using the following command:
git clone https://github.com/openefsa/foodex2-sca-frontend.git
Now, move inside the project's folder just cloned and install all the required dependencies (listed in the package.json file). Run the following command in order to automatically install all the dependencies using npm:
npm install
In order to view the app on the browser, it is needed to serve the project using Polymer. Run the following command from the project's folder:
polymer serve
Click on the link which will appear on the terminal; this will automatically open a new page in the browser and hence render all user interface components.
Please note that FoodEx2 Smart Coding Application fully support the latest version of Chrome and Firefox.
The fronted for the FoodEx2 Smart Coding Application has been developed starting from the base class provided by LitElement (from Polymer project). Each component has been built starting from the base LitElement class and hence connected to each other following the Polymer 3 framework requirements.
In this section we describe the various web components that make up the home page of FoodEx2 SCA. These, in fact, have been designed exclusively to follow the web component directives and therefore allow reusability outside of this project.
Please note that the web components are using pre-built paper-elements available from Polymer at the following link. In particular circumstances, custom elements have been developed in order to meet the system requirements.
This web component consists of an input field and a button. The input field allows the insertion of a free text that, in the case of the FoodEx2 SCA project, should describe a particular, simple or compound, food (e.g. "chocolate" or "white chocolate with hazelnuts"). The GO button, situated just next to the input field, allows to get the content of the input field and hence create and make a GET request to the backend API. More specifically the GET request is built using the free text description,the threshold value (which filter those terms not having the same or greather percentage of accuracy), the smartAcc flag which tells the backend to use smart accuracy (uses text similarity to increase or decrease the percentage of accuracy attributed to each term) and the language of input. Here is the structure of the GET request called when the "SEND" button is pressed:
GET http://hostname:port/predict HTTP/1.1
content-type: application/json
{
"desc":"white chocolate",
"thld": "0.1",
"smartAcc": "true",
"lang": "en"
}
If the request is handled correctly from the backend API, this will return a JSON object containing:
- original text description and it's tranlsation in English,
- list of base terms,
- list of facet categories,
- for each category the list of facets that can be applied to it.
- None.
- Data {Object}: JSON data file containing list of base terms, facet categories and list of facets for each category (check the backend for additional information.)
- Find the UML activity diagram (created with PlantUML) at the following link.
This web component contains a section that is populated by a series of so-called tags. The tags are arranged horizontally with respect to the section and can be scrolled through the navbar, located at the bottom, or through the shortcut ctrl+mouse wheel (or multi-touch gestures).
Each tag has the characteristic of having a grey background color by default. Instead, if the term is selected a blue background color will be applied. Inside each tag is shown the name of the term returned from the backend API as well as an inner-tag that allows to know the percentage with which the models are sure about the suggestion made. In addition, you can learn more information about each tag by hovering the cursor on the tag. By doing so, a mini window will appear showing the name, the code and the percentage of accuracy for the specific term. In this section all the tags are sorted in descending order by percentage of accuracy. Please use the specific web component propety if the auto selection of the first lef-term is requested.
- Baseterms {Object}: list of base terms suggested
- Selected baseterm {Term}: object containing the term selectd.
- Find the UML activity diagram (created with PlantUML) at the following link.
This web component contains a section that is populated by a series of so-called tags. The tags are arranged horizontally with respect to the section and can be scrolled through the navbar, located at the bottom, or through the shortcut ctrl+mouse wheel (or multi-touch gestures).
Differently from the baseterm-component, the facets-component has a drop-down list which allows the selection of the facet category of interest. At each facet category selection an event is raised which refresh the section below with the list of tags that can be applied to it. Each tag has the characteristic of having a grey background color by default. Instead, if one or more terms are selected a green background color will be applied. Inside each tag is shown the name of the term returned from the backend API as well as an inner-tag that allows to know the percentage with which the models are sure about the suggestion made. In addition, you can learn more information about each tag by hovering the cursor on the tag. By doing so, a mini window will appear showing the name, the code, the category to which it belongs to and the percentage of accuracy for the specific term. In this section all the tags are sorted in descending order by percentage of accuracy. Please use the specific web component propety if the auto selection of the terms is requested.
- FacetData {Object}: list of categories and facets.
- Selected facets {List
<Facet>
}: object containing the facets selectd.
- Find the UML activity diagram (created with PlantUML) at the following link.
The "overview-component" is a section that collects the whole list of tags selected in the "baseterm-component" and "facets-component". This, is particularly useful especially in the selection of facets as it allows to have an overview of all the selected facets for each category.
- Selected Baseterm {Term}: term object populated with the properties of the chosen base term.
- Selected Facets {List
<Facet>
}: list of facet objects populated with the properties of the chosen facets.
- None.
- Find the UML activity diagram (created with PlantUML) at the following link.
This component is updated every time the user interacts with the "baseterm-component" and "facets-component and allows to obtain the FoodEx2 code generated.
- Selected Baseterm {Term}: term object populated with the properties of the chosen base term.
- Selected Facets {List
<Facet>
}: list of facet objects populated with the properties of the chosen facets.
- None.
- Find the UML activity diagram (created with PlantUML) at the following link.
The feedback component allows, through a specific button, to access a dialog box which exposes a series of features that allow the submission of feedback. Please note that this functionality is restricted to a limited number of users. The user, after logging in, will notice a new control button at the bottom of the homepage which, if pressed, will allow the feedback window to open. In this window we find two input fields, one dedicated to the description of the food or feed and one dedicated for the coding in FoodEx2 system. In addition, on the lower right side, there are 3 command buttons that allow us to reset the input fields, cancel the feedback operation or accept the feedback (POST request in backend).
An example of the POST request submitted to the backend looks like the following:
OST http://127.0.0.1:5000/post_feedback HTTP/1.1
Content-Type: "application/json"
x-access-token: mysecretkey
{
"desc": "hazelnuts",
"lang": "en",
"code": "A034L"
}
- Description {String}: food/feed description typed in the "input-component".
- None.
- Find the UML activity diagram (created with PlantUML) at the following link.
This component is used to lock the page and show a progress bar while performing some action (e.g. retrieving data from backend).
- Open {Boolean}: variable used for toggling the dialog and hence show/hide the progress bar.
- None.
- Find the UML activity diagram (created with PlantUML) at the following link.
The following section describes how to deploy the FoodEx2 Smart Coding Application's front-end locally.
Install Docker and configure it on your local computer. From the main folder of the foodex2-sca-frontend project run the following command:
docker build -t name:tag .
This command will use the DOCKERFILE, present in the main folder, for creating the docker image. Check if the docker image is present by launching the following command:
docker images
After making sure that the docker image has been correcly created, run it with the following command:
docker run name:tag
Deploy the docker image created on kubernates by using the files present under the "/manifest" folder by running the following command:
kubectl deploy -f create ./manifest/deployment.yml