HornsAndHooves-publify_core 10.0.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/CHANGELOG.md +102 -0
- data/MIT-LICENSE +21 -0
- data/README.md +9 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.eot +0 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.svg +288 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.ttf +0 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.woff +0 -0
- data/app/assets/fonts/bootstrap/glyphicons-halflings-regular.woff2 +0 -0
- data/app/assets/fonts/open-sans-bold.woff +0 -0
- data/app/assets/fonts/open-sans.woff +0 -0
- data/app/assets/images/admin/loading.gif +0 -0
- data/app/assets/images/admin/typologo.gif +0 -0
- data/app/assets/images/calendar_date_select/calendar.gif +0 -0
- data/app/assets/images/close.gif +0 -0
- data/app/assets/images/closelabel.gif +0 -0
- data/app/assets/images/go.png +0 -0
- data/app/assets/images/loading.gif +0 -0
- data/app/assets/images/nextlabel.gif +0 -0
- data/app/assets/images/overlay.png +0 -0
- data/app/assets/images/powered.gif +0 -0
- data/app/assets/images/prevlabel.gif +0 -0
- data/app/assets/images/spinner-blue.gif +0 -0
- data/app/assets/images/spinner.gif +0 -0
- data/app/assets/images/thumb_blank.jpg +0 -0
- data/app/assets/javascripts/application.js +2 -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/bootstrap-sprockets.js +8 -0
- data/app/assets/javascripts/cookies.js +60 -0
- data/app/assets/javascripts/datetimepicker.js +1470 -0
- data/app/assets/javascripts/lang/da_DK.js +17 -0
- data/app/assets/javascripts/lang/default.js +21 -0
- data/app/assets/javascripts/lang/en_US.js +21 -0
- data/app/assets/javascripts/lang/fr_FR.js +21 -0
- data/app/assets/javascripts/lang/nl_NL.js +21 -0
- data/app/assets/javascripts/lang/zh_TW.js +17 -0
- data/app/assets/javascripts/lightbox.js +350 -0
- data/app/assets/javascripts/observe.js +28 -0
- data/app/assets/javascripts/publify.js +11 -0
- data/app/assets/javascripts/publify_admin.js +104 -0
- data/app/assets/javascripts/quicktags.js +448 -0
- data/app/assets/javascripts/set-timeago-lang.js +3 -0
- data/app/assets/javascripts/sidebar.js +28 -0
- data/app/assets/javascripts/spinnable.js +5 -0
- data/app/assets/javascripts/tagmanager.js +481 -0
- data/app/assets/javascripts/typeahead.js +1139 -0
- 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 +43 -0
- data/app/assets/stylesheets/accounts.css.scss +7 -0
- data/app/assets/stylesheets/administration_structure.css.scss +255 -0
- 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/_glyphicons.scss +307 -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 +654 -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/coderay.css +135 -0
- data/app/assets/stylesheets/datetimepicker.css +306 -0
- data/app/assets/stylesheets/lightbox.css +63 -0
- data/app/assets/stylesheets/publify.css.scss +9 -0
- data/app/assets/stylesheets/publify_admin.css.scss +10 -0
- data/app/assets/stylesheets/rss.css +53 -0
- data/app/assets/stylesheets/sidebar_admin.css.scss +36 -0
- data/app/assets/stylesheets/tagmanager.css +102 -0
- data/app/assets/stylesheets/user-styles.css +29 -0
- data/app/controllers/accounts_controller.rb +4 -0
- data/app/controllers/admin/base_controller.rb +27 -0
- data/app/controllers/admin/content_controller.rb +194 -0
- data/app/controllers/admin/dashboard_controller.rb +33 -0
- data/app/controllers/admin/feedback_controller.rb +160 -0
- data/app/controllers/admin/notes_controller.rb +73 -0
- data/app/controllers/admin/pages_controller.rb +73 -0
- data/app/controllers/admin/post_types_controller.rb +57 -0
- data/app/controllers/admin/profiles_controller.rb +57 -0
- data/app/controllers/admin/redirects_controller.rb +51 -0
- data/app/controllers/admin/resources_controller.rb +36 -0
- data/app/controllers/admin/seo_controller.rb +46 -0
- data/app/controllers/admin/settings_controller.rb +53 -0
- data/app/controllers/admin/sidebar_controller.rb +67 -0
- data/app/controllers/admin/tags_controller.rb +55 -0
- data/app/controllers/admin/themes_controller.rb +31 -0
- data/app/controllers/admin/users_controller.rb +67 -0
- data/app/controllers/articles_controller.rb +215 -0
- data/app/controllers/authors_controller.rb +30 -0
- data/app/controllers/base_controller.rb +43 -0
- data/app/controllers/comments_controller.rb +67 -0
- data/app/controllers/content_controller.rb +24 -0
- data/app/controllers/feedback_controller.rb +13 -0
- data/app/controllers/notes_controller.rb +35 -0
- data/app/controllers/setup_controller.rb +61 -0
- data/app/controllers/tags_controller.rb +50 -0
- data/app/controllers/text_controller.rb +7 -0
- data/app/controllers/textfilter_controller.rb +5 -0
- data/app/controllers/theme_controller.rb +63 -0
- data/app/controllers/xml_controller.rb +20 -0
- data/app/helpers/admin/base_helper.rb +87 -0
- data/app/helpers/admin/feedback_helper.rb +53 -0
- data/app/helpers/articles_helper.rb +10 -0
- data/app/helpers/authors_helper.rb +30 -0
- data/app/helpers/base_helper.rb +257 -0
- data/app/helpers/blog_helper.rb +14 -0
- data/app/helpers/xml_helper.rb +18 -0
- data/app/jobs/application_job.rb +5 -0
- data/app/mailers/notification_mailer.rb +40 -0
- data/app/models/ability.rb +53 -0
- data/app/models/archives_sidebar.rb +45 -0
- data/app/models/article/factory.rb +64 -0
- data/app/models/article.rb +308 -0
- data/app/models/blog.rb +280 -0
- data/app/models/comment.rb +57 -0
- data/app/models/config_manager.rb +83 -0
- data/app/models/content.rb +118 -0
- data/app/models/content_base.rb +88 -0
- data/app/models/feedback.rb +250 -0
- data/app/models/meta_sidebar.rb +10 -0
- data/app/models/note.rb +152 -0
- data/app/models/page.rb +42 -0
- data/app/models/page_sidebar.rb +14 -0
- data/app/models/ping.rb +5 -0
- data/app/models/post_type.rb +16 -0
- data/app/models/redirect.rb +51 -0
- data/app/models/redirection.rb +6 -0
- data/app/models/resource.rb +12 -0
- data/app/models/search_sidebar.rb +9 -0
- data/app/models/sidebar.rb +142 -0
- data/app/models/static_sidebar.rb +22 -0
- data/app/models/tag.rb +71 -0
- data/app/models/tag_sidebar.rb +30 -0
- data/app/models/text_filter.rb +141 -0
- data/app/models/trackback.rb +46 -0
- data/app/models/trigger.rb +34 -0
- data/app/models/user.rb +142 -0
- data/app/services/title_builder.rb +88 -0
- data/app/uploaders/resource_uploader.rb +63 -0
- data/app/views/accounts/confirm.html.erb +7 -0
- data/app/views/admin/content/_article_list.html.erb +26 -0
- data/app/views/admin/content/_form.html.erb +145 -0
- data/app/views/admin/content/autosave.js.erb +5 -0
- data/app/views/admin/content/edit.html.erb +3 -0
- data/app/views/admin/content/index.html.erb +48 -0
- data/app/views/admin/content/index.js.erb +1 -0
- data/app/views/admin/content/new.html.erb +3 -0
- data/app/views/admin/dashboard/_comment.html.erb +18 -0
- data/app/views/admin/dashboard/_comments.html.erb +10 -0
- data/app/views/admin/dashboard/_drafts.html.erb +25 -0
- data/app/views/admin/dashboard/_overview.html.erb +21 -0
- data/app/views/admin/dashboard/_welcome.html.erb +28 -0
- data/app/views/admin/dashboard/index.html.erb +16 -0
- data/app/views/admin/feedback/_button.html.erb +19 -0
- data/app/views/admin/feedback/_feedback.html.erb +7 -0
- data/app/views/admin/feedback/_ham.html.erb +17 -0
- data/app/views/admin/feedback/_spam.html.erb +23 -0
- data/app/views/admin/feedback/article.html.erb +69 -0
- data/app/views/admin/feedback/edit.html.erb +48 -0
- data/app/views/admin/feedback/ham.js +1 -0
- data/app/views/admin/feedback/index.html.erb +53 -0
- data/app/views/admin/feedback/spam.js +1 -0
- data/app/views/admin/migrations/show.html.erb +39 -0
- data/app/views/admin/notes/_form.html.erb +37 -0
- data/app/views/admin/notes/_header.html.erb +6 -0
- data/app/views/admin/notes/_list.html.erb +13 -0
- data/app/views/admin/notes/_note.html.erb +14 -0
- data/app/views/admin/notes/edit.html.erb +11 -0
- data/app/views/admin/notes/index.html.erb +11 -0
- data/app/views/admin/notes/show.html.erb +14 -0
- data/app/views/admin/pages/_form.html.erb +101 -0
- data/app/views/admin/pages/_pages.html.erb +21 -0
- data/app/views/admin/pages/edit.html.erb +1 -0
- data/app/views/admin/pages/index.html.erb +17 -0
- data/app/views/admin/pages/new.html.erb +1 -0
- data/app/views/admin/post_types/_index_and_form.html.erb +65 -0
- data/app/views/admin/post_types/edit.html.erb +1 -0
- data/app/views/admin/post_types/index.html.erb +1 -0
- data/app/views/admin/profiles/index.html.erb +10 -0
- data/app/views/admin/redirects/_index_and_form.html.erb +68 -0
- data/app/views/admin/redirects/edit.html.erb +1 -0
- data/app/views/admin/redirects/index.html.erb +1 -0
- data/app/views/admin/resources/index.html.erb +72 -0
- data/app/views/admin/seo/_general.html.erb +104 -0
- data/app/views/admin/seo/_permalinks.html.erb +53 -0
- data/app/views/admin/seo/_titles.html.erb +209 -0
- data/app/views/admin/seo/show.html.erb +28 -0
- data/app/views/admin/settings/display.html.erb +101 -0
- data/app/views/admin/settings/feedback.html.erb +118 -0
- data/app/views/admin/settings/index.html.erb +73 -0
- data/app/views/admin/settings/write.html.erb +69 -0
- data/app/views/admin/shared/_edit.html.erb +4 -0
- data/app/views/admin/shared/_menu.html.erb +121 -0
- data/app/views/admin/shared/_twitter_alert.html.erb +3 -0
- data/app/views/admin/sidebar/_available.html.erb +6 -0
- data/app/views/admin/sidebar/_available.json.erb +6 -0
- data/app/views/admin/sidebar/_config.html.erb +27 -0
- data/app/views/admin/sidebar/_target.html.erb +9 -0
- data/app/views/admin/sidebar/_target_sidebar.html.erb +20 -0
- data/app/views/admin/sidebar/destroy.js.erb +1 -0
- data/app/views/admin/sidebar/index.html.erb +31 -0
- data/app/views/admin/sidebar/sortable.js.erb +3 -0
- data/app/views/admin/sidebar/update.js.erb +2 -0
- data/app/views/admin/tags/_index_and_form.html.erb +59 -0
- data/app/views/admin/tags/edit.html.erb +1 -0
- data/app/views/admin/tags/index.html.erb +1 -0
- data/app/views/admin/themes/index.html.erb +27 -0
- data/app/views/admin/users/_form.html.erb +215 -0
- data/app/views/admin/users/edit.html.erb +8 -0
- data/app/views/admin/users/index.html.erb +39 -0
- data/app/views/admin/users/new.html.erb +8 -0
- data/app/views/archives_sidebar/_content.html.erb +13 -0
- data/app/views/articles/_archives_article.html.erb +9 -0
- data/app/views/articles/_article.html.erb +9 -0
- data/app/views/articles/_article_author.html.erb +4 -0
- data/app/views/articles/_article_collection.html.erb +8 -0
- data/app/views/articles/_article_content.html.erb +5 -0
- data/app/views/articles/_article_excerpt.html.erb +15 -0
- data/app/views/articles/_article_links.html.erb +12 -0
- data/app/views/articles/_comment.html.erb +1 -0
- data/app/views/articles/_comment_errors.html.erb +2 -0
- data/app/views/articles/_comment_form.html.erb +48 -0
- data/app/views/articles/_comment_list.html.erb +5 -0
- data/app/views/articles/_comment_preview.html.erb +4 -0
- data/app/views/articles/_full_article_content.html.erb +4 -0
- data/app/views/articles/_password_form.html.erb +10 -0
- data/app/views/articles/_trackback.html.erb +6 -0
- data/app/views/articles/archives.html.erb +15 -0
- data/app/views/articles/comment.js.erb +5 -0
- data/app/views/articles/comment_failed.js.erb +3 -0
- data/app/views/articles/error.html.erb +3 -0
- data/app/views/articles/feedback_atom_feed.atom.builder +10 -0
- data/app/views/articles/feedback_rss_feed.rss.builder +21 -0
- data/app/views/articles/index.html.erb +1 -0
- data/app/views/articles/index_atom_feed.atom.builder +9 -0
- data/app/views/articles/index_rss_feed.rss.builder +20 -0
- data/app/views/articles/live_search.html.erb +10 -0
- data/app/views/articles/read.html.erb +43 -0
- data/app/views/articles/search.html.erb +8 -0
- data/app/views/articles/trackback.xml.builder +7 -0
- data/app/views/articles/view_page.html.erb +3 -0
- data/app/views/authors/show.html.erb +30 -0
- data/app/views/authors/show_atom_feed.atom.builder +9 -0
- data/app/views/authors/show_rss_feed.rss.builder +20 -0
- data/app/views/comments/_comment.html.erb +17 -0
- data/app/views/comments/preview.html.erb +1 -0
- data/app/views/comments/preview.js.erb +3 -0
- data/app/views/devise/mailer/reset_password_instructions.html.erb +11 -0
- data/app/views/devise/passwords/edit.html.erb +28 -0
- data/app/views/devise/passwords/new.html.erb +20 -0
- data/app/views/devise/registrations/new.html.erb +36 -0
- data/app/views/devise/sessions/new.html.erb +32 -0
- data/app/views/devise/shared/_links.html.erb +11 -0
- data/app/views/errors/404.html.erb +2 -0
- 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 +33 -0
- data/app/views/layouts/administration.html.erb +37 -0
- data/app/views/layouts/default.html.erb +33 -0
- data/app/views/layouts/editor.html.erb +17 -0
- data/app/views/meta_sidebar/_content.html.erb +8 -0
- data/app/views/notes/_note.html.erb +16 -0
- data/app/views/notes/error.html.erb +3 -0
- data/app/views/notes/index.html.erb +15 -0
- data/app/views/notes/show.html.erb +5 -0
- data/app/views/notes/show_in_reply.html.erb +18 -0
- data/app/views/notification_mailer/_mail_footer.html.erb +5 -0
- data/app/views/notification_mailer/_mail_header.html.erb +3 -0
- data/app/views/notification_mailer/article.html.erb +7 -0
- data/app/views/notification_mailer/comment.html.erb +12 -0
- data/app/views/notification_mailer/notif_user.html.erb +9 -0
- data/app/views/page_sidebar/_content.html.erb +12 -0
- data/app/views/search_sidebar/_content.html.erb +10 -0
- data/app/views/settings/done.html.erb +2 -0
- data/app/views/settings/install.html.erb +12 -0
- data/app/views/setup/index.html.erb +17 -0
- data/app/views/shared/_atom_header.atom.builder +6 -0
- data/app/views/shared/_atom_item_article.atom.builder +36 -0
- data/app/views/shared/_atom_item_comment.atom.builder +10 -0
- data/app/views/shared/_atom_item_trackback.atom.builder +10 -0
- data/app/views/shared/_flash.erb +10 -0
- data/app/views/shared/_google_analytics.html.erb +8 -0
- data/app/views/shared/_page_header.html.erb +23 -0
- data/app/views/shared/_rss_item_article.rss.builder +32 -0
- data/app/views/shared/_rss_item_comment.rss.builder +9 -0
- data/app/views/shared/_rss_item_trackback.rss.builder +9 -0
- data/app/views/sidebar/_row.html.erb +1 -0
- data/app/views/sidebar/_sidebar.html.erb +5 -0
- data/app/views/sidebar/display_plugins.html.erb +5 -0
- data/app/views/sidebar/show.html.erb +1 -0
- data/app/views/static_sidebar/_content.html.erb +2 -0
- data/app/views/tag_sidebar/_content.html.erb +10 -0
- data/app/views/tags/index.html.erb +15 -0
- data/app/views/tags/show.html.erb +1 -0
- data/app/views/theme/static_view_test.html.erb +1 -0
- data/app/views/xml/_googlesitemap_item_article.googlesitemap.builder +7 -0
- data/app/views/xml/_googlesitemap_item_category.googlesitemap.builder +6 -0
- data/app/views/xml/_googlesitemap_item_page.googlesitemap.builder +6 -0
- data/app/views/xml/_googlesitemap_item_tag.googlesitemap.builder +6 -0
- data/app/views/xml/sitemap.googlesitemap.builder +9 -0
- data/config/i18n-tasks.yml +49 -0
- data/config/initializers/devise.rb +271 -0
- data/config/initializers/mime_types.rb +7 -0
- data/config/locales/da.yml +769 -0
- data/config/locales/de.yml +769 -0
- data/config/locales/en.yml +770 -0
- data/config/locales/es-MX.yml +769 -0
- data/config/locales/fr.yml +769 -0
- data/config/locales/he.yml +769 -0
- data/config/locales/it.yml +769 -0
- data/config/locales/ja.yml +769 -0
- data/config/locales/lt.yml +783 -0
- data/config/locales/nb-NO.yml +769 -0
- data/config/locales/nl.yml +769 -0
- data/config/locales/pl.yml +797 -0
- data/config/locales/pt-BR.yml +769 -0
- data/config/locales/ro.yml +782 -0
- data/config/locales/ru.yml +797 -0
- data/config/locales/sidebars.da.yml +20 -0
- data/config/locales/sidebars.de.yml +20 -0
- data/config/locales/sidebars.en.yml +20 -0
- data/config/locales/sidebars.es-MX.yml +20 -0
- data/config/locales/sidebars.fr.yml +20 -0
- data/config/locales/sidebars.he.yml +20 -0
- data/config/locales/sidebars.it.yml +20 -0
- data/config/locales/sidebars.ja.yml +20 -0
- data/config/locales/sidebars.lt.yml +20 -0
- data/config/locales/sidebars.nb-NO.yml +20 -0
- data/config/locales/sidebars.nl.yml +20 -0
- data/config/locales/sidebars.pl.yml +20 -0
- data/config/locales/sidebars.pt-BR.yml +20 -0
- data/config/locales/sidebars.ro.yml +20 -0
- data/config/locales/sidebars.ru.yml +20 -0
- data/config/locales/sidebars.zh-CN.yml +20 -0
- data/config/locales/sidebars.zh-TW.yml +20 -0
- data/config/locales/zh-CN.yml +768 -0
- data/config/locales/zh-TW.yml +769 -0
- data/config/routes.rb +174 -0
- data/db/migrate/113_initial_schema.rb +210 -0
- data/db/migrate/114_fixes_buggy_articles_and_notes.rb +56 -0
- data/db/migrate/115_drops_categories_for_tags.rb +37 -0
- data/db/migrate/20150207131657_add_missing_indexes.rb +23 -0
- data/db/migrate/20150807134129_simplify_redirect_relations.rb +45 -0
- data/db/migrate/20150808052637_add_blog_ids.rb +39 -0
- data/db/migrate/20150808191127_add_blog_id_to_redirects.rb +19 -0
- data/db/migrate/20150810094754_add_blog_id_to_tags.rb +19 -0
- data/db/migrate/20160108111120_add_devise_to_users.rb +57 -0
- data/db/migrate/20160108184201_move_last_connection_to_last_sign_in_at.rb +20 -0
- data/db/migrate/20160110094906_remove_profiles_rights.rb +18 -0
- data/db/migrate/20160605103918_replace_profile_id_with_string.rb +32 -0
- data/db/migrate/20160605154632_remove_profiles.rb +31 -0
- data/db/migrate/20160701061851_demand_blog_id_on_contents.rb +13 -0
- data/db/migrate/20160701062604_add_blog_id_to_resources.rb +32 -0
- data/db/migrate/20170528093024_move_resources_to_content.rb +9 -0
- data/db/migrate/20170528094923_move_tags_to_content.rb +10 -0
- data/db/migrate/20170528201606_remove_separate_published_flag.rb +9 -0
- data/db/migrate/20170605071626_remove_extra_state_columns_from_feedback.rb +10 -0
- data/db/migrate/20170702105201_remove_published_at_from_feedback.rb +9 -0
- data/db/migrate/20190208151235_add_text_filter_name_fields.rb +11 -0
- data/db/migrate/20190208152646_move_text_filter_to_name.rb +99 -0
- data/db/migrate/20190209155717_remove_text_filter_ids.rb +21 -0
- data/db/migrate/20190209160610_remove_text_filters.rb +19 -0
- data/db/seeds.rb +25 -0
- data/lib/email_notify.rb +28 -0
- data/lib/format.rb +9 -0
- data/lib/publify_core/engine.rb +31 -0
- data/lib/publify_core/lang.rb +9 -0
- data/lib/publify_core/testing_support/dns_mock.rb +15 -0
- data/lib/publify_core/testing_support/factories.rb +242 -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 +5 -0
- data/lib/publify_core.rb +46 -0
- data/lib/publify_guid.rb +11 -0
- data/lib/publify_plugins.rb +77 -0
- data/lib/publify_textfilter_markdown.rb +57 -0
- data/lib/publify_textfilter_none.rb +16 -0
- data/lib/publify_textfilter_smartypants.rb +16 -0
- data/lib/publify_textfilter_textile.rb +23 -0
- data/lib/publify_textfilter_twitterfilter.rb +39 -0
- data/lib/publify_time.rb +34 -0
- data/lib/sidebar_field.rb +127 -0
- data/lib/sidebar_registry.rb +35 -0
- data/lib/spam_protection.rb +103 -0
- data/lib/tasks/i18n.rake +9 -0
- data/lib/tasks/manifest.rake +30 -0
- data/lib/tasks/publify_core_tasks.rake +6 -0
- data/lib/text_filter_plugin.rb +183 -0
- data/lib/theme.rb +72 -0
- data/lib/transforms.rb +47 -0
- data/themes/plain/about.markdown +4 -0
- data/themes/plain/javascripts/theme.js +0 -0
- data/themes/plain/preview.png +0 -0
- data/themes/plain/stylesheets/theme.css +57 -0
- metadata +1062 -0
data/app/models/user.rb
ADDED
@@ -0,0 +1,142 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "digest/sha1"
|
4
|
+
|
5
|
+
# Publify user.
|
6
|
+
# TODO: Should belong to a blog
|
7
|
+
class User < ApplicationRecord
|
8
|
+
ADMIN = "admin"
|
9
|
+
PUBLISHER = "publisher"
|
10
|
+
CONTRIBUTOR = "contributor"
|
11
|
+
|
12
|
+
# Include default devise modules. Others available are:
|
13
|
+
# :confirmable, :lockable, :timeoutable and :omniauthable
|
14
|
+
devise :database_authenticatable, :registerable,
|
15
|
+
:recoverable, :rememberable, :trackable, :validatable
|
16
|
+
include ConfigManager
|
17
|
+
|
18
|
+
before_validation :set_default_profile
|
19
|
+
|
20
|
+
validates :login, uniqueness: true, on: :create
|
21
|
+
validates :email, uniqueness: true, on: :create
|
22
|
+
validates :email, :login, presence: true
|
23
|
+
validates :login, length: { in: 3..40 }
|
24
|
+
|
25
|
+
belongs_to :resource, optional: true
|
26
|
+
has_many :notifications, foreign_key: "notify_user_id"
|
27
|
+
has_many :notify_contents, -> { uniq }, through: :notifications,
|
28
|
+
source: "notify_content"
|
29
|
+
|
30
|
+
has_many :articles
|
31
|
+
|
32
|
+
serialize :settings, Hash
|
33
|
+
|
34
|
+
STATUS = %w(active inactive).freeze
|
35
|
+
|
36
|
+
attr_accessor :filename
|
37
|
+
|
38
|
+
# Settings
|
39
|
+
setting :notify_watch_my_articles, :boolean, true
|
40
|
+
setting :firstname, :string, ""
|
41
|
+
setting :lastname, :string, ""
|
42
|
+
setting :nickname, :string, ""
|
43
|
+
setting :description, :string, ""
|
44
|
+
setting :url, :string, ""
|
45
|
+
setting :msn, :string, ""
|
46
|
+
setting :aim, :string, ""
|
47
|
+
setting :yahoo, :string, ""
|
48
|
+
setting :twitter, :string, ""
|
49
|
+
setting :jabber, :string, ""
|
50
|
+
setting :admin_theme, :string, "blue"
|
51
|
+
setting :twitter_account, :string, ""
|
52
|
+
setting :twitter_oauth_token, :string, ""
|
53
|
+
setting :twitter_oauth_token_secret, :string, ""
|
54
|
+
setting :twitter_profile_image, :string, ""
|
55
|
+
|
56
|
+
# echo "publify" | sha1sum -
|
57
|
+
class_attribute :salt
|
58
|
+
|
59
|
+
def self.salt
|
60
|
+
"20ac4d290c2293702c64b3b287ae5ea79b26a5c1"
|
61
|
+
end
|
62
|
+
|
63
|
+
def first_and_last_name
|
64
|
+
return "" unless firstname.present? && lastname.present?
|
65
|
+
|
66
|
+
"#{firstname} #{lastname}"
|
67
|
+
end
|
68
|
+
|
69
|
+
def display_names
|
70
|
+
[:login, :nickname, :firstname, :lastname, :first_and_last_name].
|
71
|
+
map { |f| send(f) }.delete_if(&:empty?)
|
72
|
+
end
|
73
|
+
|
74
|
+
# Authenticate users with old password hashes
|
75
|
+
alias devise_valid_password? valid_password?
|
76
|
+
|
77
|
+
def valid_password?(password)
|
78
|
+
devise_valid_password?(password)
|
79
|
+
rescue BCrypt::Errors::InvalidHash
|
80
|
+
digest = Digest::SHA1.hexdigest("#{self.class.salt}--#{password}--")
|
81
|
+
if digest == encrypted_password
|
82
|
+
# Update old SHA1 password with new Devise ByCrypt password
|
83
|
+
self.encrypted_password = password_digest(password)
|
84
|
+
save
|
85
|
+
true
|
86
|
+
else
|
87
|
+
# If not BCrypt password and not old SHA1 password deny access
|
88
|
+
false
|
89
|
+
end
|
90
|
+
end
|
91
|
+
|
92
|
+
def active_for_authentication?
|
93
|
+
super && state == "active"
|
94
|
+
end
|
95
|
+
|
96
|
+
def text_filter
|
97
|
+
TextFilter.make_filter(text_filter_name)
|
98
|
+
end
|
99
|
+
|
100
|
+
def self.to_prefix
|
101
|
+
"author"
|
102
|
+
end
|
103
|
+
|
104
|
+
def article_counter
|
105
|
+
articles.size
|
106
|
+
end
|
107
|
+
|
108
|
+
def display_name
|
109
|
+
if nickname.present?
|
110
|
+
nickname
|
111
|
+
elsif name.present?
|
112
|
+
name
|
113
|
+
else
|
114
|
+
login
|
115
|
+
end
|
116
|
+
end
|
117
|
+
|
118
|
+
def permalink
|
119
|
+
login
|
120
|
+
end
|
121
|
+
|
122
|
+
def admin?
|
123
|
+
profile == User::ADMIN
|
124
|
+
end
|
125
|
+
|
126
|
+
def update_twitter_profile_image(img)
|
127
|
+
return if twitter_profile_image == img
|
128
|
+
|
129
|
+
self.twitter_profile_image = img
|
130
|
+
save
|
131
|
+
end
|
132
|
+
|
133
|
+
def has_twitter_configured?
|
134
|
+
twitter_oauth_token.present? && twitter_oauth_token_secret.present?
|
135
|
+
end
|
136
|
+
|
137
|
+
private
|
138
|
+
|
139
|
+
def set_default_profile
|
140
|
+
self.profile ||= User.count.zero? ? "admin" : "contributor"
|
141
|
+
end
|
142
|
+
end
|
@@ -0,0 +1,88 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
class TitleBuilder
|
4
|
+
def initialize(template)
|
5
|
+
@template = template
|
6
|
+
end
|
7
|
+
|
8
|
+
def build(item, settings, parameters)
|
9
|
+
str = @template
|
10
|
+
|
11
|
+
str = substitute_parameters(str, parameters)
|
12
|
+
str = substitute_settings(str, settings)
|
13
|
+
str = substitute_item(str, item)
|
14
|
+
str = substitute_time(str, settings)
|
15
|
+
|
16
|
+
str
|
17
|
+
end
|
18
|
+
|
19
|
+
private
|
20
|
+
|
21
|
+
def substitute_time(str, settings)
|
22
|
+
# Other
|
23
|
+
str = str.gsub("%currentdate%", Time.zone.now.strftime(settings.date_format))
|
24
|
+
str = str.gsub("%currenttime%", Time.zone.now.strftime(settings.time_format))
|
25
|
+
str = str.gsub("%currentmonth%", Time.zone.now.strftime("%B"))
|
26
|
+
str = str.gsub("%currentyear%", Time.zone.now.year.to_s)
|
27
|
+
str
|
28
|
+
end
|
29
|
+
|
30
|
+
def substitute_item(str, item)
|
31
|
+
# Tags for item
|
32
|
+
str = str.gsub("%title%", item.title) if str =~ /%title/ && item.respond_to?(:title)
|
33
|
+
if str =~ /%excerpt%/ && item.respond_to?(:excerpt_text)
|
34
|
+
str = str.gsub("%excerpt%", item.excerpt_text)
|
35
|
+
end
|
36
|
+
if str =~ /%description%/ && item.respond_to?(:description)
|
37
|
+
str = str.gsub("%description%", item.description)
|
38
|
+
end
|
39
|
+
str = str.gsub("%name%", item.name) if str =~ /%name%/ && item.respond_to?(:name)
|
40
|
+
str = str.gsub("%author%", item.name) if str =~ /%author%/ && item.respond_to?(:name)
|
41
|
+
str = str.gsub("%body%", item.body) if str =~ /%body%/ && item.respond_to?(:body)
|
42
|
+
|
43
|
+
if str =~ /%categories%/ && item.respond_to?(:categories)
|
44
|
+
str = str.gsub("%categories%", item.categories.map(&:name).join(", "))
|
45
|
+
end
|
46
|
+
|
47
|
+
if str =~ /%tags%/ && item.respond_to?(:tags)
|
48
|
+
str = str.gsub("%tags%", item.tags.map(&:display_name).join(", "))
|
49
|
+
end
|
50
|
+
|
51
|
+
str
|
52
|
+
end
|
53
|
+
|
54
|
+
def substitute_settings(str, settings)
|
55
|
+
# Tags for settings
|
56
|
+
str = str.gsub("%blog_name%", settings.blog_name)
|
57
|
+
str = str.gsub("%blog_subtitle%", settings.blog_subtitle)
|
58
|
+
str = str.gsub("%meta_keywords%", settings.meta_keywords)
|
59
|
+
|
60
|
+
str
|
61
|
+
end
|
62
|
+
|
63
|
+
def substitute_parameters(str, parameters)
|
64
|
+
str = str.gsub("%date%", parse_date(str, parameters)) if /%date%/.match?(str)
|
65
|
+
str = str.gsub("%search%", parameters[:q]) if parameters[:q]
|
66
|
+
str = str.gsub("%page%", parse_page(str, parameters)) if /%page%/.match?(str)
|
67
|
+
|
68
|
+
str
|
69
|
+
end
|
70
|
+
|
71
|
+
def parse_date(string, params)
|
72
|
+
return "" unless params[:year]
|
73
|
+
|
74
|
+
format = +""
|
75
|
+
format << "%A %d " if params[:day]
|
76
|
+
format << "%B " if params[:month]
|
77
|
+
format << "%Y" if params[:year]
|
78
|
+
|
79
|
+
string.gsub("%date%", Time.zone.local(*params.values_at(:year, :month, :day)).
|
80
|
+
strftime(format))
|
81
|
+
end
|
82
|
+
|
83
|
+
def parse_page(_string, params)
|
84
|
+
return "" unless params[:page]
|
85
|
+
|
86
|
+
"#{I18n.t("articles.index.page")} #{params[:page]}"
|
87
|
+
end
|
88
|
+
end
|
@@ -0,0 +1,63 @@
|
|
1
|
+
# frozen_string_literal: true
|
2
|
+
|
3
|
+
require "mimemagic"
|
4
|
+
|
5
|
+
class ResourceUploader < CarrierWave::Uploader::Base
|
6
|
+
include CarrierWave::MiniMagick
|
7
|
+
before :cache, :check_image_content_type!
|
8
|
+
|
9
|
+
def store_dir
|
10
|
+
"files/#{model.class.to_s.underscore}/#{model.id}"
|
11
|
+
end
|
12
|
+
|
13
|
+
version :thumb, if: :image? do
|
14
|
+
process dynamic_resize_to_fit: :thumb
|
15
|
+
end
|
16
|
+
|
17
|
+
version :medium, if: :image? do
|
18
|
+
process dynamic_resize_to_fit: :medium
|
19
|
+
end
|
20
|
+
|
21
|
+
version :avatar, if: :image? do
|
22
|
+
process dynamic_resize_to_fit: :avatar
|
23
|
+
end
|
24
|
+
|
25
|
+
def dynamic_resize_to_fit(size)
|
26
|
+
resize_setting = model.blog.send("image_#{size}_size").to_i
|
27
|
+
|
28
|
+
resize_to_fit(resize_setting, resize_setting)
|
29
|
+
end
|
30
|
+
|
31
|
+
def image?(new_file)
|
32
|
+
content_type = new_file.content_type
|
33
|
+
content_type&.include?("image")
|
34
|
+
end
|
35
|
+
|
36
|
+
def check_image_content_type!(new_file)
|
37
|
+
if image?(new_file)
|
38
|
+
magic_type = mime_magic_content_type(new_file)
|
39
|
+
if magic_type != new_file.content_type
|
40
|
+
raise CarrierWave::IntegrityError, "has MIME type mismatch"
|
41
|
+
end
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
private
|
46
|
+
|
47
|
+
# NOTE: This method was adapted from MagicMimeBlacklist#extract_content_type
|
48
|
+
# from CarrierWave 1.0.0 and SanitizedFile#mime_magic_content_type from CarrierWave 0.11.2
|
49
|
+
def mime_magic_content_type(new_file)
|
50
|
+
content_type = nil
|
51
|
+
|
52
|
+
File.open(new_file.path) do |fd|
|
53
|
+
content_type = MimeMagic.by_magic(fd).try(:type)
|
54
|
+
end
|
55
|
+
|
56
|
+
content_type
|
57
|
+
end
|
58
|
+
|
59
|
+
# NOTE: This method was copied from MagicMimeBlacklist from CarrierWave 1.0.0.
|
60
|
+
def filemagic
|
61
|
+
@filemagic ||= FileMagic.new(FileMagic::MAGIC_MIME_TYPE)
|
62
|
+
end
|
63
|
+
end
|
@@ -0,0 +1,7 @@
|
|
1
|
+
<p><%= t('.success') %></p>
|
2
|
+
<p><%= t('.login', login: current_user.login) %></p>
|
3
|
+
<div class='alert alert-warning'><%= t('.dont_lose_the_mail_sent', email: current_user.email) %></div>
|
4
|
+
|
5
|
+
<% content_for :account_links do %>
|
6
|
+
<%= raw t('.proceed_to', link: link_to(t('.admin'), controller: 'admin/dashboard')) %>
|
7
|
+
<% end %>
|
@@ -0,0 +1,26 @@
|
|
1
|
+
<% if @articles.empty? %>
|
2
|
+
<tr>
|
3
|
+
<td colspan="7">
|
4
|
+
<%= t('.no_articles') %>
|
5
|
+
</td>
|
6
|
+
</tr>
|
7
|
+
<% end %>
|
8
|
+
<% for article in @articles %>
|
9
|
+
<tr>
|
10
|
+
<td>
|
11
|
+
<% if article.published? %>
|
12
|
+
<%= link_to_permalink(article, article.title, nil, 'published') %>
|
13
|
+
<% else %>
|
14
|
+
<%= link_to(article.title, { controller: '/articles', action: 'preview', id: article.id }, { class: 'unpublished', target: '_new' }) %>
|
15
|
+
<% end %>
|
16
|
+
<%= show_actions article %>
|
17
|
+
</td>
|
18
|
+
<td>
|
19
|
+
<%= author_link(article) %><br />
|
20
|
+
<small><%= l(article.published_at || article.created_at) %></small>
|
21
|
+
</td>
|
22
|
+
<td>
|
23
|
+
<%= article.allow_comments? ? link_to("#{article.comments.ham.size} <i class='glyphicon glyphicon-comment'></i>".html_safe, controller: '/admin/feedback', id: article.id, action: 'article') : '-' %></td>
|
24
|
+
</tr>
|
25
|
+
<% end %>
|
26
|
+
<%= display_pagination(@articles, 5, 'first', 'last') %>
|
@@ -0,0 +1,145 @@
|
|
1
|
+
<%= hidden_field_tag 'user_textfilter', current_user.text_filter_name %>
|
2
|
+
<div id="autosave">
|
3
|
+
<%= hidden_field_tag('article[id]', @article.id) if @article.present? %>
|
4
|
+
</div>
|
5
|
+
<div class="row save-bar">
|
6
|
+
<div class="col-md-8 col-md-offset-2" id="save-bar">
|
7
|
+
<div class="pull-right">
|
8
|
+
<%= link_to(t('.cancel'), { action: 'index' }, { class: 'btn btn-default' }) %>
|
9
|
+
<span id="preview_link">
|
10
|
+
<%= link_to(t('.preview'), { controller: '/articles', action: 'preview', id: @article.id }, { target: 'new', class: 'btn btn-default' }) if @article.id %>
|
11
|
+
</span>
|
12
|
+
<input id="save_draft" type="submit" value="<%= t('.save_as_draft') %>" name="article[draft]" class="btn btn-default" />
|
13
|
+
<span class="btn btn-success" data-toggle="modal" data-target="#publishOptions">
|
14
|
+
<%= controller.action_name == 'new' ? t('.publish') : t('.save') %>
|
15
|
+
</span>
|
16
|
+
</div>
|
17
|
+
</div>
|
18
|
+
</div>
|
19
|
+
<div class="row">
|
20
|
+
<div class="col-md-8 col-md-offset-2" id="error-message-article">
|
21
|
+
<%= render 'shared/flash', flash: flash %>
|
22
|
+
<%= error_messages_for 'article' %>
|
23
|
+
</div>
|
24
|
+
</div>
|
25
|
+
<div class="row">
|
26
|
+
<div class="col-md-2" id="quicktags-block">
|
27
|
+
<div id="quicktags" class="pull-right">
|
28
|
+
<script type="text/javascript">edToolbar('article_body_and_extended', '<%= @article.text_filter.name %>');</script>
|
29
|
+
</div>
|
30
|
+
</div>
|
31
|
+
<div class="col-md-8">
|
32
|
+
<%= text_field 'article', 'title', class: 'form-control', placeholder: t('.title') %>
|
33
|
+
<%= select 'article', 'resource_id', resource_options, { prompt: 'Select Image' }, { class: 'form-control', required: "required" } %>
|
34
|
+
<div id="editor">
|
35
|
+
<%= text_area('article', 'body_and_extended', class: 'form-control ', style: 'height: 360px', placeholder: t('.type_your_post')) %>
|
36
|
+
</div>
|
37
|
+
</div>
|
38
|
+
</div>
|
39
|
+
<div class="modal fade" id="publishOptions" tabindex="-1" role="dialog" aria-labelledby="publishOptions" aria-hidden="true">
|
40
|
+
<div class="modal-dialog">
|
41
|
+
<div class="modal-content">
|
42
|
+
<div class="modal-header">
|
43
|
+
<h2 class="modal-title" id="myModalLabel"><%= t('.publish') %>
|
44
|
+
<%= submit_tag(t('.publish'), class: 'btn btn-success pull-right') %>
|
45
|
+
</h2>
|
46
|
+
</div>
|
47
|
+
<div class="modal-body">
|
48
|
+
<div class="well">
|
49
|
+
<h4><%= t('.tags') %></h4>
|
50
|
+
<div class="form-group">
|
51
|
+
<%= text_field 'article', 'keywords', autocomplete: 'off', class: 'form-control tm-input' %>
|
52
|
+
</div>
|
53
|
+
<p class="alert alert-warning"><%= t('.tags_explanation_html') %></p>
|
54
|
+
</div>
|
55
|
+
<% post_types = @post_types || [] %>
|
56
|
+
<% if post_types.size.zero? %>
|
57
|
+
<%= hidden_field_tag 'article[post_type]', 'read' %>
|
58
|
+
<% else %>
|
59
|
+
<div class="well">
|
60
|
+
<h4><%= t('.article_type') %></h4>
|
61
|
+
<%= select :article, :post_type, post_types.map { |pt| [pt.name, pt.permalink] }, include_blank: t('.default') %>
|
62
|
+
</div>
|
63
|
+
<% end %>
|
64
|
+
<div class="well">
|
65
|
+
<fieldset>
|
66
|
+
<legend><%= t('.publish_settings') %></legend>
|
67
|
+
<div class='control-group'>
|
68
|
+
<p>
|
69
|
+
<%= t('.permalink') %>:
|
70
|
+
<%= toggle_element('permalink') %>
|
71
|
+
</p>
|
72
|
+
<div id="permalink" class="collapse">
|
73
|
+
<div class="form-group">
|
74
|
+
<%= text_field 'article', 'permalink', autocomplete: 'off', class: 'form-control' %>
|
75
|
+
</div>
|
76
|
+
<p>
|
77
|
+
<span class="btn btn-mini btn-default">
|
78
|
+
<%= toggle_element('permalink', t('.ok')) %>
|
79
|
+
</span>
|
80
|
+
</p>
|
81
|
+
</div>
|
82
|
+
</div>
|
83
|
+
<div class="control-group">
|
84
|
+
<p>
|
85
|
+
<%= t('.allowed_comments_html', allow_comment: content_tag(:strong, @article.allow_comments? ? t('.allow_comments_status.enabled') : t('.allow_comments_status.disabled'))) %>
|
86
|
+
<%= toggle_element('conversation') %>
|
87
|
+
</p>
|
88
|
+
<div id="conversation" class="collapse">
|
89
|
+
<label for="article_allow_comments" class="checkbox">
|
90
|
+
<%= check_box 'article', 'allow_comments' %>
|
91
|
+
<%= t('.allow_comments') %>
|
92
|
+
</label>
|
93
|
+
<p>
|
94
|
+
<span class="btn btn-mini btn-default">
|
95
|
+
<%= toggle_element('conversation', t('.ok')) %>
|
96
|
+
</span>
|
97
|
+
</p>
|
98
|
+
</div>
|
99
|
+
</div>
|
100
|
+
<div class="control-group">
|
101
|
+
<p>
|
102
|
+
<%= t('.published') %>
|
103
|
+
<strong>
|
104
|
+
<% if @article.published_at.present? %>
|
105
|
+
<%= display_date_and_time(@article.published_at) %>
|
106
|
+
<% else %>
|
107
|
+
<%= t('.now') %>
|
108
|
+
<% end %>
|
109
|
+
</strong>
|
110
|
+
<%= toggle_element('publish') %>
|
111
|
+
</p>
|
112
|
+
<div id="publish" class="collapse">
|
113
|
+
<%= text_field 'article', 'published_at' %>
|
114
|
+
<p>
|
115
|
+
<span class="btn btn-mini btn-default">
|
116
|
+
<%= toggle_element('publish', t('.ok')) %>
|
117
|
+
</span>
|
118
|
+
</p>
|
119
|
+
</div>
|
120
|
+
</div>
|
121
|
+
<div class="control-group">
|
122
|
+
<p>
|
123
|
+
<%= t('.visibility') %>: <strong><%= @article.password.blank? ? t('.public') : t('.protected') %></strong>
|
124
|
+
<%= toggle_element('visibility') %>
|
125
|
+
</p>
|
126
|
+
<div id="visibility" class="collapse">
|
127
|
+
<label for="article_password"><%= t('.password') %></label>
|
128
|
+
<%= text_field 'article', 'password', class: 'form-control' %>
|
129
|
+
<p>
|
130
|
+
<span class="btn btn-mini btn-default">
|
131
|
+
<%= toggle_element('visibility', t('.ok')) %>
|
132
|
+
</span>
|
133
|
+
</p>
|
134
|
+
</div>
|
135
|
+
</div>
|
136
|
+
</fieldset>
|
137
|
+
</div>
|
138
|
+
</div>
|
139
|
+
<div class="modal-footer">
|
140
|
+
<button type="button" class="btn btn-default" data-dismiss="modal"><%= t('.cancel') %></button>
|
141
|
+
<%= submit_tag(t('.publish'), class: 'btn btn-success') %>
|
142
|
+
</div>
|
143
|
+
</div>
|
144
|
+
</div>
|
145
|
+
</div>
|
@@ -0,0 +1,5 @@
|
|
1
|
+
$('#autosave').html('<%= hidden_field_tag('article[id]', @article.id) %>');
|
2
|
+
$('#preview_link').replaceWith('<%= link_to('Preview', {:controller => '/articles', :action => 'preview', :id => @article.id}, {:target => 'new', :class => 'btn btn-default'}); %>');
|
3
|
+
<% if @article.state.to_s.downcase == "draft" %>
|
4
|
+
$("#article_published_at").val(<% Time.zone.now() %>);
|
5
|
+
<% end %>
|
@@ -0,0 +1,48 @@
|
|
1
|
+
<% content_for :page_heading do %>
|
2
|
+
<h2>
|
3
|
+
<i class="glyphicon glyphicon-large glyphicon-pencil"></i>
|
4
|
+
<%= t('.manage_articles') %>
|
5
|
+
<%= link_to(t('.new_article'), { controller: 'content', action: 'new' }, { id: 'dialog-link', class: 'btn btn-info pull-right' }) %>
|
6
|
+
</h2>
|
7
|
+
<% end %>
|
8
|
+
|
9
|
+
<%= form_tag({ action: 'index' }, { method: :get, name: 'article', remote: true, class: 'form-inline spinnable', "data-update-success": 'articleList' }) do %>
|
10
|
+
|
11
|
+
<% if params[:search] and params[:search]['state'] %>
|
12
|
+
<input type="hidden" name="search[state]" value="<%= params[:search]['state'] %>" />
|
13
|
+
<% end %>
|
14
|
+
|
15
|
+
<p>
|
16
|
+
<%= link_to(t('.all_articles'), { action: 'index' }, { class: 'label label-default' }) %>
|
17
|
+
<%= link_to(t('.published'), { action: 'index', search: { state: 'published' } }, { class: 'label label-success' }) %>
|
18
|
+
<%= link_to(t('.withdrawn'), { action: 'index', search: { state: 'withdrawn' } }, { class: 'label label-danger' }) %>
|
19
|
+
<%= link_to(t('.drafts'), { action: 'index', search: { state: 'drafts' } }, { class: 'label label-info' }) %>
|
20
|
+
<%= link_to(t('.publication_pending'), { action: 'index', search: { state: 'pending' } }, { class: 'label label-warning' }) %>
|
21
|
+
</p>
|
22
|
+
|
23
|
+
<div class="panel panel-default">
|
24
|
+
<div class="panel-heading">
|
25
|
+
<div class="pull-right">
|
26
|
+
<div class="form-group">
|
27
|
+
<%= select_tag('search[user_id]', options_from_collection_for_select(User.all, 'id', 'name'), prompt: t('.select_an_author'), class: 'form-control') %>
|
28
|
+
</div>
|
29
|
+
<div class="form-group">
|
30
|
+
<%= select_tag('search[published_at]', options_for_select(Article.publication_months), prompt: t('.publication_date'), class: 'form-control') %>
|
31
|
+
</div>
|
32
|
+
<div class="form-group">
|
33
|
+
<input id="search" type="text" name="search[searchstring]" class="form-control" />
|
34
|
+
</div>
|
35
|
+
<div class="form-group">
|
36
|
+
<%= submit_tag(t('.search'), class: 'btn btn-success') %>
|
37
|
+
<span id="spinner" style="display:none;"><%= image_tag('spinner.gif') %></span>
|
38
|
+
</div>
|
39
|
+
</div>
|
40
|
+
<br style="clear: both" />
|
41
|
+
</div>
|
42
|
+
</div>
|
43
|
+
<table class="table table-hover">
|
44
|
+
<tbody id="articleList">
|
45
|
+
<%= render 'article_list', articles: @articles %>
|
46
|
+
</tbody>
|
47
|
+
</table>
|
48
|
+
<% end %>
|
@@ -0,0 +1 @@
|
|
1
|
+
$("#articleList").html('<%= raw escape_javascript(render(partial: "article_list", locals: { articles: @articles })) %>');
|
@@ -0,0 +1,18 @@
|
|
1
|
+
<% if @comments.size == 0 %>
|
2
|
+
<li class='alert alert-info'><%= t('.no_comments_yet') %></li>
|
3
|
+
<% else %>
|
4
|
+
<% for comment in @comments %>
|
5
|
+
<li id='feedback_<%= comment.id %>'>
|
6
|
+
<%= avatar_tag(email: comment.email, url: comment.url, class: 'pull-left img-circle gravatar') %>
|
7
|
+
<h5>
|
8
|
+
<%= t('.by') %> <%= comment.url.blank? ? h(comment.author) : nofollowify_links(link_to(h(comment.author), comment.url)) %>
|
9
|
+
<%= display_date_and_time comment.created_at %>
|
10
|
+
</h5>
|
11
|
+
<p>
|
12
|
+
<%= comment.html.strip_html.slice(0..300) %>
|
13
|
+
</p>
|
14
|
+
<%= show_feedback_actions(comment, 'dashboard') %>
|
15
|
+
<hr />
|
16
|
+
</li>
|
17
|
+
<% end %>
|
18
|
+
<% end %>
|
@@ -0,0 +1,10 @@
|
|
1
|
+
<div class="panel panel-default">
|
2
|
+
<div class="panel-heading">
|
3
|
+
<h3 class='panel-title'><%= t('.latest_comments') %></h3>
|
4
|
+
</div>
|
5
|
+
<div class="panel-body">
|
6
|
+
<ul class='list-unstyled' id="commentList">
|
7
|
+
<%= render partial: 'comment' %>
|
8
|
+
</ul>
|
9
|
+
</div>
|
10
|
+
</div>
|
@@ -0,0 +1,25 @@
|
|
1
|
+
<div class="panel panel-default">
|
2
|
+
<div class="panel-heading">
|
3
|
+
<h3 class='panel-title'><%= t('.your_drafts') %></h3>
|
4
|
+
</div>
|
5
|
+
<div class="panel-body">
|
6
|
+
<ul class='list-unstyled'>
|
7
|
+
<% if @drafts.empty? %>
|
8
|
+
<li class='alert alert-info'>
|
9
|
+
<%= link_to t('.no_drafts_yet'), controller: 'content', action: 'new' %> ?
|
10
|
+
</li>
|
11
|
+
<% else %>
|
12
|
+
<% for post in @drafts %>
|
13
|
+
<li>
|
14
|
+
<h5>
|
15
|
+
<%= link_to(post.title, controller: 'admin/content', action: 'edit', id: post.id) %>
|
16
|
+
<%= display_date_and_time(post.created_at) %>
|
17
|
+
</h5>
|
18
|
+
<p><%= post.body&.strip_html&.slice(0, 300) %></p>
|
19
|
+
<hr />
|
20
|
+
</li>
|
21
|
+
<% end %>
|
22
|
+
<% end %>
|
23
|
+
</ul>
|
24
|
+
</div>
|
25
|
+
</div>
|
@@ -0,0 +1,21 @@
|
|
1
|
+
<div class='alert alert-info'>
|
2
|
+
<button type="button" class="close" data-dismiss="alert">
|
3
|
+
<span aria-hidden="true">×</span>
|
4
|
+
<span class="sr-only">Close</span>
|
5
|
+
</button>
|
6
|
+
<% links = []
|
7
|
+
links << link_to(t('.write_a_post'), controller: 'content', action: 'new') if can? :new, 'admin/content'
|
8
|
+
links << link_to(t('.write_a_page'), controller: 'pages', action: 'new') if can? :new, 'admin/pages'
|
9
|
+
links << link_to(t('.update_your_profile_or_change_your_password'), controller: 'profiles', action: 'index') %>
|
10
|
+
<p>
|
11
|
+
<%= t('.dashboard_explain_html', available_actions: safe_join(links, ', ')) %>
|
12
|
+
</p>
|
13
|
+
<% if can? :index, 'admin/themes' %>
|
14
|
+
<p>
|
15
|
+
<%= t('.customization_explain_html', theme_link: link_to(t('.change_your_blog_presentation'), controller: 'themes'), sidebar_link: link_to(t('.enable_plugins'), controller: 'sidebar')) %>
|
16
|
+
</p>
|
17
|
+
<% end %>
|
18
|
+
<p>
|
19
|
+
<%= t('.help_explain_html', doc_link: link_to(t('.read_our_documentation'), 'https://publify.github.io/')) %>
|
20
|
+
</p>
|
21
|
+
</div>
|
@@ -0,0 +1,28 @@
|
|
1
|
+
<div class="panel panel-default">
|
2
|
+
<div class="panel-heading">
|
3
|
+
<h3 class="panel-title"><%= t('.today') %></h3>
|
4
|
+
</div>
|
5
|
+
<div class="panel-body">
|
6
|
+
<p><%= t('.articles_and_comments_count_since', articles_count: @newposts_count, comments_count: @newcomments_count) %></p>
|
7
|
+
<p><%= t('.running_publify', version: PublifyCore::VERSION) %> <%= @version_message %></p>
|
8
|
+
<div class='col-md-6'>
|
9
|
+
<% if can? :index, 'admin/content' %>
|
10
|
+
<h4 class='page-header'><%= t('.content') %></h4>
|
11
|
+
<p><%= link_to(t('.articles_count', count: @statposts), controller: 'admin/content') %></p>
|
12
|
+
<p><%= link_to(t('.your_articles_count', count: @statuserposts), controller: 'admin/content', 'search[user_id]' => current_user.id) %></p>
|
13
|
+
<p><%= link_to(t('.drafts_count', count: @statsdrafts), controller: 'admin/content', 'search[state]' => 'drafts') %></p>
|
14
|
+
<p><%= link_to(t('.pages_count', count: @statspages), controller: 'admin/pages') %></p>
|
15
|
+
<p><%= link_to(t('.notes_count', count: @statuses), controller: 'admin/notes') %></p>
|
16
|
+
<% end %>
|
17
|
+
</div>
|
18
|
+
<div class='col-md-6'>
|
19
|
+
<% if can? :index, 'admin/feedback' %>
|
20
|
+
<h4 class='page-header'><%= t('.feedback') %></h4>
|
21
|
+
<p><%= link_to(t('.comments_count', count: @statcomments), controller: 'admin/feedback') %></p>
|
22
|
+
<p><%= link_to(t('.approved_count', count: @confirmed), controller: 'admin/feedback', only: 'ham') %></p>
|
23
|
+
<p><%= link_to(t('.unconfirmed_count', count: @unconfirmed), controller: 'admin/feedback', only: 'unapproved') %></p>
|
24
|
+
<p><%= link_to(t('.spam_count', count: @statspam), controller: 'admin/feedback', only: 'spam') %></p>
|
25
|
+
<% end %>
|
26
|
+
</div>
|
27
|
+
</div>
|
28
|
+
</div>
|