gritter_notices
<img src=“http://travis-ci.org/dapi/gritter_notices.png” />
Использует модуль gritter для отображения flash сообщеий, а также вводит механизм сохраняемых пользовательских сообщений (notice).
Удобно применять для отправки пользователю flash-сообщений из фоновых задач.
Визуально выглядит так: boedesign.com/demos/gritter/
Рабочий пример использования этого модуля: gritter-notices-example.heroku.com/
Модуль родился и активно используется в проекте planposter.com
Установка
Включаем модуль в Gemfile, незабываем затем сделать bundle install:
gem 'gritter_notices'
Копируем jQuery-плагин Gritter (github.com/jboesch/Gritter) в проект:
rake gritter:install
## Если хотим посылать персональные сообщения пользователям (помимо отображения flash)
Создаем таблицу ‘gritter_notices` где будут храниться сообщения:
rails g gritter_notices
rake db:migrate
Подключаем notices в модель user:
class User < ActiveRecord::Base
has_gritter_notices
...
Где-то в layout делаем так:
-
haml-пример:
%head = include_gritter %body = gflash # session сообщения добавляемые через gritter-овский gflash :success=>траляля = gritter_flash_messages # Все остальные сообщения добавляемые через вызовы типа flash[:success] или user.notice_*
-
erb-пример:
<head> <%= include_gritter %> ... <body> <%= gflash %> <%= gritter_flash_messages %>
Вместо ‘include_gritter` можно делать сразу `include_gritter_and_jquery` подробнее тут: github.com/RobinBrouwer/gritter
Использование
В расширяемую модель добавляются метод ‘notice`. Агрументы:
-
Текстовое сообщение (String) или ключ к строке локали (Symbol)
-
Хеш опций прозрачно сохраняемых в модели и используемые при подстановке в ‘I18n::translate`.
** В хеше опций пожно указать :scope для трансляции локали (по умолчанию ‘:gritter_notices`) и ** `:level` из поддерживаемых gritter-ом - [:success, :warning, :notice, :error, :progress], по умолчанию :notice ** :title ** :sticky ** другие опции понимаемые gritter-ом
Примеры использования:
user.notice 'Просто текстовое сообщение'
user.notice 'Текстовое сообщение', :level=>:notice
если в локали указать
ru:
gritter_notices:
import_contacts: Импортиорваны контакты (%{count})
то можно будет использовать ключ, вместо текстового сообщения:
user.notice :import_contacts, :count=>123
Для краткости можно :level указывать через подчеркивание после названия метода ‘notice`:
notice_success
notice_error
notice_warning
notice_progress
notice_notice # синоним просто `notice`
Также есть алиас gritter_notice со всеми вышеперечисленными типами сообщений.
Далее во вьюхе вызываем:
= gritter_flash_messages
который отображает и flash сообщения и накопвшиеся ‘notices`.
Дополнительно
Поддерживается ‘universal_flash_messages` и `flash-message-conductor`, тоесть сохранение во flash массивов сообщений, типа:
flash[:notice] = ['Сообщение1', 'Сообщение2']
О плагине jQuery Gritter - ruseller.com/adds.php?rub=11&id=2106 Также некоторая информация есть здесь: habrahabr.ru/blogs/ror/116754/
TODO
-
Удалять gritter_notice только после того как они закроются или их закроют
Контроллер gritter_notices с одной акцией delivered. Ставить ее запуск на onclose. Сделать настраиваемым текущее поведение:
1. notices помечаются доставленными когда показываются во view (контроллер не используется)
2. notices помечаются удаленными когда закрываются (сами или принудительно) onclose
3. обычные notices по методу 1, sticky notices по методу 2.
-
Показывать push-сообщения
-
Написать драйверы для других способов отображения (список ниже)
Другие способы отображения
-
КТО ЗНАЕТ ЕЩЕ ПРИМЕРЫ ??? Напишите пожалуйста мне.
Примеры:
* http://gritter-notices-example.heroku.com/
код: http://github.com/dapi/gritter_notices_example
* http://planposter.com/
Друзья, присылайте ссылки на ваши проекты использующие gritter_notices.
Нечто отдаленно подобное (альтернативы):
Вместо flash_conductor-а
https://github.com/mattpolito/flash--conductor
https://rubygems.org/gems/glennr-flash--conductor
https://github.com/QuBiT/
https://github.com/snitko/frontend_notifier
Пишут от gritter_notices
Credits
-
Robin Brouwer github.com/RobinBrouwer/gritter
-
Jordan Boesch boedesign.com/blog/2009/07/11/growl-for-jquery-gritter/
Contributing to gritter_notices
-
Check out the latest master to make sure the feature hasn’t been implemented or the bug hasn’t been fixed yet
-
Check out the issue tracker to make sure someone already hasn’t requested it and/or contributed it
-
Fork the project
-
Start a feature/bugfix branch
-
Commit and push until you are happy with your contribution
-
Make sure to add tests for it. This is important so I don’t break it in a future version unintentionally.
-
Please try not to mess with the Rakefile, version, or history. If you want to have your own version, or is otherwise necessary, that is fine, but please isolate to its own commit so I can cherry-pick around it.
Copyright
Copyright © 2011 Danil Pismenny. See LICENSE.txt for further details.