mirror of
https://github.com/bpatrik/pigallery2.git
synced 2025-01-02 03:37:54 +02:00
updating building and translations
This commit is contained in:
parent
ddf516b399
commit
e83ba7c5fa
@ -125,12 +125,9 @@ apt-get install build-essential libkrb5-dev gcc g++
|
||||
## 2. Translate the page to your own language
|
||||
1. [Install Pigallery2](#121-b-install-from-source) from source (with the release it won't work)
|
||||
2. add your language e.g: fr
|
||||
```bash
|
||||
npm run add-translation -- --fr
|
||||
```
|
||||
it creates a new `messages.fr.xls` file at `src/frontend/translate` folder,
|
||||
it will already contain dummy translation with google translate.
|
||||
3. 'fix' the dummy translation
|
||||
* copy `src/frontend/translate/messages.en.xls` to `src/frontend/translate/messages.fr.xls`
|
||||
* add the new translation to the `angular.json` `projects->pigallery2->i18n->locales` section
|
||||
3. translate the file by updating the `<target>` tags
|
||||
4. test if it works:
|
||||
build and start the app
|
||||
```bash
|
||||
|
50
angular.json
50
angular.json
@ -9,13 +9,52 @@
|
||||
"projectType": "application",
|
||||
"schematics": {},
|
||||
"prefix": "app",
|
||||
"i18n": {
|
||||
"sourceLocale": {
|
||||
"code": "en",
|
||||
"baseHref": ""
|
||||
},
|
||||
"locales": {
|
||||
"es": {
|
||||
"baseHref": "",
|
||||
"translation": "src/frontend/translate/messages.es.xlf"
|
||||
},
|
||||
"fr": {
|
||||
"baseHref": "",
|
||||
"translation": "src/frontend/translate/messages.fr.xlf"
|
||||
},
|
||||
"hu": {
|
||||
"baseHref": "",
|
||||
"translation": "src/frontend/translate/messages.hu.xlf"
|
||||
},
|
||||
"it": {
|
||||
"baseHref": "",
|
||||
"translation": "src/frontend/translate/messages.it.xlf"
|
||||
},
|
||||
"ro": {
|
||||
"baseHref": "",
|
||||
"translation": "src/frontend/translate/messages.ro.xlf"
|
||||
},
|
||||
"ru": {
|
||||
"baseHref": "",
|
||||
"translation": "src/frontend/translate/messages.ru.xlf"
|
||||
},
|
||||
"sv": {
|
||||
"baseHref": "",
|
||||
"translation": "src/frontend/translate/messages.sv.xlf"
|
||||
}
|
||||
}
|
||||
},
|
||||
"architect": {
|
||||
"build": {
|
||||
"builder": "@angular-devkit/build-angular:browser",
|
||||
"options": {
|
||||
"localize": true,
|
||||
"aot": true,
|
||||
"crossOrigin": "anonymous",
|
||||
"outputPath": "dist",
|
||||
"index": "src/frontend/index.html",
|
||||
"progress": true,
|
||||
"main": "src/frontend/main.ts",
|
||||
"tsConfig": "src/frontend/tsconfig.app.json",
|
||||
"polyfills": "src/frontend/polyfills.ts",
|
||||
@ -29,15 +68,22 @@
|
||||
"ngx-toastr/toastr.css",
|
||||
"src/frontend/styles.css"
|
||||
],
|
||||
"scripts": []
|
||||
"scripts": [],
|
||||
"i18nMissingTranslation": "warning"
|
||||
},
|
||||
"configurations": {
|
||||
"dev": {
|
||||
"localize": [
|
||||
"en"
|
||||
],
|
||||
"outputPath": "dist",
|
||||
"watch": true
|
||||
},
|
||||
"production": {
|
||||
"optimization": true,
|
||||
"outputHashing": "all",
|
||||
"sourceMap": false,
|
||||
"namedChunks": false,
|
||||
"aot": true,
|
||||
"extractLicenses": true,
|
||||
"vendorChunk": false,
|
||||
"buildOptimizer": true,
|
||||
|
81
gulpfile.ts
81
gulpfile.ts
@ -35,7 +35,7 @@ const getSwitch = (name: string, def: string = null): string => {
|
||||
return def;
|
||||
};
|
||||
|
||||
gulp.task('build-backend', function () {
|
||||
gulp.task('build-backend', function() {
|
||||
return gulp.src([
|
||||
'src/common/**/*.ts',
|
||||
'src/backend/**/*.ts',
|
||||
@ -95,30 +95,13 @@ const resetAppModule = async (language: string) => {
|
||||
|
||||
const createFrontendTask = (type: string, language: string, script: string) => {
|
||||
gulp.task(type, async (cb) => {
|
||||
let error;
|
||||
try {
|
||||
// TODO: remove this once i18n-pollify is removed from the project
|
||||
// Adding filtered translation as webpack would pack all translations into the created release
|
||||
await createDynamicTranslationFile(language);
|
||||
await setDynTransFileAtAppModule(language);
|
||||
const {stdout, stderr} = await execPr(script);
|
||||
console.log(stdout);
|
||||
console.error(stderr);
|
||||
} catch (e) {
|
||||
console.error(e);
|
||||
error = e;
|
||||
} finally {
|
||||
try {
|
||||
await resetAppModule(language);
|
||||
} catch (e) {
|
||||
|
||||
}
|
||||
try {
|
||||
await removeDynamicTranslationFile(language);
|
||||
} catch (e) {
|
||||
|
||||
}
|
||||
cb(error);
|
||||
cb(e);
|
||||
}
|
||||
});
|
||||
};
|
||||
@ -152,27 +135,14 @@ const getLanguages = () => {
|
||||
};
|
||||
|
||||
gulp.task('build-frontend', (() => {
|
||||
const languages = getLanguages().filter((l) => {
|
||||
return l !== 'en';
|
||||
});
|
||||
const tasks = [];
|
||||
createFrontendTask('build-frontend-release default', 'en',
|
||||
'ng build --aot --prod --output-path=./release/dist --no-progress --i18n-locale=en' +
|
||||
' --i18n-format xlf --i18n-file src/frontend/' + translationFolder + '/messages.en.xlf' +
|
||||
' --i18n-missing-translation warning');
|
||||
createFrontendTask('build-frontend-release default', 'all',
|
||||
'ng build --prod --no-progress');
|
||||
tasks.push('build-frontend-release default');
|
||||
for (let i = 0; i < languages.length; i++) {
|
||||
createFrontendTask('build-frontend-release ' + languages[i], languages[i],
|
||||
'ng build --aot --prod --output-path=./release/dist/' + languages[i] +
|
||||
' --no-progress --i18n-locale=' + languages[i] +
|
||||
' --i18n-format xlf --i18n-file src/frontend/' + translationFolder + '/messages.' + languages[i] + '.xlf' +
|
||||
' --i18n-missing-translation warning');
|
||||
tasks.push('build-frontend-release ' + languages[i]);
|
||||
}
|
||||
return gulp.series(...tasks);
|
||||
})());
|
||||
|
||||
gulp.task('copy-static', function () {
|
||||
gulp.task('copy-static', function() {
|
||||
return gulp.src([
|
||||
'src/backend/model/diagnostics/blank.jpg',
|
||||
'README.md',
|
||||
@ -181,7 +151,7 @@ gulp.task('copy-static', function () {
|
||||
.pipe(gulp.dest('./release'));
|
||||
});
|
||||
|
||||
gulp.task('copy-package', function () {
|
||||
gulp.task('copy-package', function() {
|
||||
return gulp.src([
|
||||
'package.json'], {base: '.'})
|
||||
.pipe(jeditor((json: {
|
||||
@ -225,7 +195,7 @@ gulp.task('copy-package', function () {
|
||||
});
|
||||
|
||||
|
||||
gulp.task('zip-release', function () {
|
||||
gulp.task('zip-release', function() {
|
||||
return gulp.src(['release/**/*'], {base: './release'})
|
||||
.pipe(zip('pigallery2.zip'))
|
||||
.pipe(gulp.dest('.'));
|
||||
@ -235,27 +205,17 @@ gulp.task('create-release', gulp.series('build-frontend', 'build-backend', 'copy
|
||||
|
||||
|
||||
const simpleBuild = (isProd: boolean) => {
|
||||
const languages = getLanguages().filter((l) => {
|
||||
return l !== 'en';
|
||||
});
|
||||
const tasks = [];
|
||||
let cmd = 'ng build --aot ';
|
||||
let cmd = 'ng build ';
|
||||
if (isProd) {
|
||||
cmd += ' --prod --no-extract-licenses ';
|
||||
}
|
||||
createFrontendTask('build-frontend default', 'en', cmd + '--output-path=./dist --no-progress --no-progress --i18n-locale en' +
|
||||
' --i18n-format=xlf --i18n-file=src/frontend/' + translationFolder + '/messages.en.xlf' + ' --i18n-missing-translation warning');
|
||||
tasks.push('build-frontend default');
|
||||
if (!process.env.CI) { // don't build languages if running in CI
|
||||
for (let i = 0; i < languages.length; i++) {
|
||||
createFrontendTask('build-frontend ' + languages[i], languages[i], cmd +
|
||||
'--output-path=./dist/' + languages[i] +
|
||||
' --no-progress --i18n-locale ' + languages[i] +
|
||||
' --i18n-format=xlf --i18n-file=src/frontend/' + translationFolder +
|
||||
'/messages.' + languages[i] + '.xlf' + ' --i18n-missing-translation warning');
|
||||
tasks.push('build-frontend ' + languages[i]);
|
||||
}
|
||||
if (!process.env.CI) {
|
||||
createFrontendTask('build-frontend default', 'all', cmd);
|
||||
} else {
|
||||
createFrontendTask('build-frontend default', 'all', cmd + '--localize=false');
|
||||
}
|
||||
tasks.push('build-frontend default');
|
||||
return gulp.series(...tasks);
|
||||
};
|
||||
|
||||
@ -263,7 +223,7 @@ gulp.task('extract-locale', async (cb) => {
|
||||
console.log('creating source translation file: locale.source.xlf');
|
||||
try {
|
||||
{
|
||||
const {stdout, stderr} = await execPr('ng extract-i18n --out-file=./../../locale.source.xlf --i18n-format=xlf --i18n-locale=en',
|
||||
const {stdout, stderr} = await execPr('ng extract-i18n --out-file=locale.source.xlf --format=xlf',
|
||||
{maxBuffer: 1024 * 1024});
|
||||
console.log(stdout);
|
||||
console.error(stderr);
|
||||
@ -299,12 +259,15 @@ const translate = async (list: any[], cb: (err?: any) => void) => {
|
||||
const merge = async (list: any[], cb: (err?: any) => void) => {
|
||||
try {
|
||||
const localsStr = '"[\\"' + list.join('\\",\\"') + '\\"]"';
|
||||
const {stdout, stderr} = await execPr('xlf-google-translate ' +
|
||||
const command = 'xlf-google-translate ' +
|
||||
'--method="extend-only" ' +
|
||||
'--source-lang="en" ' +
|
||||
'--source-file="./locale.source.xlf" ' +
|
||||
'--destination-filename="messages" ' +
|
||||
'--destination-folder="./src/frontend/"' + translationFolder + ' --destination-languages=' + localsStr);
|
||||
'--destination-folder="./src/frontend/' + translationFolder + '" ' +
|
||||
'--destination-languages=' + localsStr;
|
||||
console.log(command);
|
||||
const {stdout, stderr} = await execPr(command);
|
||||
console.log(stdout);
|
||||
console.error(stderr);
|
||||
cb();
|
||||
@ -314,10 +277,10 @@ const merge = async (list: any[], cb: (err?: any) => void) => {
|
||||
}
|
||||
};
|
||||
|
||||
gulp.task('update-translation-only', function (cb) {
|
||||
gulp.task('update-translation-only', function(cb) {
|
||||
translate(getLanguages(), cb).catch(console.error);
|
||||
});
|
||||
gulp.task('merge-translation-only', function (cb) {
|
||||
gulp.task('merge-translation-only', function(cb) {
|
||||
merge(getLanguages(), cb).catch(console.error);
|
||||
});
|
||||
|
||||
@ -346,7 +309,7 @@ gulp.task('add-translation-only', (cb) => {
|
||||
});
|
||||
|
||||
gulp.task('generate-man', async (cb) => {
|
||||
const defCFG = ConfigClassBuilder.attachInterface(new PrivateConfigClass());
|
||||
const defCFG = ConfigClassBuilder.attachInterface(new PrivateConfigClass());
|
||||
defCFG.Server.sessionSecret = [];
|
||||
let txt = '# Pigallery 2 man page\n';
|
||||
txt += 'pigallery2 uses [typeconfig](https://github.com/bpatrik/typeconfig) for configuration\n\n';
|
||||
|
32
package-lock.json
generated
32
package-lock.json
generated
@ -5316,20 +5316,14 @@
|
||||
},
|
||||
"dependencies": {
|
||||
"get-stream": {
|
||||
"version": "5.1.0",
|
||||
"resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.1.0.tgz",
|
||||
"integrity": "sha512-EXr1FOzrzTfGeL0gQdeFEvOMm2mzMOglyiOXSTpPC+iAjAKftbr3jpCMWynogwYnM+eSj9sHGc6wjIcDvYiygw==",
|
||||
"version": "5.2.0",
|
||||
"resolved": "https://registry.npmjs.org/get-stream/-/get-stream-5.2.0.tgz",
|
||||
"integrity": "sha512-nBF+F1rAZVCu/p7rjzgA+Yb4lfYXrpl7a6VmJrU8wF9I1CKvP/QwPNZHnOlwbTkY6dvtFIzFMSyQXbLoTQPRpA==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"pump": "^3.0.0"
|
||||
}
|
||||
},
|
||||
"http-cache-semantics": {
|
||||
"version": "4.0.3",
|
||||
"resolved": "https://registry.npmjs.org/http-cache-semantics/-/http-cache-semantics-4.0.3.tgz",
|
||||
"integrity": "sha512-TcIMG3qeVLgDr1TEd2XvHaTnMPwYQUQMIBLy+5pLSDKYFc7UIqj39w8EGzZkaxoLv/l2K8HaI0t5AVA+YYgUew==",
|
||||
"dev": true
|
||||
},
|
||||
"lowercase-keys": {
|
||||
"version": "2.0.0",
|
||||
"resolved": "https://registry.npmjs.org/lowercase-keys/-/lowercase-keys-2.0.0.tgz",
|
||||
@ -7636,9 +7630,9 @@
|
||||
}
|
||||
},
|
||||
"defer-to-connect": {
|
||||
"version": "1.1.1",
|
||||
"resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.1.tgz",
|
||||
"integrity": "sha512-J7thop4u3mRTkYRQ+Vpfwy2G5Ehoy82I14+14W4YMDLKdWloI9gSzRbV30s/NckQGVJtPkWNcW4oMAUigTdqiQ==",
|
||||
"version": "1.1.3",
|
||||
"resolved": "https://registry.npmjs.org/defer-to-connect/-/defer-to-connect-1.1.3.tgz",
|
||||
"integrity": "sha512-0ISdNousHvZT2EiFlZeZAHBUvSxmKswVCEf8hW7KWgG4a8MVEu/3Vb6uWYozkjylyCxe0JBIiRB1jV45S70WVQ==",
|
||||
"dev": true
|
||||
},
|
||||
"define-properties": {
|
||||
@ -24358,20 +24352,20 @@
|
||||
}
|
||||
},
|
||||
"xlf-google-translate": {
|
||||
"version": "1.0.0-beta.19",
|
||||
"resolved": "https://registry.npmjs.org/xlf-google-translate/-/xlf-google-translate-1.0.0-beta.19.tgz",
|
||||
"integrity": "sha512-zeZTvH3ijeh0/F73jrKr4/Ojr61ds6NHP+KN792uamMzCY3Fv0wfjLXSzdXINXEK+CKKNyV333i6zPMzt7fz0Q==",
|
||||
"version": "1.0.0-beta.21",
|
||||
"resolved": "https://registry.npmjs.org/xlf-google-translate/-/xlf-google-translate-1.0.0-beta.21.tgz",
|
||||
"integrity": "sha512-gKk289jY3cBYf0uJg6jxqOqGg8HFbL3YohwM9RobT0FgD3hIR+Xo6spNeseGtYEXXsiU7B4ri1UOMqlj17vDTQ==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"@k3rn31p4nic/google-translate-api": "1.1.0",
|
||||
"typeconfig": "1.0.9",
|
||||
"typeconfig": "2.0.15",
|
||||
"xml2js": "0.4.23"
|
||||
},
|
||||
"dependencies": {
|
||||
"typeconfig": {
|
||||
"version": "1.0.9",
|
||||
"resolved": "https://registry.npmjs.org/typeconfig/-/typeconfig-1.0.9.tgz",
|
||||
"integrity": "sha512-s8iCnCTSVNP6S7yF6KdkyhbvV0BDmPE/RnJOZf77sjMdfB5B/QlqrFFQWmnz+818xsP38bieD5OcP1iqzUKW/A==",
|
||||
"version": "2.0.15",
|
||||
"resolved": "https://registry.npmjs.org/typeconfig/-/typeconfig-2.0.15.tgz",
|
||||
"integrity": "sha512-KpngjnOktNxnS9dksBzQnKn7XTXlcvxouWrNYrZnZDupX/bXDjF8vaaU1AokpqE4Jb+ectygUUh10erxEZhQDQ==",
|
||||
"dev": true,
|
||||
"requires": {
|
||||
"optimist": "0.6.1"
|
||||
|
@ -16,8 +16,7 @@
|
||||
"test": "ng test && nyc mocha --recursive test",
|
||||
"coverage": "nyc report --reporter=text-lcov | coveralls",
|
||||
"start": "node ./src/backend/index",
|
||||
"run-dev": "ng build --aot --watch --output-path=./dist --i18n-locale en --i18n-file src/frontend/translate/messages.en.xlf --i18n-missing-translation warning",
|
||||
"run-dev-hu": "ng build --aot --watch --output-path=./dist --i18n-locale hu --i18n-file src/frontend/translate/messages.hu.xlf --i18n-missing-translation warning",
|
||||
"run-dev": "ng build --configuration=dev",
|
||||
"build-stats": "ng build --aot --prod --stats-json --output-path=./dist --i18n-locale en --i18n-file src/frontend/translate/messages.en.xlf --i18n-missing-translation warning",
|
||||
"merge-new-translation": "gulp merge-new-translation",
|
||||
"add-translation": "gulp add-translation",
|
||||
@ -135,7 +134,7 @@
|
||||
"ts-node": "9.1.1",
|
||||
"tslint": "6.1.3",
|
||||
"typescript": "4.1.5",
|
||||
"xlf-google-translate": "1.0.0-beta.19",
|
||||
"xlf-google-translate": "1.0.0-beta.21",
|
||||
"xml2js": "0.4.23",
|
||||
"zone.js": "0.11.4"
|
||||
},
|
||||
|
@ -26,24 +26,20 @@ declare global {
|
||||
export class PublicRouter {
|
||||
|
||||
|
||||
public static route(app: Express) {
|
||||
const setLocale = (req: Request, res: Response, next: Function) => {
|
||||
let localePath = '';
|
||||
public static route(app: Express): void {
|
||||
const setLocale = (req: Request, res: Response, next: NextFunction) => {
|
||||
let selectedLocale = req['locale'];
|
||||
if (req.cookies && req.cookies[CookieNames.lang]) {
|
||||
if (Config.Client.languages.indexOf(req.cookies[CookieNames.lang]) !== -1) {
|
||||
selectedLocale = req.cookies[CookieNames.lang];
|
||||
}
|
||||
}
|
||||
if (selectedLocale !== 'en') {
|
||||
localePath = selectedLocale;
|
||||
}
|
||||
res.cookie(CookieNames.lang, selectedLocale);
|
||||
req['localePath'] = localePath;
|
||||
req['localePath'] = selectedLocale;
|
||||
next();
|
||||
};
|
||||
|
||||
const renderIndex = (req: Request, res: Response, next: Function) => {
|
||||
const renderIndex = (req: Request, res: Response, next: NextFunction) => {
|
||||
ejs.renderFile(path.join(ProjectPath.FrontendFolder, req['localePath'], 'index.html'),
|
||||
res.tpl, (err, str) => {
|
||||
if (err) {
|
||||
@ -69,14 +65,14 @@ export class PublicRouter {
|
||||
|
||||
res.tpl.user = null;
|
||||
if (req.session.user) {
|
||||
res.tpl.user = <UserDTO>{
|
||||
res.tpl.user = {
|
||||
id: req.session.user.id,
|
||||
name: req.session.user.name,
|
||||
csrfToken: req.session.user.csrfToken,
|
||||
role: req.session.user.role,
|
||||
usedSharingKey: req.session.user.usedSharingKey,
|
||||
permissions: req.session.user.permissions
|
||||
};
|
||||
} as UserDTO;
|
||||
|
||||
if (!res.tpl.user.csrfToken && req.csrfToken) {
|
||||
res.tpl.user.csrfToken = req.csrfToken();
|
||||
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
Loading…
Reference in New Issue
Block a user