---
TradEmploi: an instantaneous translation application between two people, one of whom is allophone
Copyright (C) <2022> <Innovation Department, DSI Pôle Emploi>
This program is free software: you can redistribute it and/or modify it under the terms of the GNU Affero General Public License as published by the Free Software Foundation, either version 3 of the License, or (at your option) any later version.
This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU Affero General Public License for more details.
You should have received a copy of the GNU Affero General Public License along with this program. If not, see https://www.gnu.org/licenses/.
---
This project is distributed under the GNU AFFERO GENERAL PUBLIC LICENSE V3.0. Please check the LICENSE file.
[[TOC]]
The purpose of this application is describe in the documentation
This project is the frontend of the application. The backend is petranslate-back project. Checks readme to install it.
Node, Angular | Version |
---|---|
Node | 12.18 |
angular/cli | 10.1.3 |
firebase tools | 10.6.0 |
- under src, create the folder environments.
- under the new folder src/environments, create files: environment.ts, authflow.ts and params.ts
- fill the environment.ts and authflow.ts files with setting data, example:
environement.ts
export const environment = {
name: 'os',
production: false,
firebaseConfig: {
apiKey: 'XXXX',
authDomain: 'XXXX',
projectId: 'XXXX',
storageBucket: 'XXXX',
messagingSenderId: 'XXXX',
appId: 'XXXX',
},
gcp: {
gateWayUrl: 'XXXX',
},
microsoftSpeechConfig: {
speechToTextEnabled: false,
textToSpeechEnabled: false,
key: 'XXXX',
region: 'XXXX',
}
};
authflow.ts
import { AuthConfig } from 'angular-oauth2-oidc';
export const authCodeFlowConfig: AuthConfig = {
};
params.ts
export const params = {
defaultPassword: 'XXXX',
excludedLanguagesFromAzureSTT: [
'zh-CN',
'zh-HK',
'en-PK',
'af-ZA',
'sq-AL',
'am-ET',
'hy-AM',
'az-AZ',
'eu-ES',
'bn-BD',
'bn-IN',
'bs-BA',
'my-MM',
'zh-TW',
'gl-ES',
'ka-GE',
'is-IS',
'jv-ID',
'kk-KZ',
'km-KH',
'lo-LA',
'mk-MK',
'ml-IN',
'mr-IN',
'mn-MN',
'ne-NP',
'sr-RS',
'si-LK',
'su-ID',
'sw-TZ',
'ta-MY',
'ta-SG',
'ta-LK',
'uk-UA',
'ur-IN',
'ur-PK',
'uz-UZ',
'zu-ZA',
],
organization: {
name: 'XXXX',
organizationUser: 'Conseiller',
etabsDomain: ' ',
officalDomain: ' ',
cgus: "Nous utilisons des cookies pour nous assurer de votre sécurité. Nous n'utilisons pas de cookies pour vous conseiller et nous ne vendons pas vos données à des tiers.",
cgusEnglish: `We use cookies to ensure your security. We do not use cookies to advise you and we do not sell your data to third parties.`,
entretiens: ['Accueil', 'Inscription', 'Indemnisation', 'Accompagnement', 'Autres'],
},
};
Name | Description |
---|---|
firebaseConfig | your app's Firebase project configuration |
gcp.gateWayUrl | the gateway's url for your gcp backend project |
firebaseConfig | your app's Firebase project configuration |
microsoftSpeechConfig | settings for the microsoft azure speech to text api even when microsoftSpeechConfig.speechToTextEnabled is true |
microsoftSpeechConfig.speechToTextEnabled | converting voice to text will use the azure speech to text api if true, false otherwise |
microsoftSpeechConfig.textToSpeechEnabled | converting text to voice will use the azure text to speech api if true, false otherwise |
microsoftSpeechConfig.key | the microsoft azure speech to text api key |
microsoftSpeechConfig.region | the microsoft azure speech to text api region |
Name | Description |
---|---|
defaultPassword | the default password used to create a new firebase user account Not needed if firebase login is activated |
excludedLanguagesFromAzureSTT | the excludedLanguages will continue to use the google api for the speech to text api even if the microsoft azure api is enabled |
organization.name | your organization name |
organization.organizationUser | Main user of your app |
organization.cgus | your organisation's General Conditions of Use (GCU) in french |
organization.cgusEnglish | your organisation's General Conditions of Use (GCU) in english |
organization.entretiens | type of interviews |
the default authentication mode is the firebase authentication with firestore.
This mode is enabled when the authCodeFlowConfig.loginUrl param in the authflow.ts file is not defined.
Otherwise,when authCodeFlowConfig.loginUrl is defined, it means that authentication is based on the open id connect, using the authorization code flow.
So you need to have an authentication server,set the loginUrl and others settings in authCodeFlowConfig to setup your sso environment and initialise the authentication code flow.
Run ng serve
for a dev server. Navigate to http://localhost:4200/
. The app will automatically reload if you change any of the source files.
Run ng generate component component-name
to generate a new component. You can also use ng generate directive|pipe|service|class|guard|interface|enum|module
.
To get more help on the Angular CLI use ng help
or go check out the Angular CLI README.
1 - Build
$ npm run build:[dev|uat|prod]
2 - TEST on local
3 - Deploy
$ firebase deploy --project [dev|uat|prod]
4 - TEST
$ https://$GCP_PROJECT.firebaseapp.com
5 - TEST with Product owner