108 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			108 lines
		
	
	
		
			3.9 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # FriendlyId Global Configuration
 | |
| #
 | |
| # Use this to set up shared configuration options for your entire application.
 | |
| # Any of the configuration options shown here can also be applied to single
 | |
| # models by passing arguments to the `friendly_id` class method or defining
 | |
| # methods in your model.
 | |
| #
 | |
| # To learn more, check out the guide:
 | |
| #
 | |
| # http://norman.github.io/friendly_id/file.Guide.html
 | |
| 
 | |
| FriendlyId.defaults do |config|
 | |
|   # ## Reserved Words
 | |
|   #
 | |
|   # Some words could conflict with Rails's routes when used as slugs, or are
 | |
|   # undesirable to allow as slugs. Edit this list as needed for your app.
 | |
|   config.use :reserved
 | |
| 
 | |
|   config.reserved_words = %w[new edit index session login logout users admin
 | |
|     stylesheets assets javascripts images]
 | |
| 
 | |
|   # This adds an option to treat reserved words as conflicts rather than exceptions.
 | |
|   # When there is no good candidate, a UUID will be appended, matching the existing
 | |
|   # conflict behavior.
 | |
| 
 | |
|   config.treat_reserved_as_conflict = true
 | |
| 
 | |
|   #  ## Friendly Finders
 | |
|   #
 | |
|   # Uncomment this to use friendly finders in all models. By default, if
 | |
|   # you wish to find a record by its friendly id, you must do:
 | |
|   #
 | |
|   #    MyModel.friendly.find('foo')
 | |
|   #
 | |
|   # If you uncomment this, you can do:
 | |
|   #
 | |
|   #    MyModel.find('foo')
 | |
|   #
 | |
|   # This is significantly more convenient but may not be appropriate for
 | |
|   # all applications, so you must explicitly opt-in to this behavior. You can
 | |
|   # always also configure it on a per-model basis if you prefer.
 | |
|   #
 | |
|   # Something else to consider is that using the :finders addon boosts
 | |
|   # performance because it will avoid Rails-internal code that makes runtime
 | |
|   # calls to `Module.extend`.
 | |
| 
 | |
|   config.use :finders
 | |
| 
 | |
|   # ## Slugs
 | |
|   #
 | |
|   # Most applications will use the :slugged module everywhere. If you wish
 | |
|   # to do so, uncomment the following line.
 | |
| 
 | |
|   config.use :slugged
 | |
| 
 | |
|   # By default, FriendlyId's :slugged addon expects the slug column to be named
 | |
|   # 'slug', but you can change it if you wish.
 | |
|   #
 | |
|   # config.slug_column = 'slug'
 | |
|   #
 | |
|   # By default, slug has no size limit, but you can change it if you wish.
 | |
|   #
 | |
|   # config.slug_limit = 255
 | |
|   #
 | |
|   # When FriendlyId can not generate a unique ID from your base method, it appends
 | |
|   # a UUID, separated by a single dash. You can configure the character used as the
 | |
|   # separator. If you're upgrading from FriendlyId 4, you may wish to replace this
 | |
|   # with two dashes.
 | |
|   #
 | |
|   # config.sequence_separator = '-'
 | |
|   #
 | |
|   # Note that you must use the :slugged addon **prior** to the line which
 | |
|   # configures the sequence separator, or else FriendlyId will raise an undefined
 | |
|   # method error.
 | |
|   #
 | |
|   #  ## Tips and Tricks
 | |
|   #
 | |
|   #  ### Controlling when slugs are generated
 | |
|   #
 | |
|   # As of FriendlyId 5.0, new slugs are generated only when the slug field is
 | |
|   # nil, but if you're using a column as your base method can change this
 | |
|   # behavior by overriding the `should_generate_new_friendly_id?` method that
 | |
|   # FriendlyId adds to your model. The change below makes FriendlyId 5.0 behave
 | |
|   # more like 4.0.
 | |
|   # Note: Use(include) Slugged module in the config if using the anonymous module.
 | |
|   # If you have `friendly_id :name, use: slugged` in the model, Slugged module
 | |
|   # is included after the anonymous module defined in the initializer, so it
 | |
|   # overrides the `should_generate_new_friendly_id?` method from the anonymous module.
 | |
|   #
 | |
|   # config.use :slugged
 | |
|   # config.use Module.new {
 | |
|   #   def should_generate_new_friendly_id?
 | |
|   #     slug.blank? || <your_column_name_here>_changed?
 | |
|   #   end
 | |
|   # }
 | |
|   #
 | |
|   # FriendlyId uses Rails's `parameterize` method to generate slugs, but for
 | |
|   # languages that don't use the Roman alphabet, that's not usually sufficient.
 | |
|   # Here we use the Babosa library to transliterate Russian Cyrillic slugs to
 | |
|   # ASCII. If you use this, don't forget to add "babosa" to your Gemfile.
 | |
|   #
 | |
|   # config.use Module.new {
 | |
|   #   def normalize_friendly_id(text)
 | |
|   #     text.to_slug.normalize! :transliterations => [:russian, :latin]
 | |
|   #   end
 | |
|   # }
 | |
| end
 |