pageflow 0.11.4 → 12.0.0.rc1
Sign up to get free protection for your applications and to get access to all the features.
Potentially problematic release.
This version of pageflow might be problematic. Click here for more details.
- checksums.yaml +4 -4
- data/CHANGELOG.md +224 -1207
- data/README.md +7 -3
- data/Rakefile +2 -0
- data/admins/pageflow/accounts.rb +27 -8
- data/admins/pageflow/entry.rb +130 -47
- data/admins/pageflow/folder.rb +28 -17
- data/admins/pageflow/membership.rb +58 -6
- data/admins/pageflow/user.rb +105 -98
- data/app/assets/fonts/pageflow/fontawesome-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/fontawesome-webfont.svg +644 -463
- data/app/assets/fonts/pageflow/fontawesome-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/fontawesome-webfont.woff +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.svg +2864 -696
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.woff +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.svg +2572 -613
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.woff +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.eot +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.svg +2977 -779
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.ttf +0 -0
- data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.woff +0 -0
- data/app/assets/javascripts/pageflow/admin/entries.js +21 -3
- data/app/assets/javascripts/pageflow/audio.js +30 -15
- data/app/assets/javascripts/pageflow/audio/multi_player.js +12 -1
- data/app/assets/javascripts/pageflow/audio_player.js +15 -1
- data/app/assets/javascripts/pageflow/audio_player/rewind_method.js +3 -1
- data/app/assets/javascripts/pageflow/base.js +4 -1
- data/app/assets/javascripts/pageflow/browser.js +3 -0
- data/app/assets/javascripts/pageflow/browser/autoplay_support.js +3 -0
- data/app/assets/javascripts/pageflow/browser/facebook.js +1 -2
- data/app/assets/javascripts/pageflow/browser/ios_platform.js +5 -0
- data/app/assets/javascripts/pageflow/browser/video.js +4 -0
- data/app/assets/javascripts/pageflow/components.js +7 -0
- data/app/assets/javascripts/pageflow/cookies.js +1 -4
- data/app/assets/javascripts/pageflow/dist/react.js +4724 -5808
- data/app/assets/javascripts/pageflow/editor/api.js +201 -161
- data/app/assets/javascripts/pageflow/editor/api/errors.js +80 -0
- data/app/assets/javascripts/pageflow/editor/api/failure.js +9 -0
- data/app/assets/javascripts/pageflow/editor/api/failures.js +25 -2
- data/app/assets/javascripts/pageflow/editor/api/file_type.js +42 -3
- data/app/assets/javascripts/pageflow/editor/api/file_types.js +75 -46
- data/app/assets/javascripts/pageflow/editor/base.js +8 -0
- data/app/assets/javascripts/pageflow/editor/collections/file_types_collection.js +37 -0
- data/app/assets/javascripts/pageflow/editor/collections/files_collection.js +32 -1
- data/app/assets/javascripts/pageflow/editor/collections/mixins/ordered_collection.js +1 -1
- data/app/assets/javascripts/pageflow/editor/collections/multi_collection.js +4 -6
- data/app/assets/javascripts/pageflow/editor/collections/nested_files_collection.js +27 -0
- data/app/assets/javascripts/pageflow/editor/collections/pages_collection.js +21 -1
- data/app/assets/javascripts/pageflow/editor/collections/subset_collection.js +8 -2
- data/app/assets/javascripts/pageflow/editor/controllers/sidebar_controller.js +3 -2
- data/app/assets/javascripts/pageflow/editor/initializers/error_listener.js +10 -5
- data/app/assets/javascripts/pageflow/editor/initializers/routing.js +3 -1
- data/app/assets/javascripts/pageflow/editor/initializers/setup_collections.js +3 -0
- data/app/assets/javascripts/pageflow/editor/initializers/setup_file_types.js +136 -6
- data/app/assets/javascripts/pageflow/editor/initializers/setup_file_uploader.js +10 -0
- data/app/assets/javascripts/pageflow/editor/initializers/setup_hotkeys.js +5 -7
- data/app/assets/javascripts/pageflow/editor/initializers/stylesheet_reloading.js +1 -1
- data/app/assets/javascripts/pageflow/editor/models/configuration.js +1 -0
- data/app/assets/javascripts/pageflow/editor/models/entry.js +34 -26
- data/app/assets/javascripts/pageflow/editor/models/file_configuration.js +10 -0
- data/app/assets/javascripts/pageflow/editor/models/file_reuse.js +23 -0
- data/app/assets/javascripts/pageflow/editor/models/file_uploader.js +69 -0
- data/app/assets/javascripts/pageflow/editor/models/mixins/retryable.js +1 -1
- data/app/assets/javascripts/pageflow/editor/models/page.js +13 -0
- data/app/assets/javascripts/pageflow/editor/models/text_track_file.js +48 -0
- data/app/assets/javascripts/pageflow/editor/models/uploaded_file.js +62 -11
- data/app/assets/javascripts/pageflow/editor/routers/sidebar_router.js +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/confirm_upload.jst.ejs +18 -0
- data/app/assets/javascripts/pageflow/editor/templates/delete_row_table_cell.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/drop_down_button.jst.ejs +0 -2
- data/app/assets/javascripts/pageflow/editor/templates/drop_down_button_item.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/edit_entry.jst.ejs +3 -1
- data/app/assets/javascripts/pageflow/editor/templates/edit_file.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/editor/templates/file_item.jst.ejs +1 -6
- data/app/assets/javascripts/pageflow/editor/templates/file_meta_data_item_value_view.jst.ejs +3 -0
- data/app/assets/javascripts/pageflow/editor/templates/file_settings_dialog.jst.ejs +10 -0
- data/app/assets/javascripts/pageflow/editor/templates/files_blank_slate.jst.ejs +1 -1
- data/app/assets/javascripts/pageflow/editor/templates/filtered_files.jst.ejs +10 -0
- data/app/assets/javascripts/pageflow/{ui → editor}/templates/inputs/file_input.jst.ejs +1 -1
- data/app/assets/javascripts/pageflow/editor/templates/inputs/reference.jst.ejs +2 -2
- data/app/assets/javascripts/pageflow/editor/templates/nested_files.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/table_cell.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/editor/templates/text_tracks.jst.ejs +13 -0
- data/app/assets/javascripts/pageflow/editor/templates/uploadable_files.jst.ejs +1 -0
- data/app/assets/javascripts/pageflow/editor/utils/form_data_utils.js +19 -0
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio.js +5 -2
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_image.js +3 -2
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/groups/background.js +35 -0
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/groups/options.js +7 -9
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/video.js +6 -5
- data/app/assets/javascripts/pageflow/editor/views/confirm_upload_view.js +69 -0
- data/app/assets/javascripts/pageflow/editor/views/confirmable_file_item_view.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/drop_down_button_item_list_view.js +9 -0
- data/app/assets/javascripts/pageflow/editor/views/drop_down_button_item_view.js +14 -1
- data/app/assets/javascripts/pageflow/editor/views/drop_down_button_view.js +51 -20
- data/app/assets/javascripts/pageflow/editor/views/edit_entry_view.js +21 -2
- data/app/assets/javascripts/pageflow/editor/views/edit_file_view.js +52 -0
- data/app/assets/javascripts/pageflow/editor/views/edit_storyline_view.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/entry_preview_view.js +15 -7
- data/app/assets/javascripts/pageflow/editor/views/file_item_view.js +33 -22
- data/app/assets/javascripts/pageflow/editor/views/file_meta_data_item_value_view.js +49 -0
- data/app/assets/javascripts/pageflow/editor/views/file_meta_data_item_view.js +16 -5
- data/app/assets/javascripts/pageflow/editor/views/file_settings_dialog_view.js +31 -0
- data/app/assets/javascripts/pageflow/editor/views/files_explorer_view.js +6 -7
- data/app/assets/javascripts/pageflow/editor/views/files_view.js +13 -14
- data/app/assets/javascripts/pageflow/editor/views/filtered_files_view.js +75 -0
- data/app/assets/javascripts/pageflow/editor/views/help_view.js +3 -0
- data/app/assets/javascripts/pageflow/editor/views/inputs/file_input_view.js +217 -0
- data/app/assets/javascripts/pageflow/editor/views/inputs/page_link_input_view.js +6 -0
- data/app/assets/javascripts/pageflow/editor/views/inputs/reference_input_view.js +13 -2
- data/app/assets/javascripts/pageflow/editor/views/list_view.js +24 -14
- data/app/assets/javascripts/pageflow/editor/views/model_thumbnail_view.js +4 -1
- data/app/assets/javascripts/pageflow/editor/views/nested_files_view.js +94 -0
- data/app/assets/javascripts/pageflow/editor/views/page_preview_view.js +7 -2
- data/app/assets/javascripts/pageflow/editor/views/text_file_meta_data_item_value_view.js +25 -0
- data/app/assets/javascripts/pageflow/editor/views/text_tracks_file_meta_data_item_value_view.js +12 -0
- data/app/assets/javascripts/pageflow/editor/views/text_tracks_view.js +65 -0
- data/app/assets/javascripts/pageflow/editor/views/uploadable_files_view.js +56 -0
- data/app/assets/javascripts/pageflow/editor/views/uploader_view.js +13 -10
- data/app/assets/javascripts/pageflow/features.js +8 -12
- data/app/assets/javascripts/pageflow/focus_outline.js +2 -0
- data/app/assets/javascripts/pageflow/media_player/volume_binding.js +2 -0
- data/app/assets/javascripts/pageflow/media_player/volume_fading.js +6 -0
- data/app/assets/javascripts/pageflow/page_type.js +0 -1
- data/app/assets/javascripts/pageflow/phone_landscape_fullscreen.js +34 -0
- data/app/assets/javascripts/pageflow/react.js +4 -0
- data/app/assets/javascripts/pageflow/ready.js +3 -0
- data/app/assets/javascripts/pageflow/seed_entry_data.js +4 -1
- data/app/assets/javascripts/pageflow/slideshow.js +1 -0
- data/app/assets/javascripts/pageflow/slideshow/adjacent_preparer.js +7 -5
- data/app/assets/javascripts/pageflow/slideshow/atmo.js +3 -3
- data/app/assets/javascripts/pageflow/slideshow/hidden_text_indicator_widget.js +4 -2
- data/app/assets/javascripts/pageflow/slideshow/hide_text.js +8 -4
- data/app/assets/javascripts/pageflow/slideshow/lazy_page_widget.js +5 -0
- data/app/assets/javascripts/pageflow/slideshow/scroller_widget.js +11 -18
- data/app/assets/javascripts/pageflow/ui.js +6 -0
- data/app/assets/javascripts/pageflow/ui/templates/inputs/url_display.jst.ejs +7 -0
- data/app/assets/javascripts/pageflow/ui/templates/table.jst.ejs +7 -0
- data/app/assets/javascripts/pageflow/ui/templates/table_blank_slate.jst.ejs +3 -0
- data/app/assets/javascripts/pageflow/ui/utils/i18n_utils.js +97 -2
- data/app/assets/javascripts/pageflow/ui/views/collection_view.js +8 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/check_box_input_view.js +12 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/proxy_url_input_view.js +51 -5
- data/app/assets/javascripts/pageflow/ui/views/inputs/select_input_view.js +80 -2
- data/app/assets/javascripts/pageflow/ui/views/inputs/slider_input_view.js +8 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/text_area_input_view.js +17 -1
- data/app/assets/javascripts/pageflow/ui/views/inputs/text_input_view.js +47 -4
- data/app/assets/javascripts/pageflow/ui/views/inputs/url_display_view.js +42 -0
- data/app/assets/javascripts/pageflow/ui/views/inputs/url_input_view.js +20 -2
- data/app/assets/javascripts/pageflow/ui/views/mixins/input_view.js +74 -46
- data/app/assets/javascripts/pageflow/ui/views/table_cells/delete_row_table_cell_view.js +63 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/enum_table_cell_view.js +26 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/icon_table_cell_view.js +40 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/presence_table_cell_view.js +31 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/table_cell_view.js +101 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/table_header_cell_view.js +10 -0
- data/app/assets/javascripts/pageflow/ui/views/table_cells/text_table_cell_view.js +46 -0
- data/app/assets/javascripts/pageflow/ui/views/table_row_view.js +47 -0
- data/app/assets/javascripts/pageflow/ui/views/table_view.js +47 -0
- data/app/assets/javascripts/pageflow/video_player.js +9 -5
- data/app/assets/javascripts/pageflow/video_player/buffer_underrun_waiting.js +15 -13
- data/app/assets/javascripts/pageflow/video_player/cue_settings_methods.js +33 -0
- data/app/assets/javascripts/pageflow/video_player/dash.js +3 -0
- data/app/assets/javascripts/pageflow/video_player/filter_sources.js +1 -1
- data/app/assets/javascripts/pageflow/video_player/lazy.js +3 -9
- data/app/assets/javascripts/pageflow/video_player/prebuffering.js +11 -2
- data/app/assets/javascripts/pageflow/video_player/use_slim_controls_during_phone_playback.js +16 -0
- data/app/assets/javascripts/pageflow/videojs.js +6 -0
- data/app/assets/javascripts/pageflow/widgets.js +41 -7
- data/app/assets/stylesheets/pageflow/admin.scss +7 -4
- data/app/assets/stylesheets/pageflow/admin/{entries/user_badge_list.scss → badge_list.scss} +6 -9
- data/app/assets/stylesheets/pageflow/admin/embed_code.scss +13 -0
- data/app/assets/stylesheets/pageflow/admin/entries.scss +1 -2
- data/app/assets/stylesheets/pageflow/admin/hint.scss +20 -0
- data/app/assets/stylesheets/pageflow/admin/tooltip_bubble.scss +34 -0
- data/app/assets/stylesheets/pageflow/editor/base.scss +4 -4
- data/app/assets/stylesheets/pageflow/editor/confirm_upload.scss +66 -0
- data/app/assets/stylesheets/pageflow/editor/dialogs.scss +9 -1
- data/app/assets/stylesheets/pageflow/editor/drop_down_button.scss +56 -20
- data/app/assets/stylesheets/pageflow/editor/file_meta_data.scss +26 -6
- data/app/assets/stylesheets/pageflow/editor/file_settings_dialog.scss +32 -0
- data/app/assets/stylesheets/pageflow/editor/files.scss +5 -0
- data/app/assets/stylesheets/pageflow/editor/filtered_files.scss +25 -0
- data/app/assets/stylesheets/pageflow/editor/inputs.scss +2 -1
- data/app/assets/stylesheets/pageflow/editor/inputs/file_input.scss +65 -0
- data/app/assets/stylesheets/pageflow/editor/inputs/reference.scss +2 -2
- data/app/assets/stylesheets/pageflow/editor/text_tracks.scss +39 -0
- data/app/assets/stylesheets/pageflow/entries.scss +1 -0
- data/app/assets/stylesheets/pageflow/mixins/buttons.scss +77 -5
- data/app/assets/stylesheets/pageflow/mixins/icons/fontawesome.scss +3 -1
- data/app/assets/stylesheets/pageflow/page_types.scss +0 -4
- data/app/assets/stylesheets/pageflow/page_types/video.scss +5 -1
- data/app/assets/stylesheets/pageflow/page_types/video/content_hiding.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/base.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/built_in_page_types.scss +0 -2
- data/app/assets/stylesheets/pageflow/themes/default/definitions.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/loading_spinner.scss +31 -12
- data/app/assets/stylesheets/pageflow/themes/default/logo.scss +9 -1
- data/app/assets/stylesheets/pageflow/themes/default/logo/variant/background_image.scss +8 -2
- data/app/assets/stylesheets/pageflow/themes/default/logo/variant/watermark.scss +21 -0
- data/app/assets/stylesheets/pageflow/themes/default/mixins/cue_margins.scss +43 -0
- data/app/assets/stylesheets/pageflow/themes/default/mixins/indicator_typography.scss +7 -3
- data/app/assets/stylesheets/pageflow/themes/default/page.scss +20 -2
- data/app/assets/stylesheets/pageflow/themes/default/player_controls.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/container.scss +8 -6
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/control_bar.scss +18 -3
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/cue_margins.scss +1 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/custom.scss +14 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/icon_font.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/sprite.scss +4 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/info_box.scss +2 -2
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/menu_bar.scss +5 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/shared/menu_bar.scss +121 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim.scss +2 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/container.scss +2 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/control_bar.scss +74 -12
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/cue_margins.scss +3 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/info_box.scss +31 -5
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/menu_bar.scss +13 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/quality_menu.scss +116 -0
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/vjs_mapping.scss +13 -3
- data/app/assets/stylesheets/pageflow/themes/default/player_controls/widget_margins.scss +8 -3
- data/app/assets/stylesheets/pageflow/themes/default/text_track_cues.scss +25 -0
- data/app/assets/stylesheets/pageflow/themes/default/variables/widgets.scss +2 -2
- data/app/assets/stylesheets/pageflow/themes/default/video_player/vjs_base.scss +122 -79
- data/app/assets/stylesheets/pageflow/themes/default/video_wrapper.scss +16 -7
- data/app/assets/stylesheets/pageflow/ui.scss +5 -1
- data/app/assets/stylesheets/pageflow/ui/forms.scss +5 -58
- data/app/assets/stylesheets/pageflow/ui/table_cells/delete_row_table_cell.scss +7 -0
- data/app/assets/stylesheets/pageflow/ui/table_cells/icon_table_cell.scss +16 -0
- data/app/assets/stylesheets/pageflow/ui/table_cells/presence_table_cell.scss +8 -0
- data/app/assets/stylesheets/pageflow/ui/table_view.scss +33 -0
- data/app/assets/stylesheets/pageflow/ui/tooltip.scss +1 -1
- data/app/controllers/pageflow/editor/encoding_confirmations_controller.rb +3 -3
- data/app/controllers/pageflow/editor/entry_publications_controller.rb +3 -3
- data/app/controllers/pageflow/editor/files_controller.rb +72 -14
- data/app/controllers/pageflow/editor/widgets_controller.rb +1 -1
- data/app/controllers/pageflow/entries_controller.rb +12 -2
- data/app/controllers/pageflow/files_controller.rb +1 -1
- data/app/helpers/pageflow/admin/entries_helper.rb +17 -0
- data/app/helpers/pageflow/admin/form_helper.rb +1 -1
- data/app/helpers/pageflow/admin/memberships_helper.rb +117 -13
- data/app/helpers/pageflow/common_entry_seed_helper.rb +36 -5
- data/app/helpers/pageflow/embed_code_helper.rb +32 -0
- data/app/helpers/pageflow/entries_helper.rb +1 -1
- data/app/helpers/pageflow/entry_json_seed_helper.rb +6 -16
- data/app/helpers/pageflow/files_helper.rb +5 -2
- data/app/helpers/pageflow/folders_helper.rb +26 -2
- data/app/helpers/pageflow/page_background_asset_helper.rb +8 -0
- data/app/helpers/pageflow/quota_helper.rb +1 -1
- data/app/helpers/pageflow/video_files_helper.rb +0 -5
- data/app/jobs/pageflow/poll_zencoder_job.rb +1 -1
- data/app/jobs/pageflow/process_file_job.rb +18 -0
- data/app/mailers/pageflow/user_mailer.rb +4 -2
- data/app/models/concerns/pageflow/hosted_file.rb +9 -0
- data/app/models/concerns/pageflow/output_source.rb +60 -0
- data/app/models/concerns/pageflow/uploaded_file.rb +33 -5
- data/app/models/pageflow/account.rb +3 -1
- data/app/models/pageflow/audio_file_url_templates.rb +21 -0
- data/app/models/pageflow/draft_entry.rb +19 -9
- data/app/models/pageflow/entry.rb +2 -1
- data/app/models/pageflow/entry_duplicate.rb +2 -2
- data/app/models/pageflow/entry_role_query.rb +81 -0
- data/app/models/pageflow/file_reuse.rb +25 -0
- data/app/models/pageflow/file_usage.rb +7 -1
- data/app/models/pageflow/image_file.rb +7 -1
- data/app/models/pageflow/image_file_url_templates.rb +19 -0
- data/app/models/pageflow/invited_user.rb +2 -0
- data/app/models/pageflow/membership.rb +46 -3
- data/app/models/pageflow/published_entry.rb +2 -2
- data/app/models/pageflow/revision.rb +16 -5
- data/app/models/pageflow/roles.rb +36 -0
- data/app/models/pageflow/text_track_file.rb +45 -0
- data/app/models/pageflow/text_track_file_url_templates.rb +16 -0
- data/app/models/pageflow/thumbnail_file_resolver.rb +22 -2
- data/app/models/pageflow/url_template.rb +13 -0
- data/app/models/pageflow/used_file.rb +21 -0
- data/app/models/pageflow/video_file.rb +72 -27
- data/app/models/pageflow/video_file_url_templates.rb +34 -0
- data/app/policies/pageflow/account_policy.rb +145 -0
- data/app/policies/pageflow/admin/admin_only_tab_policy.rb +16 -0
- data/app/policies/pageflow/admin/entry_tab_policy.rb +25 -0
- data/app/policies/pageflow/application_policy.rb +11 -0
- data/app/policies/pageflow/entry_policy.rb +138 -0
- data/app/policies/pageflow/file_policy.rb +42 -0
- data/app/policies/pageflow/folder_policy.rb +54 -0
- data/app/policies/pageflow/membership_policy.rb +105 -0
- data/app/policies/pageflow/theming_policy.rb +57 -0
- data/app/policies/pageflow/user_policy.rb +69 -0
- data/app/state_machines/pageflow/encoded_file_state_machine.rb +4 -0
- data/app/state_machines/pageflow/image_file_state_machine.rb +5 -1
- data/app/views/admin/entries/_attributes_table.html.arb +21 -2
- data/app/views/admin/entries/_links.html.arb +1 -1
- data/app/views/admin/memberships/_entity_account_input.html.erb +5 -0
- data/app/views/admin/memberships/_entity_entry_input.html.erb +5 -0
- data/app/views/admin/memberships/_form.html.erb +16 -5
- data/app/views/admin/memberships/_role_hint.html.arb +2 -0
- data/app/views/admin/users/_form.html.erb +29 -20
- data/app/views/components/pageflow/admin/add_membership_button_if_needed.rb +62 -0
- data/app/views/components/pageflow/admin/embed_code_field.rb +15 -0
- data/app/views/components/pageflow/admin/entry_user_badge_list.rb +15 -7
- data/app/views/components/pageflow/admin/grouped_folder_list.rb +20 -16
- data/app/views/components/pageflow/admin/members_tab.rb +22 -11
- data/app/views/components/pageflow/admin/membership_role_with_tooltip.rb +21 -0
- data/app/views/components/pageflow/admin/tabs_view.rb +13 -13
- data/app/views/components/pageflow/admin/user_account_badge_list.rb +43 -0
- data/app/views/components/pageflow/admin/user_accounts_tab.rb +46 -0
- data/app/views/components/pageflow/admin/user_entries_tab.rb +50 -0
- data/app/views/components/pageflow/admin/users_tab.rb +32 -4
- data/app/views/layouts/pageflow/application.html.erb +3 -2
- data/app/views/pageflow/config/_editor_seeds.json.jbuilder +15 -2
- data/app/views/pageflow/editor/entries/_entry.json.jbuilder +1 -0
- data/app/views/pageflow/editor/files/_file.json.jbuilder +10 -2
- data/app/views/pageflow/entries/show.css.erb +4 -11
- data/app/views/pageflow/entries/show.json.jbuilder +1 -1
- data/app/views/pageflow/entry_json_seed/_entry.json.jbuilder +19 -0
- data/app/views/pageflow/file_types/_thumbnails.css.erb +1 -1
- data/app/views/pageflow/files/_file.json.jbuilder +12 -0
- data/app/views/pageflow/page_background_asset/_element.html.erb +3 -0
- data/app/views/pageflow/page_types/_page_type.json.jbuilder +7 -0
- data/app/views/pageflow/react/_widget.html.erb +1 -0
- data/app/views/pageflow/react/page.html.erb +6 -0
- data/app/views/pageflow/video_files/_video_file.json.jbuilder +2 -0
- data/config/initializers/admin_resource_tabs.rb +8 -1
- data/config/initializers/features.rb +1 -4
- data/config/initializers/help_entries.rb +2 -1
- data/config/initializers/paperclip.rb +4 -0
- data/config/initializers/zencoder.rb +5 -2
- data/config/locales/de.yml +370 -108
- data/config/locales/en.yml +333 -83
- data/config/routes.rb +18 -10
- data/db/migrate/20150825133449_update_audio_loop_pages_to_use_atmo.rb +24 -0
- data/db/migrate/20160304072911_rename_membership_entry_and_make_polymorphic.rb +19 -0
- data/db/migrate/20160304151327_add_role_to_membership.rb +19 -0
- data/db/migrate/20160504093145_replace_role_and_account_on_user.rb +42 -0
- data/db/migrate/20160531152500_update_users_count.rb +27 -0
- data/db/migrate/20160707125400_add_output_presences_to_video_files.rb +5 -0
- data/db/migrate/20160824115000_add_parent_file_to_video_files.rb +8 -0
- data/db/migrate/20160824115100_add_parent_file_to_audio_files.rb +8 -0
- data/db/migrate/20160824115200_add_parent_file_to_image_files.rb +8 -0
- data/db/migrate/20160929102700_add_configuration_to_files.rb +7 -0
- data/db/migrate/20161007144500_add_text_track_files.rb +31 -0
- data/db/migrate/20161216175734_move_configuration_from_file_to_file_usage.rb +27 -0
- data/db/migrate/20161230144429_add_processed_attachment_to_text_track_files.rb +8 -0
- data/db/migrate/20170222124848_update_video_file_output_presences.rb +12 -0
- data/db/migrate/20170421112300_turn_background_video_pages_into_background_image_pages.rb +22 -0
- data/lib/generators/pageflow/assets/assets_generator.rb +2 -0
- data/lib/generators/pageflow/assets/templates/components.js +4 -0
- data/lib/generators/pageflow/initializer/templates/pageflow.rb +23 -20
- data/lib/generators/pageflow/seeds/templates/seeds.rb +81 -15
- data/lib/pageflow.rb +8 -0
- data/lib/pageflow/ability_mixin.rb +196 -62
- data/lib/pageflow/admin/tab.rb +21 -0
- data/lib/pageflow/admin/tabs.rb +31 -6
- data/lib/pageflow/built_in_file_type.rb +39 -0
- data/lib/pageflow/built_in_page_types_plugin.rb +80 -0
- data/lib/pageflow/configuration.rb +13 -1
- data/lib/pageflow/engine.rb +6 -1
- data/lib/pageflow/file_type.rb +60 -15
- data/lib/pageflow/file_types.rb +20 -2
- data/lib/pageflow/page_type.rb +53 -4
- data/lib/pageflow/page_types.rb +4 -0
- data/lib/pageflow/paperclip_processors/vtt.rb +35 -0
- data/lib/pageflow/react.rb +11 -0
- data/lib/pageflow/react/page_type.rb +26 -0
- data/lib/pageflow/react/widget_type.rb +20 -0
- data/lib/pageflow/seeds.rb +59 -15
- data/lib/pageflow/user_mixin.rb +18 -25
- data/lib/pageflow/version.rb +1 -1
- data/lib/pageflow/zencoder_api.rb +18 -4
- data/lib/pageflow/zencoder_video_output_definition.rb +375 -127
- data/lib/tasks/pageflow_tasks.rake +7 -0
- data/spec/factories/accounts.rb +36 -3
- data/spec/factories/entries.rb +22 -4
- data/spec/factories/invited_user.rb +3 -4
- data/spec/factories/memberships.rb +34 -2
- data/spec/factories/text_track_files.rb +40 -0
- data/spec/factories/users.rb +32 -7
- data/spec/factories/video_files.rb +7 -1
- data/spec/fixtures/sample.srt +12 -0
- data/spec/fixtures/sample.vtt +40 -0
- data/vendor/assets/javascripts/dash.all.min.js +14 -0
- data/vendor/assets/javascripts/polyfills/bind.js +17 -11
- data/vendor/assets/javascripts/videojs-dash.js +302 -0
- data/vendor/assets/javascripts/videojs.js +26804 -0
- metadata +187 -49
- data/app/assets/images/pageflow/themes/default/page_type_pictograms/audio_loop/sprite.png +0 -0
- data/app/assets/images/pageflow/themes/default/page_type_pictograms/audio_loop/wide.png +0 -0
- data/app/assets/javascripts/pageflow/editor/collections/file_usages_collection.js +0 -21
- data/app/assets/javascripts/pageflow/editor/models/file_usage.js +0 -8
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio_loop.js +0 -20
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_video.js +0 -24
- data/app/assets/javascripts/pageflow/page_types/audio.js +0 -135
- data/app/assets/javascripts/pageflow/page_types/audio_loop.js +0 -102
- data/app/assets/javascripts/pageflow/page_types/background_image.js +0 -44
- data/app/assets/javascripts/pageflow/page_types/background_video.js +0 -137
- data/app/assets/javascripts/pageflow/page_types/video.js +0 -277
- data/app/assets/javascripts/pageflow/ui/views/inputs/file_input_view.js +0 -79
- data/app/assets/javascripts/pageflow/video_player/play_button_patch.js +0 -39
- data/app/assets/javascripts/pageflow/video_player/player_buffered_patch.js +0 -47
- data/app/assets/javascripts/pageflow/video_player/src_from_options_method.js +0 -31
- data/app/assets/stylesheets/pageflow/page_types/audio_loop.scss +0 -18
- data/app/assets/stylesheets/pageflow/page_types/background-video.scss +0 -50
- data/app/controllers/pageflow/editor/file_usages_controller.rb +0 -37
- data/app/jobs/pageflow/process_image_file_job.rb +0 -18
- data/app/views/pageflow/pages/templates/_audio.html.erb +0 -69
- data/app/views/pageflow/pages/templates/_audio_loop.html.erb +0 -34
- data/app/views/pageflow/pages/templates/_background_image.html.erb +0 -24
- data/app/views/pageflow/pages/templates/_background_video.html.erb +0 -32
- data/app/views/pageflow/pages/templates/_video.html.erb +0 -42
- data/lib/pageflow/built_in_page_type.rb +0 -79
@@ -14,6 +14,9 @@ $logo-variant: "first-page" !default;
|
|
14
14
|
/// Top position of logo.
|
15
15
|
$logo-top: 30px !default;
|
16
16
|
|
17
|
+
/// Height of the logo. (Non-watermark variants only)
|
18
|
+
$logo-phone-top: nil !default;
|
19
|
+
|
17
20
|
/// Width of the logo. (Watermark variant only)
|
18
21
|
$logo-width: 100px !default;
|
19
22
|
|
@@ -29,6 +32,9 @@ $logo-max-width: 221px !default;
|
|
29
32
|
/// Height of the logo.
|
30
33
|
$logo-height: 50px !default;
|
31
34
|
|
35
|
+
/// Height of the logo. (Non-watermark variants only)
|
36
|
+
$logo-mobile-height: 35px !default;
|
37
|
+
|
32
38
|
/// Height of the logo in phone layout. (Watermark variant only)
|
33
39
|
$logo-phone-height: 24px !default;
|
34
40
|
|
@@ -49,6 +55,8 @@ $logo-phone-height: 24px !default;
|
|
49
55
|
$min-width: $logo-min-width,
|
50
56
|
$max-width: $logo-max-width,
|
51
57
|
$width: $logo-relative-width,
|
52
|
-
$height: $logo-height
|
58
|
+
$height: $logo-height,
|
59
|
+
$mobile-height: $logo-mobile-height,
|
60
|
+
$phone-top: $logo-phone-top
|
53
61
|
);
|
54
62
|
}
|
@@ -4,7 +4,9 @@
|
|
4
4
|
$min-width,
|
5
5
|
$max-width,
|
6
6
|
$width,
|
7
|
-
$height
|
7
|
+
$height,
|
8
|
+
$mobile-height,
|
9
|
+
$phone-top
|
8
10
|
) {
|
9
11
|
$page-selector: if($first-page-only, ":first-child", "");
|
10
12
|
|
@@ -26,7 +28,11 @@
|
|
26
28
|
|
27
29
|
@include mobile {
|
28
30
|
padding-top: 1%;
|
29
|
-
height:
|
31
|
+
height: $mobile-height;
|
32
|
+
}
|
33
|
+
|
34
|
+
@include phone {
|
35
|
+
top: $phone-top;
|
30
36
|
}
|
31
37
|
}
|
32
38
|
|
@@ -5,6 +5,11 @@
|
|
5
5
|
/// - `"all-pages"`: on all pages
|
6
6
|
$logo-watermark-variant-fade-in-near-top: "first-page" !default;
|
7
7
|
|
8
|
+
/// Fade in logo when header is active. If the header logo is
|
9
|
+
/// inverted on the current page, the non-inverted logo variant
|
10
|
+
/// is displayed while the header is active.
|
11
|
+
$logo-watermark-variant-fade-in-with-header: false !default;
|
12
|
+
|
8
13
|
@mixin logo-variant-watermark(
|
9
14
|
$top,
|
10
15
|
$width,
|
@@ -84,6 +89,22 @@ $logo-watermark-variant-fade-in-near-top: "first-page" !default;
|
|
84
89
|
}
|
85
90
|
}
|
86
91
|
|
92
|
+
@if $logo-watermark-variant-fade-in-with-header {
|
93
|
+
.header {
|
94
|
+
&.active .header_logo {
|
95
|
+
opacity: 1;
|
96
|
+
}
|
97
|
+
|
98
|
+
&.invert.active .header_logo:before {
|
99
|
+
opacity: 1;
|
100
|
+
}
|
101
|
+
|
102
|
+
&.invert.active .header_logo:after {
|
103
|
+
opacity: 0;
|
104
|
+
}
|
105
|
+
}
|
106
|
+
}
|
107
|
+
|
87
108
|
.header.near_top .header_logo:hover {
|
88
109
|
opacity: 1;
|
89
110
|
}
|
@@ -0,0 +1,43 @@
|
|
1
|
+
@mixin cue-margins($controls-offset: 0) {
|
2
|
+
.vjs-text-track-display {
|
3
|
+
bottom: $controls-offset;
|
4
|
+
}
|
5
|
+
|
6
|
+
.is_control_bar_hidden .vjs-text-track-display {
|
7
|
+
bottom: 0;
|
8
|
+
}
|
9
|
+
|
10
|
+
@for $i from 1 through 20 {
|
11
|
+
$size: 10px * $i;
|
12
|
+
|
13
|
+
.cue_margin_left_#{$i} {
|
14
|
+
.vjs-text-track-display {
|
15
|
+
left: $size;
|
16
|
+
}
|
17
|
+
}
|
18
|
+
|
19
|
+
.cue_margin_right_#{$i} {
|
20
|
+
.vjs-text-track-display {
|
21
|
+
right: $size;
|
22
|
+
}
|
23
|
+
}
|
24
|
+
|
25
|
+
.cue_margin_top_#{$i} {
|
26
|
+
.vjs-text-track-display {
|
27
|
+
top: $size;
|
28
|
+
}
|
29
|
+
}
|
30
|
+
|
31
|
+
.cue_margin_bottom_#{$i} {
|
32
|
+
.vjs-text-track-display {
|
33
|
+
bottom: $size + $controls-offset;
|
34
|
+
}
|
35
|
+
}
|
36
|
+
|
37
|
+
.is_control_bar_hidden .cue_margin_bottom_#{$i} {
|
38
|
+
.vjs-text-track-display {
|
39
|
+
bottom: $size;
|
40
|
+
}
|
41
|
+
}
|
42
|
+
}
|
43
|
+
}
|
@@ -8,9 +8,9 @@ $indicator-typography: () !default;
|
|
8
8
|
/// Typography of indicators on phone.
|
9
9
|
$indicator-phone-typography: () !default;
|
10
10
|
|
11
|
-
@mixin indicator-typography {
|
11
|
+
@mixin indicator-typography($overrides: (), $desktop-overrides: (), $phone-overrides: ()) {
|
12
12
|
@include standard-typography(
|
13
|
-
$indicator-typography,
|
13
|
+
map-merge($indicator-typography, $overrides),
|
14
14
|
(
|
15
15
|
font-size: 0.92em,
|
16
16
|
letter-spacing: 0.2em,
|
@@ -18,9 +18,13 @@ $indicator-phone-typography: () !default;
|
|
18
18
|
)
|
19
19
|
);
|
20
20
|
|
21
|
+
@include desktop {
|
22
|
+
@include typography($desktop-overrides);
|
23
|
+
}
|
24
|
+
|
21
25
|
@include phone {
|
22
26
|
@include standard-typography(
|
23
|
-
$indicator-phone-typography,
|
27
|
+
map-merge($indicator-phone-typography, $phone-overrides),
|
24
28
|
(
|
25
29
|
font-size: 0.8em,
|
26
30
|
letter-spacing: 0.1em,
|
@@ -5,6 +5,18 @@
|
|
5
5
|
/// Base typography for page.
|
6
6
|
$page-typography: () !default;
|
7
7
|
|
8
|
+
/// Space for logo on first page.
|
9
|
+
$page-scroller-first-page-padding-top: nil !default;
|
10
|
+
|
11
|
+
/// Space for logo on first page in mobile layout.
|
12
|
+
$page-scroller-first-page-mobile-padding-top: 110px !default;
|
13
|
+
|
14
|
+
/// Space for logo on first page in mobile landscape layout.
|
15
|
+
$page-scroller-first-page-mobile-landscape-padding-top: 100px !default;
|
16
|
+
|
17
|
+
/// Space for logo on first page in phone layout.
|
18
|
+
$page-scroller-first-page-phone-padding-top: nil !default;
|
19
|
+
|
8
20
|
/// Typography for header.
|
9
21
|
$page-header-typography: () !default;
|
10
22
|
|
@@ -205,14 +217,20 @@ $page-content-text-line-height: 1.5em !default;
|
|
205
217
|
.js .page:first-child {
|
206
218
|
.scroller > div,
|
207
219
|
.content_and_background > .page_header {
|
220
|
+
padding-top: $page-scroller-first-page-padding-top;
|
221
|
+
|
208
222
|
@include mobile {
|
209
|
-
padding:
|
223
|
+
padding-top: $page-scroller-first-page-mobile-padding-top;
|
210
224
|
width: 100%;
|
211
225
|
|
212
226
|
@media (orientation: landscape) {
|
213
|
-
padding:
|
227
|
+
padding-top: $page-scroller-first-page-mobile-landscape-padding-top;
|
214
228
|
}
|
215
229
|
}
|
230
|
+
|
231
|
+
@include phone {
|
232
|
+
padding-top: $page-scroller-first-page-phone-padding-top;
|
233
|
+
}
|
216
234
|
}
|
217
235
|
|
218
236
|
h2 .title {
|
@@ -3,17 +3,21 @@ $player-controls-typography: () !default;
|
|
3
3
|
// Prevent unstyled player controls from being displayed inside editor
|
4
4
|
// while widget presence css classes have not yet been set:
|
5
5
|
|
6
|
+
.player_controls-menu_bar,
|
6
7
|
%player_controls-container {
|
7
8
|
display: none;
|
8
9
|
}
|
9
10
|
|
10
11
|
.widget_slim_player_controls_present,
|
11
12
|
.widget_classic_player_controls_present {
|
13
|
+
.player_controls-menu_bar,
|
12
14
|
%player_controls-container {
|
13
15
|
display: block;
|
14
16
|
}
|
15
17
|
}
|
16
18
|
|
19
|
+
@import "./player_controls/shared/menu_bar";
|
20
|
+
|
17
21
|
// Define placeholders scoped by widget presence css class:
|
18
22
|
|
19
23
|
.widget_classic_player_controls_present {
|
@@ -23,10 +23,14 @@ $classic-player-controls-images: "default" !default;
|
|
23
23
|
@import "./classic/control_bar";
|
24
24
|
@import "./classic/info_box";
|
25
25
|
@import "./classic/close_button";
|
26
|
+
@import "./classic/menu_bar";
|
27
|
+
@import "./classic/cue_margins";
|
26
28
|
|
27
29
|
@import "./classic/icons/icon_font";
|
28
30
|
@import "./classic/icons/sprite";
|
29
31
|
|
32
|
+
@import "./classic/icons/custom";
|
33
|
+
|
30
34
|
@if $classic-player-controls-icons == "sprite" {
|
31
35
|
@include player-controls-classic-icons-sprite;
|
32
36
|
} @else {
|
@@ -8,14 +8,20 @@ $classic-player-controls-typography: $player-controls-typography !default;
|
|
8
8
|
%player_controls {
|
9
9
|
&-container {
|
10
10
|
position: absolute;
|
11
|
-
bottom: 10%;
|
12
|
-
left: 50%;
|
13
11
|
z-index: 2;
|
14
12
|
pointer-events: none;
|
15
13
|
@include transition(opacity 0.1);
|
16
14
|
@include standard-typography($classic-player-controls-typography);
|
17
15
|
|
16
|
+
@include desktop {
|
17
|
+
right: 0;
|
18
|
+
bottom: 0;
|
19
|
+
left: 0;
|
20
|
+
height: 10%;
|
21
|
+
}
|
22
|
+
|
18
23
|
@include phone {
|
24
|
+
bottom: 10%;
|
19
25
|
left: 5%;
|
20
26
|
max-width: 90%;
|
21
27
|
|
@@ -28,10 +34,6 @@ $classic-player-controls-typography: $player-controls-typography !default;
|
|
28
34
|
bottom: 50px;
|
29
35
|
}
|
30
36
|
|
31
|
-
a {
|
32
|
-
pointer-events: all;
|
33
|
-
}
|
34
|
-
|
35
37
|
&-idle {
|
36
38
|
@include transition-duration(1.5s);
|
37
39
|
@include transition-delay(1s);
|
data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/control_bar.scss
CHANGED
@@ -50,7 +50,7 @@ $classic-player-controls-timestamp-position: "left" !default;
|
|
50
50
|
&-control_bar {
|
51
51
|
position: absolute;
|
52
52
|
left: 50%;
|
53
|
-
bottom:
|
53
|
+
bottom: 100%;
|
54
54
|
@include transform(translate3d(-50%, 0, 0));
|
55
55
|
z-index: 2;
|
56
56
|
|
@@ -85,8 +85,6 @@ $classic-player-controls-timestamp-position: "left" !default;
|
|
85
85
|
|
86
86
|
background: none;
|
87
87
|
border: none;
|
88
|
-
|
89
|
-
pointer-events: all;
|
90
88
|
}
|
91
89
|
}
|
92
90
|
|
@@ -186,6 +184,10 @@ $classic-player-controls-timestamp-position: "left" !default;
|
|
186
184
|
left: 31px;
|
187
185
|
opacity: 1;
|
188
186
|
@include animation(rotate 1.5s infinite linear);
|
187
|
+
|
188
|
+
svg {
|
189
|
+
display: none;
|
190
|
+
}
|
189
191
|
}
|
190
192
|
|
191
193
|
&-loading_spinner-on_underrun {
|
@@ -203,6 +205,19 @@ $classic-player-controls-timestamp-position: "left" !default;
|
|
203
205
|
&-control_bar:before {
|
204
206
|
display: none;
|
205
207
|
}
|
208
|
+
|
209
|
+
&-menu_bar {
|
210
|
+
@include transition(opacity 0.2s linear, visibility 0.2s linear);
|
211
|
+
position: fixed;
|
212
|
+
}
|
213
|
+
|
214
|
+
&-container-paused {
|
215
|
+
%player_controls-menu_bar {
|
216
|
+
opacity: 0;
|
217
|
+
visibility: hidden;
|
218
|
+
@include transition-delay(0.2s);
|
219
|
+
}
|
220
|
+
}
|
206
221
|
}
|
207
222
|
|
208
223
|
&-page_with_progress_bar {
|
@@ -0,0 +1 @@
|
|
1
|
+
@include cue-margins;
|
@@ -0,0 +1,14 @@
|
|
1
|
+
/// Color of of the custom icon displayed inside the play button.
|
2
|
+
$classic-player-controls-custom-play-button-icon-color: #000 !default;
|
3
|
+
|
4
|
+
%player_controls-play_button-custom_icon {
|
5
|
+
svg {
|
6
|
+
fill: $classic-player-controls-custom-play-button-icon-color;
|
7
|
+
position: absolute;
|
8
|
+
left: 50%;
|
9
|
+
top: 50%;
|
10
|
+
@include transform(translate(-50%, -50%));
|
11
|
+
width: 27px;
|
12
|
+
height: 27px;
|
13
|
+
}
|
14
|
+
}
|
@@ -79,9 +79,9 @@ $classic-player-controls-info-box-border-radius: 4px !default;
|
|
79
79
|
.js &-info_box {
|
80
80
|
pointer-events: none;
|
81
81
|
margin: 0;
|
82
|
-
margin-bottom: 60px + $classic-player-controls-border-width *
|
82
|
+
margin-bottom: 60px + $classic-player-controls-border-width * 4;
|
83
83
|
width: 434px;
|
84
|
-
bottom:
|
84
|
+
bottom: 100%;
|
85
85
|
position: absolute;
|
86
86
|
left: 50%;
|
87
87
|
@include transform(translate3d(-50%, 0, 0));
|
@@ -0,0 +1,121 @@
|
|
1
|
+
$player-controls-menu-icon-color: #fff !default;
|
2
|
+
|
3
|
+
$player-controls-menu-popup-background-color: rgba(17, 17, 17, 0.9) !default;
|
4
|
+
|
5
|
+
$player-controls-menu-popup-link-color: #fff !default;
|
6
|
+
|
7
|
+
$player-controls-menu-item-active-background-color: rgba(200, 200, 200, 0.8) !default;
|
8
|
+
|
9
|
+
$player-controls-quality-menu-annotation-color: #ff0000 !default;
|
10
|
+
|
11
|
+
.player_controls {
|
12
|
+
&-menu_bar {
|
13
|
+
position: absolute;
|
14
|
+
bottom: 0;
|
15
|
+
z-index: 10;
|
16
|
+
pointer-events: all;
|
17
|
+
|
18
|
+
@include transition(opacity 0.5s, visibility 0.5s);
|
19
|
+
|
20
|
+
.has_native_video_player %player_controls-container-video & {
|
21
|
+
display: none;
|
22
|
+
}
|
23
|
+
}
|
24
|
+
|
25
|
+
&-menu_bar-stand_alone {
|
26
|
+
right: 20px;
|
27
|
+
bottom: 5px;
|
28
|
+
}
|
29
|
+
|
30
|
+
&-menu_bar-hidden_on_phone {
|
31
|
+
@include phone {
|
32
|
+
opacity: 0;
|
33
|
+
visibility: hidden;
|
34
|
+
pointer-events: none;
|
35
|
+
}
|
36
|
+
}
|
37
|
+
|
38
|
+
&-menu_bar_button {
|
39
|
+
display: inline-block;
|
40
|
+
position: relative;
|
41
|
+
bottom: 0;
|
42
|
+
right: 0;
|
43
|
+
width: 40px;
|
44
|
+
height: 40px;
|
45
|
+
margin-right: 10px;
|
46
|
+
}
|
47
|
+
|
48
|
+
&-menu_bar_button_link {
|
49
|
+
display: block;
|
50
|
+
height: 100%;
|
51
|
+
}
|
52
|
+
|
53
|
+
&-menu_bar_button_icon {
|
54
|
+
position: absolute;
|
55
|
+
top: 50%;
|
56
|
+
left: 50%;
|
57
|
+
@include transform(translate(-50%, -50%));
|
58
|
+
@include transition(transform 0.3s ease);
|
59
|
+
width: 25px;
|
60
|
+
height: 25px;
|
61
|
+
|
62
|
+
fill: $player-controls-menu-icon-color;
|
63
|
+
}
|
64
|
+
|
65
|
+
&-menu_bar_button-sub_menu_visible .player_controls-quality_menu_button_icon {
|
66
|
+
@include transform(translate(-50%, -50%) rotate(40deg));
|
67
|
+
}
|
68
|
+
|
69
|
+
&-menu_bar_button_sub_menu_item_annotation {
|
70
|
+
color: $player-controls-quality-menu-annotation-color;
|
71
|
+
font-size: 70%;
|
72
|
+
vertical-align: 5px;
|
73
|
+
padding-left: 3px;
|
74
|
+
}
|
75
|
+
|
76
|
+
&-menu_bar_button_sub_menu {
|
77
|
+
visibility: hidden;
|
78
|
+
opacity: 0;
|
79
|
+
pointer-events: none;
|
80
|
+
@include transition(opacity 0.5s, visibility 0.5s);
|
81
|
+
|
82
|
+
position: absolute;
|
83
|
+
right: 0;
|
84
|
+
bottom: 40px;
|
85
|
+
margin: 0;
|
86
|
+
padding: 5px;
|
87
|
+
|
88
|
+
background-color: $player-controls-menu-popup-background-color;
|
89
|
+
border-radius: 2px;
|
90
|
+
}
|
91
|
+
|
92
|
+
&-menu_bar_button-sub_menu_visible .player_controls-menu_bar_button_sub_menu {
|
93
|
+
visibility: visible;
|
94
|
+
opacity: 1;
|
95
|
+
pointer-events: all;
|
96
|
+
@include transition(none);
|
97
|
+
}
|
98
|
+
|
99
|
+
&-menu_bar_button_sub_menu_item {
|
100
|
+
position: relative;
|
101
|
+
list-style: none;
|
102
|
+
}
|
103
|
+
|
104
|
+
&-menu_bar_button_sub_menu_item_icon {
|
105
|
+
position: absolute;
|
106
|
+
top: 8px;
|
107
|
+
left: 5px;
|
108
|
+
width: 12px;
|
109
|
+
height: 12px;
|
110
|
+
|
111
|
+
fill: $player-controls-menu-popup-link-color;
|
112
|
+
}
|
113
|
+
|
114
|
+
&-menu_bar_button_sub_menu_item_link {
|
115
|
+
display: block;
|
116
|
+
padding: 5px 10px 5px 25px;
|
117
|
+
color: $player-controls-menu-popup-link-color;
|
118
|
+
text-decoration: none;
|
119
|
+
white-space: nowrap;
|
120
|
+
}
|
121
|
+
}
|