pageflow 17.0.5 → 17.1.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- checksums.yaml +4 -4
- data/CHANGELOG.md +362 -35
- data/README.md +0 -1
- data/admins/pageflow/accounts.rb +16 -14
- data/admins/pageflow/entry.rb +68 -20
- data/admins/pageflow/entry_templates.rb +10 -9
- data/admins/pageflow/folder.rb +1 -1
- data/admins/pageflow/membership.rb +4 -4
- data/admins/pageflow/revisions.rb +5 -5
- data/admins/pageflow/site_root_entry.rb +64 -0
- data/admins/pageflow/sites.rb +12 -3
- data/admins/pageflow/translations.rb +75 -0
- data/admins/pageflow/user.rb +21 -35
- data/app/assets/javascripts/pageflow/admin/entries.js +30 -5
- data/app/assets/javascripts/pageflow/dist/ui.js +2865 -257
- data/app/assets/stylesheets/pageflow/admin/entries/index_table.scss +2 -1
- data/app/assets/stylesheets/pageflow/admin/permalink_input.scss +2 -1
- data/app/assets/stylesheets/pageflow/editor/background_positioning.scss +6 -0
- data/app/assets/stylesheets/pageflow/editor/base.scss +2 -0
- data/app/assets/stylesheets/pageflow/editor/drop_down_button.scss +7 -1
- data/app/assets/stylesheets/pageflow/editor/file_meta_data.scss +5 -1
- data/app/assets/stylesheets/pageflow/editor/files.scss +28 -16
- data/app/assets/stylesheets/pageflow/editor/filtered_files.scss +24 -0
- data/app/assets/stylesheets/pageflow/editor/info_box.scss +11 -3
- data/app/assets/stylesheets/pageflow/editor/list.scss +6 -4
- data/app/assets/stylesheets/pageflow/editor/list_search_field.scss +52 -0
- data/app/assets/stylesheets/pageflow/editor/outline.scss +0 -13
- data/app/assets/stylesheets/pageflow/editor/select_button.scss +1 -1
- data/app/assets/stylesheets/pageflow/editor/sortable.scss +12 -0
- data/app/assets/stylesheets/pageflow/mixins/buttons.scss +4 -4
- data/app/assets/stylesheets/pageflow/ui/forms.scss +4 -0
- data/app/assets/stylesheets/pageflow/ui/input/color_input.scss +8 -0
- data/app/assets/stylesheets/pageflow/ui/input/file_name_input.scss +37 -0
- data/app/assets/stylesheets/pageflow/ui/properties.scss +5 -0
- data/app/assets/stylesheets/pageflow/ui.scss +1 -0
- data/app/controllers/concerns/pageflow/controller_delegation.rb +1 -1
- data/app/controllers/concerns/pageflow/edit_locking.rb +17 -10
- data/app/controllers/concerns/pageflow/entry_password_protection.rb +1 -0
- data/app/controllers/concerns/pageflow/public_https_mode.rb +2 -1
- data/app/controllers/concerns/pageflow/quota_verification.rb +5 -4
- data/app/controllers/pageflow/admin/initial_passwords_controller.rb +1 -0
- data/app/controllers/pageflow/application_controller.rb +19 -19
- data/app/controllers/pageflow/chapters_controller.rb +3 -2
- data/app/controllers/pageflow/edit_locks_controller.rb +3 -2
- data/app/controllers/pageflow/editor/encoding_confirmations_controller.rb +1 -0
- data/app/controllers/pageflow/editor/entries_controller.rb +2 -1
- data/app/controllers/pageflow/editor/entry_publications_controller.rb +1 -0
- data/app/controllers/pageflow/editor/file_import_controller.rb +3 -3
- data/app/controllers/pageflow/editor/files_controller.rb +7 -6
- data/app/controllers/pageflow/editor/widgets_controller.rb +1 -0
- data/app/controllers/pageflow/entries_controller.rb +77 -17
- data/app/controllers/pageflow/feeds_controller.rb +1 -1
- data/app/controllers/pageflow/files_controller.rb +1 -0
- data/app/controllers/pageflow/pages_controller.rb +4 -2
- data/app/controllers/pageflow/revisions_controller.rb +2 -1
- data/app/controllers/pageflow/sitemaps_controller.rb +1 -1
- data/app/controllers/pageflow/storylines_controller.rb +1 -0
- data/app/helpers/pageflow/admin/cutoff_modes_helper.rb +12 -0
- data/app/helpers/pageflow/admin/entries_helper.rb +1 -1
- data/app/helpers/pageflow/admin/entry_translations_helper.rb +18 -0
- data/app/helpers/pageflow/admin/features_helper.rb +1 -1
- data/app/helpers/pageflow/admin/form_helper.rb +3 -3
- data/app/helpers/pageflow/admin/locales_helper.rb +10 -2
- data/app/helpers/pageflow/admin/memberships_helper.rb +32 -32
- data/app/helpers/pageflow/admin/revisions_helper.rb +1 -1
- data/app/helpers/pageflow/admin/sites_helper.rb +22 -0
- data/app/helpers/pageflow/admin/users_helper.rb +7 -5
- data/app/helpers/pageflow/admin/widgets_helper.rb +3 -3
- data/app/helpers/pageflow/asset_urls_helper.rb +1 -1
- data/app/helpers/pageflow/audio_files_helper.rb +5 -2
- data/app/helpers/pageflow/background_image_helper.rb +7 -6
- data/app/helpers/pageflow/common_entry_seed_helper.rb +2 -4
- data/app/helpers/pageflow/editor/config_helper.rb +1 -1
- data/app/helpers/pageflow/editor/files_helper.rb +1 -1
- data/app/helpers/pageflow/embed_code_helper.rb +3 -3
- data/app/helpers/pageflow/entries_helper.rb +58 -34
- data/app/helpers/pageflow/entry_json_seed_helper.rb +3 -2
- data/app/helpers/pageflow/feeds_helper.rb +2 -2
- data/app/helpers/pageflow/file_background_images_helper.rb +2 -2
- data/app/helpers/pageflow/file_thumbnails_helper.rb +4 -3
- data/app/helpers/pageflow/files_helper.rb +5 -4
- data/app/helpers/pageflow/folders_helper.rb +8 -5
- data/app/helpers/pageflow/help_entries_helper.rb +2 -2
- data/app/helpers/pageflow/hreflang_links_helper.rb +37 -0
- data/app/helpers/pageflow/info_box_helper.rb +7 -11
- data/app/helpers/pageflow/media_query_helper.rb +3 -3
- data/app/helpers/pageflow/navigation_bar_helper.rb +1 -1
- data/app/helpers/pageflow/overview_helper.rb +1 -1
- data/app/helpers/pageflow/page_types_helper.rb +5 -5
- data/app/helpers/pageflow/pages_helper.rb +29 -15
- data/app/helpers/pageflow/public_i18n_helper.rb +1 -1
- data/app/helpers/pageflow/quota_helper.rb +4 -4
- data/app/helpers/pageflow/render_json_helper.rb +6 -3
- data/app/helpers/pageflow/revision_file_helper.rb +2 -1
- data/app/helpers/pageflow/sites_helper.rb +3 -3
- data/app/helpers/pageflow/social_share_helper.rb +24 -10
- data/app/helpers/pageflow/social_share_links_helper.rb +12 -9
- data/app/helpers/pageflow/structured_data_helper.rb +1 -1
- data/app/helpers/pageflow/stub_page_configuration.rb +7 -3
- data/app/helpers/pageflow/text_direction_helper.rb +1 -1
- data/app/helpers/pageflow/themes_helper.rb +1 -1
- data/app/helpers/pageflow/video_files_helper.rb +29 -13
- data/app/helpers/pageflow/widgets_helper.rb +7 -6
- data/app/inputs/pageflow_permalink_input.rb +3 -2
- data/app/jobs/pageflow/application_job.rb +1 -0
- data/app/jobs/pageflow/entry_export_import/upload_and_publish_file_job.rb +1 -1
- data/app/jobs/pageflow/poll_meta_data_from_zencoder_job.rb +1 -0
- data/app/jobs/pageflow/poll_zencoder_job.rb +3 -2
- data/app/jobs/pageflow/process_image_or_text_track_job.rb +1 -0
- data/app/jobs/pageflow/prune_auto_snapshots_job.rb +1 -0
- data/app/jobs/pageflow/request_meta_data_from_zencoder_job.rb +1 -0
- data/app/jobs/pageflow/submit_file_to_zencoder_job.rb +1 -0
- data/app/mailers/pageflow/user_mailer.rb +1 -0
- data/app/models/concerns/pageflow/auto_generated_perma_id.rb +13 -1
- data/app/models/concerns/pageflow/entry_publication_states.rb +7 -3
- data/app/models/concerns/pageflow/feature_target.rb +8 -4
- data/app/models/concerns/pageflow/output_source.rb +3 -3
- data/app/models/concerns/pageflow/permalinkable.rb +2 -1
- data/app/models/concerns/pageflow/reusable_file.rb +23 -23
- data/app/models/concerns/pageflow/serialization_blacklist.rb +1 -1
- data/app/models/concerns/pageflow/suspendable.rb +5 -3
- data/app/models/concerns/pageflow/theme_referencer.rb +1 -1
- data/app/models/concerns/pageflow/translatable.rb +62 -0
- data/app/models/concerns/pageflow/uploadable_file.rb +6 -6
- data/app/models/pageflow/account.rb +6 -5
- data/app/models/pageflow/account_member_query.rb +1 -1
- data/app/models/pageflow/account_role_query.rb +1 -1
- data/app/models/pageflow/application_query.rb +1 -1
- data/app/models/pageflow/application_record.rb +1 -1
- data/app/models/pageflow/audio_file.rb +4 -4
- data/app/models/pageflow/audio_file_url_templates.rb +1 -1
- data/app/models/pageflow/authentication_token.rb +2 -2
- data/app/models/pageflow/chapter.rb +6 -1
- data/app/models/pageflow/chapter_scaffold.rb +2 -4
- data/app/models/pageflow/cname_site_request_scope.rb +1 -1
- data/app/models/pageflow/customized_theme.rb +6 -6
- data/app/models/pageflow/draft_entry.rb +37 -9
- data/app/models/pageflow/edit_lock.rb +19 -21
- data/app/models/pageflow/encoding_confirmation.rb +2 -2
- data/app/models/pageflow/entries_feed.rb +2 -2
- data/app/models/pageflow/entry.rb +44 -30
- data/app/models/pageflow/entry_at_revision.rb +5 -1
- data/app/models/pageflow/entry_duplicate.rb +8 -5
- data/app/models/pageflow/entry_publication.rb +2 -2
- data/app/models/pageflow/entry_role_query.rb +4 -4
- data/app/models/pageflow/entry_template.rb +4 -4
- data/app/models/pageflow/entry_title_or_account_name_query.rb +2 -2
- data/app/models/pageflow/entry_translation_group.rb +42 -0
- data/app/models/pageflow/file_reuse.rb +2 -2
- data/app/models/pageflow/file_usage.rb +10 -3
- data/app/models/pageflow/folder.rb +2 -2
- data/app/models/pageflow/home_button.rb +7 -7
- data/app/models/pageflow/image_file.rb +20 -5
- data/app/models/pageflow/image_file_url_templates.rb +1 -1
- data/app/models/pageflow/invitation_form.rb +2 -1
- data/app/models/pageflow/managed_user_query.rb +1 -1
- data/app/models/pageflow/membership.rb +5 -5
- data/app/models/pageflow/nested_revision_component_copy.rb +263 -0
- data/app/models/pageflow/null_user.rb +1 -1
- data/app/models/pageflow/overview_button.rb +1 -1
- data/app/models/pageflow/page.rb +7 -3
- data/app/models/pageflow/permalink.rb +23 -2
- data/app/models/pageflow/permalink_directory.rb +7 -0
- data/app/models/pageflow/permalink_redirect.rb +7 -0
- data/app/models/pageflow/positioned_file.rb +5 -5
- data/app/models/pageflow/potential_entry_translations.rb +55 -0
- data/app/models/pageflow/potential_memberships.rb +5 -4
- data/app/models/pageflow/published_entry.rb +62 -11
- data/app/models/pageflow/revision.rb +24 -15
- data/app/models/pageflow/roles.rb +14 -18
- data/app/models/pageflow/site.rb +36 -3
- data/app/models/pageflow/site_root_entry_form.rb +27 -0
- data/app/models/pageflow/sitemaps.rb +10 -1
- data/app/models/pageflow/storyline.rb +5 -2
- data/app/models/pageflow/storyline_scaffold.rb +1 -1
- data/app/models/pageflow/text_track_file.rb +1 -1
- data/app/models/pageflow/text_track_file_url_templates.rb +1 -1
- data/app/models/pageflow/theme_customization_file.rb +3 -2
- data/app/models/pageflow/thumbnail_file_resolver.rb +1 -1
- data/app/models/pageflow/url_template.rb +1 -1
- data/app/models/pageflow/used_file.rb +7 -3
- data/app/models/pageflow/user_name_query.rb +2 -2
- data/app/models/pageflow/video_file.rb +22 -15
- data/app/models/pageflow/video_file_url_templates.rb +6 -4
- data/app/models/pageflow/widget.rb +4 -3
- data/app/models/pageflow/with_file_usage_extension.rb +1 -1
- data/app/models/pageflow/zencoder_attachment.rb +8 -8
- data/app/policies/pageflow/account_policy.rb +3 -1
- data/app/policies/pageflow/admin/admin_only_tab_policy.rb +1 -0
- data/app/policies/pageflow/admin/entry_tab_policy.rb +1 -0
- data/app/policies/pageflow/application_policy.rb +2 -0
- data/app/policies/pageflow/entry_policy.rb +7 -1
- data/app/policies/pageflow/entry_template_policy.rb +2 -1
- data/app/policies/pageflow/file_policy.rb +4 -7
- data/app/policies/pageflow/folder_policy.rb +18 -8
- data/app/policies/pageflow/membership_policy.rb +6 -4
- data/app/policies/pageflow/site_policy.rb +10 -3
- data/app/policies/pageflow/user_policy.rb +6 -4
- data/app/state_machines/pageflow/image_and_text_track_processing_state_machine.rb +3 -2
- data/app/state_machines/pageflow/media_encoding_state_machine.rb +5 -4
- data/app/views/admin/accounts/_entry_template_details.html.arb +2 -2
- data/app/views/admin/entries/_attributes_table.html.arb +6 -5
- data/app/views/admin/entries/_form.html.erb +2 -1
- data/app/views/admin/entries/_permalink_inputs.html.erb +9 -2
- data/app/views/admin/entry_templates/_form.html.erb +1 -3
- data/app/views/admin/site_root_entry/choose.html.erb +19 -0
- data/app/views/admin/sites/_fields.html.erb +14 -1
- data/app/views/admin/translations/_form.html.erb +31 -0
- data/app/views/admin/users/_attributes_table.html.arb +13 -0
- data/app/views/components/pageflow/admin/add_membership_button.rb +13 -12
- data/app/views/components/pageflow/admin/custom_scopes_renderer.rb +1 -0
- data/app/views/components/pageflow/admin/embed_code_field.rb +1 -0
- data/app/views/components/pageflow/admin/embedded_index_table.rb +9 -10
- data/app/views/components/pageflow/admin/entries_tab.rb +1 -0
- data/app/views/components/pageflow/admin/entry_publication_state_indicator.rb +6 -5
- data/app/views/components/pageflow/admin/entry_templates_tab.rb +2 -1
- data/app/views/components/pageflow/admin/entry_translations_tab.rb +102 -0
- data/app/views/components/pageflow/admin/entry_user_badge_list.rb +1 -0
- data/app/views/components/pageflow/admin/extensible_attributes_table.rb +9 -8
- data/app/views/components/pageflow/admin/features_tab.rb +1 -0
- data/app/views/components/pageflow/admin/grouped_folder_list.rb +1 -0
- data/app/views/components/pageflow/admin/icon_link_to.rb +1 -0
- data/app/views/components/pageflow/admin/members_tab.rb +4 -3
- data/app/views/components/pageflow/admin/membership_role_with_tooltip.rb +3 -2
- data/app/views/components/pageflow/admin/revisions_tab.rb +14 -10
- data/app/views/components/pageflow/admin/sites_tab.rb +1 -0
- data/app/views/components/pageflow/admin/tabs_view.rb +1 -0
- data/app/views/components/pageflow/admin/timestamp.rb +6 -5
- data/app/views/components/pageflow/admin/user_account_badge_list.rb +2 -3
- data/app/views/components/pageflow/admin/user_accounts_tab.rb +1 -0
- data/app/views/components/pageflow/admin/user_entries_tab.rb +1 -0
- data/app/views/components/pageflow/admin/users_tab.rb +1 -0
- data/app/views/pageflow/editor/config/_seeds.json.jbuilder +1 -1
- data/app/views/pageflow/editor/entries/index.json.jbuilder +1 -1
- data/app/views/pageflow/editor/entries/show.json.jbuilder +1 -1
- data/app/views/pageflow/editor/entry_publications/check.json.jbuilder +2 -2
- data/app/views/pageflow/editor/files/_file.json.jbuilder +5 -13
- data/app/views/pageflow/editor/files/create.json.jbuilder +1 -1
- data/app/views/pageflow/editor/files/index.json.jbuilder +1 -1
- data/app/views/pageflow/editor/sites/_site.json.jbuilder +1 -0
- data/app/views/pageflow/editor/video_files/_video_file.json.jbuilder +1 -3
- data/app/views/pageflow/entries/share_menu/_bluesky_link.html.erb +8 -0
- data/app/views/pageflow/entries/share_menu/_threads_link.html.erb +8 -0
- data/app/views/pageflow/files/_file.json.jbuilder +3 -3
- data/app/views/pageflow/sitemaps/index.xml.builder +9 -1
- data/app/views/pageflow/social_share/_entry_meta_tags.html.erb +1 -1
- data/app/views/pageflow/social_share/_page_meta_tags.html.erb +1 -1
- data/config/initializers/active_admin_patches.rb +3 -6
- data/config/initializers/admin_resource_tabs.rb +3 -0
- data/config/initializers/paperclip.rb +1 -0
- data/config/initializers/symmetric_encryption.rb +1 -1
- data/config/initializers/zencoder.rb +24 -13
- data/config/locales/de.yml +110 -4
- data/config/locales/en.yml +109 -7
- data/config/routes.rb +15 -13
- data/config/spring.rb +2 -1
- data/db/migrate/20140418225525_setup_schema.rb +2 -2
- data/db/migrate/20190306161431_copy_file_attributes_of_failed_uploads.rb +2 -2
- data/db/migrate/20190820152900_drop_accounts_themes.rb +2 -1
- data/db/migrate/20191202145757_create_pageflow_scrolled_sections.rb +11 -11
- data/db/migrate/20191202150657_create_pageflow_scrolled_chapters.rb +1 -1
- data/db/migrate/20191202154723_create_pageflow_scrolled_content_elements.rb +9 -9
- data/db/migrate/20191219143450_add_position_to_content_elements.rb +2 -1
- data/db/migrate/20200117133200_change_revision_appearance_option_default_and_null.rb +2 -1
- data/db/migrate/20200122115400_create_pageflow_entry_templates.rb +25 -25
- data/db/migrate/20200206134400_convert_legacy_scrolled_content_element_types.rb +3 -3
- data/db/migrate/20221215120856_associate_entry_templates_with_sites.rb +2 -2
- data/db/migrate/20230120092923_create_other_files.rb +2 -1
- data/db/migrate/20230419083307_create_pageflow_entry_translation_group.rb +9 -0
- data/db/migrate/20240612110434_add_cutoff_mode_name_to_sites.rb +5 -0
- data/db/migrate/20240918084059_create_pageflow_permalink_redirects.rb +14 -0
- data/db/migrate/20250508172234_ensure_scrolled_entries_have_main_storyline.rb +14 -0
- data/db/migrate/20250617090048_add_custom404_entry_to_sites.rb +5 -0
- data/db/migrate/20250617100000_add_perma_id_counter_to_entries.rb +28 -0
- data/db/migrate/20250722174123_add_perma_id_to_chapters.rb +10 -0
- data/db/migrate/20250725080603_add_perma_id_indexes_to_revision_components.rb +13 -0
- data/db/migrate/20250726000000_add_display_name_to_file_usages.rb +5 -0
- data/entry_types/paged/app/assets/javascripts/pageflow_paged/dist/editor.js +3912 -1486
- data/entry_types/paged/app/assets/javascripts/pageflow_paged/dist/frontend.js +468 -1161
- data/entry_types/paged/app/assets/javascripts/pageflow_paged/dist/react-client.js +28125 -22
- data/entry_types/paged/app/assets/javascripts/pageflow_paged/dist/react-server.js +26589 -19
- data/entry_types/paged/app/controllers/pageflow_paged/entries_controller.rb +1 -0
- data/entry_types/paged/app/helpers/pageflow_paged/page_background_asset_helper.rb +1 -1
- data/entry_types/paged/app/helpers/pageflow_paged/third_party_embed_consent_helper.rb +7 -7
- data/entry_types/paged/app/views/pageflow_paged/editor/entries/_seed.json.jbuilder +1 -0
- data/entry_types/paged/app/views/pageflow_paged/entries/show.html.erb +1 -0
- data/entry_types/paged/lib/pageflow_paged/plugin.rb +4 -0
- data/entry_types/paged/lib/pageflow_paged/react/page_type.rb +1 -1
- data/entry_types/paged/lib/pageflow_paged/react/widget_type.rb +3 -3
- data/entry_types/paged/lib/pageflow_paged.rb +1 -1
- data/entry_types/scrolled/app/controllers/pageflow_scrolled/editor/chapters_controller.rb +5 -3
- data/entry_types/scrolled/app/controllers/pageflow_scrolled/editor/content_elements_controller.rb +2 -2
- data/entry_types/scrolled/app/controllers/pageflow_scrolled/editor/sections_controller.rb +2 -2
- data/entry_types/scrolled/app/controllers/pageflow_scrolled/entries_controller.rb +2 -1
- data/entry_types/scrolled/app/helpers/pageflow_scrolled/cache_helper.rb +2 -2
- data/entry_types/scrolled/app/helpers/pageflow_scrolled/editor/entry_json_seed_helper.rb +1 -0
- data/entry_types/scrolled/app/helpers/pageflow_scrolled/editor/seed_html_helper.rb +2 -1
- data/entry_types/scrolled/app/helpers/pageflow_scrolled/entry_json_seed_helper.rb +60 -6
- data/entry_types/scrolled/app/helpers/pageflow_scrolled/packs_helper.rb +16 -2
- data/entry_types/scrolled/app/helpers/pageflow_scrolled/react_server_side_rendering_helper.rb +21 -23
- data/entry_types/scrolled/app/helpers/pageflow_scrolled/themes_helper.rb +16 -1
- data/entry_types/scrolled/app/models/pageflow_scrolled/chapter.rb +15 -14
- data/entry_types/scrolled/app/models/pageflow_scrolled/content_element.rb +12 -0
- data/entry_types/scrolled/app/models/pageflow_scrolled/section.rb +12 -1
- data/entry_types/scrolled/app/models/pageflow_scrolled/storyline.rb +19 -1
- data/entry_types/scrolled/app/views/pageflow_scrolled/editor/entries/_head.html.erb +1 -0
- data/entry_types/scrolled/app/views/pageflow_scrolled/editor/sections/_section_with_content_elements.json.jbuilder +2 -2
- data/entry_types/scrolled/app/views/pageflow_scrolled/entries/show.html.erb +2 -0
- data/entry_types/scrolled/app/views/pageflow_scrolled/entry_json_seed/_entry.json.jbuilder +17 -9
- data/entry_types/scrolled/app/views/pageflow_scrolled/entry_json_seed/_entry_translations.json.jbuilder +14 -0
- data/entry_types/scrolled/app/views/pageflow_scrolled/entry_json_seed/_theme.json.jbuilder +25 -5
- data/entry_types/scrolled/app/views/pageflow_scrolled/storylines/_storyline.json.jbuilder +7 -0
- data/entry_types/scrolled/config/locales/de.yml +614 -45
- data/entry_types/scrolled/config/locales/en.yml +586 -47
- data/entry_types/scrolled/config/routes.rb +18 -8
- data/entry_types/scrolled/lib/generators/pageflow_scrolled/install/install_generator.rb +11 -11
- data/entry_types/scrolled/lib/generators/pageflow_scrolled/install/templates/theme/logoDarkVariantDesktop.svg +56 -0
- data/entry_types/scrolled/lib/generators/pageflow_scrolled/install/templates/theme/logoDarkVariantMobile.svg +22 -0
- data/entry_types/scrolled/lib/generators/pageflow_scrolled/install/templates/themes_plugin.rb.tt +26 -11
- data/entry_types/scrolled/lib/pageflow_scrolled/additional_packs.rb +27 -8
- data/entry_types/scrolled/lib/pageflow_scrolled/additional_seed_data.rb +1 -1
- data/entry_types/scrolled/lib/pageflow_scrolled/additional_theme_assets.rb +27 -0
- data/entry_types/scrolled/lib/pageflow_scrolled/configuration.rb +16 -4
- data/entry_types/scrolled/lib/pageflow_scrolled/content_element_consent_vendors.rb +1 -1
- data/entry_types/scrolled/lib/pageflow_scrolled/plugin.rb +24 -4
- data/entry_types/scrolled/lib/pageflow_scrolled/seeds.rb +24 -22
- data/entry_types/scrolled/lib/pageflow_scrolled.rb +1 -1
- data/entry_types/scrolled/lib/tasks/pageflow_scrolled/storybook.rake +6 -5
- data/entry_types/scrolled/package/config/webpack.js +22 -0
- data/entry_types/scrolled/package/contentElements/hotspots-frontend.css +1 -0
- data/entry_types/scrolled/package/contentElements/hotspots-frontend.js +1529 -0
- data/entry_types/scrolled/package/contentElements/tikTokEmbed-frontend.css +1 -0
- data/entry_types/scrolled/package/contentElements/tikTokEmbed-frontend.js +59 -0
- data/entry_types/scrolled/package/contentElements-editor.js +2075 -321
- data/entry_types/scrolled/package/contentElements-frontend.css +1 -1
- data/entry_types/scrolled/package/contentElements-frontend.js +1019 -643
- data/entry_types/scrolled/package/editor.js +2086 -1091
- data/entry_types/scrolled/package/frontend/{EditableInlineText.module-ebd22921.js → FloatingPortalRootProvider-51914be7.js} +1200 -1258
- data/entry_types/scrolled/package/frontend/{PhonePlatformContext-4ec6b2de.js → PhonePlatformContext-9f76033e.js} +7 -8
- data/entry_types/scrolled/package/frontend/ThemeIcon-81f2f066.js +1932 -0
- data/entry_types/scrolled/package/frontend/ToggleFullscreenCornerButton-788e9cdb.js +39 -0
- data/entry_types/scrolled/package/frontend/{Viewer-1bb5597c.js → Viewer-0345ce57.js} +36 -63
- data/entry_types/scrolled/package/frontend/{Viewer-1ecf3375.js → Viewer-cdc549cc.js} +15 -22
- data/entry_types/scrolled/package/frontend/{Wavesurfer-7d9cf1b7.js → Wavesurfer-1cdc3925.js} +54 -74
- data/entry_types/scrolled/package/frontend/{components-024a9893.js → components-96660ffd.js} +1791 -841
- data/entry_types/scrolled/package/frontend/{index-11f32f10.js → index-eb670c2f.js} +11 -18
- data/entry_types/scrolled/package/frontend/index.css +1 -1
- data/entry_types/scrolled/package/frontend/index.js +517 -903
- data/entry_types/scrolled/package/frontend/{createSuper-d0f30da3.js → inherits-539844a6.js} +40 -56
- data/entry_types/scrolled/package/frontend/{useContentElementEditorState-4f4c3cf6.js → useContentElementEditorState-77fe6c79.js} +7 -8
- data/entry_types/scrolled/package/frontend/usePhonePlatform-c2ba875d.js +8 -0
- data/entry_types/scrolled/package/frontend-server.js +0 -1
- data/entry_types/scrolled/package/package.json +18 -10
- data/entry_types/scrolled/package/testHelpers.js +306 -70
- data/entry_types/scrolled/package/values/widgets.module.css +18 -0
- data/entry_types/scrolled/package/widgets/consentBar.css +1 -1
- data/entry_types/scrolled/package/widgets/consentBar.js +47 -66
- data/entry_types/scrolled/package/widgets/defaultNavigation.css +2 -2
- data/entry_types/scrolled/package/widgets/defaultNavigation.js +177 -207
- data/entry_types/scrolled/package/widgets/excursionDialog.css +1 -0
- data/entry_types/scrolled/package/widgets/excursionDialog.js +109 -0
- data/entry_types/scrolled/package/widgets/excursionSheet.css +1 -0
- data/entry_types/scrolled/package/widgets/excursionSheet.js +262 -0
- data/entry_types/scrolled/package/widgets/iconInlineFileRights.css +1 -1
- data/entry_types/scrolled/package/widgets/iconInlineFileRights.js +6 -9
- data/entry_types/scrolled/package/widgets/iconScrollIndicator.css +1 -0
- data/entry_types/scrolled/package/widgets/iconScrollIndicator.js +48 -0
- data/entry_types/scrolled/package/widgets/mainStorylineSheet.css +1 -0
- data/entry_types/scrolled/package/widgets/mainStorylineSheet.js +144 -0
- data/entry_types/scrolled/package/widgets/textInlineFileRights.css +1 -1
- data/entry_types/scrolled/package/widgets/textInlineFileRights.js +26 -9
- data/entry_types/scrolled/package/widgets-server.js +1 -0
- data/entry_types/scrolled/spec/factories/chapters.rb +14 -1
- data/entry_types/scrolled/spec/factories/content_elements.rb +1 -1
- data/lib/generators/pageflow/active_admin_initializer/active_admin_initializer_generator.rb +5 -3
- data/lib/generators/pageflow/assets/assets_generator.rb +7 -5
- data/lib/generators/pageflow/cancan/cancan_generator.rb +2 -1
- data/lib/generators/pageflow/cancan/templates/ability.rb +1 -1
- data/lib/generators/pageflow/error_pages/error_pages_generator.rb +2 -1
- data/lib/generators/pageflow/initializer/initializer_generator.rb +3 -2
- data/lib/generators/pageflow/install/install_generator.rb +2 -2
- data/lib/generators/pageflow/procfile/procfile_generator.rb +2 -1
- data/lib/generators/pageflow/resque/resque_generator.rb +6 -4
- data/lib/generators/pageflow/resque/templates/resque.rake +1 -1
- data/lib/generators/pageflow/routes/routes_generator.rb +4 -2
- data/lib/generators/pageflow/seeds/seeds_generator.rb +3 -2
- data/lib/generators/pageflow/seeds/templates/seeds.rb +6 -6
- data/lib/generators/pageflow/theme/theme_generator.rb +2 -1
- data/lib/generators/pageflow/user/user_generator.rb +2 -1
- data/lib/pageflow/ability_mixin.rb +25 -15
- data/lib/pageflow/active_admin_patches/views/attributes_table.rb +1 -0
- data/lib/pageflow/active_admin_patches/views/pages/base.rb +3 -2
- data/lib/pageflow/active_admin_patches/views/table_for.rb +1 -0
- data/lib/pageflow/additional_headers.rb +27 -0
- data/lib/pageflow/admin/attributes_table_rows.rb +3 -3
- data/lib/pageflow/admin/tabs.rb +1 -1
- data/lib/pageflow/built_in_file_type.rb +1 -1
- data/lib/pageflow/built_in_page_types_plugin.rb +1 -1
- data/lib/pageflow/built_in_widget_type.rb +2 -2
- data/lib/pageflow/built_in_widget_types_plugin.rb +2 -1
- data/lib/pageflow/configuration.rb +141 -18
- data/lib/pageflow/cutoff_modes.rb +39 -0
- data/lib/pageflow/editor_controller.rb +6 -10
- data/lib/pageflow/engine.rb +4 -5
- data/lib/pageflow/entry_export_import/attachment_files.rb +1 -1
- data/lib/pageflow/entry_export_import/entry_serialization.rb +5 -4
- data/lib/pageflow/entry_export_import/file_mappings.rb +1 -0
- data/lib/pageflow/entry_export_import/revision_serialization/import.rb +1 -1
- data/lib/pageflow/entry_export_import.rb +3 -3
- data/lib/pageflow/entry_types.rb +2 -2
- data/lib/pageflow/feature.rb +1 -1
- data/lib/pageflow/features.rb +4 -6
- data/lib/pageflow/file_importers.rb +4 -4
- data/lib/pageflow/file_type.rb +3 -3
- data/lib/pageflow/file_types.rb +3 -3
- data/lib/pageflow/global_config_api.rb +5 -6
- data/lib/pageflow/help_entries.rb +7 -7
- data/lib/pageflow/help_entry.rb +1 -1
- data/lib/pageflow/hooks.rb +1 -1
- data/lib/pageflow/nested_revision_component.rb +9 -27
- data/lib/pageflow/news_item_api.rb +1 -1
- data/lib/pageflow/page_type.rb +2 -3
- data/lib/pageflow/page_types.rb +3 -3
- data/lib/pageflow/paperclip_interpolations/support.rb +1 -1
- data/lib/pageflow/paperclip_processors/vtt.rb +1 -0
- data/lib/pageflow/paperclip_processors/webp.rb +2 -2
- data/lib/pageflow/partial_editor_fragment_renderer.rb +2 -2
- data/lib/pageflow/plugin.rb +1 -2
- data/lib/pageflow/quota.rb +9 -5
- data/lib/pageflow/quotas.rb +1 -1
- data/lib/pageflow/rails_version.rb +1 -0
- data/lib/pageflow/react.rb +1 -1
- data/lib/pageflow/revision_component.rb +8 -40
- data/lib/pageflow/revision_components.rb +16 -6
- data/lib/pageflow/seeds.rb +12 -16
- data/lib/pageflow/theme.rb +1 -1
- data/lib/pageflow/theme_customizations.rb +10 -10
- data/lib/pageflow/themes.rb +3 -3
- data/lib/pageflow/user_mixin.rb +6 -6
- data/lib/pageflow/version.rb +1 -1
- data/lib/pageflow/widget_type.rb +4 -4
- data/lib/pageflow/widget_types.rb +9 -9
- data/lib/pageflow/zencoder_api.rb +32 -42
- data/lib/pageflow/zencoder_audio_output_definition.rb +14 -13
- data/lib/pageflow/zencoder_meta_data_output_definition.rb +3 -2
- data/lib/pageflow/zencoder_output_definition.rb +16 -14
- data/lib/pageflow/zencoder_video_output_definition.rb +140 -88
- data/lib/pageflow.rb +7 -2
- data/lib/tasks/pageflow_tasks.rake +1 -1
- data/package/editor.js +954 -868
- data/package/frontend.js +113 -387
- data/package/package.json +2 -1
- data/package/testHelpers.js +10 -56
- data/package/ui.js +209 -251
- data/spec/factories/accounts.rb +37 -22
- data/spec/factories/audio_files.rb +2 -2
- data/spec/factories/authentication_tokens.rb +4 -4
- data/spec/factories/chapters.rb +4 -4
- data/spec/factories/draft_entries.rb +14 -6
- data/spec/factories/edit_locks.rb +1 -1
- data/spec/factories/entries.rb +28 -19
- data/spec/factories/entry_translation_groups.rb +6 -0
- data/spec/factories/file_usages.rb +2 -1
- data/spec/factories/folders.rb +1 -1
- data/spec/factories/image_files.rb +2 -2
- data/spec/factories/pages.rb +3 -3
- data/spec/factories/published_entries.rb +26 -8
- data/spec/factories/revisions.rb +1 -1
- data/spec/factories/sites.rb +6 -0
- data/spec/factories/test_multi_attachment_files.rb +1 -1
- data/spec/factories/text_track_files.rb +1 -1
- data/spec/factories/uploadable_files.rb +1 -1
- data/spec/factories/users.rb +6 -6
- data/spec/factories/video_files.rb +2 -2
- data/spec/factories/widgets.rb +1 -1
- data/spec/fixtures/7x15_rotated.jpg +0 -0
- data/vendor/assets/javascripts/wysihtml-toolbar.js +19288 -0
- metadata +98 -45
- data/config/initializers/revision_components.rb +0 -5
- data/config/locales/twitter_to_x.de.yml +0 -6
- data/config/locales/twitter_to_x.en.yml +0 -6
- data/entry_types/scrolled/config/locales/twitter_to_x.de.yml +0 -12
- data/entry_types/scrolled/config/locales/twitter_to_x.en.yml +0 -12
- data/entry_types/scrolled/config/locales/vr_image_projection.de.yml +0 -24
- data/entry_types/scrolled/config/locales/vr_image_projection.en.yml +0 -24
- data/entry_types/scrolled/package/frontend/ToggleFullscreenCornerButton-b79159cc.js +0 -107
- data/entry_types/scrolled/package/frontend/arrowRight-62998af9.js +0 -77
- data/entry_types/scrolled/package/frontend/i18n-ce13a8bf.js +0 -1129
@@ -5,7 +5,7 @@ module Pageflow
|
|
5
5
|
true => 'enabled',
|
6
6
|
false => 'disabled',
|
7
7
|
nil => 'default'
|
8
|
-
}
|
8
|
+
}.freeze
|
9
9
|
|
10
10
|
extend ActiveSupport::Concern
|
11
11
|
|
@@ -21,7 +21,7 @@ module Pageflow
|
|
21
21
|
|
22
22
|
def feature_state(name)
|
23
23
|
state = own_feature_state(name)
|
24
|
-
state
|
24
|
+
state.nil? ? inherited_feature_state(name) : state
|
25
25
|
end
|
26
26
|
|
27
27
|
def own_feature_state(name)
|
@@ -32,6 +32,8 @@ module Pageflow
|
|
32
32
|
Pageflow.config.features.enabled_by_default?(name)
|
33
33
|
end
|
34
34
|
|
35
|
+
# rubocop:todo Metrics/PerceivedComplexity
|
36
|
+
# rubocop:todo Metrics/CyclomaticComplexity
|
35
37
|
def feature_states=(states)
|
36
38
|
boolean_states = states.each_with_object({}) do |(key, value), result|
|
37
39
|
if value == true || value == STATE_MAPPING[true]
|
@@ -44,9 +46,11 @@ module Pageflow
|
|
44
46
|
end
|
45
47
|
|
46
48
|
self.features_configuration = features_configuration
|
47
|
-
|
48
|
-
|
49
|
+
.merge(boolean_states)
|
50
|
+
.compact
|
49
51
|
end
|
52
|
+
# rubocop:enable Metrics/CyclomaticComplexity
|
53
|
+
# rubocop:enable Metrics/PerceivedComplexity
|
50
54
|
|
51
55
|
def features_configuration
|
52
56
|
self[:features_configuration] || {}
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Pageflow
|
2
|
-
module OutputSource
|
2
|
+
module OutputSource # rubocop:todo Style/Documentation
|
3
3
|
STATE_MAPPING = {
|
4
4
|
true => 'finished',
|
5
5
|
false => 'skipped'
|
@@ -36,7 +36,7 @@ module Pageflow
|
|
36
36
|
|
37
37
|
self[:output_presences] = output_presences
|
38
38
|
.merge(boolean_presences)
|
39
|
-
.
|
39
|
+
.compact
|
40
40
|
end
|
41
41
|
|
42
42
|
def output_presences
|
@@ -55,7 +55,7 @@ module Pageflow
|
|
55
55
|
[label.to_s, true]
|
56
56
|
end
|
57
57
|
|
58
|
-
|
58
|
+
pairs.to_h
|
59
59
|
end
|
60
60
|
end
|
61
61
|
end
|
@@ -4,7 +4,8 @@ module Pageflow
|
|
4
4
|
extend ActiveSupport::Concern
|
5
5
|
|
6
6
|
included do
|
7
|
-
belongs_to :permalink, optional: true
|
7
|
+
belongs_to :permalink, optional: true, dependent: :destroy
|
8
|
+
has_many :permalink_redirects, dependent: :destroy
|
8
9
|
|
9
10
|
accepts_nested_attributes_for :permalink, update_only: true
|
10
11
|
end
|
@@ -1,21 +1,22 @@
|
|
1
1
|
module Pageflow
|
2
|
-
module ReusableFile
|
2
|
+
module ReusableFile # rubocop:todo Style/Documentation
|
3
3
|
extend ActiveSupport::Concern
|
4
4
|
|
5
5
|
included do
|
6
6
|
belongs_to :uploader, class_name: 'User', optional: true
|
7
7
|
belongs_to :entry, optional: true
|
8
|
-
belongs_to :parent_file, polymorphic: true, foreign_type: :parent_file_model_type,
|
8
|
+
belongs_to :parent_file, polymorphic: true, foreign_type: :parent_file_model_type,
|
9
|
+
optional: true
|
9
10
|
|
10
|
-
has_many :usages, :
|
11
|
+
has_many :usages, as: :file, class_name: 'Pageflow::FileUsage', dependent: :destroy
|
11
12
|
has_one :import,
|
12
13
|
as: :file,
|
13
14
|
class_name: 'Pageflow::FileImport',
|
14
15
|
required: false,
|
15
16
|
dependent: :destroy
|
16
|
-
has_many :using_revisions, :
|
17
|
-
has_many :using_entries, :
|
18
|
-
has_many :using_accounts, :
|
17
|
+
has_many :using_revisions, through: :usages, source: :revision
|
18
|
+
has_many :using_entries, through: :using_revisions, source: :entry
|
19
|
+
has_many :using_accounts, through: :using_entries, source: :account
|
19
20
|
|
20
21
|
validate :parent_allows_type_for_nesting, :parent_belongs_to_same_entry
|
21
22
|
|
@@ -25,30 +26,29 @@ module Pageflow
|
|
25
26
|
end
|
26
27
|
|
27
28
|
def parent_allows_type_for_nesting
|
28
|
-
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
34
|
-
|
35
|
-
|
36
|
-
|
29
|
+
return unless parent_file.present?
|
30
|
+
|
31
|
+
parent_class = parent_file.class
|
32
|
+
file_type_of_parent = Pageflow.config.file_types.find_by_model!(parent_class)
|
33
|
+
models_of_nested_file_types = file_type_of_parent.nested_file_types.map(&:model)
|
34
|
+
return if models_of_nested_file_types.include?(self.class)
|
35
|
+
|
36
|
+
errors.add(:base, 'File type of provided parent file does not permit nesting files of ' \
|
37
|
+
"type #{self.class.name}")
|
37
38
|
end
|
38
39
|
|
39
40
|
def parent_belongs_to_same_entry
|
40
|
-
|
41
|
-
|
42
|
-
|
43
|
-
|
44
|
-
end
|
41
|
+
return unless parent_file.present?
|
42
|
+
return if parent_file.using_entries.include?(entry)
|
43
|
+
|
44
|
+
errors.add(:base, 'Parent file does not belong to same entry as nested file')
|
45
45
|
end
|
46
46
|
|
47
47
|
def nested_files(model)
|
48
48
|
model_table_name = model.table_name
|
49
49
|
model
|
50
50
|
.select("#{model_table_name}.*")
|
51
|
-
.where("#{model_table_name}.parent_file_id = #{id} AND "\
|
51
|
+
.where("#{model_table_name}.parent_file_id = #{id} AND " \
|
52
52
|
"#{model_table_name}.parent_file_model_type = '#{self.class.name}'")
|
53
53
|
end
|
54
54
|
|
@@ -65,7 +65,6 @@ module Pageflow
|
|
65
65
|
"#{super}-#{state}"
|
66
66
|
end
|
67
67
|
|
68
|
-
|
69
68
|
# The following are method defaults for file types that do not require processing/encoding.
|
70
69
|
# They are overwritten with default values in UploadableFile for files that are uploaded
|
71
70
|
# through the editor.
|
@@ -131,7 +130,8 @@ module Pageflow
|
|
131
130
|
raise 'Not implemented!'
|
132
131
|
end
|
133
132
|
|
134
|
-
# Gets called to trigger the `file_uploaded` event in the upload state
|
133
|
+
# Gets called to trigger the `file_uploaded` event in the upload state
|
134
|
+
# machine of UploadableFile.
|
135
135
|
# Files that are not uploaded through the editor (and therefore not using the
|
136
136
|
# upload state machine of UploadableFile) can overwrite this method to trigger whatever
|
137
137
|
# the file does (i.e. processing/transcoding), depending on the including class'
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Pageflow
|
2
|
-
module Suspendable
|
2
|
+
module Suspendable # rubocop:todo Style/Documentation
|
3
3
|
def active_for_authentication?
|
4
4
|
super && !suspended?
|
5
5
|
end
|
@@ -10,14 +10,16 @@ module Pageflow
|
|
10
10
|
|
11
11
|
def suspend!
|
12
12
|
return if suspended?
|
13
|
+
|
13
14
|
self.suspended_at = Time.zone.now
|
14
|
-
save(:
|
15
|
+
save(validate: false)
|
15
16
|
end
|
16
17
|
|
17
18
|
def unsuspend!
|
18
19
|
return unless suspended?
|
20
|
+
|
19
21
|
self.suspended_at = nil
|
20
|
-
save(:
|
22
|
+
save(validate: false)
|
21
23
|
end
|
22
24
|
end
|
23
25
|
end
|
@@ -0,0 +1,62 @@
|
|
1
|
+
module Pageflow
|
2
|
+
# @api private
|
3
|
+
module Translatable
|
4
|
+
extend ActiveSupport::Concern
|
5
|
+
|
6
|
+
included do
|
7
|
+
belongs_to(:translation_group,
|
8
|
+
optional: true,
|
9
|
+
class_name: 'EntryTranslationGroup')
|
10
|
+
|
11
|
+
has_many(:translations,
|
12
|
+
through: :translation_group,
|
13
|
+
source: :entries)
|
14
|
+
|
15
|
+
after_destroy do
|
16
|
+
if translation_group&.single_item_or_empty?
|
17
|
+
translation_group.destroy
|
18
|
+
elsif default_translation?
|
19
|
+
translation_group.update(default_translation: nil)
|
20
|
+
end
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
def mark_as_translation_of(entry)
|
25
|
+
transaction do
|
26
|
+
ensure_translation_group(entry)
|
27
|
+
|
28
|
+
if !entry.translation_group
|
29
|
+
entry.update!(translation_group:)
|
30
|
+
elsif entry.translation_group != translation_group
|
31
|
+
entry.translation_group.merge_into(translation_group)
|
32
|
+
end
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
def remove_from_translation_group
|
37
|
+
if translation_group.entries.count <= 2
|
38
|
+
translation_group.destroy
|
39
|
+
else
|
40
|
+
translation_group.update(default_translation: nil) if default_translation?
|
41
|
+
update!(translation_group: nil)
|
42
|
+
end
|
43
|
+
end
|
44
|
+
|
45
|
+
def mark_as_default_translation
|
46
|
+
translation_group.update!(default_translation: self)
|
47
|
+
end
|
48
|
+
|
49
|
+
def default_translation?
|
50
|
+
translation_group&.default_translation == self
|
51
|
+
end
|
52
|
+
|
53
|
+
private
|
54
|
+
|
55
|
+
def ensure_translation_group(other_entry)
|
56
|
+
return if translation_group
|
57
|
+
|
58
|
+
update!(translation_group: other_entry.translation_group ||
|
59
|
+
build_translation_group(default_translation: self))
|
60
|
+
end
|
61
|
+
end
|
62
|
+
end
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Pageflow
|
2
|
-
module UploadableFile
|
2
|
+
module UploadableFile # rubocop:todo Style/Documentation
|
3
3
|
extend ActiveSupport::Concern
|
4
4
|
include ReusableFile
|
5
5
|
|
@@ -20,7 +20,7 @@ module Pageflow
|
|
20
20
|
))
|
21
21
|
|
22
22
|
validates_attachment_presence :attachment_on_s3
|
23
|
-
validates_attachment_file_name :attachment_on_s3, matches: %r{^[
|
23
|
+
validates_attachment_file_name :attachment_on_s3, matches: %r{^[^/\\]+\.\w{3,4}$}
|
24
24
|
do_not_validate_attachment_file_type :attachment_on_s3
|
25
25
|
|
26
26
|
state_machine initial: 'uploading' do
|
@@ -76,9 +76,9 @@ module Pageflow
|
|
76
76
|
end
|
77
77
|
|
78
78
|
def url
|
79
|
-
|
80
|
-
|
81
|
-
|
79
|
+
return unless attachment.present?
|
80
|
+
|
81
|
+
attachment.url
|
82
82
|
end
|
83
83
|
|
84
84
|
def basename
|
@@ -109,7 +109,7 @@ module Pageflow
|
|
109
109
|
file_uploaded!
|
110
110
|
end
|
111
111
|
|
112
|
-
module ClassMethods
|
112
|
+
module ClassMethods # rubocop:todo Style/Documentation
|
113
113
|
def processing_state_machine(&block)
|
114
114
|
state_machine do
|
115
115
|
extend StateMachineJob::Macro
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Pageflow
|
2
|
-
class Account < ApplicationRecord
|
2
|
+
class Account < ApplicationRecord # rubocop:todo Style/Documentation
|
3
3
|
include FeatureTarget
|
4
4
|
include SerializationBlacklist
|
5
5
|
|
@@ -10,17 +10,18 @@ module Pageflow
|
|
10
10
|
has_many :entry_memberships, through: :entries, source: :memberships
|
11
11
|
|
12
12
|
has_many :sites, dependent: :destroy
|
13
|
-
belongs_to :default_site, :
|
13
|
+
belongs_to :default_site, class_name: 'Site'
|
14
14
|
|
15
|
-
validates :default_site, :
|
15
|
+
validates :default_site, presence: true
|
16
16
|
|
17
|
-
accepts_nested_attributes_for :default_site, :
|
17
|
+
accepts_nested_attributes_for :default_site, update_only: true
|
18
18
|
|
19
|
-
scope :with_landing_page, -> { where.not(:
|
19
|
+
scope :with_landing_page, -> { where.not(landing_page_name: '') }
|
20
20
|
|
21
21
|
def build_default_site(*args)
|
22
22
|
super.tap do |site|
|
23
23
|
site.account = self
|
24
|
+
site.build_root_permalink_directory
|
24
25
|
end
|
25
26
|
end
|
26
27
|
|
@@ -1,7 +1,7 @@
|
|
1
1
|
module Pageflow
|
2
2
|
# Query accounts for members, e.g. based on role
|
3
3
|
class AccountMemberQuery < ApplicationQuery
|
4
|
-
class Scope < ApplicationQuery::Scope
|
4
|
+
class Scope < ApplicationQuery::Scope # rubocop:todo Style/Documentation
|
5
5
|
# Account whose members we scope
|
6
6
|
# @return [Pageflow::Account]
|
7
7
|
attr_reader :account
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Pageflow
|
2
|
-
class AudioFile < ApplicationRecord
|
2
|
+
class AudioFile < ApplicationRecord # rubocop:todo Style/Documentation
|
3
3
|
include UploadableFile
|
4
4
|
include MediaEncodingStateMachine
|
5
5
|
|
@@ -21,15 +21,15 @@ module Pageflow
|
|
21
21
|
end
|
22
22
|
|
23
23
|
def m4a
|
24
|
-
ZencoderAttachment.new(self,
|
24
|
+
ZencoderAttachment.new(self, 'audio.m4a')
|
25
25
|
end
|
26
26
|
|
27
27
|
def mp3
|
28
|
-
ZencoderAttachment.new(self,
|
28
|
+
ZencoderAttachment.new(self, 'audio.mp3')
|
29
29
|
end
|
30
30
|
|
31
31
|
def ogg
|
32
|
-
ZencoderAttachment.new(self,
|
32
|
+
ZencoderAttachment.new(self, 'audio.ogg')
|
33
33
|
end
|
34
34
|
|
35
35
|
def output_definition
|
@@ -4,7 +4,7 @@ module Pageflow
|
|
4
4
|
# AuthenticationToken stores the tokens with expiry time against user and provider
|
5
5
|
class AuthenticationToken < ApplicationRecord
|
6
6
|
belongs_to :user, class_name: 'User'
|
7
|
-
default_scope -> { where(['expiry_time > :expiry', expiry: Time.zone.now]) }
|
7
|
+
default_scope -> { where(['expiry_time > :expiry', {expiry: Time.zone.now}]) }
|
8
8
|
|
9
9
|
def auth_token
|
10
10
|
SymmetricEncryption.decrypt(read_attribute(:auth_token))
|
@@ -31,7 +31,7 @@ module Pageflow
|
|
31
31
|
|
32
32
|
def self.find_auth_token(current_user, provider)
|
33
33
|
where(user_id: current_user.id,
|
34
|
-
provider:
|
34
|
+
provider:)
|
35
35
|
end
|
36
36
|
end
|
37
37
|
end
|
@@ -1,7 +1,8 @@
|
|
1
1
|
module Pageflow
|
2
|
-
class Chapter < ApplicationRecord
|
2
|
+
class Chapter < ApplicationRecord # rubocop:todo Style/Documentation
|
3
3
|
include SerializedConfiguration
|
4
4
|
include NestedRevisionComponent
|
5
|
+
include AutoGeneratedPermaId
|
5
6
|
|
6
7
|
belongs_to :storyline, touch: true
|
7
8
|
has_many :pages, -> { order('position ASC') }, dependent: :destroy, inverse_of: :chapter
|
@@ -15,5 +16,9 @@ module Pageflow
|
|
15
16
|
def pages
|
16
17
|
super.tap { |p| p.first.is_first = true if is_first && p.present? }
|
17
18
|
end
|
19
|
+
|
20
|
+
def entry_for_auto_generated_perma_id
|
21
|
+
storyline.revision.entry
|
22
|
+
end
|
18
23
|
end
|
19
24
|
end
|
@@ -1,5 +1,5 @@
|
|
1
1
|
module Pageflow
|
2
|
-
class ChapterScaffold
|
2
|
+
class ChapterScaffold # rubocop:todo Style/Documentation
|
3
3
|
def initialize(chapter, options)
|
4
4
|
@chapter = chapter
|
5
5
|
@options = options
|
@@ -8,9 +8,7 @@ module Pageflow
|
|
8
8
|
delegate :save!, to: :@chapter
|
9
9
|
|
10
10
|
def build
|
11
|
-
if @options[:depth] == 'page'
|
12
|
-
@page = @chapter.pages.build(template: 'background_image')
|
13
|
-
end
|
11
|
+
@page = @chapter.pages.build(template: 'background_image') if @options[:depth] == 'page'
|
14
12
|
|
15
13
|
self
|
16
14
|
end
|
@@ -11,8 +11,8 @@ module Pageflow
|
|
11
11
|
|
12
12
|
def self.find(entry:, theme:)
|
13
13
|
build(
|
14
|
-
entry
|
15
|
-
theme
|
14
|
+
entry:,
|
15
|
+
theme:,
|
16
16
|
theme_customization: Pageflow.theme_customizations.get(
|
17
17
|
site: entry.site,
|
18
18
|
entry_type_name: entry.type_name
|
@@ -26,13 +26,13 @@ module Pageflow
|
|
26
26
|
new(theme,
|
27
27
|
config.transform_theme_customization_overrides.call(
|
28
28
|
theme_customization.overrides,
|
29
|
-
entry
|
30
|
-
theme:
|
29
|
+
entry:,
|
30
|
+
theme:
|
31
31
|
),
|
32
32
|
config.transform_theme_customization_files.call(
|
33
33
|
theme_customization.selected_files.transform_values(&:urls),
|
34
|
-
entry
|
35
|
-
theme:
|
34
|
+
entry:,
|
35
|
+
theme:
|
36
36
|
))
|
37
37
|
end
|
38
38
|
end
|
@@ -1,3 +1,5 @@
|
|
1
|
+
require 'securerandom'
|
2
|
+
|
1
3
|
module Pageflow
|
2
4
|
# A merged view of an entry and its draft revision
|
3
5
|
class DraftEntry < EntryAtRevision
|
@@ -14,20 +16,35 @@ module Pageflow
|
|
14
16
|
entry.title
|
15
17
|
end
|
16
18
|
|
19
|
+
def translations(scope = -> { self }, **)
|
20
|
+
return [] unless entry.translation_group
|
21
|
+
|
22
|
+
PublishedEntry.wrap_all_drafts(
|
23
|
+
entry.translation_group.entries.instance_exec(&scope)
|
24
|
+
)
|
25
|
+
end
|
26
|
+
|
27
|
+
def cutoff_mode_enabled_for?(_request)
|
28
|
+
false
|
29
|
+
end
|
30
|
+
|
17
31
|
def create_file!(file_type, attributes)
|
18
32
|
check_foreign_key_custom_attributes(file_type.custom_attributes, attributes)
|
19
33
|
|
20
|
-
file = file_type.model.create!(
|
21
|
-
|
22
|
-
|
34
|
+
file = file_type.model.create!(
|
35
|
+
attributes
|
36
|
+
.except(:configuration, :display_name)
|
37
|
+
.merge(file_name: generate_file_name(attributes[:display_name]))
|
38
|
+
) { |f| f.entry = entry }
|
23
39
|
|
24
|
-
usage = revision.file_usages.
|
25
|
-
|
40
|
+
usage = revision.file_usages.create!(file:,
|
41
|
+
configuration: attributes[:configuration],
|
42
|
+
display_name: attributes[:display_name])
|
26
43
|
UsedFile.new(file, usage)
|
27
44
|
end
|
28
45
|
|
29
|
-
def remove_file(file)
|
30
|
-
draft.file_usages.where(file:
|
46
|
+
def remove_file(file) # rubocop:todo Metrics/AbcSize
|
47
|
+
draft.file_usages.where(file:).destroy_all
|
31
48
|
|
32
49
|
file.file_type.nested_file_types.each do |nested_file_type|
|
33
50
|
nested_file_ids = file.nested_files(nested_file_type.model).map(&:id)
|
@@ -44,7 +61,8 @@ module Pageflow
|
|
44
61
|
|
45
62
|
def use_file(file)
|
46
63
|
draft.file_usages.create!(file: file.to_model,
|
47
|
-
configuration: file.configuration
|
64
|
+
configuration: file.configuration,
|
65
|
+
display_name: file.display_name)
|
48
66
|
end
|
49
67
|
|
50
68
|
def save!
|
@@ -77,6 +95,10 @@ module Pageflow
|
|
77
95
|
draft.cache_key
|
78
96
|
end
|
79
97
|
|
98
|
+
def published_revision?
|
99
|
+
false
|
100
|
+
end
|
101
|
+
|
80
102
|
private
|
81
103
|
|
82
104
|
def check_foreign_key_custom_attributes(custom_attributes, attributes)
|
@@ -93,8 +115,14 @@ module Pageflow
|
|
93
115
|
end
|
94
116
|
end
|
95
117
|
|
118
|
+
def generate_file_name(file_name)
|
119
|
+
return nil if file_name.blank?
|
120
|
+
|
121
|
+
"#{SecureRandom.alphanumeric(8).downcase}#{File.extname(file_name)}"
|
122
|
+
end
|
123
|
+
|
96
124
|
def file_is_used(file_type, file_id)
|
97
|
-
draft.file_usages.where(file_type
|
125
|
+
draft.file_usages.where(file_type:, file_id:).exists?
|
98
126
|
end
|
99
127
|
end
|
100
128
|
end
|