npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

grunt-angular-translate-compare

v0.1.1

Published

Compares angular-translate translation files for missing keys and variables within those keys

Downloads

66

Readme

grunt-angular-translate-compare

Compares angular-translate translation files for missing keys and variables within those keys

Getting Started

This plugin requires Grunt ~0.4.5

If you haven't used Grunt before, be sure to check out the Getting Started guide, as it explains how to create a Gruntfile as well as install and use Grunt plugins. Once you're familiar with that process, you may install this plugin with this command:

npm install grunt-angular-translate-compare --save-dev

Once the plugin has been installed, it may be enabled inside your Gruntfile with this line of JavaScript:

grunt.loadNpmTasks('grunt-angular-translate-compare');

The "angular_translate_compare" task

Overview

In your project's Gruntfile, add a section named angular_translate_compare to the data object passed into grunt.initConfig().

grunt.initConfig({
  angular_translate_compare: {
    options: {
      baseLang: 'en', // the canonical language file to use as a base for comparison. languages determined by file name
      ext: 'json', // the file extensions to load,
      fatal: false, // whether this task should fail a build or not
      parsers: {} // additional parser functions for custom interpolations
    },
    src: 'locales/*.json' // file collection to use in comparison.  Base language file must be included in the collection
  }
});

Options

options.baseLang

Type: String Default value: 'en'

The base language to do comparisons against. This file represents what should be correct keys and variables. It's usually your native language and the one you're adding strings to during development.

options.fatal

Type: Boolean Default value: false

Whether or not this task should fail if there are errors in translations. Error messages will be printed regardless.

options.parsers

Type: Object Default value: null

Parsers for additional variable interpolations. The Angular and MessageFormat interpolations that are standard in angular-translate are included already.

The object keys are parser names, and the values are to be functions which take a single string, which will be the value from a translation file. This function should return an array of variable names within the string.

Note that parsers do need to accomodate the other possible parsers to prevent possible false positives. The included MessageFormat parser, for example, will match {varName} but not {{varName}}.

Usage Examples

Sample Translation Files

Base (test/fixtures/base.json):

{
  "SINGLE_KEY": "Test Key",
  "ANGULAR_VARIABLE": "This has an {{ angularVar }}-style variable in it",
  "MF_VARIABLE": "This has a {messageFormatVar}-style variable in it",
  "MF_CALCULATED_VARIABLE": "This has a multipart {messageFormatVarMulti, plural, one{foo} other{foos}}-style variable in it",
  "MF_MULTI_VARIABLE": "This has one {simpleVar} in it and one {multiVar, select, gender male{foo} female{fooette}} in it",
  "EXTRA_KEY": "This key is in the base, but not the comparison",
  "EMPTY_KEY": "This is only empty in the comparison",
  "MISSING_VARS": "This has two variables {{var1}} {{var2}} in it",
  "MISMATCHED_VARS": "{{ goodVarName }}",
  "EXTRA_VARS": "This does not have a variable",
  "MULTI_LEVEL": {
    "FIRST_KEY": "First Key"
  }
}

Comparison (test/fixtures/compare.json):

{
  "SINGLE_KEY": "Test Key",
  "ANGULAR_VARIABLE": "This has an {{ angularVar }}-style variable in it",
  "MF_VARIABLE": "This has a {messageFormatVar}-style variable in it",
  "MF_CALCULATED_VARIABLE": "This has a multipart {messageFormatVarMulti, plural, one{foo} other{foos}}-style variable in it",
  "MF_MULTI_VARIABLE": "This has one {simpleVar} in it and one {multiVar, select, gender male{foo} female{fooette}} in it",
  "EMPTY_KEY": "",
  "MISSING_VARS": "This is missing a variable",
  "EXTRA_VARS": "This has an extra {{variable}}",
  "MISMATCHED_VARS": "{{ barVarName }}",
  "MULTI_LEVEL": {
    "FIRST_KEY": "First Key"
  }
}

Sample Output

When comparing the two translation files above, the output for the task would be:

Checking language 'compare'... ERROR
>> 'compare' is missing keys: 
>>    EXTRA_KEY
>>    EMPTY_KEY
>> 'compare' is missing variables in key 'MISSING_VARS' compared to base: 
>>    var1
>>    var2
>> 'compare' has extra variables in key 'MISMATCHED_VARS' compared to base: 
>>    badVarName
>> 'compare' is missing variables in key 'MISMATCHED_VARS' compared to base: 
>>    goodVarName
>> 'compare' has extra variables in key 'EXTRA_VARS' compared to base: 
>>    variable