0.0
No commit activity in last 3 years
No release in over 3 years
Add `from_file` option to Rails enum.
2005
2006
2007
2008
2009
2010
2011
2012
2013
2014
2015
2016
2017
2018
2019
2020
2021
2022
2023
2024
2025
 Dependencies

Development

Runtime

>= 4.2.0
 Project Readme

EnumFromFile

Build Status Gem Version

If you've ever found yourself in a situation where you feel like you should use enum, but it has 50 positions so you don't know where to put it, the answer is here!

Just store your enums in a .yml file!

This makes little sense when you have a small enum with just a couple of options, but the more options you have, the easier it is to see the benefits of using it.

Usage

  1. Create a folder /config/enums to store your enum files in .yml format.
  2. Make sure your enum column has a type string.

Et voila!

Given a file /config/enums/eye_colors.yml you can add eye_color enum to a Cat model with the following line:

enum :eye_color, from_file: :eye_colors

You can continue using regular syntax for regular cases:

enum status: { active: "active", archived: "archived" }

All the options will be passed to native enum implementation as expected.

You can structure your .yml file either as a hash

blue:   blue
copper: copper
yellow: yellow

Or as a list

gold
orange
green
red

The list will be converted automatically, so both structures yield the same result.

Installation

Add this line to your application's Gemfile:

gem "enum_from_file"

And then execute:

$ bundle

Contributing

Bug reports and pull requests are welcome on project's page at GitHub

License

The gem is available as open source under the terms of the MIT License.