Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/infinum/phrasing
Edit phrases inline for your Ruby on Rails applications!
https://github.com/infinum/phrasing
open-source ruby
Last synced: 2 months ago
JSON representation
Edit phrases inline for your Ruby on Rails applications!
- Host: GitHub
- URL: https://github.com/infinum/phrasing
- Owner: infinum
- License: mit
- Created: 2013-07-18T08:57:51.000Z (over 11 years ago)
- Default Branch: master
- Last Pushed: 2021-12-23T08:21:55.000Z (about 3 years ago)
- Last Synced: 2024-11-19T21:38:27.355Z (2 months ago)
- Topics: open-source, ruby
- Language: Ruby
- Homepage: https://www.infinum.co/the-capsized-eight/articles/simple-ruby-on-rails-content-editing
- Size: 2.05 MB
- Stars: 545
- Watchers: 26
- Forks: 86
- Open Issues: 2
-
Metadata Files:
- Readme: README-3.md
- Changelog: CHANGELOG.md
- License: MIT-LICENSE
Awesome Lists containing this project
README
# Phrasing!
[![Build Status](https://travis-ci.org/infinum/phrasing.png)](https://travis-ci.org/infinum/phrasing)
![Phrasing](http://www.miataturbo.net/attachments/miata-parts-sale-trade-5/74257-lots-leftovers-near-boston-archer-phrasing2-300x225-jpg?dateline=1366600534)
Phrasing is a gem for live editing phrases (copy) on websites.
## Installation
Include the gem in your Gemfile
```ruby
gem "phrasing"
```Bundle the Gemfile
```ruby
bundle install
```Run the install script which will create a migration file and a config file.
```ruby
rake phrasing:install
```Migrate your database
```ruby
rake db:migrate
```## Setup
The rake task will also generate phrasing_helper.rb in your app/helpers folder. Here you will need to implement the can_edit_phrases? method. Use this to hook-up your existing user authentication system to work with Phrasing.
For example:
```ruby
module PhrasingHelperdef can_edit_phrases?
current_user.is_admin?
endend
```
Include the phrasing **html** initializer at the top of your application layout file.```haml
= render 'phrasing/initializer'
```Include the required **javascript** file:
```javascript
//= require phrasing
```Include the required **stylesheet** file:
```css
*= require phrasing
```## How to use phrasing?
You can start adding new phrases by simply adding them in your view file:
= phrase('my-first-phrase')
Aside from editing phrases (basically, Rails translations) you can also edit model attributes inline. Use the same `phrase` method, with the first attribute being the record in question, and the second one the attribute you wish to make editable:
= phrase(@post, :title)
In the above example, @post is the record with a title attribute.
## Security
Since Phrasing can be used to update any attribute in any table (using the model_phrase method), special care must be taken into consideration from a security standpoint.
By default, Phrasing doesn't allow updating of any attribute apart from PhrasingPhrase.value. To be able to work with other attributes, you need to whitelist them.
In the config/initializers/phrasing.rb file you can whitelist your model attributes like this:
```ruby
Phrasing.white_list = ["Post.title", "Post.body"]
```or you can whitelist all of them (not recommended) with:
```ruby
Phrasing.allow_update_on_all_models_and_attributes = true
```## Upgrading from version 2.x to 3.x
In versions 3.0.0 and above we have added the Phrasing Versioning System which requires an additional table, so if you are upgrading to a 3.x release, run rake phrasing:install to get the additional migration file, then run rake db:migrate.
## Turbolinks
If you're experiencing problems with Rails apps using Turbolinks, include the [jQuery-turbolinks](https://github.com/kossnocorp/jquery.turbolinks) gem in your application and simply require it in the following order:
```javascript
//= require jquery
//= require jquery.turbolinks
//= require phrasing
//= require turbolinks
```## Phrasing Appearance
The `phrase` view helper can take the `options` hash as the last parameter. Features:
```ruby
url: custom_url # point Phrasing to other actions in other controllers
inverse: true # change the hovered background and underline colors to better fit darker backgrounds
class: custom_class # add custom CSS classes to your phrases to change the appearance of phrases in your application
interpolation: { %min: 10 } # add variables to your translations just like w/ I18n
scope: 'homepage.footer' # add scopes just like you would w/ I18.n. If the first argument is 'test', than the key would be 'homepage.footer.test'
```## Credits
Phrasing is maintained and sponsored by
[Infinum] (http://www.infinum.co).![Infinum](https://www.infinum.co/assets/logo_pic-2e19713f50692ed9b0805b199676c19a.png)
Phrasing leverages parts of [Copycat](https://github.com/Zorros/copycat) and [ZenPen](https://github.com/tholman/zenpen/tree/master/).
## License
Phrasing is Copyright © 2013 Infinum. It is free software, and may be redistributed under the terms specified in the LICENSE file.