gulp-resx-out
v1.1.2
Published
Gulp plugin to allow custom formatting of resx files through callbacks.
Downloads
466
Maintainers
Readme
gulp-resx-out
Gulp plugin to allow custom formatting of resx files through callbacks.
Features
- use delimiter to create a structured object.
- intercept and modify output of the resx file.
- default output json, but can be modified through callbacks.
How to install
npm install gulp-resx-out --save-dev
Options
onwrite?: (obj, file) => string|obj
- Callback to change the final output.onparse?: (item, result, file) => { item: string, value: string } | null
- Callback to change item in the resx before its attatched to output.delimiter?: string
- split character for resx name(s)
Basic Usage
//`gulpfile.js`
const gulp = require("gulp");
const debug = require("gulp-debug");
const resx_out = require("gulp-resx-out");
const ext_replace = require('gulp-ext-replace');
gulp.task("default", () => {
//return string that should be written to file
function onwrite(result, file) {
return `const Phrases = ${JSON.stringify(result, null, "\t")};`;
}
//return null to skip, or object { name: '', value: '' }
function onparse(item, element, result, file) {
return {
name: item.name,
value: item.value
};
}
return gulp.src("./res/*.resx")
.pipe(debug())
.pipe(resx_out({
delimiter: '.',
onwrite: onwrite,
onparse: onparse
}))
.pipe(ext_replace(".ts"))
.pipe(gulp.dest("./out"));
});
Examples of onparse
//simple ignore
function onparse(item, result, file) {
var name = element.attr("name").value();
return name.indexOf(".skip.") > -1 ? null : item;
}
//censor special words (regex)
var nasties = ["list", "of", "word[s]?", "resulting", "in", "censoring"];
var match = new RegExp("(" + nasties.join(")|(") + ")", "gi");
function onparse(item, result, file) {
var result = item.value;
item.value = {
value: result,
censored: match.test(result) ? result.replace(match, "*censored*") : null
};
return item;
}
//resx file
<?xml version="1.0" encoding="utf-8"?>
<root>
<data name="Censor.This.One">
<value>This should be subject of censoring</value>
</data>
<data name="Common.Labels.DefiniteTime">
<value>Definite time</value>
</data>
<data name="Common.Labels.DefiniteTimeTooltip">
<value>Possible to register events as start time and end time</value>
</data>
<data name="ActiveTime.Texts.FutureVersionExists">
<value>There is a future version of this code. The changes you have made to this version are not included in the future version.</value>
</data>
<data name="ActiveTime.Texts.InCurrentVersion">
<value>In current version</value>
</data>
<data name="ActiveTime.Texts.InNewVersion">
<value>In new version</value>
</data>
<data name="ActiveTime.Texts.InUse">
<value>This version is in use. Changes will affect back to the from date of the current version</value>
</data>
<data name="ActiveTime.Texts.IsHistoricalVersion">
<value>This is a historical version. If you make changes here. it will mean that historical calculations will be recalculated.</value>
</data>
</root>
//Output
const Phrases = {
"Common": {
"Labels": {
"DefiniteTime": "Definite time",
"DefiniteTimeTooltip": "Possible to register events as start time and end time",
},
"ActiveTime": {
"Texts": {
"FutureVersionExists": "There is a future version of this code. The changes you have made to this version are not included in the future version.",
"InCurrentVersion": "In current version",
"InNewVersion": "In new version",
"InUse": "This version is in use. Changes will affect back to the from date of the current version",
"IsHistoricalVersion": "This is a historical version. If you make changes here. it will mean that historical calculations will be recalculated."
}
}
};
License
gulp-resx-out is licensed under the MIT license.