elabs 2.0.0.pre
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.eslintrc.yml +26 -0
- data/.gitignore +49 -0
- data/.gitlab-ci.yml +93 -0
- data/.haml-lint.yml +4 -0
- data/.node-version +1 -0
- data/.rspec +1 -0
- data/.rubocop.yml +59 -0
- data/.ruby-version +1 -0
- data/.simplecov +5 -0
- data/.stylelintrc.yml +218 -0
- data/CHANGELOG.md +273 -0
- data/CODE_OF_CONDUCT.md +78 -0
- data/Gemfile +75 -0
- data/Gemfile.lock +376 -0
- data/LICENSE +21 -0
- data/LICENSES.md +6 -0
- data/README.md +41 -0
- data/ROADMAP.md +61 -0
- data/Rakefile +32 -0
- data/app/assets/config/elabs_manifest.js +3 -0
- data/app/assets/images/elabs/preview_placeholder.png +0 -0
- data/app/assets/images/elabs/preview_placeholder_nsfw.png +0 -0
- data/app/assets/javascripts/elabs/application.js +27 -0
- data/app/assets/javascripts/elabs/helpers-codemirror.js +29 -0
- data/app/assets/javascripts/elabs/helpers-markdown.js +42 -0
- data/app/assets/javascripts/elabs/helpers.js +17 -0
- data/app/assets/javascripts/elabs/modals.js +19 -0
- data/app/assets/javascripts/elabs/tabs.js +32 -0
- data/app/assets/stylesheets/elabs/_colors.scss +345 -0
- data/app/assets/stylesheets/elabs/_icons.scss +9 -0
- data/app/assets/stylesheets/elabs/_variables.scss +13 -0
- data/app/assets/stylesheets/elabs/app/_acts.scss +58 -0
- data/app/assets/stylesheets/elabs/app/_alerts.scss +3 -0
- data/app/assets/stylesheets/elabs/app/_buttons.scss +21 -0
- data/app/assets/stylesheets/elabs/app/_comments.scss +1 -0
- data/app/assets/stylesheets/elabs/app/_content.scss +10 -0
- data/app/assets/stylesheets/elabs/app/_content_uploads.scss +39 -0
- data/app/assets/stylesheets/elabs/app/_empty.scss +19 -0
- data/app/assets/stylesheets/elabs/app/_errors.scss +9 -0
- data/app/assets/stylesheets/elabs/app/_filter_links.scss +27 -0
- data/app/assets/stylesheets/elabs/app/_forms.scss +69 -0
- data/app/assets/stylesheets/elabs/app/_helpers.scss +3 -0
- data/app/assets/stylesheets/elabs/app/_languages.scss +6 -0
- data/app/assets/stylesheets/elabs/app/_layout.scss +194 -0
- data/app/assets/stylesheets/elabs/app/_licenses.scss +6 -0
- data/app/assets/stylesheets/elabs/app/_link-to-top.scss +8 -0
- data/app/assets/stylesheets/elabs/app/_medias.scss +12 -0
- data/app/assets/stylesheets/elabs/app/_modals.scss +53 -0
- data/app/assets/stylesheets/elabs/app/_nsfw.scss +5 -0
- data/app/assets/stylesheets/elabs/app/_pagination.scss +16 -0
- data/app/assets/stylesheets/elabs/app/_tabs.scss +54 -0
- data/app/assets/stylesheets/elabs/app/_tags.scss +6 -0
- data/app/assets/stylesheets/elabs/app/_toolbars.scss +3 -0
- data/app/assets/stylesheets/elabs/app/_users.scss +6 -0
- data/app/assets/stylesheets/elabs/app/admin-members/_forms.scss +6 -0
- data/app/assets/stylesheets/elabs/app/admin-members/_indexes.scss +70 -0
- data/app/assets/stylesheets/elabs/app/admin-members/_layout.scss +17 -0
- data/app/assets/stylesheets/elabs/app/areas/_devise.scss +31 -0
- data/app/assets/stylesheets/elabs/app/components/_cards.scss +16 -0
- data/app/assets/stylesheets/elabs/app/components/_container.scss +4 -0
- data/app/assets/stylesheets/elabs/app/mixins/_classifier-card.scss +16 -0
- data/app/assets/stylesheets/elabs/app/mixins/_content-card.scss +58 -0
- data/app/assets/stylesheets/elabs/app/mixins/_content-full.scss +39 -0
- data/app/assets/stylesheets/elabs/app/mixins/_icon.scss +9 -0
- data/app/assets/stylesheets/elabs/application.css +14 -0
- data/app/assets/stylesheets/elabs/lib/_codemirror.scss +26 -0
- data/app/assets/stylesheets/elabs/lib/fontawesome/_fontawesome.scss +38 -0
- data/app/assets/stylesheets/elabs/lib/fontawesome/_fonts.scss +42 -0
- data/app/assets/stylesheets/elabs/lib/fontawesome/_icons.scss +1118 -0
- data/app/assets/stylesheets/elabs/lib/knacss/_knacss-variables.scss +230 -0
- data/app/assets/stylesheets/elabs/lib/knacss/_knacss.scss +59 -0
- data/app/assets/stylesheets/elabs/style.scss +72 -0
- data/app/controllers/elabs/acts_controller.rb +12 -0
- data/app/controllers/elabs/admin/admin_application_controller.rb +19 -0
- data/app/controllers/elabs/admin/admin_content_application_controller.rb +66 -0
- data/app/controllers/elabs/admin/albums_controller.rb +10 -0
- data/app/controllers/elabs/admin/articles_controller.rb +10 -0
- data/app/controllers/elabs/admin/languages_controller.rb +77 -0
- data/app/controllers/elabs/admin/licenses_controller.rb +77 -0
- data/app/controllers/elabs/admin/notes_controller.rb +10 -0
- data/app/controllers/elabs/admin/projects_controller.rb +10 -0
- data/app/controllers/elabs/admin/reports_controller.rb +34 -0
- data/app/controllers/elabs/admin/tags_controller.rb +56 -0
- data/app/controllers/elabs/admin/uploads_controller.rb +10 -0
- data/app/controllers/elabs/admin/users_controller.rb +43 -0
- data/app/controllers/elabs/albums_controller.rb +26 -0
- data/app/controllers/elabs/articles_controller.rb +25 -0
- data/app/controllers/elabs/auth/callbacks_controller.rb +38 -0
- data/app/controllers/elabs/auth/confirmations_controller.rb +43 -0
- data/app/controllers/elabs/auth/passwords_controller.rb +47 -0
- data/app/controllers/elabs/auth/registrations_controller.rb +70 -0
- data/app/controllers/elabs/auth/sessions_controller.rb +36 -0
- data/app/controllers/elabs/auth/unlocks_controller.rb +38 -0
- data/app/controllers/elabs/concerns/elabs_controller.rb +18 -0
- data/app/controllers/elabs/concerns/localizable.rb +11 -0
- data/app/controllers/elabs/concerns/reportable.rb +17 -0
- data/app/controllers/elabs/content_application_controller.rb +45 -0
- data/app/controllers/elabs/elabs_application_controller.rb +95 -0
- data/app/controllers/elabs/languages_controller.rb +36 -0
- data/app/controllers/elabs/licenses_controller.rb +31 -0
- data/app/controllers/elabs/member/albums_controller.rb +11 -0
- data/app/controllers/elabs/member/articles_controller.rb +11 -0
- data/app/controllers/elabs/member/member_application_controller.rb +12 -0
- data/app/controllers/elabs/member/member_content_application_controller.rb +128 -0
- data/app/controllers/elabs/member/notes_controller.rb +11 -0
- data/app/controllers/elabs/member/preferences_controller.rb +36 -0
- data/app/controllers/elabs/member/projects_controller.rb +11 -0
- data/app/controllers/elabs/member/uploads_controller.rb +11 -0
- data/app/controllers/elabs/member/users_controller.rb +28 -0
- data/app/controllers/elabs/notes_controller.rb +25 -0
- data/app/controllers/elabs/projects_controller.rb +30 -0
- data/app/controllers/elabs/reports_controller.rb +36 -0
- data/app/controllers/elabs/tags_controller.rb +36 -0
- data/app/controllers/elabs/uploads_controller.rb +24 -0
- data/app/controllers/elabs/users_controller.rb +36 -0
- data/app/helpers/elabs/acts_helper.rb +22 -0
- data/app/helpers/elabs/admin_content_helper.rb +54 -0
- data/app/helpers/elabs/application_helper.rb +54 -0
- data/app/helpers/elabs/content_filters_helper.rb +97 -0
- data/app/helpers/elabs/content_renderer_helper.rb +13 -0
- data/app/helpers/elabs/member_content_helper.rb +47 -0
- data/app/helpers/elabs/thumbnails_helper.rb +28 -0
- data/app/helpers/elabs/time_helper.rb +19 -0
- data/app/helpers/elabs/uploads_helper.rb +19 -0
- data/app/jobs/elabs/application_job.rb +4 -0
- data/app/mailers/elabs/application_mailer.rb +6 -0
- data/app/models/elabs/act.rb +7 -0
- data/app/models/elabs/album.rb +24 -0
- data/app/models/elabs/albums_tag.rb +21 -0
- data/app/models/elabs/albums_upload.rb +21 -0
- data/app/models/elabs/application_content_record.rb +10 -0
- data/app/models/elabs/application_record.rb +5 -0
- data/app/models/elabs/article.rb +23 -0
- data/app/models/elabs/articles_tag.rb +21 -0
- data/app/models/elabs/comment.rb +12 -0
- data/app/models/elabs/concerns/actable_entity.rb +52 -0
- data/app/models/elabs/concerns/content_entity.rb +70 -0
- data/app/models/elabs/concerns/countable_entity.rb +81 -0
- data/app/models/elabs/concerns/taggable.rb +33 -0
- data/app/models/elabs/language.rb +17 -0
- data/app/models/elabs/license.rb +15 -0
- data/app/models/elabs/note.rb +21 -0
- data/app/models/elabs/notes_tag.rb +21 -0
- data/app/models/elabs/preference.rb +9 -0
- data/app/models/elabs/project.rb +25 -0
- data/app/models/elabs/projects_album.rb +21 -0
- data/app/models/elabs/projects_article.rb +21 -0
- data/app/models/elabs/projects_note.rb +21 -0
- data/app/models/elabs/projects_tag.rb +21 -0
- data/app/models/elabs/projects_upload.rb +21 -0
- data/app/models/elabs/report.rb +11 -0
- data/app/models/elabs/tag.rb +18 -0
- data/app/models/elabs/upload.rb +28 -0
- data/app/models/elabs/uploads_tag.rb +21 -0
- data/app/models/elabs/user.rb +30 -0
- data/app/validators/elabs/associated_author_validator.rb +11 -0
- data/app/views/elabs/acts/_act.json.jbuilder +2 -0
- data/app/views/elabs/acts/_filters.html.haml +3 -0
- data/app/views/elabs/acts/index.html.haml +27 -0
- data/app/views/elabs/acts/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/albums/_album.json.jbuilder +2 -0
- data/app/views/elabs/admin/albums/index.html.haml +43 -0
- data/app/views/elabs/admin/albums/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/articles/_article.json.jbuilder +2 -0
- data/app/views/elabs/admin/articles/index.html.haml +41 -0
- data/app/views/elabs/admin/articles/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/languages/_form.html.haml +18 -0
- data/app/views/elabs/admin/languages/_language.json.jbuilder +2 -0
- data/app/views/elabs/admin/languages/edit.html.haml +6 -0
- data/app/views/elabs/admin/languages/index.html.haml +34 -0
- data/app/views/elabs/admin/languages/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/languages/new.html.haml +3 -0
- data/app/views/elabs/admin/licenses/_form.html.haml +25 -0
- data/app/views/elabs/admin/licenses/_license.json.jbuilder +2 -0
- data/app/views/elabs/admin/licenses/edit.html.haml +6 -0
- data/app/views/elabs/admin/licenses/index.html.haml +42 -0
- data/app/views/elabs/admin/licenses/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/licenses/new.html.haml +3 -0
- data/app/views/elabs/admin/notes/_note.json.jbuilder +2 -0
- data/app/views/elabs/admin/notes/index.html.haml +40 -0
- data/app/views/elabs/admin/notes/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/projects/_project.json.jbuilder +2 -0
- data/app/views/elabs/admin/projects/index.html.haml +45 -0
- data/app/views/elabs/admin/projects/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/reports/index.html.haml +27 -0
- data/app/views/elabs/admin/reports/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/tags/_form.html.haml +17 -0
- data/app/views/elabs/admin/tags/_tag.json.jbuilder +2 -0
- data/app/views/elabs/admin/tags/edit.html.haml +6 -0
- data/app/views/elabs/admin/tags/index.html.haml +27 -0
- data/app/views/elabs/admin/tags/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/uploads/_upload.json.jbuilder +2 -0
- data/app/views/elabs/admin/uploads/index.html.haml +45 -0
- data/app/views/elabs/admin/uploads/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/users/_admin_user.json.jbuilder +2 -0
- data/app/views/elabs/admin/users/index.html.haml +33 -0
- data/app/views/elabs/admin/users/index.json.jbuilder +1 -0
- data/app/views/elabs/admin/users/show.html.haml +26 -0
- data/app/views/elabs/admin/users/show.json.jbuilder +1 -0
- data/app/views/elabs/albums/_album.html.haml +38 -0
- data/app/views/elabs/albums/_album.json.jbuilder +2 -0
- data/app/views/elabs/albums/_filters.html.haml +8 -0
- data/app/views/elabs/albums/index.html.haml +9 -0
- data/app/views/elabs/albums/index.json.jbuilder +1 -0
- data/app/views/elabs/albums/show.html.haml +60 -0
- data/app/views/elabs/albums/show.json.jbuilder +1 -0
- data/app/views/elabs/articles/_article.html.haml +30 -0
- data/app/views/elabs/articles/_article.json.jbuilder +2 -0
- data/app/views/elabs/articles/_filters.html.haml +8 -0
- data/app/views/elabs/articles/index.html.haml +9 -0
- data/app/views/elabs/articles/index.json.jbuilder +1 -0
- data/app/views/elabs/articles/show.html.haml +45 -0
- data/app/views/elabs/articles/show.json.jbuilder +1 -0
- data/app/views/elabs/auth/confirmations/new.html.haml +26 -0
- data/app/views/elabs/auth/passwords/edit.html.haml +31 -0
- data/app/views/elabs/auth/passwords/new.html.haml +23 -0
- data/app/views/elabs/auth/registrations/edit.html.haml +48 -0
- data/app/views/elabs/auth/registrations/new.html.haml +34 -0
- data/app/views/elabs/auth/sessions/_new.html.haml +15 -0
- data/app/views/elabs/auth/sessions/new.html.haml +8 -0
- data/app/views/elabs/auth/shared/_links.html.haml +16 -0
- data/app/views/elabs/auth/unlocks/new.html.haml +23 -0
- data/app/views/elabs/comments/_comment.json.jbuilder +2 -0
- data/app/views/elabs/comments/_comments.html.haml +21 -0
- data/app/views/elabs/comments/_form.html.haml +31 -0
- data/app/views/elabs/languages/_associations.html.haml +51 -0
- data/app/views/elabs/languages/_filters.html.haml +6 -0
- data/app/views/elabs/languages/_language.json.jbuilder +2 -0
- data/app/views/elabs/languages/index.html.haml +33 -0
- data/app/views/elabs/languages/index.json.jbuilder +1 -0
- data/app/views/elabs/languages/show.html.haml +38 -0
- data/app/views/elabs/languages/show.json.jbuilder +1 -0
- data/app/views/elabs/layouts/_empty.html.haml +3 -0
- data/app/views/elabs/layouts/_footer.html.haml +6 -0
- data/app/views/elabs/layouts/_hidden_entry.html.haml +6 -0
- data/app/views/elabs/layouts/_hidden_entry_full.html.haml +6 -0
- data/app/views/elabs/layouts/_language_menu.html.haml +2 -0
- data/app/views/elabs/layouts/_menu.html.haml +72 -0
- data/app/views/elabs/layouts/admin_application.html.haml +21 -0
- data/app/views/elabs/layouts/application.html.haml +37 -0
- data/app/views/elabs/layouts/lists/_albums.html.haml +10 -0
- data/app/views/elabs/layouts/lists/_projects.html.haml +10 -0
- data/app/views/elabs/layouts/lists/_tags.html.haml +9 -0
- data/app/views/elabs/layouts/mailer.html.haml +8 -0
- data/app/views/elabs/layouts/mailer.text.haml +1 -0
- data/app/views/elabs/layouts/member_application.html.haml +21 -0
- data/app/views/elabs/licenses/_associations.html.haml +51 -0
- data/app/views/elabs/licenses/_filters.html.haml +3 -0
- data/app/views/elabs/licenses/_license.json.jbuilder +2 -0
- data/app/views/elabs/licenses/index.html.haml +27 -0
- data/app/views/elabs/licenses/index.json.jbuilder +1 -0
- data/app/views/elabs/licenses/show.html.haml +44 -0
- data/app/views/elabs/licenses/show.json.jbuilder +1 -0
- data/app/views/elabs/member/albums/_album.json.jbuilder +2 -0
- data/app/views/elabs/member/albums/_form.html.haml +64 -0
- data/app/views/elabs/member/albums/edit.html.haml +6 -0
- data/app/views/elabs/member/albums/index.html.haml +49 -0
- data/app/views/elabs/member/albums/index.json.jbuilder +1 -0
- data/app/views/elabs/member/albums/new.html.haml +3 -0
- data/app/views/elabs/member/articles/_article.json.jbuilder +2 -0
- data/app/views/elabs/member/articles/_form.html.haml +70 -0
- data/app/views/elabs/member/articles/edit.html.haml +6 -0
- data/app/views/elabs/member/articles/index.html.haml +47 -0
- data/app/views/elabs/member/articles/index.json.jbuilder +1 -0
- data/app/views/elabs/member/articles/new.html.haml +3 -0
- data/app/views/elabs/member/layouts/_empty.html.haml +4 -0
- data/app/views/elabs/member/layouts/_markdown-preview.html.haml +8 -0
- data/app/views/elabs/member/notes/_form.html.haml +54 -0
- data/app/views/elabs/member/notes/_note.json.jbuilder +2 -0
- data/app/views/elabs/member/notes/edit.html.haml +6 -0
- data/app/views/elabs/member/notes/index.html.haml +47 -0
- data/app/views/elabs/member/notes/index.json.jbuilder +1 -0
- data/app/views/elabs/member/notes/new.html.haml +3 -0
- data/app/views/elabs/member/preferences/_form.html.haml +20 -0
- data/app/views/elabs/member/preferences/edit.html.haml +3 -0
- data/app/views/elabs/member/projects/_form.html.haml +71 -0
- data/app/views/elabs/member/projects/_project.json.jbuilder +2 -0
- data/app/views/elabs/member/projects/edit.html.haml +6 -0
- data/app/views/elabs/member/projects/index.html.haml +53 -0
- data/app/views/elabs/member/projects/index.json.jbuilder +1 -0
- data/app/views/elabs/member/projects/new.html.haml +3 -0
- data/app/views/elabs/member/uploads/_form.html.haml +67 -0
- data/app/views/elabs/member/uploads/_upload.json.jbuilder +2 -0
- data/app/views/elabs/member/uploads/edit.html.haml +6 -0
- data/app/views/elabs/member/uploads/index.html.haml +61 -0
- data/app/views/elabs/member/uploads/index.json.jbuilder +1 -0
- data/app/views/elabs/member/uploads/new.html.haml +3 -0
- data/app/views/elabs/member/users/_form.html.haml +38 -0
- data/app/views/elabs/notes/_filters.html.haml +7 -0
- data/app/views/elabs/notes/_note.html.haml +31 -0
- data/app/views/elabs/notes/_note.json.jbuilder +2 -0
- data/app/views/elabs/notes/index.html.haml +9 -0
- data/app/views/elabs/notes/index.json.jbuilder +1 -0
- data/app/views/elabs/notes/show.html.haml +44 -0
- data/app/views/elabs/notes/show.json.jbuilder +1 -0
- data/app/views/elabs/projects/_associations.html.haml +46 -0
- data/app/views/elabs/projects/_filters.html.haml +8 -0
- data/app/views/elabs/projects/_project.html.haml +29 -0
- data/app/views/elabs/projects/index.html.haml +9 -0
- data/app/views/elabs/projects/index.json.jbuilder +1 -0
- data/app/views/elabs/projects/show.html.haml +71 -0
- data/app/views/elabs/projects/show.json.jbuilder +1 -0
- data/app/views/elabs/reports/_form.html.haml +29 -0
- data/app/views/elabs/tags/_associations.html.haml +51 -0
- data/app/views/elabs/tags/_filters.html.haml +3 -0
- data/app/views/elabs/tags/_tag.json.jbuilder +2 -0
- data/app/views/elabs/tags/index.html.haml +26 -0
- data/app/views/elabs/tags/index.json.jbuilder +1 -0
- data/app/views/elabs/tags/show.html.haml +34 -0
- data/app/views/elabs/tags/show.json.jbuilder +1 -0
- data/app/views/elabs/uploads/_filters.html.haml +7 -0
- data/app/views/elabs/uploads/_player.html.haml +10 -0
- data/app/views/elabs/uploads/_preview.html.haml +17 -0
- data/app/views/elabs/uploads/_upload.html.haml +41 -0
- data/app/views/elabs/uploads/_upload.json.jbuilder +2 -0
- data/app/views/elabs/uploads/index.html.haml +9 -0
- data/app/views/elabs/uploads/index.json.jbuilder +1 -0
- data/app/views/elabs/uploads/show.html.haml +58 -0
- data/app/views/elabs/uploads/show.json.jbuilder +1 -0
- data/app/views/elabs/users/_associations.html.haml +51 -0
- data/app/views/elabs/users/_filters.html.haml +4 -0
- data/app/views/elabs/users/_user.html.haml +31 -0
- data/app/views/elabs/users/_user.json.jbuilder +2 -0
- data/app/views/elabs/users/index.html.haml +7 -0
- data/app/views/elabs/users/index.json.jbuilder +1 -0
- data/app/views/elabs/users/show.html.haml +48 -0
- data/app/views/elabs/users/show.json.jbuilder +1 -0
- data/bin/rails +14 -0
- data/config.ru +5 -0
- data/config/brakeman.ignore +124 -0
- data/config/brakeman.yml +3 -0
- data/config/cucumber.yml +9 -0
- data/config/routes.rb +116 -0
- data/db/migrate/20180813000000_devise_update_users.rb +15 -0
- data/db/migrate/20180813000001_create_languages.rb +16 -0
- data/db/migrate/20180813000002_create_tags.rb +14 -0
- data/db/migrate/20180813000004_create_licenses.rb +17 -0
- data/db/migrate/20180813000005_create_reports.rb +15 -0
- data/db/migrate/20180813000006_create_comments.rb +15 -0
- data/db/migrate/20180813000007_create_acts.rb +10 -0
- data/db/migrate/20180813000008_create_preferences.rb +13 -0
- data/db/migrate/20180813000009_create_active_storage_tables.active_storage.rb +26 -0
- data/db/migrate/20180813000010_create_albums.rb +23 -0
- data/db/migrate/20180813000011_create_articles.rb +23 -0
- data/db/migrate/20180813000012_create_notes.rb +21 -0
- data/db/migrate/20180813000013_create_uploads.rb +26 -0
- data/db/migrate/20180813000014_create_projects.rb +44 -0
- data/db/seeds.rb +10 -0
- data/db/seeds_development.rb +21 -0
- data/db/seeds_production.rb +0 -0
- data/docs/contributing.md +52 -0
- data/docs/cucumber_terms.md +9 -0
- data/docs/migrating.md +4 -0
- data/docs/overriding.md +20 -0
- data/docs/setup.md +136 -0
- data/docs/tips.md +13 -0
- data/elabs.gemspec +25 -0
- data/lib/assets/javascripts/README-highlight.js.md +39 -0
- data/lib/assets/javascripts/codemirror-5.39.2/addon/mode/overlay.js +90 -0
- data/lib/assets/javascripts/codemirror-5.39.2/lib/codemirror.js +9684 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/clike/clike.js +834 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/css/css.js +832 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/gfm/gfm.js +129 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/htmlmixed/htmlmixed.js +152 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/javascript/javascript.js +896 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/markdown/markdown.js +882 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/meta.js +217 -0
- data/lib/assets/javascripts/codemirror-5.39.2/mode/xml/xml.js +402 -0
- data/lib/assets/javascripts/highlight.js-9.12.0/highlight.pack.js +2 -0
- data/lib/assets/javascripts/markdown-it-8.4.2.min.js +1 -0
- data/lib/assets/stylesheets/codemirror-5.39.2/lib/codemirror.css +346 -0
- data/lib/assets/stylesheets/codemirror-5.39.2/theme/base16-dark.css +38 -0
- data/lib/assets/stylesheets/codemirror-5.39.2/theme/base16-light.css +38 -0
- data/lib/assets/stylesheets/highlight.js-9.12.0/styles/atelier-sulphurpool-light.css +69 -0
- data/lib/elabs.rb +41 -0
- data/lib/elabs/engine.rb +5 -0
- data/lib/elabs/version.rb +3 -0
- data/lib/generators/elabs/assets_generator.rb +36 -0
- data/lib/generators/elabs/devise_views_generator.rb +24 -0
- data/lib/generators/elabs/install_generator.rb +26 -0
- data/lib/generators/elabs/required_assets_generator.rb +26 -0
- data/lib/generators/elabs/views_generator.rb +25 -0
- data/lib/generators/templates/elabs.rb +25 -0
- data/lib/generators/templates/fast_gettext.rb +3 -0
- data/lib/tasks/.keep +0 -0
- data/lib/tasks/cucumber.rake +75 -0
- data/lib/tasks/elabs_tasks.rake +4 -0
- data/lib/tasks/factory_bot.rake +14 -0
- data/lib/tasks/wipe.rake +31 -0
- data/locale/app.pot +1124 -0
- data/locale/devise_strings.rb +88 -0
- data/locale/en/app.edit.po +1123 -0
- data/locale/en/app.po +1123 -0
- data/locale/en/app.po.time_stamp +0 -0
- data/locale/fr/app.edit.po +1126 -0
- data/locale/fr/app.po +1125 -0
- data/locale/fr/app.po.time_stamp +0 -0
- data/locale/model_attributes.rb +85 -0
- data/package.json +22 -0
- data/script/cucumber +10 -0
- data/tmp/pids/.keep +0 -0
- data/yarn.lock +2759 -0
- metadata +463 -0
@@ -0,0 +1 @@
|
|
1
|
+
json.array! @albums, partial: 'albums/album', as: :album
|
@@ -0,0 +1,60 @@
|
|
1
|
+
- if !show_item? @album
|
2
|
+
- @page_title = _('Content not displayed')
|
3
|
+
= render 'elabs/layouts/hidden_entry_full', entity: @album
|
4
|
+
- else
|
5
|
+
- @page_title = @album.name
|
6
|
+
.album.album--full
|
7
|
+
%aside
|
8
|
+
%ul
|
9
|
+
%li
|
10
|
+
= icon('user', ['fw'])
|
11
|
+
%strong= _('Author:')
|
12
|
+
= link_to @album.user.username, @album.user
|
13
|
+
|
14
|
+
%li
|
15
|
+
= icon('calendar-check', ['fw'])
|
16
|
+
%strong= _('Published at:')
|
17
|
+
.date= @album.published_at
|
18
|
+
|
19
|
+
%li
|
20
|
+
= icon('calendar', ['fw'])
|
21
|
+
%strong= _('Updated at:')
|
22
|
+
.date= @album.updated_at
|
23
|
+
|
24
|
+
%li
|
25
|
+
= icon('info', ['fw'])
|
26
|
+
%strong= _('SFW:')
|
27
|
+
= boolean_icon_tag @album.sfw, 'is-sfw', 'is-nsfw'
|
28
|
+
|
29
|
+
%li
|
30
|
+
= icon('language', ['fw'])
|
31
|
+
%strong= _('Language:')
|
32
|
+
= link_to @album.language.name, @album.language
|
33
|
+
|
34
|
+
%li
|
35
|
+
= icon('copyright', ['fw'])
|
36
|
+
%strong= _('License:')
|
37
|
+
.license= link_to @album.license.name, @album.license
|
38
|
+
|
39
|
+
%li
|
40
|
+
= icon('upload', ['fw'])
|
41
|
+
%strong= _('Uploads:')
|
42
|
+
= @album.uploads_count
|
43
|
+
|
44
|
+
%li.separator= render 'elabs/layouts/lists/projects', projects: @album.projects
|
45
|
+
%li.separator= render 'elabs/layouts/lists/tags', tags: @album.tags
|
46
|
+
|
47
|
+
.content
|
48
|
+
%article{ lang: @album.language.iso639_1 }
|
49
|
+
= markdown @album.description
|
50
|
+
|
51
|
+
.content__relations
|
52
|
+
= render 'elabs/layouts/empty' if @album.uploads.length.zero?
|
53
|
+
%section.uploads-list
|
54
|
+
- @album.uploads.published.each do |u|
|
55
|
+
= render 'elabs/uploads/preview', upload: u
|
56
|
+
|
57
|
+
= render 'elabs/comments/comments',
|
58
|
+
entity: @album,
|
59
|
+
new_comment: @new_comment,
|
60
|
+
url: album_create_comment_path(@album)
|
@@ -0,0 +1 @@
|
|
1
|
+
json.partial! 'albums/album', album: @album
|
@@ -0,0 +1,30 @@
|
|
1
|
+
- if !show_item? article
|
2
|
+
= render 'elabs/layouts/hidden_entry', entity: article
|
3
|
+
- else
|
4
|
+
.article.article-card
|
5
|
+
%header
|
6
|
+
.icon= icon 'font', %w[3x fw]
|
7
|
+
.headers
|
8
|
+
%h3{ lang: article.language.iso639_1 }= link_to article.title, article, class: 'title'
|
9
|
+
|
10
|
+
%ul.informations
|
11
|
+
%li
|
12
|
+
= icon('user', ['fw'])
|
13
|
+
%strong= _('User:')
|
14
|
+
= link_to article.user.username, article.user
|
15
|
+
%li
|
16
|
+
= icon('language', ['fw'])
|
17
|
+
%strong= _('Language:')
|
18
|
+
= link_to article.language.name, article.language
|
19
|
+
%li
|
20
|
+
= icon('copyright', ['fw'])
|
21
|
+
%strong= _('License:')
|
22
|
+
= link_to article.license.name, article.license
|
23
|
+
%li
|
24
|
+
= icon('info', ['fw'])
|
25
|
+
%strong= _('SFW:')
|
26
|
+
= boolean_icon_tag article.sfw, 'is-sfw', 'is-nsfw'
|
27
|
+
%li= render 'elabs/layouts/lists/projects', projects: article.projects
|
28
|
+
%li= render 'elabs/layouts/lists/tags', tags: article.tags
|
29
|
+
|
30
|
+
%article{ lang: article.language.iso639_1 }= markdown article.excerpt
|
@@ -0,0 +1 @@
|
|
1
|
+
json.array! @articles, partial: 'articles/article', as: :article
|
@@ -0,0 +1,45 @@
|
|
1
|
+
- if !show_item? @article
|
2
|
+
- @page_title = _('Content not displayed')
|
3
|
+
= render 'elabs/layouts/hidden_entry_full', entity: @article
|
4
|
+
- else
|
5
|
+
- @page_title = @article.title
|
6
|
+
.article.article--full
|
7
|
+
%aside
|
8
|
+
%ul
|
9
|
+
%li
|
10
|
+
= icon('user', ['fw'])
|
11
|
+
%strong= _('Author:')
|
12
|
+
= link_to @article.user.username, @article.user
|
13
|
+
%li
|
14
|
+
= icon('calendar-check', ['fw'])
|
15
|
+
%strong= _('Published at:')
|
16
|
+
= @article.published_at
|
17
|
+
%li
|
18
|
+
= icon('calendar', ['fw'])
|
19
|
+
%strong= _('Updated at:')
|
20
|
+
= @article.updated_at
|
21
|
+
%li
|
22
|
+
= icon('info', ['fw'])
|
23
|
+
%strong= _('SFW:')
|
24
|
+
= @article.sfw
|
25
|
+
%li
|
26
|
+
= icon('language', ['fw'])
|
27
|
+
%strong= _('Language:')
|
28
|
+
= link_to @article.language.name, @article.language
|
29
|
+
%li
|
30
|
+
= icon('copyright', ['fw'])
|
31
|
+
%strong= _('License:')
|
32
|
+
= link_to @article.license.name, @article.license
|
33
|
+
|
34
|
+
%li.separator= render 'elabs/layouts/lists/projects', projects: @article.projects
|
35
|
+
%li.separator= render 'elabs/layouts/lists/tags', tags: @article.tags
|
36
|
+
|
37
|
+
.content
|
38
|
+
%article{ lang: @article.language.iso639_1 }
|
39
|
+
= markdown @article.excerpt
|
40
|
+
= markdown @article.content
|
41
|
+
|
42
|
+
= render 'elabs/comments/comments',
|
43
|
+
entity: @article,
|
44
|
+
new_comment: @new_comment,
|
45
|
+
url: article_create_comment_path(@article)
|
@@ -0,0 +1 @@
|
|
1
|
+
json.partial! 'articles/article', article: @article
|
@@ -0,0 +1,26 @@
|
|
1
|
+
- @page_title = _('Resend confirmation instructions')
|
2
|
+
|
3
|
+
.devise
|
4
|
+
.devise__form
|
5
|
+
.devise__form__wrapper
|
6
|
+
= form_for(resource, as: resource_name, url: user_confirmation_path, html: { method: :post }) do |f|
|
7
|
+
|
8
|
+
- if resource.errors.any?
|
9
|
+
.error
|
10
|
+
%h2= format(n_('An error prevented the instructions from being sent:',
|
11
|
+
'%<nb>i errors prevented the instructions from being sent:',
|
12
|
+
resource.errors.count), nb: resource.errors.count)
|
13
|
+
%ul
|
14
|
+
- resource.errors.full_messages.each do |message|
|
15
|
+
%li= message
|
16
|
+
|
17
|
+
.field
|
18
|
+
= f.label :email
|
19
|
+
.field-input= f.email_field :email,
|
20
|
+
autofocus: true,
|
21
|
+
autocomplete: 'email',
|
22
|
+
value: (resource.pending_reconfirmation? ? resource.unconfirmed_email : resource.email)
|
23
|
+
.actions
|
24
|
+
= f.submit _('Resend confirmation instructions'), class: 'btn btn--brand btn--block'
|
25
|
+
|
26
|
+
= render 'elabs/auth/shared/links'
|
@@ -0,0 +1,31 @@
|
|
1
|
+
- @page_title = _('Change your password')
|
2
|
+
|
3
|
+
.devise
|
4
|
+
.devise__form
|
5
|
+
.devise__form__wrapper
|
6
|
+
= form_for(resource, as: resource_name,
|
7
|
+
url: { controller: 'elabs/auth/passwords', action: 'update' }, html: { method: :put }) do |f|
|
8
|
+
- if resource.errors.any?
|
9
|
+
.error
|
10
|
+
%h2= format(n_('An error prevented your password from being changed:',
|
11
|
+
'%<nb>i errors prevented your password from being changed:',
|
12
|
+
resource.errors.count), nb: resource.errors.count)
|
13
|
+
%ul
|
14
|
+
- resource.errors.full_messages.each do |message|
|
15
|
+
%li= message
|
16
|
+
|
17
|
+
= f.hidden_field :reset_password_token
|
18
|
+
|
19
|
+
.field
|
20
|
+
= f.label :password, _('New password')
|
21
|
+
.field-input
|
22
|
+
= f.password_field :password, autofocus: true, autocomplete: 'off'
|
23
|
+
- if @minimum_password_length
|
24
|
+
.field-hint= format(_('%<number>i characters minimum'), number: @minimum_password_length)
|
25
|
+
.field
|
26
|
+
= f.label :password_confirmation, _('Confirm new password')
|
27
|
+
.field-input= f.password_field :password_confirmation, autocomplete: 'off'
|
28
|
+
.actions
|
29
|
+
= f.submit _('Change my password'), class: 'btn btn--brand btn--block'
|
30
|
+
|
31
|
+
= render 'elabs/auth/shared/links'
|
@@ -0,0 +1,23 @@
|
|
1
|
+
- @page_title = _('Forgot your password?')
|
2
|
+
|
3
|
+
.devise
|
4
|
+
.devise__form
|
5
|
+
.devise__form__wrapper
|
6
|
+
= form_for(resource, as: resource_name, url: user_password_path, html: { method: :post }) do |f|
|
7
|
+
|
8
|
+
- if resource.errors.any?
|
9
|
+
.error
|
10
|
+
%h2= format(n_('An error prevented the instructions from being sent:',
|
11
|
+
'%<nb>i errors prevented the instructions from being sent:',
|
12
|
+
resource.errors.count), nb: resource.errors.count)
|
13
|
+
%ul
|
14
|
+
- resource.errors.full_messages.each do |message|
|
15
|
+
%li= message
|
16
|
+
|
17
|
+
.field
|
18
|
+
= f.label :email
|
19
|
+
.field-input= f.email_field :email, autofocus: true, autocomplete: 'email'
|
20
|
+
.actions
|
21
|
+
= f.submit _('Send me reset password instructions'), class: 'btn btn--brand btn--block'
|
22
|
+
|
23
|
+
= render 'elabs/auth/shared/links'
|
@@ -0,0 +1,48 @@
|
|
1
|
+
- @page_title = _('Account')
|
2
|
+
|
3
|
+
%h2= _('About')
|
4
|
+
= render 'elabs/member/users/form'
|
5
|
+
|
6
|
+
= form_for(resource, as: resource_name, url: { controller: 'elabs/auth/registrations', action: :update },
|
7
|
+
html: { method: :put }) do |f|
|
8
|
+
= devise_error_messages!
|
9
|
+
|
10
|
+
%h2.separator= _('Sensitive changes')
|
11
|
+
.field
|
12
|
+
= f.label :current_password
|
13
|
+
.field-input
|
14
|
+
= f.password_field :current_password, autocomplete: 'off'
|
15
|
+
.field-hint= _('(we need your current password to confirm the following changes)')
|
16
|
+
%hr.separator
|
17
|
+
.field
|
18
|
+
= f.label :email
|
19
|
+
.field-input
|
20
|
+
= f.email_field :email, autofocus: true, autocomplete: 'email'
|
21
|
+
- if devise_mapping.confirmable? && resource.pending_reconfirmation?
|
22
|
+
.field-hint= format(_('Currently waiting confirmation for: %<email>s'), email: resource.unconfirmed_email)
|
23
|
+
|
24
|
+
.field
|
25
|
+
= f.label :password
|
26
|
+
.field-input
|
27
|
+
= f.password_field :password, autocomplete: 'off'
|
28
|
+
.field-hint= _("(leave blank if you don't want to change it)")
|
29
|
+
- if @minimum_password_length
|
30
|
+
.field-hint= format(_('%<number>i characters minimum'), number: @minimum_password_length)
|
31
|
+
|
32
|
+
.field
|
33
|
+
= f.label :password_confirmation
|
34
|
+
.field-input= f.password_field :password_confirmation, autocomplete: 'off'
|
35
|
+
|
36
|
+
.actions
|
37
|
+
= f.submit 'Save', class: 'btn btn--save'
|
38
|
+
|
39
|
+
%h2.separator= _('Cancel my account')
|
40
|
+
.alert.alert--warning.mbs
|
41
|
+
-# haml-lint:disable LineLength
|
42
|
+
= _('Cancelling your account will delete all the content you created, with no possibility to restore it. This is definitive.')
|
43
|
+
-# haml-lint:enable LineLength
|
44
|
+
= button_to({ controller: 'elabs/auth/registrations', action: :destroy },
|
45
|
+
data: { confirm: _('Are you sure?') },
|
46
|
+
class: 'btn btn--danger',
|
47
|
+
method: :delete) do
|
48
|
+
= icon_text 'angry', _('Cancel my account')
|
@@ -0,0 +1,34 @@
|
|
1
|
+
- @page_title = _('Sign up')
|
2
|
+
|
3
|
+
.devise
|
4
|
+
.devise__form
|
5
|
+
.devise__form__wrapper
|
6
|
+
= form_for(resource, as: resource_name, url: user_registration_path) do |f|
|
7
|
+
- if resource.errors.any?
|
8
|
+
.error
|
9
|
+
%h2= format(n_('An error prevented your account from being created:',
|
10
|
+
'%<nb>i errors prevented your account from being created:',
|
11
|
+
resource.errors.count), nb: resource.errors.count)
|
12
|
+
%ul
|
13
|
+
- resource.errors.full_messages.each do |message|
|
14
|
+
%li= message
|
15
|
+
.field
|
16
|
+
= f.label :username
|
17
|
+
.field-input= f.text_field :username, autofocus: true, autocomplete: 'email'
|
18
|
+
.field
|
19
|
+
= f.label :email
|
20
|
+
.field-input= f.email_field :email, autocomplete: 'email'
|
21
|
+
.field
|
22
|
+
= f.label :password
|
23
|
+
.field-input
|
24
|
+
= f.password_field :password, autocomplete: 'off'
|
25
|
+
- if @minimum_password_length
|
26
|
+
.field-hint= format(_('%<number>i characters minimum'), number: @minimum_password_length)
|
27
|
+
.field
|
28
|
+
= f.label _('Confirmation')
|
29
|
+
.field-input= f.password_field :password_confirmation, autocomplete: 'off'
|
30
|
+
|
31
|
+
.actions
|
32
|
+
= f.submit _('Sign up'), class: 'btn btn--brand btn--block'
|
33
|
+
|
34
|
+
= render 'elabs/auth/shared/links'
|
@@ -0,0 +1,15 @@
|
|
1
|
+
= form_for(resource, as: resource_name, url: user_session_path) do |f|
|
2
|
+
.field
|
3
|
+
= f.label :email
|
4
|
+
.field-input= f.email_field :email, autofocus: true, autocomplete: 'email'
|
5
|
+
.field
|
6
|
+
= f.label :password
|
7
|
+
.field-input= f.password_field :password, autocomplete: 'off'
|
8
|
+
- if devise_mapping.rememberable?
|
9
|
+
.field
|
10
|
+
.field-input
|
11
|
+
= f.check_box :remember_me
|
12
|
+
= f.label :remember_me
|
13
|
+
|
14
|
+
.actions
|
15
|
+
= f.submit _('Log in'), class: 'btn btn--block btn--brand'
|
@@ -0,0 +1,16 @@
|
|
1
|
+
.devise__actions
|
2
|
+
- if controller_name != 'sessions'
|
3
|
+
= active_link_to _('Log in'), new_user_session_path
|
4
|
+
- if devise_mapping.registerable? && controller_name != 'registrations'
|
5
|
+
= active_link_to _('Sign up'), new_user_registration_path
|
6
|
+
- if devise_mapping.recoverable? && controller_name != 'passwords' && controller_name != 'registrations'
|
7
|
+
= active_link_to _('Forgot your password?'), new_user_password_path
|
8
|
+
- if devise_mapping.confirmable? && controller_name != 'confirmations'
|
9
|
+
= active_link_to _("Didn't receive confirmation instructions?"), new_user_confirmation_path
|
10
|
+
- if devise_mapping.lockable? && resource_class.unlock_strategy_enabled?(:email) && controller_name != 'unlocks'
|
11
|
+
= active_link_to _("Didn't receive unlock instructions?"), new_user_unlock_path
|
12
|
+
|
13
|
+
- if devise_mapping.omniauthable?
|
14
|
+
- resource_class.omniauth_providers.each do |provider|
|
15
|
+
= active_link_to format(_('Sign in with %<provider>s'), provider: OmniAuth::Utils.camelize(provider)),
|
16
|
+
auth_omniauth_authorize_path(resource_name, provider)
|
@@ -0,0 +1,23 @@
|
|
1
|
+
- @page_title = _('Resend unlock instructions')
|
2
|
+
|
3
|
+
.devise
|
4
|
+
.devise__form
|
5
|
+
.devise__form__wrapper
|
6
|
+
= form_for(resource, as: resource_name, url: unlock_path, html: { method: :post }) do |f|
|
7
|
+
|
8
|
+
- if resource.errors.any?
|
9
|
+
.error
|
10
|
+
%h2= format(n_('An error prevented the instructions from being sent:',
|
11
|
+
'%<nb>i errors prevented the instructions from being sent:',
|
12
|
+
resource.errors.count), nb: resource.errors.count)
|
13
|
+
%ul
|
14
|
+
- resource.errors.full_messages.each do |message|
|
15
|
+
%li= message
|
16
|
+
|
17
|
+
.field
|
18
|
+
= f.label :email
|
19
|
+
.field-input= f.email_field :email, autofocus: true, autocomplete: 'email'
|
20
|
+
.actions
|
21
|
+
= f.submit _('Resend unlock instructions'), class: 'btn btn--brand btn--block'
|
22
|
+
|
23
|
+
= render 'elabs/auth/shared/links'
|
@@ -0,0 +1,21 @@
|
|
1
|
+
%section.comments-list
|
2
|
+
- if user_is_author_of entity
|
3
|
+
%h2= _('Comments')
|
4
|
+
- if entity.comments.count.zero?
|
5
|
+
.empty
|
6
|
+
= _('No comment has been left')
|
7
|
+
- entity.comments.each do |comment|
|
8
|
+
.comment.comment-card
|
9
|
+
%header
|
10
|
+
.headers
|
11
|
+
%ul.informations
|
12
|
+
%li
|
13
|
+
= icon('user', ['fw'])
|
14
|
+
= comment.name || link_to("@#{comment.user.username}", comment.user)
|
15
|
+
%li
|
16
|
+
= icon('calendar', ['fw'])
|
17
|
+
%strong= _('Posted on:')
|
18
|
+
= comment.created_at
|
19
|
+
%article= markdown comment.comment
|
20
|
+
|
21
|
+
= render 'elabs/comments/form', url: url, new_comment: new_comment
|
@@ -0,0 +1,31 @@
|
|
1
|
+
-# You must provide an url for the form
|
2
|
+
%h3#new-comment= _('Leave a comment')
|
3
|
+
= form_for new_comment, url: url do |f|
|
4
|
+
- if new_comment.errors.any?
|
5
|
+
.error
|
6
|
+
%h2= format(n_('An error prevented your comment from being saved:',
|
7
|
+
'%<nb>i errors prevented your comment from being saved:',
|
8
|
+
new_comment.errors.count), nb: new_comment.errors.count)
|
9
|
+
%ul
|
10
|
+
- new_comment.errors.full_messages.each do |message|
|
11
|
+
%li= message
|
12
|
+
|
13
|
+
- if user_signed_in?
|
14
|
+
.alert.alert--info
|
15
|
+
%p= format(_('This comment will be posted as "%<name>s"'), name: current_user.username)
|
16
|
+
%p= _('By submitting this comment, you agree to be recontacted by the author.')
|
17
|
+
- else
|
18
|
+
.field
|
19
|
+
= f.label :name
|
20
|
+
.field-input= f.text_field :name, required: true
|
21
|
+
.field
|
22
|
+
= f.label :email
|
23
|
+
.field-input= f.text_field :email, required: true
|
24
|
+
.field
|
25
|
+
= f.label :allow_contact
|
26
|
+
.field-input= f.check_box :allow_contact
|
27
|
+
.field
|
28
|
+
= f.label :comment
|
29
|
+
.field-input= f.text_area :comment, required: true
|
30
|
+
.actions
|
31
|
+
= f.submit 'Save', class: 'btn btn--save'
|