Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/katrotz/meteor-inflector
Ruby on Rails to JS to Node to Meteor port of the inflector module :sparkles:
https://github.com/katrotz/meteor-inflector
inflector meteor meteor-inflector
Last synced: 10 days ago
JSON representation
Ruby on Rails to JS to Node to Meteor port of the inflector module :sparkles:
- Host: GitHub
- URL: https://github.com/katrotz/meteor-inflector
- Owner: katrotz
- Created: 2015-10-10T19:12:45.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2015-10-11T19:22:43.000Z (over 9 years ago)
- Last Synced: 2024-11-14T08:08:15.590Z (2 months ago)
- Topics: inflector, meteor, meteor-inflector
- Language: JavaScript
- Size: 141 KB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Meteor Inflector
[![Build Status](https://travis-ci.org/katrotz/meteor-inflector.svg)](https://travis-ci.org/katrotz/meteor-inflector)
> The [Inflector](http://api.rubyonrails.org/classes/ActiveSupport/Inflector.html) transforms words from singular to plural, class names to table names, modularized class names to ones without, and class names to foreign keys. The default inflections for pluralization, singularization, and uncountable words are kept in inflections.rb *(ruby on rails)*## About
This is a meteor package wrapping the [NodeJS inflection](https://github.com/dreamerslab/node.inflection) package which is a port of [inflection-js](https://code.google.com/p/inflection-js/) which is a port of Ruby on Rails [Inflector module](http://api.rubyonrails.org/classes/ActiveSupport/Inflector.html)## How to use
#### Server and Client
This package exports the `Inflector` object that can be accessed from the global scope which exposes all the inflection methods from nodes package:Inflector.indexOf(arr, item, fromIndex, compareFunc)
> Checks if an array contains a given element.Inflector.pluralize(string, plural)
> Computes the plural form of a noun.
Inflector.singularize(string, singular)
> The reverse of pluralize, returns the singular form of a word.Inflector.inflect(string, count, singular, plural)
> This function will pluralize or singularlize a string respectively based on an count valueInflector.camelize(string, lowFirstLetter)
> Lower case underscored words will be returned in camel case. Additionally "/" is translated to "::"Inflector.underscore(string, allUpperCase)
> Camel cased words are returned as lower cased and underscored. Additionally "::" is translated to "/"Inflector.humanize(string, lowFirstLetter)
> Lower case underscored words will be returned in humanized form.Inflector.capitalize(string)
> All characters will be lower case and the first will be upper.Inflector.dasherize(string)
> Replaces underscores with dashes in the string.Inflector.titleize(string)
> Capitalizes words as you would for a book title.Inflector.demodulize(string)
> Removes module names leaving only class names.(Ruby style)Inflector.tableize(string)
> Return camel cased words into their underscored plural form.Inflector.classify(string)
> Create a class name from a plural table name like Rails does for table names to models.Inflector.foreign_key(string, dropIdUnderscore)
> Creates a foreign key name from a class name.Inflector.ordinalize(string)
> Turns a number into an ordinal string used to denote the position in an ordered sequence such as 1st, 2nd, 3rd, 4th.Inflector.transform(string, transforms)
> This function performs multiple inflection methods on a string### Client template helpers
The inflector helpers work with both positional and keyword arguments. For the sake of example, both mandatory and optional keyword arguments are listed:- ```{{pluralize string plural=}}```
- ```{{singularize string singular=}}```
- ```{{inflect string count singular= plural=}}```
- ```{{camelize string lowFirstLetter=}}```
- ```{{underscore string allUpperCase=}}```
- ```{{humanize string lowFirstLetter=}}```
- ```{{capitalize string}}```
- ```{{dasherize string}}```
- ```{{titleize string}}```
- ```{{ordinalize string}}```