publify_core 9.0.0.pre5 → 9.2.0
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of publify_core might be problematic. Click here for more details.
- checksums.yaml +5 -5
- data/CHANGELOG.md +102 -6
- data/README.md +9 -0
- data/app/assets/javascripts/bootstrap-sprockets.js +8 -0
- data/app/assets/javascripts/bootstrap/affix.js +164 -0
- data/app/assets/javascripts/bootstrap/alert.js +95 -0
- data/app/assets/javascripts/bootstrap/button.js +125 -0
- data/app/assets/javascripts/bootstrap/collapse.js +212 -0
- data/app/assets/javascripts/bootstrap/dropdown.js +165 -0
- data/app/assets/javascripts/bootstrap/modal.js +358 -0
- data/app/assets/javascripts/bootstrap/tab.js +155 -0
- data/app/assets/javascripts/bootstrap/transition.js +59 -0
- data/app/assets/javascripts/lightbox.js +4 -4
- data/app/assets/javascripts/publify_admin.js +1 -35
- data/app/assets/stylesheets/_bootstrap-compass.scss +9 -0
- data/app/assets/stylesheets/_bootstrap-mincer.scss +19 -0
- data/app/assets/stylesheets/_bootstrap-sprockets.scss +9 -0
- data/app/assets/stylesheets/_bootstrap.scss +42 -0
- data/app/assets/stylesheets/administration_structure.css.scss +1 -45
- data/app/assets/stylesheets/bootstrap/_alerts.scss +73 -0
- data/app/assets/stylesheets/bootstrap/_button-groups.scss +242 -0
- data/app/assets/stylesheets/bootstrap/_buttons.scss +168 -0
- data/app/assets/stylesheets/bootstrap/_close.scss +37 -0
- data/app/assets/stylesheets/bootstrap/_code.scss +69 -0
- data/app/assets/stylesheets/bootstrap/_component-animations.scss +38 -0
- data/app/assets/stylesheets/bootstrap/_dropdowns.scss +213 -0
- data/app/assets/stylesheets/bootstrap/_forms.scss +586 -0
- data/app/assets/stylesheets/bootstrap/_grid.scss +94 -0
- data/app/assets/stylesheets/bootstrap/_labels.scss +66 -0
- data/app/assets/stylesheets/bootstrap/_media.scss +66 -0
- data/app/assets/stylesheets/bootstrap/_mixins.scss +37 -0
- data/app/assets/stylesheets/bootstrap/_modals.scss +150 -0
- data/app/assets/stylesheets/bootstrap/_navbar.scss +479 -0
- data/app/assets/stylesheets/bootstrap/_navs.scss +242 -0
- data/app/assets/stylesheets/bootstrap/_normalize.scss +427 -0
- data/app/assets/stylesheets/bootstrap/_pagination.scss +86 -0
- data/app/assets/stylesheets/bootstrap/_panels.scss +222 -0
- data/app/assets/stylesheets/bootstrap/_print.scss +99 -0
- data/app/assets/stylesheets/bootstrap/_scaffolding.scss +160 -0
- data/app/assets/stylesheets/bootstrap/_tables.scss +234 -0
- data/app/assets/stylesheets/bootstrap/_theme.scss +224 -0
- data/app/assets/stylesheets/bootstrap/_type.scss +296 -0
- data/app/assets/stylesheets/bootstrap/_utilities.scss +55 -0
- data/app/assets/stylesheets/bootstrap/_variables.scss +638 -0
- data/app/assets/stylesheets/bootstrap/_wells.scss +29 -0
- data/app/assets/stylesheets/bootstrap/mixins/_alerts.scss +15 -0
- data/app/assets/stylesheets/bootstrap/mixins/_background-variant.scss +12 -0
- data/app/assets/stylesheets/bootstrap/mixins/_border-radius.scss +18 -0
- data/app/assets/stylesheets/bootstrap/mixins/_buttons.scss +56 -0
- data/app/assets/stylesheets/bootstrap/mixins/_center-block.scss +7 -0
- data/app/assets/stylesheets/bootstrap/mixins/_clearfix.scss +22 -0
- data/app/assets/stylesheets/bootstrap/mixins/_forms.scss +82 -0
- data/app/assets/stylesheets/bootstrap/mixins/_gradients.scss +56 -0
- data/app/assets/stylesheets/bootstrap/mixins/_grid-framework.scss +81 -0
- data/app/assets/stylesheets/bootstrap/mixins/_grid.scss +122 -0
- data/app/assets/stylesheets/bootstrap/mixins/_hide-text.scss +21 -0
- data/app/assets/stylesheets/bootstrap/mixins/_image.scss +28 -0
- data/app/assets/stylesheets/bootstrap/mixins/_labels.scss +12 -0
- data/app/assets/stylesheets/bootstrap/mixins/_nav-divider.scss +10 -0
- data/app/assets/stylesheets/bootstrap/mixins/_nav-vertical-align.scss +9 -0
- data/app/assets/stylesheets/bootstrap/mixins/_opacity.scss +7 -0
- data/app/assets/stylesheets/bootstrap/mixins/_pagination.scss +24 -0
- data/app/assets/stylesheets/bootstrap/mixins/_panels.scss +20 -0
- data/app/assets/stylesheets/bootstrap/mixins/_reset-filter.scss +8 -0
- data/app/assets/stylesheets/bootstrap/mixins/_resize.scss +6 -0
- data/app/assets/stylesheets/bootstrap/mixins/_responsive-visibility.scss +17 -0
- data/app/assets/stylesheets/bootstrap/mixins/_size.scss +10 -0
- data/app/assets/stylesheets/bootstrap/mixins/_tab-focus.scss +9 -0
- data/app/assets/stylesheets/bootstrap/mixins/_table-row.scss +28 -0
- data/app/assets/stylesheets/bootstrap/mixins/_text-emphasis.scss +12 -0
- data/app/assets/stylesheets/bootstrap/mixins/_text-overflow.scss +8 -0
- data/app/assets/stylesheets/bootstrap/mixins/_vendor-prefixes.scss +222 -0
- data/app/assets/stylesheets/lightbox.css +3 -3
- data/app/assets/stylesheets/publify_admin.css.scss +0 -1
- data/app/controllers/accounts_controller.rb +2 -0
- data/app/controllers/admin/base_controller.rb +8 -22
- data/app/controllers/admin/content_controller.rb +69 -48
- data/app/controllers/admin/dashboard_controller.rb +20 -74
- data/app/controllers/admin/feedback_controller.rb +45 -36
- data/app/controllers/admin/notes_controller.rb +16 -10
- data/app/controllers/admin/pages_controller.rb +20 -34
- data/app/controllers/admin/post_types_controller.rb +7 -5
- data/app/controllers/admin/profiles_controller.rb +15 -5
- data/app/controllers/admin/redirects_controller.rb +9 -5
- data/app/controllers/admin/resources_controller.rb +7 -4
- data/app/controllers/admin/seo_controller.rb +12 -10
- data/app/controllers/admin/settings_controller.rb +7 -5
- data/app/controllers/admin/sidebar_controller.rb +7 -5
- data/app/controllers/admin/tags_controller.rb +7 -3
- data/app/controllers/admin/themes_controller.rb +10 -7
- data/app/controllers/admin/users_controller.rb +10 -7
- data/app/controllers/articles_controller.rb +92 -81
- data/app/controllers/authors_controller.rb +6 -3
- data/app/controllers/base_controller.rb +9 -11
- data/app/controllers/comments_controller.rb +15 -16
- data/app/controllers/content_controller.rb +12 -19
- data/app/controllers/feedback_controller.rb +7 -39
- data/app/controllers/notes_controller.rb +6 -6
- data/app/controllers/setup_controller.rb +25 -26
- data/app/controllers/tags_controller.rb +16 -16
- data/app/controllers/text_controller.rb +2 -4
- data/app/controllers/textfilter_controller.rb +2 -0
- data/app/controllers/theme_controller.rb +22 -17
- data/app/controllers/xml_controller.rb +13 -59
- data/app/helpers/admin/base_helper.rb +28 -29
- data/app/helpers/admin/feedback_helper.rb +34 -24
- data/app/helpers/articles_helper.rb +4 -2
- data/app/helpers/authors_helper.rb +9 -18
- data/app/helpers/base_helper.rb +66 -55
- data/app/helpers/blog_helper.rb +4 -2
- data/app/helpers/xml_helper.rb +5 -3
- data/app/jobs/application_job.rb +4 -0
- data/app/mailers/notification_mailer.rb +5 -3
- data/app/models/ability.rb +25 -24
- data/app/models/archives_sidebar.rb +18 -18
- data/app/models/article.rb +84 -99
- data/app/models/article/factory.rb +14 -6
- data/app/models/blog.rb +98 -110
- data/app/models/comment.rb +14 -10
- data/app/models/config_manager.rb +4 -2
- data/app/models/content.rb +45 -65
- data/app/models/content_base.rb +7 -14
- data/app/models/feedback.rb +91 -66
- data/app/models/meta_sidebar.rb +5 -3
- data/app/models/note.rb +31 -23
- data/app/models/page.rb +16 -10
- data/app/models/page_sidebar.rb +4 -2
- data/app/models/ping.rb +2 -113
- data/app/models/post_type.rb +4 -3
- data/app/models/redirect.rb +13 -7
- data/app/models/redirection.rb +3 -1
- data/app/models/resource.rb +6 -22
- data/app/models/search_sidebar.rb +4 -2
- data/app/models/sidebar.rb +12 -7
- data/app/models/static_sidebar.rb +15 -13
- data/app/models/tag.rb +23 -15
- data/app/models/tag_sidebar.rb +10 -7
- data/app/models/text_filter.rb +85 -11
- data/app/models/trackback.rb +7 -18
- data/app/models/trigger.rb +8 -19
- data/app/models/user.rb +46 -52
- data/app/services/title_builder.rb +52 -45
- data/app/uploaders/resource_uploader.rb +35 -2
- data/app/views/accounts/confirm.html.erb +3 -4
- data/app/views/admin/content/_article_list.html.erb +24 -9
- data/app/views/admin/content/_form.html.erb +71 -51
- data/app/views/admin/content/autosave.js.erb +2 -2
- data/app/views/admin/content/edit.html.erb +1 -1
- data/app/views/admin/content/index.html.erb +25 -15
- data/app/views/admin/content/new.html.erb +2 -2
- data/app/views/admin/dashboard/_comment.html.erb +5 -5
- data/app/views/admin/dashboard/_comments.html.erb +2 -2
- data/app/views/admin/dashboard/_drafts.html.erb +5 -5
- data/app/views/admin/dashboard/_overview.html.erb +7 -9
- data/app/views/admin/dashboard/_welcome.html.erb +11 -11
- data/app/views/admin/dashboard/index.html.erb +12 -7
- data/app/views/admin/feedback/_button.html.erb +6 -6
- data/app/views/admin/feedback/_feedback.html.erb +3 -3
- data/app/views/admin/feedback/_ham.html.erb +27 -9
- data/app/views/admin/feedback/_spam.html.erb +26 -16
- data/app/views/admin/feedback/article.html.erb +20 -21
- data/app/views/admin/feedback/edit.html.erb +14 -15
- data/app/views/admin/feedback/{ham.js → ham.js.erb} +0 -0
- data/app/views/admin/feedback/index.html.erb +25 -23
- data/app/views/admin/feedback/{spam.js → spam.js.erb} +0 -0
- data/app/views/admin/migrations/show.html.erb +10 -11
- data/app/views/admin/notes/_form.html.erb +13 -13
- data/app/views/admin/notes/_list.html.erb +19 -8
- data/app/views/admin/notes/_note.html.erb +12 -7
- data/app/views/admin/notes/edit.html.erb +6 -1
- data/app/views/admin/notes/index.html.erb +5 -1
- data/app/views/admin/notes/show.html.erb +2 -2
- data/app/views/admin/pages/_form.html.erb +86 -77
- data/app/views/admin/pages/_pages.html.erb +11 -4
- data/app/views/admin/pages/edit.html.erb +3 -1
- data/app/views/admin/pages/index.html.erb +10 -6
- data/app/views/admin/pages/new.html.erb +3 -1
- data/app/views/admin/post_types/_index_and_form.html.erb +15 -16
- data/app/views/admin/post_types/edit.html.erb +1 -1
- data/app/views/admin/post_types/index.html.erb +1 -1
- data/app/views/admin/profiles/index.html.erb +2 -3
- data/app/views/admin/redirects/_index_and_form.html.erb +10 -11
- data/app/views/admin/redirects/edit.html.erb +1 -1
- data/app/views/admin/redirects/index.html.erb +1 -1
- data/app/views/admin/resources/index.html.erb +19 -16
- data/app/views/admin/seo/_general.html.erb +40 -59
- data/app/views/admin/seo/_permalinks.html.erb +17 -17
- data/app/views/admin/seo/_titles.html.erb +81 -82
- data/app/views/admin/seo/show.html.erb +14 -19
- data/app/views/admin/settings/display.html.erb +42 -52
- data/app/views/admin/settings/feedback.html.erb +59 -67
- data/app/views/admin/settings/index.html.erb +30 -31
- data/app/views/admin/settings/write.html.erb +27 -46
- data/app/views/admin/shared/_edit.html.erb +3 -3
- data/app/views/admin/shared/_menu.html.erb +26 -26
- data/app/views/admin/shared/_twitter_alert.html.erb +1 -1
- data/app/views/admin/sidebar/_config.html.erb +5 -5
- data/app/views/admin/sidebar/_target_sidebar.html.erb +4 -4
- data/app/views/admin/sidebar/index.html.erb +7 -7
- data/app/views/admin/tags/_index_and_form.html.erb +11 -12
- data/app/views/admin/tags/edit.html.erb +1 -1
- data/app/views/admin/tags/index.html.erb +1 -1
- data/app/views/admin/themes/index.html.erb +5 -6
- data/app/views/admin/users/_form.html.erb +34 -34
- data/app/views/admin/users/edit.html.erb +2 -2
- data/app/views/admin/users/index.html.erb +10 -12
- data/app/views/admin/users/new.html.erb +2 -2
- data/app/views/archives_sidebar/_content.html.erb +2 -2
- data/app/views/articles/_archives_article.html.erb +9 -0
- data/app/views/articles/_article.html.erb +9 -9
- data/app/views/articles/_article_author.html.erb +4 -0
- data/app/views/articles/_article_collection.html.erb +1 -1
- data/app/views/articles/_article_content.html.erb +2 -2
- data/app/views/articles/_article_excerpt.html.erb +11 -9
- data/app/views/articles/_article_links.html.erb +5 -3
- data/app/views/articles/_comment_errors.html.erb +1 -1
- data/app/views/articles/_comment_form.html.erb +12 -12
- data/app/views/articles/_comment_list.html.erb +5 -5
- data/app/views/articles/_comment_preview.html.erb +3 -3
- data/app/views/articles/_full_article_content.html.erb +4 -2
- data/app/views/articles/_password_form.html.erb +4 -4
- data/app/views/articles/_trackback.html.erb +2 -2
- data/app/views/articles/archives.html.erb +11 -21
- data/app/views/articles/feedback_atom_feed.atom.builder +7 -5
- data/app/views/articles/feedback_rss_feed.rss.builder +11 -11
- data/app/views/articles/index_atom_feed.atom.builder +5 -4
- data/app/views/articles/index_rss_feed.rss.builder +8 -8
- data/app/views/articles/live_search.html.erb +3 -3
- data/app/views/articles/read.html.erb +19 -37
- data/app/views/articles/search.html.erb +3 -3
- data/app/views/articles/trackback.xml.builder +3 -1
- data/app/views/articles/view_page.html.erb +2 -2
- data/app/views/authors/show.html.erb +18 -28
- data/app/views/authors/show_atom_feed.atom.builder +5 -4
- data/app/views/authors/show_rss_feed.rss.builder +8 -8
- data/app/views/comments/_comment.html.erb +17 -16
- data/app/views/devise/mailer/reset_password_instructions.html.erb +7 -9
- data/app/views/devise/passwords/edit.html.erb +4 -4
- data/app/views/devise/passwords/new.html.erb +1 -1
- data/app/views/devise/registrations/new.html.erb +5 -5
- data/app/views/devise/sessions/new.html.erb +3 -3
- data/app/views/errors/404.html.erb +2 -2
- data/app/views/feedback/index.atom.builder +9 -0
- data/app/views/feedback/index.rss.builder +20 -0
- data/app/views/layouts/accounts.html.erb +26 -26
- data/app/views/layouts/administration.html.erb +31 -31
- data/app/views/layouts/default.html.erb +4 -3
- data/app/views/layouts/editor.html.erb +5 -19
- data/app/views/meta_sidebar/_content.html.erb +2 -2
- data/app/views/notes/_note.html.erb +16 -15
- data/app/views/notes/index.html.erb +2 -2
- data/app/views/notes/show_in_reply.html.erb +1 -1
- data/app/views/notification_mailer/_mail_footer.html.erb +3 -5
- data/app/views/notification_mailer/_mail_header.html.erb +2 -0
- data/app/views/notification_mailer/article.html.erb +5 -4
- data/app/views/notification_mailer/comment.html.erb +9 -8
- data/app/views/notification_mailer/notif_user.html.erb +4 -9
- data/app/views/page_sidebar/_content.html.erb +1 -1
- data/app/views/search_sidebar/_content.html.erb +2 -2
- data/app/views/settings/install.html.erb +2 -2
- data/app/views/setup/index.html.erb +9 -5
- data/app/views/shared/_atom_header.atom.builder +4 -4
- data/app/views/shared/_atom_item_article.atom.builder +19 -22
- data/app/views/shared/_atom_item_comment.atom.builder +5 -5
- data/app/views/shared/_atom_item_trackback.atom.builder +5 -4
- data/app/views/shared/_google_analytics.html.erb +8 -0
- data/app/views/shared/_page_header.html.erb +10 -13
- data/app/views/shared/_rss_item_article.rss.builder +12 -15
- data/app/views/shared/_rss_item_comment.rss.builder +2 -1
- data/app/views/shared/_rss_item_trackback.rss.builder +2 -0
- data/app/views/sidebar/display_plugins.html.erb +1 -1
- data/app/views/tag_sidebar/_content.html.erb +1 -1
- data/app/views/tags/index.html.erb +2 -2
- data/app/views/xml/_googlesitemap_item_article.googlesitemap.builder +2 -0
- data/app/views/xml/_googlesitemap_item_category.googlesitemap.builder +2 -0
- data/app/views/xml/_googlesitemap_item_page.googlesitemap.builder +2 -0
- data/app/views/xml/_googlesitemap_item_tag.googlesitemap.builder +2 -0
- data/app/views/xml/sitemap.googlesitemap.builder +9 -0
- data/config/i18n-tasks.yml +0 -5
- data/config/initializers/devise.rb +10 -4
- data/config/initializers/mime_types.rb +3 -2
- data/config/locales/da.yml +140 -108
- data/config/locales/de.yml +147 -111
- data/config/locales/en.yml +133 -102
- data/config/locales/es-MX.yml +141 -106
- data/config/locales/fr.yml +172 -122
- data/config/locales/he.yml +132 -105
- data/config/locales/it.yml +141 -108
- data/config/locales/ja.yml +115 -100
- data/config/locales/lt.yml +158 -110
- data/config/locales/nb-NO.yml +128 -101
- data/config/locales/nl.yml +147 -113
- data/config/locales/pl.yml +335 -275
- data/config/locales/pt-BR.yml +143 -107
- data/config/locales/ro.yml +155 -108
- data/config/locales/ru.yml +166 -105
- data/config/locales/zh-CN.yml +112 -96
- data/config/locales/zh-TW.yml +116 -99
- data/config/routes.rb +70 -87
- data/db/migrate/113_initial_schema.rb +6 -6
- data/db/migrate/114_fixes_buggy_articles_and_notes.rb +8 -6
- data/db/migrate/115_drops_categories_for_tags.rb +7 -6
- data/db/migrate/20150207131657_add_missing_indexes.rb +3 -1
- data/db/migrate/20150807134129_simplify_redirect_relations.rb +6 -1
- data/db/migrate/20150808052637_add_blog_ids.rb +11 -7
- data/db/migrate/20150808191127_add_blog_id_to_redirects.rb +3 -1
- data/db/migrate/20150810094754_add_blog_id_to_tags.rb +3 -1
- data/db/migrate/20160108111120_add_devise_to_users.rb +3 -1
- data/db/migrate/20160108184201_move_last_connection_to_last_sign_in_at.rb +3 -1
- data/db/migrate/20160110094906_remove_profiles_rights.rb +3 -1
- data/db/migrate/20160605103918_replace_profile_id_with_string.rb +3 -3
- data/db/migrate/20160605154632_remove_profiles.rb +12 -7
- data/db/migrate/20160701061851_demand_blog_id_on_contents.rb +3 -1
- data/db/migrate/20160701062604_add_blog_id_to_resources.rb +3 -1
- data/db/migrate/20170528093024_move_resources_to_content.rb +7 -0
- data/db/migrate/20170528094923_move_tags_to_content.rb +8 -0
- data/db/migrate/20170528201606_remove_separate_published_flag.rb +7 -0
- data/db/migrate/20170605071626_remove_extra_state_columns_from_feedback.rb +8 -0
- data/db/migrate/20170702105201_remove_published_at_from_feedback.rb +7 -0
- data/db/migrate/20190208151235_add_text_filter_name_fields.rb +9 -0
- data/db/migrate/20190208152646_move_text_filter_to_name.rb +97 -0
- data/db/migrate/20190209155717_remove_text_filter_ids.rb +19 -0
- data/db/migrate/20190209160610_remove_text_filters.rb +17 -0
- data/db/migrate/20200413140440_add_unique_indexes.rb +10 -0
- data/db/seeds.rb +8 -20
- data/lib/email_notify.rb +3 -1
- data/lib/format.rb +4 -12
- data/lib/publify_core.rb +36 -36
- data/lib/publify_core/engine.rb +11 -4
- data/lib/publify_core/lang.rb +5 -1
- data/lib/publify_core/testing_support/dns_mock.rb +15 -0
- data/lib/publify_core/testing_support/factories.rb +240 -0
- data/lib/publify_core/testing_support/feed_assertions.rb +48 -0
- data/lib/publify_core/testing_support/fixtures/exploit.svg +4 -0
- data/lib/publify_core/testing_support/fixtures/fakepng.png +1 -0
- data/lib/publify_core/testing_support/fixtures/otherfile.txt +1 -0
- data/lib/publify_core/testing_support/fixtures/testfile.png +0 -0
- data/lib/publify_core/testing_support/fixtures/testfile.txt +1 -0
- data/lib/publify_core/testing_support/upload_fixtures.rb +15 -0
- data/lib/publify_core/version.rb +3 -1
- data/lib/publify_guid.rb +4 -2
- data/lib/publify_plugins.rb +10 -5
- data/lib/publify_textfilter_markdown.rb +38 -25
- data/lib/publify_textfilter_none.rb +5 -3
- data/lib/publify_textfilter_smartypants.rb +5 -3
- data/lib/publify_textfilter_textile.rb +7 -4
- data/lib/publify_textfilter_twitterfilter.rb +13 -7
- data/lib/publify_time.rb +6 -2
- data/lib/sidebar_field.rb +29 -20
- data/lib/sidebar_registry.rb +5 -3
- data/lib/spam_protection.rb +19 -17
- data/lib/tasks/i18n.rake +9 -0
- data/lib/tasks/manifest.rake +30 -0
- data/lib/tasks/publify_core_tasks.rake +2 -0
- data/lib/text_filter_plugin.rb +30 -29
- data/lib/theme.rb +5 -5
- data/lib/transforms.rb +22 -20
- data/{app/assets/stylesheets/publify_core/.keep → themes/plain/javascripts/theme.js} +0 -0
- metadata +304 -130
- data/.gitignore +0 -13
- data/.rspec +0 -2
- data/.rubocop.yml +0 -84
- data/.rubocop_todo.yml +0 -148
- data/.travis.yml +0 -27
- data/Gemfile +0 -17
- data/README.rdoc +0 -3
- data/Rakefile +0 -35
- data/app/assets/javascripts/widearea.js +0 -486
- data/app/assets/stylesheets/widearea.css +0 -133
- data/app/controllers/.keep +0 -0
- data/app/controllers/admin/migrations_controller.rb +0 -19
- data/app/controllers/admin/textfilters_controller.rb +0 -6
- data/app/controllers/concerns/.keep +0 -0
- data/app/controllers/trackbacks_controller.rb +0 -36
- data/app/helpers/.keep +0 -0
- data/app/mailers/.keep +0 -0
- data/app/models/.keep +0 -0
- data/app/models/article/states.rb +0 -179
- data/app/models/concerns/.keep +0 -0
- data/app/models/feedback/states.rb +0 -256
- data/app/services/migrator.rb +0 -25
- data/app/views/.keep +0 -0
- data/app/views/admin/dashboard/_inbound.html.erb +0 -31
- data/app/views/admin/notes/_header.html.erb +0 -6
- data/app/views/articles/_protected_article_content.html.erb +0 -6
- data/app/views/comments/index.html.erb +0 -1
- data/app/views/comments/index_atom_feed.atom.builder +0 -8
- data/app/views/comments/index_rss_feed.rss.builder +0 -20
- data/app/views/trackbacks/index_atom_feed.atom.builder +0 -7
- data/app/views/trackbacks/index_rss_feed.rss.builder +0 -20
- data/app/views/trackbacks/trackback.xml.builder +0 -4
- data/app/views/xml/feed.googlesitemap.builder +0 -7
- data/app/views/xml/rsd.rsd.builder +0 -8
- data/lib/stateful.rb +0 -106
- data/publify_core.gemspec +0 -54
@@ -7,9 +7,9 @@
|
|
7
7
|
<small><%= link_to_permalink(note, display_date_and_time(note.published_at)) %></small>
|
8
8
|
</footer>
|
9
9
|
</article>
|
10
|
-
<hr
|
10
|
+
<hr />
|
11
11
|
</div>
|
12
12
|
<% end %>
|
13
13
|
</div>
|
14
14
|
|
15
|
-
<%= paginate @notes
|
15
|
+
<%= paginate @notes %>
|
@@ -2,7 +2,7 @@
|
|
2
2
|
<div class='h-entry hentry h-as-note'>
|
3
3
|
<article class=' well well-small'>
|
4
4
|
<% if @reply['user']['profile_image_url'] %>
|
5
|
-
<%= image_tag(@reply['user']['profile_image_url'], class:
|
5
|
+
<%= image_tag(@reply['user']['profile_image_url'], class: 'alignleft', alt: @reply['user']['name']) %>
|
6
6
|
<% end %>
|
7
7
|
<strong><%= get_reply_context_url(@reply) %></strong>
|
8
8
|
<p><%= nofollowify_links(PublifyApp::Textfilter::Twitterfilter.filtertext(@reply['text'])) %></p>
|
@@ -1,7 +1,5 @@
|
|
1
|
-
|
2
|
-
|
3
|
-
<p><em>This is being sent to <%=h @user.name %> because you asked to be notified via email whenever
|
4
|
-
new content is posted to <a href="<%= @blog.base_url%>"><%= @blog.blog_name %></a>
|
1
|
+
<p><em>This is being sent to <%= h @user.name %> because you asked to be notified via email whenever
|
2
|
+
new content is posted to <a href="<%= @blog.base_url %>"><%= @blog.blog_name %></a>
|
5
3
|
To unsubscribe, go to
|
6
|
-
<a href="<%= @link_url = @blog.url_for(:
|
4
|
+
<a href="<%= @link_url = @blog.url_for(controller: '/admin/users', action: 'edit', id: @user.id) %>"><%= h @link_url %></a>
|
7
5
|
and change your user settings.</p>
|
@@ -1,6 +1,7 @@
|
|
1
|
-
<p>A new article has been posted on <%=h @blog.blog_name %>:</p>
|
1
|
+
<p>A new article has been posted on <%= h @blog.blog_name %>:</p>
|
2
2
|
|
3
|
-
<%= render 'mail_header' %>
|
4
|
-
<h2><%=h @article.title %></h2>
|
5
|
-
<%= html @article, :body %>
|
3
|
+
<%= render 'mail_header' do %>
|
4
|
+
<h2><%= h @article.title %></h2>
|
5
|
+
<%= html @article, :body %>
|
6
|
+
<% end %>
|
6
7
|
<%= render 'mail_footer' %>
|
@@ -1,11 +1,12 @@
|
|
1
1
|
<p>A new comment has been posted on
|
2
|
-
<a href="<%= @blog.base_url%>"><%= @blog.blog_name %></a>, responding to
|
3
|
-
<a href="<%= @comment.article.permalink_url %>"><%=h(@comment.article.title) %></a>.</p>
|
2
|
+
<a href="<%= @blog.base_url %>"><%= @blog.blog_name %></a>, responding to
|
3
|
+
<a href="<%= @comment.article.permalink_url %>"><%= h(@comment.article.title) %></a>.</p>
|
4
4
|
|
5
|
-
<%= render 'mail_header' %>
|
6
|
-
<h2><%=h @comment.title %></h2>
|
7
|
-
<cite><strong><%=
|
8
|
-
|
9
|
-
|
10
|
-
<%= html @comment %>
|
5
|
+
<%= render 'mail_header' do %>
|
6
|
+
<h2><%= h @comment.title %></h2>
|
7
|
+
<cite><strong><%= @comment.url.blank? ? h(@comment.author) : link_to(h(@comment.author), @comment.url) %></strong> </cite>
|
8
|
+
<%= link_to('said', @comment.permalink_url) %>
|
9
|
+
<%= display_date_and_time @comment.created_at %> <br />
|
10
|
+
<%= html @comment %>
|
11
|
+
<% end %>
|
11
12
|
<%= render 'mail_footer' %>
|
@@ -1,14 +1,9 @@
|
|
1
1
|
<html>
|
2
2
|
<body>
|
3
|
-
<p>Your <a href="<%= @blog.base_url%>"><%= @blog.blog_name %></a> account has been created.</p>
|
3
|
+
<p>Your <a href="<%= @blog.base_url %>"><%= @blog.blog_name %></a> account has been created.</p>
|
4
4
|
|
5
|
-
<%= render 'mail_header' %>
|
6
|
-
<p>Your
|
7
|
-
|
8
|
-
<ul>
|
9
|
-
<li>Login: <%= h @user.login %></li>
|
10
|
-
<li>Password: <%= h @user.password %></li>
|
11
|
-
</ul>
|
12
|
-
</div>
|
5
|
+
<%= render 'mail_header' do %>
|
6
|
+
<p>Your can log in using your chosen login name, <%= h @user.login %>, and your password.</p>
|
7
|
+
<% end %>
|
13
8
|
</body>
|
14
9
|
</html>
|
@@ -2,9 +2,9 @@
|
|
2
2
|
<label for="q"><%= sidebar.title %></label>
|
3
3
|
</h3>
|
4
4
|
<div class="sidebar-body">
|
5
|
-
<%= form_tag({:
|
5
|
+
<%= form_tag({ controller: 'articles', action: 'search' }, { method: 'get', id: 'sform' }) do %>
|
6
6
|
<input type="text" id="q" name="q" value="" size="15" />
|
7
|
-
<input type="submit" value="<%= t(
|
7
|
+
<input type="submit" value="<%= t('.search') %>" />
|
8
8
|
<% end %>
|
9
9
|
</div>
|
10
10
|
<br style="clear: right" />
|
@@ -1,13 +1,17 @@
|
|
1
|
-
<%= form_tag :
|
1
|
+
<%= form_tag action: 'index' do %>
|
2
2
|
<div class='alert alert-info'>
|
3
|
-
<small><%= t(
|
3
|
+
<small><%= t('.welcome_to_your_blog_setup', publify: link_to('Publify', 'https://publify.github.io/')) %></small>
|
4
4
|
</div>
|
5
5
|
<div class='form-group'>
|
6
|
-
<%= text_field(:setting, :blog_name,
|
6
|
+
<%= text_field(:setting, :blog_name, class: 'form-control', placeholder: t('.blog_name')) %>
|
7
7
|
</div>
|
8
8
|
<div class='form-group'>
|
9
|
-
<%= text_field(:setting, :email,
|
9
|
+
<%= text_field(:setting, :email, class: 'form-control', placeholder: t('.your_mail')) %>
|
10
|
+
</div>
|
11
|
+
<div class='form-group'>
|
12
|
+
<%= label_tag :setting_password, t('.password') %><br />
|
13
|
+
<%= password_field(:setting, :password, class: 'form-control') %>
|
10
14
|
</div>
|
11
15
|
|
12
|
-
<input type="submit" id="submit" class='btn btn-lg btn-success btn-block' value="<%= t('generic.save')%>"
|
16
|
+
<input type="submit" id="submit" class='btn btn-lg btn-success btn-block' value="<%= t('generic.save') %>" />
|
13
17
|
<% end %>
|
@@ -1,6 +1,6 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
feed.title(feed_title)
|
2
|
-
|
3
|
-
feed.subtitle(this_blog.blog_subtitle, "type" => "html")
|
4
|
-
end
|
4
|
+
feed.subtitle(this_blog.blog_subtitle, "type" => "html") if this_blog.blog_subtitle.present?
|
5
5
|
feed.updated items.first.updated_at if items.first
|
6
|
-
feed.generator "Publify", uri: "
|
6
|
+
feed.generator "Publify", uri: "https://publify.github.io", version: PublifyCore::VERSION
|
@@ -1,39 +1,36 @@
|
|
1
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
feed.entry(item, id: "urn:uuid:#{item.guid}", published: item.published_at,
|
4
|
+
url: item.permalink_url) do |entry|
|
2
5
|
entry.author do
|
3
|
-
|
4
|
-
email = item.user.email rescue nil
|
5
|
-
entry.name name
|
6
|
-
entry.email email if this_blog.link_to_author unless email.blank?
|
6
|
+
entry.name item.author_name
|
7
7
|
end
|
8
8
|
|
9
9
|
if item.is_a?(Note)
|
10
|
-
|
10
|
+
truncated_body = truncate(item.html(:body).strip_html,
|
11
|
+
length: 80, separator: " ", omissions: "...")
|
12
|
+
entry.title truncated_body, "type" => "html"
|
11
13
|
else
|
12
|
-
entry.title item.title, "type"=>"html"
|
14
|
+
entry.title item.title, "type" => "html"
|
13
15
|
end
|
14
16
|
|
15
17
|
if item.is_a?(Article)
|
16
18
|
|
17
19
|
item.tags.each do |tag|
|
18
|
-
entry.category "term" => tag.display_name, "scheme" => tag.
|
20
|
+
entry.category "term" => tag.display_name, "scheme" => tag_url(tag.permalink)
|
19
21
|
end
|
20
22
|
|
23
|
+
# TODO: Add tests for this
|
21
24
|
item.resources.each do |resource|
|
22
|
-
|
23
|
-
|
24
|
-
|
25
|
-
|
26
|
-
|
27
|
-
|
28
|
-
|
29
|
-
entry.tag! :link, "rel" => "enclosure",
|
30
|
-
:type => resource.mime,
|
31
|
-
:title => item.title,
|
32
|
-
:href => this_blog.file_url(resource.upload_url)
|
33
|
-
end
|
25
|
+
link_options = { rel: "enclosure",
|
26
|
+
type: resource.mime,
|
27
|
+
title: item.title,
|
28
|
+
href: this_blog.file_url(resource.upload_url) }
|
29
|
+
# The Atom spec disallows files with size=0
|
30
|
+
link_options[:length] = resource.size if resource.size > 0
|
31
|
+
entry.tag! :link, link_options
|
34
32
|
end
|
35
33
|
end
|
36
34
|
content_html = fetch_html_content_for_feeds(item, this_blog)
|
37
|
-
entry.content content_html + item.
|
35
|
+
entry.content content_html + item.rss_description, "type" => "html"
|
38
36
|
end
|
39
|
-
|
@@ -1,10 +1,10 @@
|
|
1
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
feed.entry item, id: "urn:uuid:#{item.guid}", url: item.permalink_url do |entry|
|
2
4
|
entry.author do
|
3
5
|
entry.name item.author
|
4
6
|
entry.uri item.url
|
5
7
|
end
|
6
|
-
entry.title item.feed_title, "type"=>"html"
|
7
|
-
entry.content html(item), "type"=>"html"
|
8
|
+
entry.title item.feed_title, "type" => "html"
|
9
|
+
entry.content html(item), "type" => "html"
|
8
10
|
end
|
9
|
-
|
10
|
-
|
@@ -1,9 +1,10 @@
|
|
1
|
-
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
feed.entry item, id: "urn:uuid:#{item.guid}", url: item.permalink_url do |entry|
|
2
4
|
entry.author do
|
3
5
|
entry.name item.blog_name
|
4
6
|
entry.uri item.url
|
5
7
|
end
|
6
|
-
entry.title item.feed_title, "type"=>"html"
|
7
|
-
entry.summary item.excerpt, "type"=>"html"
|
8
|
+
entry.title item.feed_title, "type" => "html"
|
9
|
+
entry.summary item.excerpt, "type" => "html"
|
8
10
|
end
|
9
|
-
|
@@ -0,0 +1,8 @@
|
|
1
|
+
<script type="text/javascript">
|
2
|
+
var gaJsHost = (("https:" == document.location.protocol) ? "https://ssl." : "http://www.");
|
3
|
+
document.write(unescape("%3Cscript src='" + gaJsHost + "google-analytics.com/ga.js' type='text/javascript'%3E%3C/script%3E"));
|
4
|
+
</script>
|
5
|
+
<script type="text/javascript">
|
6
|
+
var pageTracker = _gat._getTracker("<%= this_blog.google_analytics %>");
|
7
|
+
pageTracker._trackPageview();
|
8
|
+
</script>
|
@@ -1,26 +1,23 @@
|
|
1
|
-
<meta http-equiv="content-type" content="text/html; charset=utf-8"
|
1
|
+
<meta http-equiv="content-type" content="text/html; charset=utf-8" />
|
2
2
|
<%= meta_tag 'ICBM', this_blog.geourl_location if this_blog.geourl_location.present? %>
|
3
|
-
<%= meta_tag 'description', @description
|
3
|
+
<%= meta_tag 'description', @description if @description.present? %>
|
4
4
|
<%= meta_tag 'robots', 'noindex, follow' if stop_index_robots?(this_blog) %>
|
5
|
-
<%= meta_tag 'google-site-verification', this_blog.google_verification
|
6
|
-
<meta name="generator" content="Publify <%=PublifyCore::VERSION%>"
|
5
|
+
<%= meta_tag 'google-site-verification', this_blog.google_verification if this_blog.google_verification.present? %>
|
6
|
+
<meta name="generator" content="Publify <%= PublifyCore::VERSION %>" />
|
7
7
|
<%= show_meta_keyword %>
|
8
|
-
<link rel="EditURI" type="application/rsd+xml" title="RSD" href="<%= url_for :controller => '/xml', :action => 'rsd' %>">
|
9
8
|
<% if feed_atom %>
|
10
|
-
<link rel="alternate" type="application/atom+xml" title="Atom" href="<%= feed_atom %>"
|
9
|
+
<link rel="alternate" type="application/atom+xml" title="Atom" href="<%= feed_atom %>" />
|
11
10
|
<% end %>
|
12
11
|
<% if feed_rss %>
|
13
|
-
<link rel="alternate" type="application/rss+xml" title="RSS" href="<%= feed_rss %>"
|
12
|
+
<link rel="alternate" type="application/rss+xml" title="RSS" href="<%= feed_rss %>" />
|
14
13
|
<% end %>
|
15
14
|
<%= javascript_include_tag :publify, async: Rails.env.production? %>
|
15
|
+
<%= csrf_meta_tags %>
|
16
16
|
<%= stylesheet_link_tag :publify %>
|
17
17
|
<%= page_header_includes %>
|
18
|
-
|
19
|
-
|
20
|
-
|
21
|
-
<%= raw this_blog.custom_tracking_field unless this_blog.custom_tracking_field.blank? %>
|
22
|
-
<%= google_analytics %>
|
18
|
+
<link rel="canonical" href="<%= this_blog.url_for request.fullpath %>" />
|
19
|
+
<%= raw this_blog.custom_tracking_field if this_blog.custom_tracking_field.present? %>
|
20
|
+
<%= render 'shared/google_analytics' if this_blog.google_analytics.present? %>
|
23
21
|
|
24
22
|
<%= meta_tag 'og:site_name', this_blog.blog_name %>
|
25
23
|
<%= meta_tag 'og:title', @article ? @article.title : @page_title %>
|
26
|
-
<link ref='author' href="humans.txt">
|
@@ -1,35 +1,32 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
xm.item do
|
2
4
|
if item.is_a?(Note)
|
3
|
-
xm.title truncate(item.html(:body).strip_html, length: 80, separator:
|
5
|
+
xm.title truncate(item.html(:body).strip_html, length: 80, separator: " ",
|
6
|
+
omissions: "...")
|
4
7
|
else
|
5
8
|
xm.title item.title
|
6
9
|
end
|
7
10
|
content_html = fetch_html_content_for_feeds(item, this_blog)
|
8
|
-
xm.description content_html + item.
|
11
|
+
xm.description content_html + item.rss_description
|
9
12
|
xm.pubDate item.published_at.rfc822
|
10
13
|
xm.guid "urn:uuid:#{item.guid}", "isPermaLink" => "false"
|
11
|
-
|
12
|
-
xm.author "#{item.user.email} (#{item.user.name})"
|
13
|
-
end
|
14
|
+
xm.dc :creator, item.author_name
|
14
15
|
|
15
16
|
if item.is_a?(Article)
|
16
17
|
xm.comments(item.permalink_url("comments"))
|
17
|
-
|
18
|
+
item.tags.each do |tag|
|
18
19
|
xm.category tag.display_name
|
19
20
|
end
|
20
21
|
# RSS 2.0 only allows a single enclosure per item, so only include the first one here.
|
21
|
-
|
22
|
+
unless item.resources.empty?
|
22
23
|
resource = item.resources.first
|
23
24
|
xm.enclosure(
|
24
|
-
:
|
25
|
-
:
|
26
|
-
:
|
27
|
-
end
|
25
|
+
url: item.blog.file_url(resource.upload_url),
|
26
|
+
length: resource.size,
|
27
|
+
type: resource.mime)
|
28
28
|
end
|
29
|
-
|
30
|
-
if item.allow_pings?
|
31
|
-
xm.trackback :ping, item.trackback_url
|
32
29
|
end
|
30
|
+
|
33
31
|
xm.link item.permalink_url
|
34
32
|
end
|
35
|
-
|
@@ -9,7 +9,7 @@
|
|
9
9
|
<% end %>
|
10
10
|
</ul>
|
11
11
|
<% else %>
|
12
|
-
<p><%= t(
|
12
|
+
<p><%= t('.there_are_no_tags') %></p>
|
13
13
|
<% end %>
|
14
14
|
</div>
|
15
|
-
<p><%= paginate
|
15
|
+
<p><%= paginate @tags %></p>
|
@@ -0,0 +1,9 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
xml.instruct! :xml, version: "1.0", encoding: "UTF-8"
|
4
|
+
xml.urlset "xmlns" => "http://www.google.com/schemas/sitemap/0.84" do
|
5
|
+
@items.each do |item|
|
6
|
+
render "googlesitemap_item_#{item.class.name.to_s.downcase}",
|
7
|
+
item: item, xm: xml
|
8
|
+
end
|
9
|
+
end
|
data/config/i18n-tasks.yml
CHANGED
@@ -17,11 +17,6 @@ data:
|
|
17
17
|
- ['*_sidebar.*', 'config/locales/sidebars.%{locale}.yml']
|
18
18
|
- config/locales/%{locale}.yml
|
19
19
|
|
20
|
-
yaml:
|
21
|
-
write:
|
22
|
-
# do not wrap lines at 80 characters
|
23
|
-
line_width: -1
|
24
|
-
|
25
20
|
# Find translate calls
|
26
21
|
search:
|
27
22
|
## Paths or `File.find` patterns to search in:
|
@@ -1,3 +1,5 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
1
3
|
# Use this hook to configure devise mailer, warden hooks and so forth.
|
2
4
|
# Many of these configuration options can be set straight in your model.
|
3
5
|
Devise.setup do |config|
|
@@ -6,13 +8,15 @@ Devise.setup do |config|
|
|
6
8
|
# confirmation, reset password and unlock tokens in the database.
|
7
9
|
# Devise will use the `secret_key_base` on Rails 4+ applications as its `secret_key`
|
8
10
|
# by default. You can change it below and use your own secret key.
|
9
|
-
# config.secret_key =
|
11
|
+
# config.secret_key =
|
12
|
+
# '99a1fd068906f7a32686e001fff91fdfb88703303de85657ab63ad5405ae7c3b' \
|
13
|
+
# '215c144c0dd4eaf2e68f3e3dae8c43e132968dd0b32e4c78ac1e86b202e3c6ee'
|
10
14
|
|
11
15
|
# ==> Mailer Configuration
|
12
16
|
# Configure the e-mail address which will be shown in Devise::Mailer,
|
13
17
|
# note that it will be overwritten if you use your own mailer class
|
14
18
|
# with default "from" parameter.
|
15
|
-
config.mailer_sender =
|
19
|
+
config.mailer_sender = "change-me@example.com"
|
16
20
|
|
17
21
|
# Configure the class responsible to send e-mails.
|
18
22
|
# config.mailer = 'Devise::Mailer'
|
@@ -21,7 +25,7 @@ Devise.setup do |config|
|
|
21
25
|
# Load and configure the ORM. Supports :active_record (default) and
|
22
26
|
# :mongoid (bson_ext recommended) by default. Other ORMs may be
|
23
27
|
# available as additional gems.
|
24
|
-
require
|
28
|
+
require "devise/orm/active_record"
|
25
29
|
|
26
30
|
# ==> Configuration for any authentication mechanism
|
27
31
|
# Configure which keys are used when authenticating a user. The default is
|
@@ -99,7 +103,9 @@ Devise.setup do |config|
|
|
99
103
|
config.stretches = Rails.env.test? ? 1 : 10
|
100
104
|
|
101
105
|
# Setup a pepper to generate the encrypted password.
|
102
|
-
# config.pepper =
|
106
|
+
# config.pepper =
|
107
|
+
# 'cd666dfd37982f9981838aa0bc32a04099d309a831dffcf64c3ec1814e9ae9ad' \
|
108
|
+
# '4fde148638675ee2443b5c532222ff007c032e76fc0eec24c5fb4fccfd3546a3'
|
103
109
|
|
104
110
|
# Send a notification email when the user's password is changed
|
105
111
|
# config.send_password_change_notification = false
|