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! @notes, partial: 'notes/note', as: :note
|
@@ -0,0 +1,20 @@
|
|
1
|
+
= form_for preference, url: member_update_preferences_path do |f|
|
2
|
+
- if preference.errors.any?
|
3
|
+
.error
|
4
|
+
%h2= format(n_('An error prevented your preferences from being saved:',
|
5
|
+
'%<nb>i errors prevented your preferences from being saved:',
|
6
|
+
preference.errors.count), nb: preference.errors.count)
|
7
|
+
%ul
|
8
|
+
- preference.errors.full_messages.each do |message|
|
9
|
+
%li= message
|
10
|
+
|
11
|
+
.field
|
12
|
+
.field-input
|
13
|
+
= f.check_box :show_nsfw
|
14
|
+
= f.label :show_nsfw
|
15
|
+
.field
|
16
|
+
= f.label :locale
|
17
|
+
.field-input= f.collection_select(:locale, Elabs::Language.available_site_translations, :iso639_1, :name)
|
18
|
+
|
19
|
+
.actions
|
20
|
+
= f.submit 'Save', class: 'btn btn--save'
|
@@ -0,0 +1,71 @@
|
|
1
|
+
= form_for project, url: project.id ? member_project_path : member_projects_path do |f|
|
2
|
+
- if project.errors.any?
|
3
|
+
.error
|
4
|
+
%h2= format(n_('An error prevented this project from being saved:',
|
5
|
+
'%<nb>i errors prevented this project from being saved:',
|
6
|
+
project.errors.count), nb: project.errors.count)
|
7
|
+
%ul
|
8
|
+
- project.errors.full_messages.each do |message|
|
9
|
+
%li= message
|
10
|
+
|
11
|
+
.field
|
12
|
+
= f.label :name
|
13
|
+
.field-input= f.text_field :name
|
14
|
+
.field
|
15
|
+
= f.label :short_description
|
16
|
+
.field-input
|
17
|
+
= f.text_field :short_description
|
18
|
+
.field-hint= raw format(_('Markdown supported. %<preview_button>s'),
|
19
|
+
preview_button: content_tag('a',
|
20
|
+
_('Preview'),
|
21
|
+
href: '#',
|
22
|
+
onclick: 'shortDescriptionCM(event)'))
|
23
|
+
.field
|
24
|
+
= f.label :description
|
25
|
+
.field-input
|
26
|
+
= f.text_area :description
|
27
|
+
.field-hint= raw format(_('Markdown supported. %<preview_button>s'),
|
28
|
+
preview_button: content_tag('a',
|
29
|
+
_('Preview'),
|
30
|
+
href: '#',
|
31
|
+
onclick: 'descriptionCM(event)'))
|
32
|
+
.field
|
33
|
+
= f.label :main_url
|
34
|
+
.field-input= f.text_field :main_url
|
35
|
+
.field
|
36
|
+
.field-input
|
37
|
+
= f.check_box :sfw
|
38
|
+
= f.label :sfw
|
39
|
+
.field
|
40
|
+
.field-input
|
41
|
+
= f.check_box :published
|
42
|
+
= f.label :published
|
43
|
+
.field
|
44
|
+
.field-input
|
45
|
+
= f.check_box :hidden_in_history
|
46
|
+
= f.label :hidden_in_history
|
47
|
+
.field
|
48
|
+
= f.label :license
|
49
|
+
.field-input= f.collection_select :license_id, Elabs::License.all, :id, :name
|
50
|
+
.field
|
51
|
+
= f.label :language
|
52
|
+
.field-input= f.collection_select :language_id, Elabs::Language.all, :id, :name
|
53
|
+
.field
|
54
|
+
= f.label :tags, for: :tags_list
|
55
|
+
.field-input
|
56
|
+
= f.text_field :tags_list
|
57
|
+
.field-hint= _('List of comma-separated tags')
|
58
|
+
|
59
|
+
.actions
|
60
|
+
= f.submit _('Save'), class: 'btn btn--save'
|
61
|
+
|
62
|
+
= render 'elabs/member/layouts/markdown-preview'
|
63
|
+
|
64
|
+
:javascript
|
65
|
+
var shortDescriptionCM = initializeCodeMirrorIn(document.getElementById('project_short_description'))
|
66
|
+
shortDescriptionCM.setOption('maxLength', 255)
|
67
|
+
shortDescriptionCM.on('beforeChange', limitCMToLength)
|
68
|
+
var descriptionCM = initializeCodeMirrorIn(document.getElementById('project_description'))
|
69
|
+
var mdPreviewShortDescription = createMDPreviewer(shortDescriptionCM)
|
70
|
+
var mdPreviewDescription = createMDPreviewer(descriptionCM)
|
71
|
+
|
@@ -0,0 +1,53 @@
|
|
1
|
+
- @page_title = _('Projects')
|
2
|
+
|
3
|
+
.page__actions
|
4
|
+
= link_to _('New Project'), new_member_project_path, class: 'btn btn--new'
|
5
|
+
|
6
|
+
- if @projects.length.zero?
|
7
|
+
= render 'elabs/member/layouts/empty', link: new_member_project_path
|
8
|
+
- else
|
9
|
+
%table.projects-list
|
10
|
+
%thead
|
11
|
+
%tr
|
12
|
+
%th= member_order_by_link _('Name'), 'name'
|
13
|
+
%th= member_order_by_link _('Main url'), 'main_url'
|
14
|
+
%th= member_order_by_link _('SFW'), 'sfw'
|
15
|
+
%th= member_order_by_link _('Pub.'), 'published'
|
16
|
+
%th= member_order_by_link _('Lock.'), 'locked'
|
17
|
+
%th= member_order_by_link _('Skip hist.'), 'hidden_in_history'
|
18
|
+
%th= member_order_by_link _('Published at'), 'published_at'
|
19
|
+
%th= _('License')
|
20
|
+
%th= _('Language')
|
21
|
+
%th= member_order_by_link _('Albums'), 'albums_count'
|
22
|
+
%th= member_order_by_link _('Articles'), 'articles_count'
|
23
|
+
%th= member_order_by_link _('Notes'), 'notes_count'
|
24
|
+
%th= member_order_by_link _('Uploads'), 'uploads_count'
|
25
|
+
%th= _('Tags')
|
26
|
+
%th
|
27
|
+
|
28
|
+
%tbody
|
29
|
+
- @projects.each do |project|
|
30
|
+
%tr.project
|
31
|
+
%td= project.name
|
32
|
+
%td= link_to project.main_url, project.main_url, target: '_blank'
|
33
|
+
%td.is-icon= boolean_icon_tag project.sfw
|
34
|
+
%td.is-icon= boolean_icon_tag project.published
|
35
|
+
%td.is-icon= boolean_icon_tag project.locked, 'lock', 'unlock'
|
36
|
+
%td.is-icon= boolean_icon_tag project.hidden_in_history
|
37
|
+
%td= project.published_at
|
38
|
+
%td
|
39
|
+
= license_icon project.license
|
40
|
+
= project.license.name
|
41
|
+
%td= project.language.name
|
42
|
+
%td.is-counter= project.albums_count
|
43
|
+
%td.is-counter= project.articles_count
|
44
|
+
%td.is-counter= project.notes_count
|
45
|
+
%td.is-counter= project.uploads_count
|
46
|
+
%td.relations
|
47
|
+
- project.tags.each do |t|
|
48
|
+
%span.tag= t.name
|
49
|
+
%td
|
50
|
+
.btn-group
|
51
|
+
= member_action_links 'project', project
|
52
|
+
|
53
|
+
= paginate @projects
|
@@ -0,0 +1 @@
|
|
1
|
+
json.array! @projects, partial: 'projects/project', as: :project
|
@@ -0,0 +1,67 @@
|
|
1
|
+
= form_for upload, url: upload.id ? member_upload_path : member_uploads_path do |f|
|
2
|
+
- if upload.errors.any?
|
3
|
+
.error
|
4
|
+
%h2= format(n_('An error prevented this upload from being saved:',
|
5
|
+
'%<nb>i errors prevented this upload from being saved:',
|
6
|
+
upload.errors.count), nb: upload.errors.count)
|
7
|
+
%ul
|
8
|
+
- upload.errors.full_messages.each do |message|
|
9
|
+
%li= message
|
10
|
+
|
11
|
+
.field
|
12
|
+
= f.label :title
|
13
|
+
.field-input= f.text_field :title
|
14
|
+
.field
|
15
|
+
= f.label :description
|
16
|
+
.field-input
|
17
|
+
= f.text_area :description
|
18
|
+
.field-hint= raw format(_('Markdown supported. %<preview_button>s'),
|
19
|
+
preview_button: content_tag('a',
|
20
|
+
_('Preview'),
|
21
|
+
href: '#',
|
22
|
+
onclick: 'mdPreviewDescription(event)'))
|
23
|
+
.field
|
24
|
+
.field-input
|
25
|
+
= f.check_box :sfw
|
26
|
+
= f.label :sfw
|
27
|
+
.field
|
28
|
+
.field-input
|
29
|
+
= f.check_box :published
|
30
|
+
= f.label :published
|
31
|
+
.field
|
32
|
+
.field-input
|
33
|
+
= f.check_box :hidden_in_history
|
34
|
+
= f.label :hidden_in_history
|
35
|
+
.field
|
36
|
+
= f.label :license
|
37
|
+
.field-input= f.collection_select :license_id, Elabs::License.all, :id, :name
|
38
|
+
.field
|
39
|
+
= f.label :language
|
40
|
+
.field-input= f.collection_select :language_id, Elabs::Language.all, :id, :name
|
41
|
+
.field
|
42
|
+
= f.label :file
|
43
|
+
.field-input
|
44
|
+
= f.file_field :file
|
45
|
+
.field-hint= format(_('The following formats will be viewable online; other will need a download: %<formats>s'),
|
46
|
+
formats: available_formats.join(', '))
|
47
|
+
.field
|
48
|
+
= f.label :albums
|
49
|
+
.field-input= f.collection_select :album_ids, Elabs::Album.by_member(current_user), :id, :name, {}, multiple: true
|
50
|
+
.field
|
51
|
+
= f.label :projects
|
52
|
+
.field-input= f.collection_select :project_ids,
|
53
|
+
Elabs::Project.by_member(current_user), :id, :name, {}, multiple: true
|
54
|
+
.field
|
55
|
+
= f.label :tags, for: :tags_list
|
56
|
+
.field-input
|
57
|
+
= f.text_field :tags_list
|
58
|
+
.field-hint= _('List of comma-separated tags')
|
59
|
+
|
60
|
+
.actions
|
61
|
+
= f.submit _('Save'), class: 'btn btn--save'
|
62
|
+
|
63
|
+
= render 'elabs/member/layouts/markdown-preview'
|
64
|
+
|
65
|
+
:javascript
|
66
|
+
var descriptionCM = initializeCodeMirrorIn(document.getElementById('upload_description'))
|
67
|
+
var mdPreviewDescription = createMDPreviewer(descriptionCM)
|
@@ -0,0 +1,61 @@
|
|
1
|
+
- @page_title = _('Uploads')
|
2
|
+
|
3
|
+
.page__actions
|
4
|
+
= link_to _('New Upload'), new_member_upload_path, class: 'btn btn--new'
|
5
|
+
|
6
|
+
- if @uploads.length.zero?
|
7
|
+
= render 'elabs/member/layouts/empty', link: new_member_upload_path
|
8
|
+
- else
|
9
|
+
%table.uploads-list
|
10
|
+
%thead
|
11
|
+
%tr
|
12
|
+
%th
|
13
|
+
%th= member_order_by_link _('Title'), 'title'
|
14
|
+
%th= member_order_by_link _('SFW'), 'sfw'
|
15
|
+
%th= member_order_by_link _('Pub.'), 'published'
|
16
|
+
%th= member_order_by_link _('Lock.'), 'locked'
|
17
|
+
%th= member_order_by_link _('Skip hist.'), 'hidden_in_history'
|
18
|
+
%th= member_order_by_link _('Published at'), 'published_at'
|
19
|
+
%th= _('Language')
|
20
|
+
%th= _('License')
|
21
|
+
%th= _('Albums')
|
22
|
+
%th= _('Projects')
|
23
|
+
%th= _('Tags')
|
24
|
+
%th
|
25
|
+
|
26
|
+
%tbody
|
27
|
+
- @uploads.each do |upload|
|
28
|
+
%tr.upload
|
29
|
+
%td
|
30
|
+
- if upload.file.variable?
|
31
|
+
= image_tag main_app.url_for(upload.file.variant(thumbnail_center_crop_properties(:small)).processed),
|
32
|
+
class: 'thumbnail--small'
|
33
|
+
- elsif upload.file.previewable?
|
34
|
+
= image_tag main_app.url_for(upload.file.preview(thumbnail_center_crop_properties(:small)).processed),
|
35
|
+
class: 'thumbnail--small'
|
36
|
+
- else
|
37
|
+
= image_tag main_app.url_for(thumbnail_preview_placeholder_file), class: 'thumbnail--small'
|
38
|
+
%td= upload.title
|
39
|
+
%td.is-icon= boolean_icon_tag upload.sfw
|
40
|
+
%td.is-icon= boolean_icon_tag upload.published
|
41
|
+
%td.is-icon= boolean_icon_tag upload.locked, 'lock', 'unlock'
|
42
|
+
%td.is-icon= boolean_icon_tag upload.hidden_in_history
|
43
|
+
%td= upload.published_at
|
44
|
+
%td= upload.language.name
|
45
|
+
%td
|
46
|
+
= license_icon upload.license
|
47
|
+
= upload.license.name
|
48
|
+
%td.relations
|
49
|
+
- upload.albums.each do |a|
|
50
|
+
%span.album= a.name
|
51
|
+
%td.relations
|
52
|
+
- upload.projects.each do |p|
|
53
|
+
%span.project= p.name
|
54
|
+
%td.relations
|
55
|
+
- upload.tags.each do |t|
|
56
|
+
%span.tag= t.name
|
57
|
+
%td
|
58
|
+
.btn-group
|
59
|
+
= member_action_links 'upload', upload
|
60
|
+
|
61
|
+
= paginate @uploads
|
@@ -0,0 +1 @@
|
|
1
|
+
json.array! @uploads, partial: 'uploads/upload', as: :upload
|
@@ -0,0 +1,38 @@
|
|
1
|
+
-# haml-lint:disable InstanceVariables
|
2
|
+
- user = @user || current_user
|
3
|
+
-# haml-lint:enable InstanceVariables
|
4
|
+
|
5
|
+
= form_for user, url: { controller: 'elabs/member/users', action: :update } do |f|
|
6
|
+
|
7
|
+
- if user.errors.any?
|
8
|
+
.error
|
9
|
+
%h2= format(n_('An error prevented your account from being updated:',
|
10
|
+
'%<nb>i errors prevented your account from being updated:',
|
11
|
+
user.errors.count), nb: user.errors.count)
|
12
|
+
%ul
|
13
|
+
- user.errors.full_messages.each do |message|
|
14
|
+
%li= message
|
15
|
+
|
16
|
+
|
17
|
+
.field
|
18
|
+
= f.label :real_name
|
19
|
+
.field-input= f.text_field :real_name
|
20
|
+
|
21
|
+
.field
|
22
|
+
= f.label :biography
|
23
|
+
.field-input
|
24
|
+
= f.text_area :biography
|
25
|
+
.field-hint= raw format(_('Markdown supported. %<preview_button>s'),
|
26
|
+
preview_button: content_tag('a',
|
27
|
+
_('Preview'),
|
28
|
+
href: '#',
|
29
|
+
onclick: 'mdPreviewBiography(event)'))
|
30
|
+
|
31
|
+
.actions
|
32
|
+
= f.submit _('Save'), class: 'btn btn--save'
|
33
|
+
|
34
|
+
= render 'elabs/member/layouts/markdown-preview'
|
35
|
+
|
36
|
+
:javascript
|
37
|
+
var biographyCM = initializeCodeMirrorIn(document.getElementById('user_biography'))
|
38
|
+
var mdPreviewBiography = createMDPreviewer(biographyCM)
|
@@ -0,0 +1,31 @@
|
|
1
|
+
- if !show_item? note
|
2
|
+
= render 'elabs/layouts/hidden_entry', entity: note
|
3
|
+
- else
|
4
|
+
.note.note-card
|
5
|
+
%header
|
6
|
+
.icon= icon 'sticky-note', %w[3x fw]
|
7
|
+
.headers
|
8
|
+
%ul.informations
|
9
|
+
%li
|
10
|
+
= icon('link', ['fw'])
|
11
|
+
= link_to _('Permalink'), note, class: 'title'
|
12
|
+
%li
|
13
|
+
= icon('user', ['fw'])
|
14
|
+
%strong= _('User:')
|
15
|
+
= link_to note.user.username, note.user
|
16
|
+
%li
|
17
|
+
= icon('language', ['fw'])
|
18
|
+
%strong= _('Language:')
|
19
|
+
= link_to note.language.name, note.language
|
20
|
+
%li
|
21
|
+
= icon('copyright', ['fw'])
|
22
|
+
%strong= _('License:')
|
23
|
+
= link_to note.license.name, note.license
|
24
|
+
%li
|
25
|
+
= icon('info', ['fw'])
|
26
|
+
%strong= _('SFW:')
|
27
|
+
= boolean_icon_tag note.sfw, 'is-sfw', 'is-nsfw'
|
28
|
+
%li= render 'elabs/layouts/lists/projects', projects: note.projects
|
29
|
+
%li= render 'elabs/layouts/lists/tags', tags: note.tags
|
30
|
+
|
31
|
+
%article{ lang: note.language.iso639_1 }= markdown note.content
|
@@ -0,0 +1 @@
|
|
1
|
+
json.array! @notes, partial: 'notes/note', as: :note
|
@@ -0,0 +1,44 @@
|
|
1
|
+
- if !show_item? @note
|
2
|
+
- @page_title = _('Content not displayed')
|
3
|
+
= render 'elabs/layouts/hidden_entry_full', entity: @note
|
4
|
+
- else
|
5
|
+
- @page_title = _('A note')
|
6
|
+
.note.note--full
|
7
|
+
%aside
|
8
|
+
%ul
|
9
|
+
%li
|
10
|
+
= icon('user', ['fw'])
|
11
|
+
%b= _('Author:')
|
12
|
+
= link_to @note.user.username, @note.user
|
13
|
+
%li
|
14
|
+
= icon('calendar-check', ['fw'])
|
15
|
+
%b= _('Published at:')
|
16
|
+
= @note.published_at
|
17
|
+
%li
|
18
|
+
= icon('calendar', ['fw'])
|
19
|
+
%b= _('Updated at:')
|
20
|
+
= @note.updated_at
|
21
|
+
%li
|
22
|
+
= icon('info', ['fw'])
|
23
|
+
%b= _('SFW:')
|
24
|
+
= boolean_icon_tag @note.sfw, 'is-sfw', 'is-nsfw'
|
25
|
+
%li
|
26
|
+
= icon('language', ['fw'])
|
27
|
+
%b= _('Language:')
|
28
|
+
= link_to @note.language.name, @note.language
|
29
|
+
%li
|
30
|
+
= icon('copyright', ['fw'])
|
31
|
+
%b= _('License:')
|
32
|
+
= link_to @note.license.name, @note.license
|
33
|
+
|
34
|
+
%li.separator= render 'elabs/layouts/lists/projects', projects: @note.projects
|
35
|
+
%li.separator= render 'elabs/layouts/lists/tags', tags: @note.tags
|
36
|
+
|
37
|
+
.content
|
38
|
+
%article{ lang: @note.language.iso639_1 }
|
39
|
+
= markdown @note.content
|
40
|
+
|
41
|
+
= render 'elabs/comments/comments',
|
42
|
+
entity: @note,
|
43
|
+
new_comment: @new_comment,
|
44
|
+
url: note_create_comment_path(@note)
|