atreides 2.0.0
Sign up to get free protection for your applications and to get access to all the features.
- data/LICENSE +7 -0
- data/README.rdoc +1 -0
- data/app/assets/javascripts/atreides/admin.js +22 -0
- data/app/assets/javascripts/atreides/admin_base.js.erb +247 -0
- data/app/assets/javascripts/atreides/admin_edit.js +9 -0
- data/app/assets/javascripts/atreides/application.js +15 -0
- data/app/assets/javascripts/atreides/comments.coffee +50 -0
- data/app/assets/javascripts/atreides/public.js +24 -0
- data/app/assets/javascripts/atreides/public_base.js.erb +119 -0
- data/app/assets/javascripts/atreides/terryblr.js +57 -0
- data/app/assets/stylesheets/atreides/admin.css +21 -0
- data/app/assets/stylesheets/atreides/admin_base.css.erb +1762 -0
- data/app/assets/stylesheets/atreides/application.css +13 -0
- data/app/assets/stylesheets/atreides/formtastic_changes.css +10 -0
- data/app/assets/stylesheets/atreides/iphone-checkboxes.css.erb +97 -0
- data/app/assets/stylesheets/atreides/jBreadCrumb.css +109 -0
- data/app/assets/stylesheets/atreides/public.css +15 -0
- data/app/assets/stylesheets/atreides/public_base.css +101 -0
- data/app/assets/stylesheets/atreides/swfupload.css.erb +63 -0
- data/app/controllers/admin/atreides/comments_controller.rb +47 -0
- data/app/controllers/admin/atreides/content_parts_controller.rb +43 -0
- data/app/controllers/admin/atreides/dropbox_controller.rb +40 -0
- data/app/controllers/admin/atreides/features_controller.rb +63 -0
- data/app/controllers/admin/atreides/github_controller.rb +35 -0
- data/app/controllers/admin/atreides/links_controller.rb +3 -0
- data/app/controllers/admin/atreides/messages_controller.rb +3 -0
- data/app/controllers/admin/atreides/orders_controller.rb +35 -0
- data/app/controllers/admin/atreides/pages_controller.rb +59 -0
- data/app/controllers/admin/atreides/photos_controller.rb +79 -0
- data/app/controllers/admin/atreides/posts_controller.rb +109 -0
- data/app/controllers/admin/atreides/products_controller.rb +39 -0
- data/app/controllers/admin/atreides/sessions_controller.rb +7 -0
- data/app/controllers/admin/atreides/sizes_controller.rb +4 -0
- data/app/controllers/admin/atreides/tags_controller.rb +20 -0
- data/app/controllers/admin/atreides/users_controller.rb +50 -0
- data/app/controllers/admin/atreides/videos_controller.rb +53 -0
- data/app/controllers/atreides/admin_controller.rb +96 -0
- data/app/controllers/atreides/admin_home_controller.rb +211 -0
- data/app/controllers/atreides/application_controller.rb +93 -0
- data/app/controllers/atreides/comments_controller.rb +43 -0
- data/app/controllers/atreides/home_controller.rb +71 -0
- data/app/controllers/atreides/likes_controller.rb +44 -0
- data/app/controllers/atreides/pages_controller.rb +34 -0
- data/app/controllers/atreides/posts_controller.rb +119 -0
- data/app/controllers/atreides/public_controller.rb +43 -0
- data/app/helpers/admin/atreides/comments_helper.rb +8 -0
- data/app/helpers/admin/atreides/dropbox_helper.rb +42 -0
- data/app/helpers/admin/atreides/features_helper.rb +4 -0
- data/app/helpers/admin/atreides/github_helper.rb +43 -0
- data/app/helpers/admin/atreides/links_helper.rb +4 -0
- data/app/helpers/admin/atreides/messages_helper.rb +4 -0
- data/app/helpers/admin/atreides/orders_helper.rb +30 -0
- data/app/helpers/admin/atreides/pages_helper.rb +17 -0
- data/app/helpers/admin/atreides/photos_helper.rb +14 -0
- data/app/helpers/admin/atreides/posts_helper.rb +41 -0
- data/app/helpers/admin/atreides/products_helper.rb +37 -0
- data/app/helpers/admin/atreides/sizes_helper.rb +4 -0
- data/app/helpers/admin/atreides/user_sessions_helper.rb +4 -0
- data/app/helpers/admin/atreides/users_helper.rb +8 -0
- data/app/helpers/admin/atreides/videos_helper.rb +4 -0
- data/app/helpers/atreides/admin_helper.rb +243 -0
- data/app/helpers/atreides/admin_home_helper.rb +4 -0
- data/app/helpers/atreides/application_helper.rb +210 -0
- data/app/helpers/atreides/home_helper.rb +4 -0
- data/app/helpers/atreides/posts_helper.rb +119 -0
- data/app/inputs/files_input.rb +13 -0
- data/app/inputs/price_input.rb +18 -0
- data/app/inputs/underline_input.rb +16 -0
- data/app/models/atreides/ability.rb +24 -0
- data/app/models/atreides/comment.rb +93 -0
- data/app/models/atreides/content_part.rb +107 -0
- data/app/models/atreides/feature.rb +90 -0
- data/app/models/atreides/github.rb +74 -0
- data/app/models/atreides/like.rb +35 -0
- data/app/models/atreides/line_item.rb +4 -0
- data/app/models/atreides/link.rb +32 -0
- data/app/models/atreides/message.rb +34 -0
- data/app/models/atreides/order.rb +209 -0
- data/app/models/atreides/page.rb +114 -0
- data/app/models/atreides/photo.rb +130 -0
- data/app/models/atreides/post.rb +271 -0
- data/app/models/atreides/product.rb +75 -0
- data/app/models/atreides/site.rb +59 -0
- data/app/models/atreides/size.rb +44 -0
- data/app/models/atreides/tag.rb +31 -0
- data/app/models/atreides/tweet.rb +123 -0
- data/app/models/atreides/user.rb +129 -0
- data/app/models/atreides/video.rb +206 -0
- data/app/models/atreides/vote.rb +43 -0
- data/app/models/fb_post_publisher_job.rb +72 -0
- data/app/models/settings.rb +19 -0
- data/app/models/tumblr_post_publisher_job.rb +75 -0
- data/app/models/tw_post_publisher_job.rb +54 -0
- data/app/views/admin/_edit_head_content.html.haml +2 -0
- data/app/views/admin/atreides/comments/_line.html.haml +60 -0
- data/app/views/admin/atreides/comments/_sidebar.html.haml +52 -0
- data/app/views/admin/atreides/comments/create.js.haml +1 -0
- data/app/views/admin/atreides/comments/index.html.haml +34 -0
- data/app/views/admin/atreides/content_parts/_form.html.haml +21 -0
- data/app/views/admin/atreides/content_parts/_photos.html.haml +18 -0
- data/app/views/admin/atreides/content_parts/_text.html.haml +1 -0
- data/app/views/admin/atreides/content_parts/_videos.html.haml +12 -0
- data/app/views/admin/atreides/content_parts/destroy.js.haml +3 -0
- data/app/views/admin/atreides/content_parts/edit.html.haml +0 -0
- data/app/views/admin/atreides/content_parts/new.html.haml +0 -0
- data/app/views/admin/atreides/content_parts/new.js.haml +11 -0
- data/app/views/admin/atreides/dropbox/_uploader.html.haml +134 -0
- data/app/views/admin/atreides/dropbox/list.html.haml +27 -0
- data/app/views/admin/atreides/dropbox/setup.html.haml +8 -0
- data/app/views/admin/atreides/features/_form.html.haml +60 -0
- data/app/views/admin/atreides/features/edit.html.haml +1 -0
- data/app/views/admin/atreides/features/index.html.haml +24 -0
- data/app/views/admin/atreides/features/new.html.haml +1 -0
- data/app/views/admin/atreides/github/index.html.haml +26 -0
- data/app/views/admin/atreides/github/show.html.haml +19 -0
- data/app/views/admin/atreides/likes/create.js.haml +2 -0
- data/app/views/admin/atreides/orders/_sidebar.html.haml +20 -0
- data/app/views/admin/atreides/orders/edit.html.haml +52 -0
- data/app/views/admin/atreides/orders/index.html.haml +8 -0
- data/app/views/admin/atreides/pages/_form.html.haml +31 -0
- data/app/views/admin/atreides/pages/edit.html.haml +3 -0
- data/app/views/admin/atreides/pages/index.html.haml +15 -0
- data/app/views/admin/atreides/pages/index.js.haml +4 -0
- data/app/views/admin/atreides/pages/new.html.haml +2 -0
- data/app/views/admin/atreides/photos/create.js.haml +18 -0
- data/app/views/admin/atreides/photos/destroy.js.haml +3 -0
- data/app/views/admin/atreides/posts/_archives.html.haml +19 -0
- data/app/views/admin/atreides/posts/_form.html.haml +66 -0
- data/app/views/admin/atreides/posts/_form_buttons.html.haml +9 -0
- data/app/views/admin/atreides/posts/_form_sidebar.html.haml +85 -0
- data/app/views/admin/atreides/posts/edit.html.haml +2 -0
- data/app/views/admin/atreides/posts/index.html.haml +24 -0
- data/app/views/admin/atreides/posts/index.js.haml +1 -0
- data/app/views/admin/atreides/posts/new.html.haml +2 -0
- data/app/views/admin/atreides/products/edit.html.haml +69 -0
- data/app/views/admin/atreides/products/index.html.haml +31 -0
- data/app/views/admin/atreides/sessions/new.html.haml +13 -0
- data/app/views/admin/atreides/user_sessions/new.html.haml +10 -0
- data/app/views/admin/atreides/users/_form.html.haml +19 -0
- data/app/views/admin/atreides/users/edit.html.haml +6 -0
- data/app/views/admin/atreides/users/index.html.haml +11 -0
- data/app/views/admin/atreides/users/new.html.haml +6 -0
- data/app/views/admin/atreides/users/show.html.haml +4 -0
- data/app/views/admin/atreides/videos/create.js.haml +9 -0
- data/app/views/admin/atreides/videos/destroy.js.haml +3 -0
- data/app/views/admin/common/_archive_sidebar.html.haml +29 -0
- data/app/views/admin/common/_list_table.html.erb +37 -0
- data/app/views/admin/common/_list_table_row.html.erb +18 -0
- data/app/views/admin/common/_pagination.html.erb +1 -0
- data/app/views/admin/common/_search_form.html.erb +6 -0
- data/app/views/admin/common/access_denied.html.haml +1 -0
- data/app/views/atreides/admin/_content_nav.html.haml +8 -0
- data/app/views/atreides/admin_home/_analytics.html.haml +93 -0
- data/app/views/atreides/admin_home/_fb_page_likes_analytics_tbody.haml +10 -0
- data/app/views/atreides/admin_home/_fb_page_views_analytics_tbody.haml +10 -0
- data/app/views/atreides/admin_home/_top_landing_pages_analytics_tbody.haml +14 -0
- data/app/views/atreides/admin_home/_top_referrers_analytics_tbody.haml +12 -0
- data/app/views/atreides/admin_home/_tweets_analytics_tbody.html.haml +8 -0
- data/app/views/atreides/admin_home/_visitors_analytics_tbody.html.haml +12 -0
- data/app/views/atreides/admin_home/index.html.haml +57 -0
- data/app/views/atreides/admin_home/search.html.haml +11 -0
- data/app/views/atreides/admin_home/setup.html.haml +15 -0
- data/app/views/atreides/common/_gallery_params.xml.erb +174 -0
- data/app/views/atreides/common/slideshow.xml.haml +6 -0
- data/app/views/atreides/errors/404.html.haml +10 -0
- data/app/views/atreides/errors/500.html.haml +4 -0
- data/app/views/atreides/home/index.html.haml +30 -0
- data/app/views/atreides/home/index.js.haml +1 -0
- data/app/views/atreides/home/robots.txt.erb +5 -0
- data/app/views/atreides/home/sitemap.xml.builder +35 -0
- data/app/views/atreides/pages/show.html.haml +3 -0
- data/app/views/atreides/posts/_archives.html.haml +19 -0
- data/app/views/atreides/posts/_featured_posts.html.haml +10 -0
- data/app/views/atreides/posts/_list.html.haml +9 -0
- data/app/views/atreides/posts/archives.html.haml +3 -0
- data/app/views/atreides/posts/archives.js.haml +1 -0
- data/app/views/atreides/posts/gallery_params.xml.haml +1 -0
- data/app/views/atreides/posts/index.atom.builder +22 -0
- data/app/views/atreides/posts/index.html.haml +13 -0
- data/app/views/atreides/posts/index.rss.builder +21 -0
- data/app/views/atreides/posts/show.html.haml +23 -0
- data/app/views/atreides/posts/tagged.html.haml +4 -0
- data/app/views/atreides/posts/tagged.js.haml +1 -0
- data/app/views/layouts/admin.html.haml +62 -0
- data/app/views/layouts/application.html.haml +37 -0
- data/app/views/layouts/atreides/application.html.erb +14 -0
- data/app/views/layouts/public.html.haml +39 -0
- data/config/cucumber.yml +11 -0
- data/config/locales/en.yml +236 -0
- data/config/locales/fr.yml +199 -0
- data/config/routes.rb +119 -0
- data/lib/assets/images/atreides/admin/add.png +0 -0
- data/lib/assets/images/atreides/admin/add_btn.png +0 -0
- data/lib/assets/images/atreides/admin/add_dashboard.png +0 -0
- data/lib/assets/images/atreides/admin/add_photo_button_sprite.png +0 -0
- data/lib/assets/images/atreides/admin/add_photos_btn.png +0 -0
- data/lib/assets/images/atreides/admin/background.png +0 -0
- data/lib/assets/images/atreides/admin/calendar.png +0 -0
- data/lib/assets/images/atreides/admin/chevron.gif +0 -0
- data/lib/assets/images/atreides/admin/chevron_overlay.png +0 -0
- data/lib/assets/images/atreides/admin/choose_photos_button_sprite.png +0 -0
- data/lib/assets/images/atreides/admin/content_bg.png +0 -0
- data/lib/assets/images/atreides/admin/content_bg_edit_form.png +0 -0
- data/lib/assets/images/atreides/admin/content_part_break.png +0 -0
- data/lib/assets/images/atreides/admin/content_part_drop_target.png +0 -0
- data/lib/assets/images/atreides/admin/content_part_icons.png +0 -0
- data/lib/assets/images/atreides/admin/content_part_photos.png +0 -0
- data/lib/assets/images/atreides/admin/content_part_text.png +0 -0
- data/lib/assets/images/atreides/admin/content_part_videos.png +0 -0
- data/lib/assets/images/atreides/admin/content_top_edit_form.png +0 -0
- data/lib/assets/images/atreides/admin/dashboard-indicator.gif +0 -0
- data/lib/assets/images/atreides/admin/dashboard_controls_activity.png +0 -0
- data/lib/assets/images/atreides/admin/dashboard_controls_customize.png +0 -0
- data/lib/assets/images/atreides/admin/dashboard_controls_drafts.png +0 -0
- data/lib/assets/images/atreides/admin/dashboard_controls_open.png +0 -0
- data/lib/assets/images/atreides/admin/dashboard_controls_posts.png +0 -0
- data/lib/assets/images/atreides/admin/dashboard_controls_queue.png +0 -0
- data/lib/assets/images/atreides/admin/dashboard_nav_border.png +0 -0
- data/lib/assets/images/atreides/admin/delete_bg.png +0 -0
- data/lib/assets/images/atreides/admin/down_arrow.png +0 -0
- data/lib/assets/images/atreides/admin/dropbox_big.jpg +0 -0
- data/lib/assets/images/atreides/admin/dropbox_btn.png +0 -0
- data/lib/assets/images/atreides/admin/dropbox_folder.png +0 -0
- data/lib/assets/images/atreides/admin/dropbox_icon.gif +0 -0
- data/lib/assets/images/atreides/admin/dropbox_icon.png +0 -0
- data/lib/assets/images/atreides/admin/expand_collapse.png +0 -0
- data/lib/assets/images/atreides/admin/form_sidebar_divider.png +0 -0
- data/lib/assets/images/atreides/admin/grey_hatch_bg.png +0 -0
- data/lib/assets/images/atreides/admin/header.png +0 -0
- data/lib/assets/images/atreides/admin/icon_dropbox.gif +0 -0
- data/lib/assets/images/atreides/admin/icon_home.gif +0 -0
- data/lib/assets/images/atreides/admin/input_bg.gif +0 -0
- data/lib/assets/images/atreides/admin/large_loading.gif +0 -0
- data/lib/assets/images/atreides/admin/new_content_icons.png +0 -0
- data/lib/assets/images/atreides/admin/off.png +0 -0
- data/lib/assets/images/atreides/admin/on.png +0 -0
- data/lib/assets/images/atreides/admin/page_icon.png +0 -0
- data/lib/assets/images/atreides/admin/permalink.png +0 -0
- data/lib/assets/images/atreides/admin/photos-display-type-gallery.png +0 -0
- data/lib/assets/images/atreides/admin/photos-display-type-photos.png +0 -0
- data/lib/assets/images/atreides/admin/product.png +0 -0
- data/lib/assets/images/atreides/admin/remove.png +0 -0
- data/lib/assets/images/atreides/admin/resize.png +0 -0
- data/lib/assets/images/atreides/admin/save_btn.png +0 -0
- data/lib/assets/images/atreides/admin/search_icon.png +0 -0
- data/lib/assets/images/atreides/admin/select_arrows.png +0 -0
- data/lib/assets/images/atreides/admin/slider.png +0 -0
- data/lib/assets/images/atreides/admin/slider_center.png +0 -0
- data/lib/assets/images/atreides/admin/slider_left.png +0 -0
- data/lib/assets/images/atreides/admin/slider_right.png +0 -0
- data/lib/assets/images/atreides/admin/sprite.png +0 -0
- data/lib/assets/images/atreides/admin/upload_btn.png +0 -0
- data/lib/assets/images/atreides/admin/video_bg.png +0 -0
- data/lib/assets/images/atreides/blank.gif +0 -0
- data/lib/assets/images/atreides/closelabel.png +0 -0
- data/lib/assets/images/atreides/loading.gif +0 -0
- data/lib/assets/images/atreides/sprite.png +0 -0
- data/lib/assets/images/atreides/tipsy.gif +0 -0
- data/lib/atreides.rb +82 -0
- data/lib/atreides/base/aasmstates.rb +117 -0
- data/lib/atreides/base/base.rb +40 -0
- data/lib/atreides/base/taggable.rb +43 -0
- data/lib/atreides/base/validation.rb +23 -0
- data/lib/atreides/configuration.rb +61 -0
- data/lib/atreides/engine.rb +41 -0
- data/lib/atreides/extendable.rb +12 -0
- data/lib/atreides/i18n_helpers.rb +65 -0
- data/lib/atreides/railties/tasks.rake +68 -0
- data/lib/atreides/time_formats.rb +19 -0
- data/lib/atreides/validators.rb +15 -0
- data/lib/atreides/version.rb +4 -0
- data/lib/generators/atreides/USAGE +0 -0
- data/lib/generators/atreides/atreides_generator.rb +58 -0
- data/lib/generators/templates/Procfile +2 -0
- data/lib/generators/templates/add_role_to_users.rb +16 -0
- data/lib/generators/templates/add_userid_to_resources.rb +15 -0
- data/lib/generators/templates/create_comments.rb +19 -0
- data/lib/generators/templates/create_content_parts.rb +66 -0
- data/lib/generators/templates/create_features.rb +21 -0
- data/lib/generators/templates/create_likes.rb +16 -0
- data/lib/generators/templates/create_line_items.rb +21 -0
- data/lib/generators/templates/create_links.rb +16 -0
- data/lib/generators/templates/create_messages.rb +24 -0
- data/lib/generators/templates/create_orders.rb +31 -0
- data/lib/generators/templates/create_pages.rb +31 -0
- data/lib/generators/templates/create_photos.rb +22 -0
- data/lib/generators/templates/create_posts.rb +38 -0
- data/lib/generators/templates/create_products.rb +24 -0
- data/lib/generators/templates/create_sessions.rb +16 -0
- data/lib/generators/templates/create_sites.rb +35 -0
- data/lib/generators/templates/create_sizes.rb +16 -0
- data/lib/generators/templates/create_tweets.rb +25 -0
- data/lib/generators/templates/create_videos.rb +24 -0
- data/lib/generators/templates/create_votes.rb +20 -0
- data/lib/generators/templates/delayed_job.rb +5 -0
- data/lib/generators/templates/devise_create_users.rb +42 -0
- data/lib/generators/templates/disqussion.rb +30 -0
- data/lib/generators/templates/em-net-http_override.rb +74 -0
- data/lib/generators/templates/initializer.rb +21 -0
- data/lib/generators/templates/new_relic.rb +6 -0
- data/lib/generators/templates/oembed.yml +63 -0
- data/lib/generators/templates/settings.yml +110 -0
- data/lib/generators/templates/string_extensions.rb +20 -0
- data/lib/generators/templates/unicorn.rb +2 -0
- data/lib/tasks/atreides_tasks.rake +4 -0
- data/lib/tasks/cucumber.rake +58 -0
- data/lib/tasks/tasks.rake +403 -0
- data/lib/tasks/yard.rake +18 -0
- metadata +1458 -0
@@ -0,0 +1,60 @@
|
|
1
|
+
.comment.span-17{:id => "comment-#{comment.id}", :class => "#{'approved' if comment.isApproved}"}
|
2
|
+
%label.span-1.comment-select.approved{:for => "check-#{comment.id}"}
|
3
|
+
= check_box_tag "", nil, false, :id => "check-#{comment.id}"
|
4
|
+
= hidden_field_tag "", comment.id
|
5
|
+
/ Excerpt block. This is shown by default and hidden when the parent is given the class "expanded"
|
6
|
+
.comment-excerpt-block.span-16.last
|
7
|
+
.comment-avatar
|
8
|
+
= image_tag comment.author.avatar.cache, :class => "comment-avatar", :size => "32x32"
|
9
|
+
.comment-excerpt
|
10
|
+
%p
|
11
|
+
%span.comment-name
|
12
|
+
= comment.author.name
|
13
|
+
%span
|
14
|
+
= "(#{comment.author.email}):" unless comment.author.email.blank?
|
15
|
+
%span.comment-body= comment.raw_message
|
16
|
+
.comment-time
|
17
|
+
Posted
|
18
|
+
= distance_of_time_in_words seconds_from_now(Time.parse(comment.createdAt))
|
19
|
+
ago.
|
20
|
+
.clear
|
21
|
+
/ End excerpt block
|
22
|
+
/ hidden by default, shown by javascript when expanded.
|
23
|
+
.comment-header{:style => "display:none"}
|
24
|
+
.comment-user
|
25
|
+
%a{:href => "#", :rel => "userlist"}
|
26
|
+
= image_tag comment.author.avatar.cache, :class => "comment-avatar", :size => "32x32"
|
27
|
+
.comment-name
|
28
|
+
= link_to comment.author.name, comment.author.url, :class => "profile-launcher", "data-profile-username" => comment.author.username, :target => "_blank"
|
29
|
+
%span
|
30
|
+
!= "(#{mail_to(comment.author.email)})" unless comment.author.email.blank?
|
31
|
+
/ %small
|
32
|
+
/ = link_to "#{comment.ipAddress}.", "?query=ip:#{comment.ipAddress}"
|
33
|
+
/ = link_to comment.author.url, comment.author.url, :target => "_blank"
|
34
|
+
.comment-time
|
35
|
+
Posted
|
36
|
+
= distance_of_time_in_words seconds_from_now(Time.parse(comment.createdAt))
|
37
|
+
ago.
|
38
|
+
.clear
|
39
|
+
/ hidden by default, shown by javascript when expanded.
|
40
|
+
.comment-body{:style => "display:none"}
|
41
|
+
.content
|
42
|
+
.content-wrapper
|
43
|
+
%p= comment.raw_message
|
44
|
+
.media
|
45
|
+
/ hidden by default, shown by javascript when expanded.
|
46
|
+
.comment-footer.clear
|
47
|
+
.comment-actions-left.span-12.prepend-1
|
48
|
+
= ttc(".see_also")
|
49
|
+
\:
|
50
|
+
= link_to comment.author.email, "?query=email:#{comment.author.email}"
|
51
|
+
= link_to comment.ipAddress, "?query=ip:#{comment.ipAddress}"
|
52
|
+
= link_to tt(".this thread"), "?query=thread:#{comment.thread}"
|
53
|
+
|
54
|
+
.comment-actions-left.span-4.last
|
55
|
+
= ttc ".this comment is"
|
56
|
+
%span.txt-approved= comment.isApproved ? tt('.approved') : tt('.not yet approved')
|
57
|
+
%a.add-userlist.blacklist{:href => "#", :style => "display: none; "}
|
58
|
+
= ttc ".add commenter to", :list => content_tag(:strong, "Blacklist")
|
59
|
+
%a.add-userlist.whitelist{:href => "#", :style => "display: none; "}
|
60
|
+
= ttc ".add commenter to", :list => content_tag(:strong, "Whitelist")
|
@@ -0,0 +1,52 @@
|
|
1
|
+
- content_for :sidebar do
|
2
|
+
#filters.comments-panel-wrapper
|
3
|
+
%ul.summary
|
4
|
+
%li.new-content
|
5
|
+
= link_to "Disqus.com", "http://#{Settings.disqus.forum}.disqus.com/admin/moderate/"
|
6
|
+
|
7
|
+
%li.divider
|
8
|
+
%li
|
9
|
+
%h3= ttt '.filter'
|
10
|
+
= form_tag '', :method => :get, :id => "filter-list", :class => 'formtastic' do
|
11
|
+
%ul
|
12
|
+
%li.machine_tag
|
13
|
+
%label#filter-approved{:for => "show_approved"}
|
14
|
+
/ Filter's default to "approved"
|
15
|
+
- if !params.has_key?(:filter) || params.has_key?(:filter) && params[:filter].include?("approved")
|
16
|
+
%input#show_approved{:checked => "checked", :type => "checkbox", :name => "filter[]", :value => "approved"}/
|
17
|
+
- else
|
18
|
+
%input#show_approved{:type => "checkbox", :name => "filter[]", :value => "approved"}/
|
19
|
+
= ttt ".approved"
|
20
|
+
|
21
|
+
%li.machine_tag
|
22
|
+
%label#filter-unapproved{:for => "show_unapproved"}
|
23
|
+
- if params.has_key?(:filter) && params[:filter].include?("unapproved")
|
24
|
+
%input#show_unapproved{:checked => "checked", :type => "checkbox", :name => "filter[]", :value => "unapproved"}/
|
25
|
+
- else
|
26
|
+
%input#show_unapproved{:type => "checkbox", :name => "filter[]", :value => "unapproved"}/
|
27
|
+
= ttt ".unapproved"
|
28
|
+
%li.machine_tag
|
29
|
+
%label#filter-flagged{:for => "show_flagged"}
|
30
|
+
- if params.has_key?(:filter) && params[:filter].include?("flagged")
|
31
|
+
%input#show_flagged{:checked => "checked", :type => "checkbox", :name => "filter[]", :value => "flagged"}/
|
32
|
+
- else
|
33
|
+
%input#show_flagged{:type => "checkbox", :name => "filter[]", :value => "flagged"}/
|
34
|
+
= ttt ".flagged"
|
35
|
+
%li.machine_tag
|
36
|
+
%label#filter-spam.hidden{:for => "show_spam"}
|
37
|
+
- if params.has_key?(:filter) && params[:filter].include?("spam")
|
38
|
+
%input#show_spam{:checked => "checked", :type => "checkbox", :type => "checkbox", :name => "filter[]", :value => "spam"}/
|
39
|
+
- else
|
40
|
+
%input#show_spam{:type => "checkbox", :type => "checkbox", :name => "filter[]", :value => "spam"}/
|
41
|
+
= ttt ".spam"
|
42
|
+
%li.machine_tag
|
43
|
+
%label#filter-deleted.hidden{:for => "show_deleted"}
|
44
|
+
- if params.has_key?(:filter) && params[:filter].include?("deleted")
|
45
|
+
%input#show_spam{:checked => "checked", :type => "checkbox", :type => "checkbox", :name => "filter[]", :value => "deleted"}/
|
46
|
+
- else
|
47
|
+
%input#show_spam{:type => "checkbox", :type => "checkbox", :name => "filter[]", :value => "deleted"}/
|
48
|
+
= ttt ".deleted"
|
49
|
+
%li.machine_tag
|
50
|
+
%label#filter-button.hidden{:for => "submit_button", :style => "display:none"}
|
51
|
+
%input#submit_button{:type => "submit"}
|
52
|
+
= ttt ".submit"
|
@@ -0,0 +1 @@
|
|
1
|
+
$("##{parent_object.dom_id('comments')}").html("#{escape_javascript(comment_item(resource))}")
|
@@ -0,0 +1,34 @@
|
|
1
|
+
= render :partial => 'sidebar'
|
2
|
+
|
3
|
+
%h2 #{ttt :'.comments'}
|
4
|
+
|
5
|
+
.clear
|
6
|
+
|
7
|
+
#comments_list
|
8
|
+
- @collection.response.each do |comment|
|
9
|
+
= render :partial => 'line', :locals => { :comment => comment}
|
10
|
+
|
11
|
+
.clear
|
12
|
+
|
13
|
+
%fieldset#comment_buttons.buttons.actions
|
14
|
+
%ol
|
15
|
+
%li.commit
|
16
|
+
= form_tag '/admin/comments/update_many', :method => :put do
|
17
|
+
= hidden_field_tag "comment_action", "approve"
|
18
|
+
%input#approve-selected.create{:type => "button", :value => ttc(".approve")}
|
19
|
+
%li.delete
|
20
|
+
= form_tag '/admin/comments/delete_many', :method => :delete do
|
21
|
+
%input#delete-selected.cancel{:type => "button", :value => ttc(".delete")}
|
22
|
+
%li.cancel
|
23
|
+
= form_tag '/admin/comments/update_many', :method => :put do
|
24
|
+
= hidden_field_tag "comment_action", "mark-spam"
|
25
|
+
%input#mark-as-spam-selected.cancel{:type => "button", :value => ttc(".mark as spam")}
|
26
|
+
|
27
|
+
#pagination.pagination.clear
|
28
|
+
- if @collection.cursor.hasPrev
|
29
|
+
.previous= link_to tt("Previous"), admin_comments_path(params.merge(:cursor => @collection.cursor.prev))
|
30
|
+
- if @collection.cursor.hasNext
|
31
|
+
.next= link_to tt("Next"), admin_comments_path(params.merge(:cursor => @collection.cursor.next))
|
32
|
+
|
33
|
+
- content_for :js do
|
34
|
+
= javascript_include_tag 'atreides/comments'
|
@@ -0,0 +1,21 @@
|
|
1
|
+
- deletable = defined?(deletable) ? deletable : true
|
2
|
+
- post ||= Atreides::Post.new
|
3
|
+
- part ||= resource
|
4
|
+
- resource_type ||= :post
|
5
|
+
= semantic_fields_for resource_type, post do |post_form|
|
6
|
+
.part-container{:id => part.dom_id}
|
7
|
+
= post_form.inputs :for => [:parts, part] do |fp|
|
8
|
+
- if deletable
|
9
|
+
%li.part-delete-btn
|
10
|
+
- unless part.new_record?
|
11
|
+
= link_to image_tag("atreides/admin/remove.png"), send("admin_#{resource_type.to_s}_part_path", post, part, :format => 'js'), :remote => true, :'data-method' => :delete
|
12
|
+
- else
|
13
|
+
= link_to_function image_tag("atreides/admin/remove.png"), "$(this).parents('.part-container').fadeOut(function(){ $(this).remove() })"
|
14
|
+
%li.part-drag-handle
|
15
|
+
= image_tag("atreides/admin/resize.png")
|
16
|
+
= fp.input :id, :as => :hidden unless part.new_record?
|
17
|
+
= fp.input :content_type, :as => :hidden
|
18
|
+
= fp.input :display_order, :as => :hidden
|
19
|
+
= render :partial => "admin/atreides/content_parts/#{part.content_type}", :locals => {:f => fp, :part => part, :resource_type => resource_type}
|
20
|
+
.clear
|
21
|
+
.part-break
|
@@ -0,0 +1,18 @@
|
|
1
|
+
- part ||= resource
|
2
|
+
- part_uid ||= part.new_record? ? part.object_id : part.id
|
3
|
+
- photos_list_id = "photos_list_#{part_uid}"
|
4
|
+
%li.photos-upload
|
5
|
+
%label= ttt(:photos)
|
6
|
+
= photos_uploaders(part, photos_list_id, resource_type, part_uid)
|
7
|
+
%p.inline-hints.clear= tt('.upload_hint')
|
8
|
+
%li.photos-display-type
|
9
|
+
%label= ttt('.gallery_display')
|
10
|
+
- Atreides::ContentPart.display_types.each do |dt|
|
11
|
+
%span{:class => "#{dt} #{'selected' if resource.display_type==dt}"}
|
12
|
+
= radio_button_tag "#{resource_type.to_s}[parts_attributes][0][display_type]", dt, :title => dt.humanize.titleize
|
13
|
+
= image_tag "atreides/admin/photos-display-type-#{dt}.png", :alt => dt.humanize.titleize
|
14
|
+
= dt.humanize.titleize
|
15
|
+
%p.inline-hints.clear= ttt(:".show_photos_as_a_slideshow_gallery_or_stacked_above_each_other")
|
16
|
+
%li.clear.photos-list
|
17
|
+
= edit_photos_for_assoc(part, photos_list_id)
|
18
|
+
|
@@ -0,0 +1 @@
|
|
1
|
+
= f.input :body, :label => ttt(:body), :as => 'text', :wrapper_html => { :class => "rich-text" }, :input_html => { :style => "height:30em;" }, :required => true
|
@@ -0,0 +1,12 @@
|
|
1
|
+
- part ||= resource
|
2
|
+
- part_uid ||= part.new_record? ? part.object_id : part.id
|
3
|
+
- videos_list_id = "videos_list_#{part_uid}"
|
4
|
+
%li.string.optional.video-url.half
|
5
|
+
%label{:for => "#{resource_type.to_s}_videos_attributes__url"} #{ttt :'.video_url'}
|
6
|
+
= text_field_tag "video_url"
|
7
|
+
= link_to ttt(:'.save'), admin_videos_path(:format => "js", :list_id => videos_list_id, :resource_type => resource_type), :'data-submit' => "#video_url", :after => "$('.video-url input').val(null)", :id => "save_video_btn", :remote => true, :'data-method' => 'POST', :'data-submit' => '#video_url'
|
8
|
+
%p.inline-hints #{tt :'.paste_in_a_URL_to_a_vimeo_or_youtube_video'}
|
9
|
+
%li.video-list
|
10
|
+
= edit_videos_for_assoc(part, videos_list_id)
|
11
|
+
%p.inline-hints.clear #{ttt :'.reorder_and_caption_videos'}
|
12
|
+
|
File without changes
|
File without changes
|
@@ -0,0 +1,11 @@
|
|
1
|
+
$("#flash_messages").html("#{escape_javascript(flash_messages)}").hide().fadeIn()
|
2
|
+
var content_parts_container = $("#content_parts_container")
|
3
|
+
content_parts_container.find('.part-container').last().after("#{escape_javascript(render(:partial => 'form'))}")
|
4
|
+
- case resource.content_type.to_sym
|
5
|
+
- when :text
|
6
|
+
createRichTextArea(content_parts_container.find('.rich-text textarea').last())
|
7
|
+
- else
|
8
|
+
fixRailsEmbeddedFormHashOrder(content_parts_container)
|
9
|
+
content_parts_container.sortable('refresh')
|
10
|
+
- # Scroll to element
|
11
|
+
$('html,body').animate({scrollTop: content_parts_container.find(".part-container").last().offset().top}, 500);
|
@@ -0,0 +1,134 @@
|
|
1
|
+
#dropbox_browser{:style => "min-height:420px; height:420px; display:none;", :rel => "Dropbox import"}
|
2
|
+
%table
|
3
|
+
%tr
|
4
|
+
%td{ :height => "420", :width => '780', :style => 'background: white;'}
|
5
|
+
%center
|
6
|
+
= image_tag 'atreides/admin/dashboard-indicator.gif'
|
7
|
+
#dropbox_uploader.upload-btn
|
8
|
+
- if dropbox_session.authorized? then
|
9
|
+
%a{:rel => "facebox", :href => "#dropbox_browser", :title => "Click to import from Dropbox"}
|
10
|
+
Click to import from Dropbox
|
11
|
+
:javascript
|
12
|
+
$(function(){
|
13
|
+
var browser = $('#dropbox_browser');
|
14
|
+
var loading_html = browser.html();
|
15
|
+
var uploadImagesFromDropbox = function(image_paths) {
|
16
|
+
$('.inline-hints').hide();
|
17
|
+
$('.upload-progress').show();
|
18
|
+
$('.upload-progress').progressbar()
|
19
|
+
var nDone = 0, nTotal = image_paths.length;
|
20
|
+
|
21
|
+
var updateProgressMonitor = function(fileName) {
|
22
|
+
$('.upload-progress span').text((1 + nDone) + ' / ' + nTotal + ' - Importing ' + fileName);
|
23
|
+
$('.upload-progress').progressbar('value',((nDone/nTotal)*100))
|
24
|
+
};
|
25
|
+
|
26
|
+
var uploadFirstImage = function(image_paths) {
|
27
|
+
if(!image_paths || !image_paths.length) {
|
28
|
+
$('.upload-progress').hide();
|
29
|
+
$('.inline-hints').show();
|
30
|
+
return;
|
31
|
+
}
|
32
|
+
var image_path = image_paths.shift();
|
33
|
+
updateProgressMonitor(image_path.split('/').pop());
|
34
|
+
$.post("/admin/photos.js?part_id=#{part_id}&list_id=#{list_id}&resource_type=post&post_type=photos&dropbox_path=" + encodeURIComponent(image_path), {}, function(data, textStatus, xhr) {
|
35
|
+
nDone += 1;
|
36
|
+
if(textStatus == 'success') {
|
37
|
+
uploadFirstImage(image_paths);
|
38
|
+
} else {
|
39
|
+
alert('Error uploading ' + image_path + ' !\n'+ data);
|
40
|
+
// Keep on trying with the others
|
41
|
+
uploadFirstImage(image_paths);
|
42
|
+
}
|
43
|
+
}, 'script');
|
44
|
+
};
|
45
|
+
uploadFirstImage(image_paths);
|
46
|
+
};
|
47
|
+
|
48
|
+
var loadDropboxPath = function(path) {
|
49
|
+
var list = $('.dropbox_list', browser);
|
50
|
+
list.fadeOut();
|
51
|
+
browser.load('/admin/dropbox/list?path=' + encodeURIComponent(path), null, function(responseText, textStatus, xhr){
|
52
|
+
if(textStatus !== 'success') {
|
53
|
+
browser.html([
|
54
|
+
'<b>Failed listing ' + path + '</b>.<br/>',
|
55
|
+
'<a class="directory" rel="' + path + '">Try again</a> or ',
|
56
|
+
'<a class="directory" rel="/">get back to the root</a>.'
|
57
|
+
].join(''));
|
58
|
+
} else {
|
59
|
+
var list = $('#dropbox_browser .dropbox_list');
|
60
|
+
list.animate({
|
61
|
+
opacity: 1
|
62
|
+
}, 200, 'easeOutQuad');
|
63
|
+
var sel = $("#dropbox_browser .selector");
|
64
|
+
sel.multipleSelectBox();
|
65
|
+
$(".breadCrumb").jBreadCrumb({easing: 'easeOutQuad'});
|
66
|
+
}
|
67
|
+
});
|
68
|
+
};
|
69
|
+
|
70
|
+
browser.dialog({
|
71
|
+
title: browser.attr('rel'),
|
72
|
+
autoOpen: false,
|
73
|
+
width: 800,
|
74
|
+
height: 500,
|
75
|
+
show: 'puff',
|
76
|
+
open: function(e, ui) {
|
77
|
+
var default_path = '/';
|
78
|
+
if(window['localStorage']) {
|
79
|
+
default_path = localStorage.getItem('dropbox_browser_path') || default_path;
|
80
|
+
}
|
81
|
+
loadDropboxPath(default_path);
|
82
|
+
},
|
83
|
+
buttons: {
|
84
|
+
"Use selected": function() {
|
85
|
+
var sel = $("#dropbox_browser .selector");
|
86
|
+
var img_links = sel.find('.selected a');
|
87
|
+
var img_paths = [];
|
88
|
+
img_links.each(function(i, e){
|
89
|
+
img_paths.push($(e).attr('rel'));
|
90
|
+
});
|
91
|
+
$(this).dialog("close");
|
92
|
+
uploadImagesFromDropbox(img_paths);
|
93
|
+
},
|
94
|
+
"Cancel": function() { $(this).dialog("close"); },
|
95
|
+
}
|
96
|
+
});
|
97
|
+
|
98
|
+
$('#dropbox_uploader a').tipsy({gravity: 'w'}).click(function(e){
|
99
|
+
e.preventDefault();
|
100
|
+
browser.dialog('open');
|
101
|
+
});
|
102
|
+
|
103
|
+
$("#dropbox_browser a").live('click', function(e, el) {
|
104
|
+
e.preventDefault();
|
105
|
+
var el = $(this);
|
106
|
+
if(el.hasClass('directory')) {
|
107
|
+
var new_path = el.attr('rel');
|
108
|
+
if(window['localStorage']) { localStorage.setItem('dropbox_browser_path', new_path); }
|
109
|
+
loadDropboxPath(new_path);
|
110
|
+
}
|
111
|
+
});
|
112
|
+
|
113
|
+
$("a[href*='www.dropbox.com']").bind("click", function(e){
|
114
|
+
if (hasPageChanged()){
|
115
|
+
var message = "You've made changes to this document, authenticating with dropbox will leave this page and changes will be lost. If you wish to save your changes, please save a draft and then authenticate with Dropbox to add photos.";
|
116
|
+
if(confirm(message)) {
|
117
|
+
pageChanged = false;
|
118
|
+
return true;
|
119
|
+
} else {
|
120
|
+
return false;
|
121
|
+
}
|
122
|
+
}
|
123
|
+
});
|
124
|
+
|
125
|
+
// debug:
|
126
|
+
// setTimeout(function(){
|
127
|
+
// $('#dropbox_uploader img').click()
|
128
|
+
// }, 300);
|
129
|
+
});
|
130
|
+
- else
|
131
|
+
- puts "Must authorize dropbox !"
|
132
|
+
= link_to "Connect with Dropbox", dropbox_authorize_link+"?add_content[]=photos", :target => '_self', :title => "Connect with Dropbox"
|
133
|
+
:javascript
|
134
|
+
$('#dropbox_uploader a').tipsy({gravity: 'w'})
|
@@ -0,0 +1,27 @@
|
|
1
|
+
.dropbox_list{:style => "opacity:.5"}
|
2
|
+
.breadCrumb.module
|
3
|
+
%ul
|
4
|
+
- path = ''
|
5
|
+
- *segs, last_seg = @dropbox_path.split('/')
|
6
|
+
- for seg in segs
|
7
|
+
- path = "#{path}/#{seg}".gsub /^\/\//, '/'
|
8
|
+
%li.directory
|
9
|
+
%a.directory{ :rel => path }= if seg.present? then seg else "/" end
|
10
|
+
- if path == ''
|
11
|
+
%li.directory
|
12
|
+
%a.directory{ :rel => path } Home
|
13
|
+
- else
|
14
|
+
%li.directory= last_seg
|
15
|
+
|
16
|
+
%ul.selector
|
17
|
+
- for dir in @dirs
|
18
|
+
%li.directory{ :class => dir['icon']}
|
19
|
+
%a.directory{ :rel => dir['path'] }= basename dir['path']
|
20
|
+
- for img in @imgs
|
21
|
+
%li.selected
|
22
|
+
%img{:src => admin_dropbox_thumbnail_path(:path => img['path'])}
|
23
|
+
%a.image{ :rel => img['path'] }= basename img['path']
|
24
|
+
- unless @imgs.size > 0 || @dirs.size > 0
|
25
|
+
%li.back
|
26
|
+
%a.directory{:rel => path} ← No image found.
|
27
|
+
|
@@ -0,0 +1,60 @@
|
|
1
|
+
= render :partial => 'admin/edit_head_content'
|
2
|
+
= semantic_form_for @feature, :url => (@feature.new_record? ? admin_features_path : admin_feature_path(@feature)), :as => "feature" do |f|
|
3
|
+
|
4
|
+
#form_content{:class => "span-17"}
|
5
|
+
%h2= ttt("#{params[:action].to_s}_feature").html_safe
|
6
|
+
= error_messages_for :resource, :header_message => ttt(:validation_error_header, :model => @feature.class.to_s.demodulize), :message => ttt(:validation_error_message)
|
7
|
+
= f.semantic_errors
|
8
|
+
= f.inputs do
|
9
|
+
= f.input :title, :input_html => { :class => "title" }
|
10
|
+
%li.photos-upload
|
11
|
+
%label #{ttt :'.photo'}
|
12
|
+
= multi_file_uploader(:url => admin_feature_photo_path((@feature.new_record? ? '-' : @feature), :format => :js), :css_parent_class => "photos-upload", :resource_type => "feature")
|
13
|
+
.clear
|
14
|
+
%li.photos-choose
|
15
|
+
%label #{ttt :'.existing_post'}
|
16
|
+
= hidden_field :feature, :post_id
|
17
|
+
= link_to_function ttt(:'.choose'), remote_function(:url => admin_posts_path(:format => :js), :type => :get, :success => "$('#feature_post_browser').toggle(); ")
|
18
|
+
.clear
|
19
|
+
%li.photo
|
20
|
+
#feature_photo.media-list
|
21
|
+
%ul#feature_photo_ul
|
22
|
+
- if @feature.photo
|
23
|
+
= photo_for_assoc(@feature.photo, @feature, "photos_list")
|
24
|
+
- elsif @feature.post && @feature.video
|
25
|
+
= image_tag @feature.video.thumb_url
|
26
|
+
|
27
|
+
#feature_post_browser{:style => 'display:none;'}
|
28
|
+
.close= link_to_function 'close', "$('#feature_post_browser').hide();$(this).find('.archives').remove()"
|
29
|
+
%label #{ttt :'.choose_a_post'}
|
30
|
+
#pagination
|
31
|
+
|
32
|
+
= f.input :caption, :label => ttt(:'.caption'), :as => 'text', :input_html => { :style => "height:10em;" }
|
33
|
+
= f.input :url, :label => ttt(:'.url'), :input_html => { :class => "title" }
|
34
|
+
|
35
|
+
= f.actions do
|
36
|
+
= f.action :submit, :as => :button, :label => ttt(:save)
|
37
|
+
%li.cancel
|
38
|
+
= link_to ttt(:back), admin_features_path, :class => "cancel"
|
39
|
+
%li.delete
|
40
|
+
= link_to ttt(:delete), admin_feature_path(@feature), :class => "cancel", :confirm => ttt(:are_you_absolutely_sure), :method => "delete" unless @feature.new_record?
|
41
|
+
|
42
|
+
#form_sidebar{:class => "sidebar span-6 last"}
|
43
|
+
= f.inputs do
|
44
|
+
- selected = (@feature.pending? || @feature.published?) ? (@feature.published_at? ? :published_at : :published_now) : @feature.state.to_sym
|
45
|
+
|
46
|
+
- @feature.published_at = (@feature.published_at || Time.now).in_time_zone # Needed to show time in user's TZ
|
47
|
+
- label = @feature.published_at.past? ? "Published on: " : "Will be published on:"
|
48
|
+
|
49
|
+
= f.input :state, :as => "select", :collection => @feature.states_for_select, :selected => selected, :include_blank => false, :wrapper_html => { :class => "post-states" }
|
50
|
+
= f.input :state, :as => "hidden", :wrapper_html => { :class => "post-hidden" }
|
51
|
+
= f.input :published_at, :label => label, :as => "string", :wrapper_html => { :class => "date-picker", :style => "display:#{selected==:published_at ? 'block' : 'none'}"}
|
52
|
+
|
53
|
+
- if defined?(Settings.tags.posts.features)
|
54
|
+
%li{:class => "features-tag-group tag-picker"}
|
55
|
+
%label #{ttt :'.location'}
|
56
|
+
%ul
|
57
|
+
- Settings.tags.posts.features.each do |tag|
|
58
|
+
%li.machine_tag.feature_tag{:class => @feature.tag_list.include?(tag) ? "selected" : "" }
|
59
|
+
= radio_button_tag 'feature[tag_list][]', tag, @feature.tag_list.include?(tag)
|
60
|
+
= tag.humanize.titleize
|