mix-rails 0.5.0 → 0.6.0
Sign up to get free protection for your applications and to get access to all the features.
- data/lib/mix-rails/all.rb +1 -1
- data/lib/mix-rails/version.rb +1 -1
- data/message-board/.gitignore +7 -0
- data/message-board/Gemfile +17 -0
- data/message-board/MIT-LICENSE +20 -0
- data/message-board/README.rdoc +3 -0
- data/message-board/Rakefile +27 -0
- data/message-board/app/assets/images/message-board/.gitkeep +0 -0
- data/message-board/app/assets/javascripts/message-board/.gitkeep +0 -0
- data/message-board/app/assets/stylesheets/message-board/.gitkeep +0 -0
- data/message-board/app/controllers/.gitkeep +0 -0
- data/message-board/app/controllers/admix/board_messages_controller.rb +17 -0
- data/message-board/app/controllers/admix/board_replies_controller.rb +21 -0
- data/message-board/app/controllers/admix/dashboard_controller.rb +7 -0
- data/message-board/app/controllers/board_messages_controller.rb +23 -0
- data/message-board/app/helpers/.gitkeep +0 -0
- data/message-board/app/mailers/.gitkeep +0 -0
- data/message-board/app/mailers/message_board_mailer.rb +10 -0
- data/message-board/app/models/.gitkeep +0 -0
- data/message-board/app/models/admix/board_messages_datagrid.rb +31 -0
- data/message-board/app/models/admix/board_replies_datagrid.rb +29 -0
- data/message-board/app/models/board_message.rb +29 -0
- data/message-board/app/models/board_reply.rb +28 -0
- data/message-board/app/views/.gitkeep +0 -0
- data/message-board/app/views/admix/board_messages/_form_fields.html.haml +5 -0
- data/message-board/app/views/admix/board_messages/_show.html.haml +11 -0
- data/message-board/app/views/admix/board_messages/_table_actions.html.haml +10 -0
- data/message-board/app/views/admix/board_replies/_form_fields.html.haml +5 -0
- data/message-board/app/views/admix/board_replies/_show.html.haml +11 -0
- data/message-board/app/views/admix/board_replies/_table_actions.html.haml +8 -0
- data/message-board/app/views/admix/dashboard/index.html.haml +4 -0
- data/message-board/app/views/board_messages/_board_message.html.haml +21 -0
- data/message-board/app/views/board_messages/index.html.haml +16 -0
- data/message-board/app/views/board_messages/show.html.haml +9 -0
- data/message-board/app/views/message_board_mailer/message_replied.text.erb +7 -0
- data/message-board/config/locales/message-board.pt-BR.yml +46 -0
- data/message-board/config/routes.rb +20 -0
- data/message-board/lib/message-board.rb +4 -0
- data/message-board/lib/message-board/engine.rb +19 -0
- data/message-board/lib/mix-rails-message-board.rb +1 -0
- data/message-board/lib/tasks/message-board_tasks.rake +4 -0
- data/message-board/mix-rails-message-board.gemspec +20 -0
- data/message-board/script/rails +8 -0
- data/message-board/spec/dummy/README.rdoc +261 -0
- data/message-board/spec/dummy/Rakefile +7 -0
- data/message-board/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/message-board/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/message-board/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/message-board/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/message-board/spec/dummy/app/mailers/.gitkeep +0 -0
- data/message-board/spec/dummy/app/models/.gitkeep +0 -0
- data/message-board/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/message-board/spec/dummy/config.ru +4 -0
- data/message-board/spec/dummy/config/application.rb +65 -0
- data/message-board/spec/dummy/config/boot.rb +10 -0
- data/message-board/spec/dummy/config/environment.rb +5 -0
- data/message-board/spec/dummy/config/environments/development.rb +31 -0
- data/message-board/spec/dummy/config/environments/production.rb +64 -0
- data/message-board/spec/dummy/config/environments/test.rb +35 -0
- data/message-board/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/message-board/spec/dummy/config/initializers/inflections.rb +15 -0
- data/message-board/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/message-board/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/message-board/spec/dummy/config/initializers/session_store.rb +8 -0
- data/message-board/spec/dummy/config/initializers/wrap_parameters.rb +10 -0
- data/message-board/spec/dummy/config/locales/en.yml +5 -0
- data/message-board/spec/dummy/config/routes.rb +58 -0
- data/message-board/spec/dummy/lib/assets/.gitkeep +0 -0
- data/message-board/spec/dummy/log/.gitkeep +0 -0
- data/message-board/spec/dummy/public/404.html +26 -0
- data/message-board/spec/dummy/public/422.html +26 -0
- data/message-board/spec/dummy/public/500.html +25 -0
- data/message-board/spec/dummy/public/favicon.ico +0 -0
- data/message-board/spec/dummy/script/rails +6 -0
- data/mix-rails.gemspec +5 -2
- data/videos/.gitignore +7 -0
- data/videos/Gemfile +19 -0
- data/videos/MIT-LICENSE +20 -0
- data/videos/README.rdoc +3 -0
- data/videos/Rakefile +27 -0
- data/videos/app/assets/images/videos/.gitkeep +0 -0
- data/videos/app/assets/javascripts/videos/.gitkeep +0 -0
- data/videos/app/assets/stylesheets/videos/.gitkeep +0 -0
- data/videos/app/controllers/admix/videos_controller.rb +5 -0
- data/videos/app/controllers/videos_controller.rb +11 -0
- data/videos/app/helpers/.gitkeep +0 -0
- data/videos/app/mailers/.gitkeep +0 -0
- data/videos/app/models/admix/videos_datagrid.rb +21 -0
- data/videos/app/models/video.rb +83 -0
- data/videos/app/views/.gitkeep +0 -0
- data/videos/app/views/admix/videos/_form_fields.html.haml +1 -0
- data/videos/app/views/admix/videos/_show.html.haml +20 -0
- data/videos/app/views/videos/_video.html.haml +12 -0
- data/videos/app/views/videos/_video_show.html.haml +14 -0
- data/videos/app/views/videos/index.html.haml +9 -0
- data/videos/app/views/videos/show.html.haml +3 -0
- data/videos/config/locales/videos.pt-BR.yml +8 -0
- data/videos/config/routes.rb +7 -0
- data/videos/lib/mix-rails-videos.rb +1 -0
- data/videos/lib/tasks/videos_tasks.rake +4 -0
- data/videos/lib/videos.rb +5 -0
- data/videos/lib/videos/engine.rb +19 -0
- data/videos/mix-rails-videos.gemspec +21 -0
- data/videos/script/rails +8 -0
- data/videos/spec/dummy/README.rdoc +261 -0
- data/videos/spec/dummy/Rakefile +7 -0
- data/videos/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/videos/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/videos/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/videos/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/videos/spec/dummy/app/mailers/.gitkeep +0 -0
- data/videos/spec/dummy/app/models/.gitkeep +0 -0
- data/videos/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/videos/spec/dummy/config.ru +4 -0
- data/videos/spec/dummy/config/application.rb +65 -0
- data/videos/spec/dummy/config/boot.rb +10 -0
- data/videos/spec/dummy/config/environment.rb +5 -0
- data/videos/spec/dummy/config/environments/development.rb +31 -0
- data/videos/spec/dummy/config/environments/production.rb +64 -0
- data/videos/spec/dummy/config/environments/test.rb +35 -0
- data/videos/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/videos/spec/dummy/config/initializers/inflections.rb +15 -0
- data/videos/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/videos/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/videos/spec/dummy/config/initializers/session_store.rb +8 -0
- data/videos/spec/dummy/config/initializers/wrap_parameters.rb +10 -0
- data/videos/spec/dummy/config/locales/en.yml +5 -0
- data/videos/spec/dummy/config/routes.rb +58 -0
- data/videos/spec/dummy/lib/assets/.gitkeep +0 -0
- data/videos/spec/dummy/log/.gitkeep +0 -0
- data/videos/spec/dummy/public/404.html +26 -0
- data/videos/spec/dummy/public/422.html +26 -0
- data/videos/spec/dummy/public/500.html +25 -0
- data/videos/spec/dummy/public/favicon.ico +0 -0
- data/videos/spec/dummy/script/rails +6 -0
- data/vouchers/.gitignore +7 -0
- data/vouchers/Gemfile +19 -0
- data/vouchers/MIT-LICENSE +20 -0
- data/vouchers/README.rdoc +3 -0
- data/vouchers/Rakefile +27 -0
- data/vouchers/app/assets/images/mix-vouchers/.gitkeep +0 -0
- data/vouchers/app/assets/javascripts/mix-vouchers/.gitkeep +0 -0
- data/vouchers/app/assets/stylesheets/mix-vouchers/.gitkeep +0 -0
- data/vouchers/app/controllers/admix/vouchers_controller.rb +24 -0
- data/vouchers/app/controllers/vouchers_controller.rb +68 -0
- data/vouchers/app/helpers/.gitkeep +0 -0
- data/vouchers/app/mailers/.gitkeep +0 -0
- data/vouchers/app/mailers/voucher_mailer.rb +10 -0
- data/vouchers/app/models/admix/vouchers_datagrid.rb +18 -0
- data/vouchers/app/models/email_validator.rb +9 -0
- data/vouchers/app/models/voucher.rb +22 -0
- data/vouchers/app/models/voucher_user.rb +48 -0
- data/vouchers/app/models/vouchers/contact.rb +17 -0
- data/vouchers/app/uploaders/vouchers/photo_uploader.rb +65 -0
- data/vouchers/app/views/.gitkeep +0 -0
- data/vouchers/app/views/admix/vouchers/_form_fields.html.haml +6 -0
- data/vouchers/app/views/admix/vouchers/_show.html.haml +9 -0
- data/vouchers/app/views/admix/vouchers/_table_actions.html.haml +9 -0
- data/vouchers/app/views/admix/vouchers/print.html.haml +27 -0
- data/vouchers/app/views/admix/vouchers/users.html.haml +31 -0
- data/vouchers/app/views/voucher_mailer/send_confirmation_link.text.erb +7 -0
- data/vouchers/app/views/vouchers/_voucher.html.haml +12 -0
- data/vouchers/app/views/vouchers/_voucher_show.html.haml +30 -0
- data/vouchers/app/views/vouchers/confirmation.html.haml +0 -0
- data/vouchers/app/views/vouchers/confirmation_error.html.haml +5 -0
- data/vouchers/app/views/vouchers/email_sent.html.haml +4 -0
- data/vouchers/app/views/vouchers/index.html.haml +9 -0
- data/vouchers/app/views/vouchers/print.html.haml +56 -0
- data/vouchers/app/views/vouchers/show.html.haml +3 -0
- data/vouchers/config/initializers/carrier_wave.rb +0 -0
- data/vouchers/config/locales/vouchers.pt-BR.yml +15 -0
- data/vouchers/config/routes.rb +15 -0
- data/vouchers/lib/mix-rails-vouchers.rb +5 -0
- data/vouchers/lib/mix-vouchers/engine.rb +21 -0
- data/vouchers/lib/tasks/mix-vouchers_tasks.rake +4 -0
- data/vouchers/mix-rails-vouchers.gemspec +21 -0
- data/vouchers/script/rails +8 -0
- data/vouchers/spec/dummy/README.rdoc +261 -0
- data/vouchers/spec/dummy/Rakefile +7 -0
- data/vouchers/spec/dummy/app/assets/javascripts/application.js +15 -0
- data/vouchers/spec/dummy/app/assets/stylesheets/application.css +13 -0
- data/vouchers/spec/dummy/app/controllers/application_controller.rb +3 -0
- data/vouchers/spec/dummy/app/helpers/application_helper.rb +2 -0
- data/vouchers/spec/dummy/app/mailers/.gitkeep +0 -0
- data/vouchers/spec/dummy/app/models/.gitkeep +0 -0
- data/vouchers/spec/dummy/app/views/layouts/application.html.erb +14 -0
- data/vouchers/spec/dummy/config.ru +4 -0
- data/vouchers/spec/dummy/config/application.rb +65 -0
- data/vouchers/spec/dummy/config/boot.rb +10 -0
- data/vouchers/spec/dummy/config/environment.rb +5 -0
- data/vouchers/spec/dummy/config/environments/development.rb +31 -0
- data/vouchers/spec/dummy/config/environments/production.rb +64 -0
- data/vouchers/spec/dummy/config/environments/test.rb +35 -0
- data/vouchers/spec/dummy/config/initializers/backtrace_silencers.rb +7 -0
- data/vouchers/spec/dummy/config/initializers/inflections.rb +15 -0
- data/vouchers/spec/dummy/config/initializers/mime_types.rb +5 -0
- data/vouchers/spec/dummy/config/initializers/secret_token.rb +7 -0
- data/vouchers/spec/dummy/config/initializers/session_store.rb +8 -0
- data/vouchers/spec/dummy/config/initializers/wrap_parameters.rb +10 -0
- data/vouchers/spec/dummy/config/locales/en.yml +5 -0
- data/vouchers/spec/dummy/config/routes.rb +58 -0
- data/vouchers/spec/dummy/lib/assets/.gitkeep +0 -0
- data/vouchers/spec/dummy/log/.gitkeep +0 -0
- data/vouchers/spec/dummy/public/404.html +26 -0
- data/vouchers/spec/dummy/public/422.html +26 -0
- data/vouchers/spec/dummy/public/500.html +25 -0
- data/vouchers/spec/dummy/public/favicon.ico +0 -0
- data/vouchers/spec/dummy/script/rails +6 -0
- data/vouchers/test/functional/voucher_mailer_test.rb +7 -0
- metadata +269 -15
data/lib/mix-rails/all.rb
CHANGED
data/lib/mix-rails/version.rb
CHANGED
@@ -0,0 +1,17 @@
|
|
1
|
+
source "http://rubygems.org"
|
2
|
+
|
3
|
+
# Declare your gem's dependencies in message-board.gemspec.
|
4
|
+
# Bundler will treat runtime dependencies like base dependencies, and
|
5
|
+
# development dependencies will be added by default to the :development group.
|
6
|
+
gemspec
|
7
|
+
|
8
|
+
# jquery-rails is used by the dummy application
|
9
|
+
gem "jquery-rails"
|
10
|
+
|
11
|
+
# Declare any dependencies that are still in development here instead of in
|
12
|
+
# your gemspec. These might include edge Rails or gems from your path or
|
13
|
+
# Git. Remember to move these dependencies to your gemspec before releasing
|
14
|
+
# your gem to rubygems.org.
|
15
|
+
|
16
|
+
# To use debugger
|
17
|
+
# gem 'debugger'
|
@@ -0,0 +1,20 @@
|
|
1
|
+
Copyright 2013 YOURNAME
|
2
|
+
|
3
|
+
Permission is hereby granted, free of charge, to any person obtaining
|
4
|
+
a copy of this software and associated documentation files (the
|
5
|
+
"Software"), to deal in the Software without restriction, including
|
6
|
+
without limitation the rights to use, copy, modify, merge, publish,
|
7
|
+
distribute, sublicense, and/or sell copies of the Software, and to
|
8
|
+
permit persons to whom the Software is furnished to do so, subject to
|
9
|
+
the following conditions:
|
10
|
+
|
11
|
+
The above copyright notice and this permission notice shall be
|
12
|
+
included in all copies or substantial portions of the Software.
|
13
|
+
|
14
|
+
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
|
15
|
+
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
|
16
|
+
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
|
17
|
+
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE
|
18
|
+
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION
|
19
|
+
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION
|
20
|
+
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
|
@@ -0,0 +1,27 @@
|
|
1
|
+
#!/usr/bin/env rake
|
2
|
+
begin
|
3
|
+
require 'bundler/setup'
|
4
|
+
rescue LoadError
|
5
|
+
puts 'You must `gem install bundler` and `bundle install` to run rake tasks'
|
6
|
+
end
|
7
|
+
begin
|
8
|
+
require 'rdoc/task'
|
9
|
+
rescue LoadError
|
10
|
+
require 'rdoc/rdoc'
|
11
|
+
require 'rake/rdoctask'
|
12
|
+
RDoc::Task = Rake::RDocTask
|
13
|
+
end
|
14
|
+
|
15
|
+
RDoc::Task.new(:rdoc) do |rdoc|
|
16
|
+
rdoc.rdoc_dir = 'rdoc'
|
17
|
+
rdoc.title = 'MessageBoard'
|
18
|
+
rdoc.options << '--line-numbers'
|
19
|
+
rdoc.rdoc_files.include('README.rdoc')
|
20
|
+
rdoc.rdoc_files.include('lib/**/*.rb')
|
21
|
+
end
|
22
|
+
|
23
|
+
|
24
|
+
|
25
|
+
|
26
|
+
Bundler::GemHelper.install_tasks
|
27
|
+
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
@@ -0,0 +1,17 @@
|
|
1
|
+
class Admix::BoardMessagesController < Admix::InheritedController
|
2
|
+
|
3
|
+
def approve
|
4
|
+
resource.approved = :approved
|
5
|
+
resource.save!
|
6
|
+
flash[:notice] = t('boardmessages.flashes.approved')
|
7
|
+
redirect_to collection_url
|
8
|
+
end
|
9
|
+
|
10
|
+
def disapprove
|
11
|
+
resource.approved = :disapproved
|
12
|
+
resource.save!
|
13
|
+
flash[:notice] = t('boardmessages.flashes.disapproved')
|
14
|
+
redirect_to collection_url
|
15
|
+
end
|
16
|
+
|
17
|
+
end
|
@@ -0,0 +1,21 @@
|
|
1
|
+
class Admix::BoardRepliesController < Admix::InheritedController
|
2
|
+
|
3
|
+
polymorphic_belongs_to :board_message, param: :board_message_id
|
4
|
+
|
5
|
+
after_filter :message_replied, only: [:create]
|
6
|
+
|
7
|
+
def message_replied
|
8
|
+
if resource.errors.empty?
|
9
|
+
MessageBoardMailer.message_replied(parent).deliver
|
10
|
+
end
|
11
|
+
end
|
12
|
+
|
13
|
+
def report
|
14
|
+
datagrid = @datagrid_class.new(params[:guess_datagrid_params])
|
15
|
+
datagrid.scope do
|
16
|
+
parent.board_replies
|
17
|
+
end
|
18
|
+
datagrid
|
19
|
+
end
|
20
|
+
|
21
|
+
end
|
@@ -0,0 +1,23 @@
|
|
1
|
+
class BoardMessagesController < ApplicationController
|
2
|
+
|
3
|
+
def index
|
4
|
+
@board_message = BoardMessage.new
|
5
|
+
@board_messages = BoardMessage.approved.paginate(:page => params[:page], :per_page => 12)
|
6
|
+
end
|
7
|
+
|
8
|
+
def create
|
9
|
+
@board_message = BoardMessage.new(params[:board_message])
|
10
|
+
if @board_message.save
|
11
|
+
flash[:notice] = t('message_board.flashes.success_wait_moderation')
|
12
|
+
redirect_to board_messages_path
|
13
|
+
else
|
14
|
+
@board_messages = BoardMessage.approved.paginate(:page => params[:page], :per_page => 12)
|
15
|
+
render 'index'
|
16
|
+
end
|
17
|
+
end
|
18
|
+
|
19
|
+
def show
|
20
|
+
@board_message = BoardMessage.find(params[:id])
|
21
|
+
end
|
22
|
+
|
23
|
+
end
|
File without changes
|
File without changes
|
File without changes
|
@@ -0,0 +1,31 @@
|
|
1
|
+
class Admix::BoardMessagesDatagrid
|
2
|
+
|
3
|
+
include Datagrid
|
4
|
+
extend AdmixHelper
|
5
|
+
|
6
|
+
scope do
|
7
|
+
BoardMessage.desc(:date)
|
8
|
+
end
|
9
|
+
|
10
|
+
filter :date do |value|
|
11
|
+
value.to_s(:created_at)
|
12
|
+
end
|
13
|
+
|
14
|
+
column :name, header: input_label(:board_message, :name)
|
15
|
+
column :email, header: input_label(:board_message, :email)
|
16
|
+
column :message, header: input_label(:board_message, :message)
|
17
|
+
column :date, header: input_label(:board_message, :date) do |board_message|
|
18
|
+
board_message.date.strftime("%d/%m/%Y")
|
19
|
+
end
|
20
|
+
|
21
|
+
column :replies_count, header: input_label(:board_message, :replies_count) do |board_message|
|
22
|
+
board_message.board_replies.count
|
23
|
+
end
|
24
|
+
|
25
|
+
column :approved, header: input_label(:board_message, :approved) do |board_message|
|
26
|
+
board_message.approved.text
|
27
|
+
end
|
28
|
+
|
29
|
+
include Admix::TableActions
|
30
|
+
|
31
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
class Admix::BoardRepliesDatagrid
|
2
|
+
|
3
|
+
include Datagrid
|
4
|
+
|
5
|
+
extend AdmixHelper
|
6
|
+
|
7
|
+
|
8
|
+
scope do
|
9
|
+
BoardReply
|
10
|
+
end
|
11
|
+
|
12
|
+
filter :date do |value|
|
13
|
+
value.to_s(:created_at)
|
14
|
+
end
|
15
|
+
|
16
|
+
column :name, header: input_label(:board_reply, :name)
|
17
|
+
column :email, header: input_label(:board_reply, :email)
|
18
|
+
column :message, header: input_label(:board_reply, :message)
|
19
|
+
column :date, header: input_label(:board_reply, :date) do |board_reply|
|
20
|
+
board_reply.date.strftime("%d/%m/%Y")
|
21
|
+
end
|
22
|
+
|
23
|
+
column :approved, header: input_label(:board_reply, :approved) do |board_reply|
|
24
|
+
board_reply.approved.text
|
25
|
+
end
|
26
|
+
|
27
|
+
include Admix::TableActions
|
28
|
+
|
29
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
class BoardMessage
|
2
|
+
|
3
|
+
include Mongoid::Document
|
4
|
+
include Mongoid::Timestamps
|
5
|
+
include Mongoid::Paranoia
|
6
|
+
|
7
|
+
extend Enumerize
|
8
|
+
|
9
|
+
field :name, type: String
|
10
|
+
field :email, type: String
|
11
|
+
field :message, type: String
|
12
|
+
field :date, type: DateTime, default: -> { Time.now }
|
13
|
+
field :approved, type: String
|
14
|
+
enumerize :approved, in: [:pending, :approved, :disapproved], default: :pending, predicates: true
|
15
|
+
|
16
|
+
|
17
|
+
validates_presence_of :name
|
18
|
+
validates_presence_of :email
|
19
|
+
validates_presence_of :message
|
20
|
+
validates_presence_of :date
|
21
|
+
|
22
|
+
validates :email, email: true
|
23
|
+
|
24
|
+
scope :approved, where(approved: :approved)
|
25
|
+
scope :pending, where(approved: :pending)
|
26
|
+
|
27
|
+
embeds_many :board_replies, cascade_callbacks: true
|
28
|
+
|
29
|
+
end
|
@@ -0,0 +1,28 @@
|
|
1
|
+
class BoardReply
|
2
|
+
|
3
|
+
include Mongoid::Document
|
4
|
+
include Mongoid::Timestamps
|
5
|
+
include Mongoid::Paranoia
|
6
|
+
|
7
|
+
extend Enumerize
|
8
|
+
|
9
|
+
field :name, type: String, default: -> { Setting.app_title }
|
10
|
+
field :email, type: String, default: -> { Setting.app_email }
|
11
|
+
field :message, type: String
|
12
|
+
field :date, type: DateTime, default: -> { Time.now }
|
13
|
+
field :approved, type: String
|
14
|
+
enumerize :approved, in: [:pending, :approved, :disapproved], default: :approved, predicates: true
|
15
|
+
|
16
|
+
|
17
|
+
validates_presence_of :name
|
18
|
+
validates_presence_of :email
|
19
|
+
validates_presence_of :date
|
20
|
+
|
21
|
+
validates :email, email: true
|
22
|
+
|
23
|
+
scope :approved, where(approved: :approved)
|
24
|
+
scope :pending, where(approved: :pending)
|
25
|
+
|
26
|
+
embedded_in :board_message
|
27
|
+
|
28
|
+
end
|
File without changes
|
@@ -0,0 +1,11 @@
|
|
1
|
+
%dl
|
2
|
+
%dt= input_label(:board_message, :name)
|
3
|
+
%dd= resource.name
|
4
|
+
%dt= input_label(:board_message, :email)
|
5
|
+
%dd= resource.email
|
6
|
+
%dt= input_label(:board_message, :message)
|
7
|
+
%dd= resource.message
|
8
|
+
%dt= input_label(:board_message, :date)
|
9
|
+
%dd= localize(resource.date)
|
10
|
+
%dt= input_label(:board_message, :approved)
|
11
|
+
%dd= resource.approved.text
|
@@ -0,0 +1,10 @@
|
|
1
|
+
- if resource.disapproved? or resource.approved.pending?
|
2
|
+
= link_to image_tag('admix/icons/shield_go.png'), approve_admix_board_message_path(resource), method: :put, data: { confirm: t('message_board.confirms.approve') }, class: 'btn', title:'Aprovar'
|
3
|
+
- if resource.approved.approved? or resource.approved.pending?
|
4
|
+
= link_to image_tag('admix/icons/shield_delete.png'), disapprove_admix_board_message_path(resource), method: :put,data: { confirm: t('message_board.confirms.disapprove') }, class: 'btn', title:'Reprovar'
|
5
|
+
|
6
|
+
= link_to image_tag('admix/icons/comment_add.png'), new_admix_board_message_board_reply_path(resource), class: 'btn', title:'Adicionar comentário'
|
7
|
+
|
8
|
+
= link_to image_tag('admix/zoom.png'), resource_url(resource), class: 'btn', title:'Visualizar registro'
|
9
|
+
= link_to image_tag('admix/page_edit.png'), edit_resource_url(resource), class: 'btn', title:'Editar registro'
|
10
|
+
= link_to image_tag('admix/cancel.png'), resource_url(resource), method: :delete, data: { confirm: t('admix.crud.destroy_confirm') }, class: 'btn', title:'Deletar registro'
|
@@ -0,0 +1,11 @@
|
|
1
|
+
%dl
|
2
|
+
%dt= input_label(:board_message, :name)
|
3
|
+
%dd= resource.name
|
4
|
+
%dt= input_label(:board_message, :email)
|
5
|
+
%dd= resource.email
|
6
|
+
%dt= input_label(:board_message, :message)
|
7
|
+
%dd= resource.message
|
8
|
+
%dt= input_label(:board_message, :date)
|
9
|
+
%dd= localize(resource.date)
|
10
|
+
%dt= input_label(:board_message, :approved)
|
11
|
+
%dd= resource.approved.text
|
@@ -0,0 +1,8 @@
|
|
1
|
+
- if resource.disapproved? or resource.approved.pending?
|
2
|
+
= link_to image_tag('admix/icons/shield_go.png'), approve_admix_board_message_path(resource), method: :put, data: { confirm: t('message_board.confirms.approve') }, class: 'btn', title:'Aprovar'
|
3
|
+
- if resource.approved.approved? or resource.approved.pending?
|
4
|
+
= link_to image_tag('admix/icons/shield_delete.png'), disapprove_admix_board_message_path(resource), method: :put,data: { confirm: t('message_board.confirms.disapprove') }, class: 'btn', title:'Reprovar'
|
5
|
+
|
6
|
+
= link_to image_tag('admix/zoom.png'), resource_url(resource), class: 'btn', title:'Visualizar registro'
|
7
|
+
= link_to image_tag('admix/page_edit.png'), edit_resource_url(resource), class: 'btn', title:'Editar registro'
|
8
|
+
= link_to image_tag('admix/cancel.png'), resource_url(resource), method: :delete, data: { confirm: t('admix.crud.destroy_confirm') }, class: 'btn', title:'Deletar registro'
|
@@ -0,0 +1,21 @@
|
|
1
|
+
%li
|
2
|
+
%p
|
3
|
+
%span.red= link_to board_message.name, board_message_path(board_message)
|
4
|
+
|
|
5
|
+
%small
|
6
|
+
%span.white= I18n.localize(board_message.date)
|
7
|
+
%p.muted.p.super= board_message.message
|
8
|
+
- if board_message.board_replies?
|
9
|
+
- board_message.board_replies.each do |r|
|
10
|
+
.pad.p
|
11
|
+
%span.yellow= r.name
|
12
|
+
%span :
|
13
|
+
= r.message
|
14
|
+
.p
|
15
|
+
.pull-left
|
16
|
+
%a.addthis_button_facebook_like{"addthis:url" => board_message_url(board_message),"fb:like:layout" => "button_count"}
|
17
|
+
.pull-left
|
18
|
+
%a.addthis_button_tweet{'tw:text' => "#{app_title}: #{@board_message.name}: #{@board_message.message} #{board_message_url(board_message)}"}
|
19
|
+
.pull-left
|
20
|
+
%a.addthis_button_google_plusone
|
21
|
+
.clearfix
|
@@ -0,0 +1,16 @@
|
|
1
|
+
- content_for(:board_messages_content) do
|
2
|
+
= simple_form_for @board_message do |f|
|
3
|
+
= f.error_notification
|
4
|
+
.row.p
|
5
|
+
.span8
|
6
|
+
.p= f.input :name, input_html: {class: 'span8'}
|
7
|
+
%div= f.input :email, input_html: {class: 'span8'}
|
8
|
+
.span8= f.input :message, as: 'text', input_html: {class: 'span8'}
|
9
|
+
.ta-r
|
10
|
+
%button.no-style{:type => "submit"}
|
11
|
+
= image_tag 'btn_enviar.png'
|
12
|
+
%hr.great-margin
|
13
|
+
%ul.list.sequential
|
14
|
+
= render @board_messages
|
15
|
+
= will_paginate @board_messages
|
16
|
+
= render template: 'templates/board_messages/index'
|
@@ -0,0 +1,9 @@
|
|
1
|
+
- content_for :metas do
|
2
|
+
%meta{property: "og:title", content: "Mural de recados do Forró com Turista"}
|
3
|
+
%meta{property: "og:type", content: "website"}
|
4
|
+
%meta{property: "og:image", content: asset_path('forrocomturista_logo.jpg')}
|
5
|
+
%meta{property: "og:description", content: "#{@board_message.name}: #{@board_message.message}" }
|
6
|
+
|
7
|
+
- content_for(:board_message_content) do
|
8
|
+
= render @board_message
|
9
|
+
= render template: 'templates/board_messages/show'
|