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

@rxweb/ngx-translate-extension

v1.0.6

Published

[![Build Status](https://travis-ci.org/rxweb/rxweb.svg?branch=master)](https://travis-ci.org/rxweb/rxweb) [![Gitter](https://badges.gitter.im/rx-web/Lobby.svg)](https://gitter.im/rxweb-project/rxweb?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge

Downloads

34

Readme

Build Status Gitter Codacy Badge DeepScan grade GitHub license

An extensible library of ngx-translate for Angular Internationalization with more than 50+ spectacular features 🌈.

The objective of this library to extend the features of ngx-translate, fix the bugs which are opened since long on ngx-translate project.

For existing ngx-translate developer community

That's it.

How can be sure that after replacing the package name, everything will work as expected?

We have copied the spec from @ngx-translate/core project and follows the above mentioned steps, it's working as expected. Please refer the Spec Code Comparision Page.

💪 Features

Attribute Directive (Working Example of below features)

<span translate="introduction"></span>
<span translate="notification" [translateParams]="{name:'John'}"></span>
<span translate="note" translateLang="fr"></span>
<span translate="dashboardHeading" translationName="dashboard"></span>

Impure Pipe (Working Example of below features)

{{'greet' | translate}}
{{'notification' | translate:{name:'John'} }}
{{'note' | translate:{lang:'fr'} }}
{{'dashboardHeading' | translate:{translationName:'dashboard'} }}

Pure Pipe (Working Example of below features)

{{global.raw.notification | rxTranslate:{'name':'Munad'} }}
{{global.raw.notification | rxTranslate:{'name':name} }}

Decorator (Working Example of below features)

COMPONENT

@translate() global:{[key:string]:any};

HTML

{{global.introduction}}
{{global.notification}} // Not required to passing the parameter, automatically managed.
@translate({languageCode:'fr'}) global:{[key:string]:any}; // HTML binding is same as above.
@translate({translationName:'dashboard'}) dashboard:{[key:string]:any}; 
@translate({ filePath:"..."}) global:{[key:string]:any}; 
@translate({
  translationName: 'inliners',
  inlineTranslations: {
      en: () => import('./i18n/en.json'),
      fr: () => import('./i18n/fr.json')
  }
}) inline: any; // inline loader
@translateAsync({
    serviceModel: LanguageService,
    serviceMethod: LanguageService.prototype.get
}) languages : any[];

FormControl Validation Message Translation

  1. Binds Validation message in errors object of FormControl, as per active language.
  2. Binds Validation message with custom parameter.
  3. Binds Validation message with array values.

Runtime Change Language By (Working Example of below features)

  1. URL
  2. Code

Structrual Directive (Working Example of below features)

<app-child *rxTranslate="true"></app-child>

Other Intuitive Features

  1. Automatically set the page title.
  2. Lazy Load Translation Files as per Angular PreLoadModule Stratergy.

Sanitizers

  1. Currency
  2. Date
  3. Decimal
  4. Percent
  5. LowerCase
  6. UpperCase
  7. TitleCase
  8. Custom

Ohh! We missed the initial configuration like module registration and all 😜, Don't worry that won't take much time, it's a one time configuration for accessing the services of translation throughout the application.

Installation

This package have dependency of @ngx-translate/core and @rxweb/translate.

npm install @rxweb/ngx-translate-extension

Now we are going to register the module in the root module of the application.

@NgModule({
  declarations: [...],
  imports: [
	TranslateModule.forRoot()
  ],
  providers: [],
  bootstrap: [...]
})
export class AppModule { }

one time component level code for setting up the default language and current language.

export class AppComponent {
    constructor(public translate: TranslateService) {
        translate.addLangs(['en', 'es','fr']);
        translate.setDefaultLang('en');

        const browserLang = translate.getBrowserLang();
        translate.use('en');
    }
}

All Done, Feel free to share your suggestions if something is missing or we enchance this package 🙂.

Contributing

If you are thinking to make rxweb framework better, that's truly great. You can contribute from a single character to core architectural work or significant documentation – all with the goal of making a robust rxweb framework which helps for everyone in their projects. Even if you are don’t feel up to writing code or documentation yet, there are a variety of other ways that you can contribute like reporting issues to testing patches.

Check out the docs on how you can put your precious efforts on the rxweb framework and contribute in the respective area.

Need Help

We highly recommend for help please ask your questions on our gitter/rxweb-project to get quick response from us. Otherthan our gitter channel you can ask your question on StackOverflow or create a new issue in our Github Repository.

For, issue please refer our issue workflow wiki for better visibility our issue process.

Feature Request

You can request a new feature by submitting an issue to our GitHub Repository. If you would like to implement a new feature, please submit an issue with a proposal for your work first, to be sure that we can use it.

License

MIT