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.

Files changed (416) hide show
  1. checksums.yaml +4 -4
  2. data/CHANGELOG.md +224 -1207
  3. data/README.md +7 -3
  4. data/Rakefile +2 -0
  5. data/admins/pageflow/accounts.rb +27 -8
  6. data/admins/pageflow/entry.rb +130 -47
  7. data/admins/pageflow/folder.rb +28 -17
  8. data/admins/pageflow/membership.rb +58 -6
  9. data/admins/pageflow/user.rb +105 -98
  10. data/app/assets/fonts/pageflow/fontawesome-webfont.eot +0 -0
  11. data/app/assets/fonts/pageflow/fontawesome-webfont.svg +644 -463
  12. data/app/assets/fonts/pageflow/fontawesome-webfont.ttf +0 -0
  13. data/app/assets/fonts/pageflow/fontawesome-webfont.woff +0 -0
  14. data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.eot +0 -0
  15. data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.svg +2864 -696
  16. data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.ttf +0 -0
  17. data/app/assets/fonts/pageflow/sourcesanspro-bold-webfont.woff +0 -0
  18. data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.eot +0 -0
  19. data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.svg +2572 -613
  20. data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.ttf +0 -0
  21. data/app/assets/fonts/pageflow/sourcesanspro-light-webfont.woff +0 -0
  22. data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.eot +0 -0
  23. data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.svg +2977 -779
  24. data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.ttf +0 -0
  25. data/app/assets/fonts/pageflow/sourcesanspro-regular-webfont.woff +0 -0
  26. data/app/assets/javascripts/pageflow/admin/entries.js +21 -3
  27. data/app/assets/javascripts/pageflow/audio.js +30 -15
  28. data/app/assets/javascripts/pageflow/audio/multi_player.js +12 -1
  29. data/app/assets/javascripts/pageflow/audio_player.js +15 -1
  30. data/app/assets/javascripts/pageflow/audio_player/rewind_method.js +3 -1
  31. data/app/assets/javascripts/pageflow/base.js +4 -1
  32. data/app/assets/javascripts/pageflow/browser.js +3 -0
  33. data/app/assets/javascripts/pageflow/browser/autoplay_support.js +3 -0
  34. data/app/assets/javascripts/pageflow/browser/facebook.js +1 -2
  35. data/app/assets/javascripts/pageflow/browser/ios_platform.js +5 -0
  36. data/app/assets/javascripts/pageflow/browser/video.js +4 -0
  37. data/app/assets/javascripts/pageflow/components.js +7 -0
  38. data/app/assets/javascripts/pageflow/cookies.js +1 -4
  39. data/app/assets/javascripts/pageflow/dist/react.js +4724 -5808
  40. data/app/assets/javascripts/pageflow/editor/api.js +201 -161
  41. data/app/assets/javascripts/pageflow/editor/api/errors.js +80 -0
  42. data/app/assets/javascripts/pageflow/editor/api/failure.js +9 -0
  43. data/app/assets/javascripts/pageflow/editor/api/failures.js +25 -2
  44. data/app/assets/javascripts/pageflow/editor/api/file_type.js +42 -3
  45. data/app/assets/javascripts/pageflow/editor/api/file_types.js +75 -46
  46. data/app/assets/javascripts/pageflow/editor/base.js +8 -0
  47. data/app/assets/javascripts/pageflow/editor/collections/file_types_collection.js +37 -0
  48. data/app/assets/javascripts/pageflow/editor/collections/files_collection.js +32 -1
  49. data/app/assets/javascripts/pageflow/editor/collections/mixins/ordered_collection.js +1 -1
  50. data/app/assets/javascripts/pageflow/editor/collections/multi_collection.js +4 -6
  51. data/app/assets/javascripts/pageflow/editor/collections/nested_files_collection.js +27 -0
  52. data/app/assets/javascripts/pageflow/editor/collections/pages_collection.js +21 -1
  53. data/app/assets/javascripts/pageflow/editor/collections/subset_collection.js +8 -2
  54. data/app/assets/javascripts/pageflow/editor/controllers/sidebar_controller.js +3 -2
  55. data/app/assets/javascripts/pageflow/editor/initializers/error_listener.js +10 -5
  56. data/app/assets/javascripts/pageflow/editor/initializers/routing.js +3 -1
  57. data/app/assets/javascripts/pageflow/editor/initializers/setup_collections.js +3 -0
  58. data/app/assets/javascripts/pageflow/editor/initializers/setup_file_types.js +136 -6
  59. data/app/assets/javascripts/pageflow/editor/initializers/setup_file_uploader.js +10 -0
  60. data/app/assets/javascripts/pageflow/editor/initializers/setup_hotkeys.js +5 -7
  61. data/app/assets/javascripts/pageflow/editor/initializers/stylesheet_reloading.js +1 -1
  62. data/app/assets/javascripts/pageflow/editor/models/configuration.js +1 -0
  63. data/app/assets/javascripts/pageflow/editor/models/entry.js +34 -26
  64. data/app/assets/javascripts/pageflow/editor/models/file_configuration.js +10 -0
  65. data/app/assets/javascripts/pageflow/editor/models/file_reuse.js +23 -0
  66. data/app/assets/javascripts/pageflow/editor/models/file_uploader.js +69 -0
  67. data/app/assets/javascripts/pageflow/editor/models/mixins/retryable.js +1 -1
  68. data/app/assets/javascripts/pageflow/editor/models/page.js +13 -0
  69. data/app/assets/javascripts/pageflow/editor/models/text_track_file.js +48 -0
  70. data/app/assets/javascripts/pageflow/editor/models/uploaded_file.js +62 -11
  71. data/app/assets/javascripts/pageflow/editor/routers/sidebar_router.js +1 -0
  72. data/app/assets/javascripts/pageflow/editor/templates/confirm_upload.jst.ejs +18 -0
  73. data/app/assets/javascripts/pageflow/editor/templates/delete_row_table_cell.jst.ejs +1 -0
  74. data/app/assets/javascripts/pageflow/editor/templates/drop_down_button.jst.ejs +0 -2
  75. data/app/assets/javascripts/pageflow/editor/templates/drop_down_button_item.jst.ejs +1 -0
  76. data/app/assets/javascripts/pageflow/editor/templates/edit_entry.jst.ejs +3 -1
  77. data/app/assets/javascripts/pageflow/editor/templates/edit_file.jst.ejs +0 -0
  78. data/app/assets/javascripts/pageflow/editor/templates/file_item.jst.ejs +1 -6
  79. data/app/assets/javascripts/pageflow/editor/templates/file_meta_data_item_value_view.jst.ejs +3 -0
  80. data/app/assets/javascripts/pageflow/editor/templates/file_settings_dialog.jst.ejs +10 -0
  81. data/app/assets/javascripts/pageflow/editor/templates/files_blank_slate.jst.ejs +1 -1
  82. data/app/assets/javascripts/pageflow/editor/templates/filtered_files.jst.ejs +10 -0
  83. data/app/assets/javascripts/pageflow/{ui → editor}/templates/inputs/file_input.jst.ejs +1 -1
  84. data/app/assets/javascripts/pageflow/editor/templates/inputs/reference.jst.ejs +2 -2
  85. data/app/assets/javascripts/pageflow/editor/templates/nested_files.jst.ejs +1 -0
  86. data/app/assets/javascripts/pageflow/editor/templates/table_cell.jst.ejs +0 -0
  87. data/app/assets/javascripts/pageflow/editor/templates/text_tracks.jst.ejs +13 -0
  88. data/app/assets/javascripts/pageflow/editor/templates/uploadable_files.jst.ejs +1 -0
  89. data/app/assets/javascripts/pageflow/editor/utils/form_data_utils.js +19 -0
  90. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio.js +5 -2
  91. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_image.js +3 -2
  92. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/groups/background.js +35 -0
  93. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/groups/options.js +7 -9
  94. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/video.js +6 -5
  95. data/app/assets/javascripts/pageflow/editor/views/confirm_upload_view.js +69 -0
  96. data/app/assets/javascripts/pageflow/editor/views/confirmable_file_item_view.js +1 -1
  97. data/app/assets/javascripts/pageflow/editor/views/drop_down_button_item_list_view.js +9 -0
  98. data/app/assets/javascripts/pageflow/editor/views/drop_down_button_item_view.js +14 -1
  99. data/app/assets/javascripts/pageflow/editor/views/drop_down_button_view.js +51 -20
  100. data/app/assets/javascripts/pageflow/editor/views/edit_entry_view.js +21 -2
  101. data/app/assets/javascripts/pageflow/editor/views/edit_file_view.js +52 -0
  102. data/app/assets/javascripts/pageflow/editor/views/edit_storyline_view.js +1 -1
  103. data/app/assets/javascripts/pageflow/editor/views/entry_preview_view.js +15 -7
  104. data/app/assets/javascripts/pageflow/editor/views/file_item_view.js +33 -22
  105. data/app/assets/javascripts/pageflow/editor/views/file_meta_data_item_value_view.js +49 -0
  106. data/app/assets/javascripts/pageflow/editor/views/file_meta_data_item_view.js +16 -5
  107. data/app/assets/javascripts/pageflow/editor/views/file_settings_dialog_view.js +31 -0
  108. data/app/assets/javascripts/pageflow/editor/views/files_explorer_view.js +6 -7
  109. data/app/assets/javascripts/pageflow/editor/views/files_view.js +13 -14
  110. data/app/assets/javascripts/pageflow/editor/views/filtered_files_view.js +75 -0
  111. data/app/assets/javascripts/pageflow/editor/views/help_view.js +3 -0
  112. data/app/assets/javascripts/pageflow/editor/views/inputs/file_input_view.js +217 -0
  113. data/app/assets/javascripts/pageflow/editor/views/inputs/page_link_input_view.js +6 -0
  114. data/app/assets/javascripts/pageflow/editor/views/inputs/reference_input_view.js +13 -2
  115. data/app/assets/javascripts/pageflow/editor/views/list_view.js +24 -14
  116. data/app/assets/javascripts/pageflow/editor/views/model_thumbnail_view.js +4 -1
  117. data/app/assets/javascripts/pageflow/editor/views/nested_files_view.js +94 -0
  118. data/app/assets/javascripts/pageflow/editor/views/page_preview_view.js +7 -2
  119. data/app/assets/javascripts/pageflow/editor/views/text_file_meta_data_item_value_view.js +25 -0
  120. data/app/assets/javascripts/pageflow/editor/views/text_tracks_file_meta_data_item_value_view.js +12 -0
  121. data/app/assets/javascripts/pageflow/editor/views/text_tracks_view.js +65 -0
  122. data/app/assets/javascripts/pageflow/editor/views/uploadable_files_view.js +56 -0
  123. data/app/assets/javascripts/pageflow/editor/views/uploader_view.js +13 -10
  124. data/app/assets/javascripts/pageflow/features.js +8 -12
  125. data/app/assets/javascripts/pageflow/focus_outline.js +2 -0
  126. data/app/assets/javascripts/pageflow/media_player/volume_binding.js +2 -0
  127. data/app/assets/javascripts/pageflow/media_player/volume_fading.js +6 -0
  128. data/app/assets/javascripts/pageflow/page_type.js +0 -1
  129. data/app/assets/javascripts/pageflow/phone_landscape_fullscreen.js +34 -0
  130. data/app/assets/javascripts/pageflow/react.js +4 -0
  131. data/app/assets/javascripts/pageflow/ready.js +3 -0
  132. data/app/assets/javascripts/pageflow/seed_entry_data.js +4 -1
  133. data/app/assets/javascripts/pageflow/slideshow.js +1 -0
  134. data/app/assets/javascripts/pageflow/slideshow/adjacent_preparer.js +7 -5
  135. data/app/assets/javascripts/pageflow/slideshow/atmo.js +3 -3
  136. data/app/assets/javascripts/pageflow/slideshow/hidden_text_indicator_widget.js +4 -2
  137. data/app/assets/javascripts/pageflow/slideshow/hide_text.js +8 -4
  138. data/app/assets/javascripts/pageflow/slideshow/lazy_page_widget.js +5 -0
  139. data/app/assets/javascripts/pageflow/slideshow/scroller_widget.js +11 -18
  140. data/app/assets/javascripts/pageflow/ui.js +6 -0
  141. data/app/assets/javascripts/pageflow/ui/templates/inputs/url_display.jst.ejs +7 -0
  142. data/app/assets/javascripts/pageflow/ui/templates/table.jst.ejs +7 -0
  143. data/app/assets/javascripts/pageflow/ui/templates/table_blank_slate.jst.ejs +3 -0
  144. data/app/assets/javascripts/pageflow/ui/utils/i18n_utils.js +97 -2
  145. data/app/assets/javascripts/pageflow/ui/views/collection_view.js +8 -1
  146. data/app/assets/javascripts/pageflow/ui/views/inputs/check_box_input_view.js +12 -1
  147. data/app/assets/javascripts/pageflow/ui/views/inputs/proxy_url_input_view.js +51 -5
  148. data/app/assets/javascripts/pageflow/ui/views/inputs/select_input_view.js +80 -2
  149. data/app/assets/javascripts/pageflow/ui/views/inputs/slider_input_view.js +8 -1
  150. data/app/assets/javascripts/pageflow/ui/views/inputs/text_area_input_view.js +17 -1
  151. data/app/assets/javascripts/pageflow/ui/views/inputs/text_input_view.js +47 -4
  152. data/app/assets/javascripts/pageflow/ui/views/inputs/url_display_view.js +42 -0
  153. data/app/assets/javascripts/pageflow/ui/views/inputs/url_input_view.js +20 -2
  154. data/app/assets/javascripts/pageflow/ui/views/mixins/input_view.js +74 -46
  155. data/app/assets/javascripts/pageflow/ui/views/table_cells/delete_row_table_cell_view.js +63 -0
  156. data/app/assets/javascripts/pageflow/ui/views/table_cells/enum_table_cell_view.js +26 -0
  157. data/app/assets/javascripts/pageflow/ui/views/table_cells/icon_table_cell_view.js +40 -0
  158. data/app/assets/javascripts/pageflow/ui/views/table_cells/presence_table_cell_view.js +31 -0
  159. data/app/assets/javascripts/pageflow/ui/views/table_cells/table_cell_view.js +101 -0
  160. data/app/assets/javascripts/pageflow/ui/views/table_cells/table_header_cell_view.js +10 -0
  161. data/app/assets/javascripts/pageflow/ui/views/table_cells/text_table_cell_view.js +46 -0
  162. data/app/assets/javascripts/pageflow/ui/views/table_row_view.js +47 -0
  163. data/app/assets/javascripts/pageflow/ui/views/table_view.js +47 -0
  164. data/app/assets/javascripts/pageflow/video_player.js +9 -5
  165. data/app/assets/javascripts/pageflow/video_player/buffer_underrun_waiting.js +15 -13
  166. data/app/assets/javascripts/pageflow/video_player/cue_settings_methods.js +33 -0
  167. data/app/assets/javascripts/pageflow/video_player/dash.js +3 -0
  168. data/app/assets/javascripts/pageflow/video_player/filter_sources.js +1 -1
  169. data/app/assets/javascripts/pageflow/video_player/lazy.js +3 -9
  170. data/app/assets/javascripts/pageflow/video_player/prebuffering.js +11 -2
  171. data/app/assets/javascripts/pageflow/video_player/use_slim_controls_during_phone_playback.js +16 -0
  172. data/app/assets/javascripts/pageflow/videojs.js +6 -0
  173. data/app/assets/javascripts/pageflow/widgets.js +41 -7
  174. data/app/assets/stylesheets/pageflow/admin.scss +7 -4
  175. data/app/assets/stylesheets/pageflow/admin/{entries/user_badge_list.scss → badge_list.scss} +6 -9
  176. data/app/assets/stylesheets/pageflow/admin/embed_code.scss +13 -0
  177. data/app/assets/stylesheets/pageflow/admin/entries.scss +1 -2
  178. data/app/assets/stylesheets/pageflow/admin/hint.scss +20 -0
  179. data/app/assets/stylesheets/pageflow/admin/tooltip_bubble.scss +34 -0
  180. data/app/assets/stylesheets/pageflow/editor/base.scss +4 -4
  181. data/app/assets/stylesheets/pageflow/editor/confirm_upload.scss +66 -0
  182. data/app/assets/stylesheets/pageflow/editor/dialogs.scss +9 -1
  183. data/app/assets/stylesheets/pageflow/editor/drop_down_button.scss +56 -20
  184. data/app/assets/stylesheets/pageflow/editor/file_meta_data.scss +26 -6
  185. data/app/assets/stylesheets/pageflow/editor/file_settings_dialog.scss +32 -0
  186. data/app/assets/stylesheets/pageflow/editor/files.scss +5 -0
  187. data/app/assets/stylesheets/pageflow/editor/filtered_files.scss +25 -0
  188. data/app/assets/stylesheets/pageflow/editor/inputs.scss +2 -1
  189. data/app/assets/stylesheets/pageflow/editor/inputs/file_input.scss +65 -0
  190. data/app/assets/stylesheets/pageflow/editor/inputs/reference.scss +2 -2
  191. data/app/assets/stylesheets/pageflow/editor/text_tracks.scss +39 -0
  192. data/app/assets/stylesheets/pageflow/entries.scss +1 -0
  193. data/app/assets/stylesheets/pageflow/mixins/buttons.scss +77 -5
  194. data/app/assets/stylesheets/pageflow/mixins/icons/fontawesome.scss +3 -1
  195. data/app/assets/stylesheets/pageflow/page_types.scss +0 -4
  196. data/app/assets/stylesheets/pageflow/page_types/video.scss +5 -1
  197. data/app/assets/stylesheets/pageflow/page_types/video/content_hiding.scss +1 -0
  198. data/app/assets/stylesheets/pageflow/themes/default/base.scss +1 -0
  199. data/app/assets/stylesheets/pageflow/themes/default/built_in_page_types.scss +0 -2
  200. data/app/assets/stylesheets/pageflow/themes/default/definitions.scss +1 -0
  201. data/app/assets/stylesheets/pageflow/themes/default/loading_spinner.scss +31 -12
  202. data/app/assets/stylesheets/pageflow/themes/default/logo.scss +9 -1
  203. data/app/assets/stylesheets/pageflow/themes/default/logo/variant/background_image.scss +8 -2
  204. data/app/assets/stylesheets/pageflow/themes/default/logo/variant/watermark.scss +21 -0
  205. data/app/assets/stylesheets/pageflow/themes/default/mixins/cue_margins.scss +43 -0
  206. data/app/assets/stylesheets/pageflow/themes/default/mixins/indicator_typography.scss +7 -3
  207. data/app/assets/stylesheets/pageflow/themes/default/page.scss +20 -2
  208. data/app/assets/stylesheets/pageflow/themes/default/player_controls.scss +4 -0
  209. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic.scss +4 -0
  210. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/container.scss +8 -6
  211. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/control_bar.scss +18 -3
  212. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/cue_margins.scss +1 -0
  213. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/custom.scss +14 -0
  214. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/icon_font.scss +4 -0
  215. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/icons/sprite.scss +4 -0
  216. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/info_box.scss +2 -2
  217. data/app/assets/stylesheets/pageflow/themes/default/player_controls/classic/menu_bar.scss +5 -0
  218. data/app/assets/stylesheets/pageflow/themes/default/player_controls/shared/menu_bar.scss +121 -0
  219. data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim.scss +2 -0
  220. data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/container.scss +2 -0
  221. data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/control_bar.scss +74 -12
  222. data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/cue_margins.scss +3 -0
  223. data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/info_box.scss +31 -5
  224. data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/menu_bar.scss +13 -0
  225. data/app/assets/stylesheets/pageflow/themes/default/player_controls/slim/quality_menu.scss +116 -0
  226. data/app/assets/stylesheets/pageflow/themes/default/player_controls/vjs_mapping.scss +13 -3
  227. data/app/assets/stylesheets/pageflow/themes/default/player_controls/widget_margins.scss +8 -3
  228. data/app/assets/stylesheets/pageflow/themes/default/text_track_cues.scss +25 -0
  229. data/app/assets/stylesheets/pageflow/themes/default/variables/widgets.scss +2 -2
  230. data/app/assets/stylesheets/pageflow/themes/default/video_player/vjs_base.scss +122 -79
  231. data/app/assets/stylesheets/pageflow/themes/default/video_wrapper.scss +16 -7
  232. data/app/assets/stylesheets/pageflow/ui.scss +5 -1
  233. data/app/assets/stylesheets/pageflow/ui/forms.scss +5 -58
  234. data/app/assets/stylesheets/pageflow/ui/table_cells/delete_row_table_cell.scss +7 -0
  235. data/app/assets/stylesheets/pageflow/ui/table_cells/icon_table_cell.scss +16 -0
  236. data/app/assets/stylesheets/pageflow/ui/table_cells/presence_table_cell.scss +8 -0
  237. data/app/assets/stylesheets/pageflow/ui/table_view.scss +33 -0
  238. data/app/assets/stylesheets/pageflow/ui/tooltip.scss +1 -1
  239. data/app/controllers/pageflow/editor/encoding_confirmations_controller.rb +3 -3
  240. data/app/controllers/pageflow/editor/entry_publications_controller.rb +3 -3
  241. data/app/controllers/pageflow/editor/files_controller.rb +72 -14
  242. data/app/controllers/pageflow/editor/widgets_controller.rb +1 -1
  243. data/app/controllers/pageflow/entries_controller.rb +12 -2
  244. data/app/controllers/pageflow/files_controller.rb +1 -1
  245. data/app/helpers/pageflow/admin/entries_helper.rb +17 -0
  246. data/app/helpers/pageflow/admin/form_helper.rb +1 -1
  247. data/app/helpers/pageflow/admin/memberships_helper.rb +117 -13
  248. data/app/helpers/pageflow/common_entry_seed_helper.rb +36 -5
  249. data/app/helpers/pageflow/embed_code_helper.rb +32 -0
  250. data/app/helpers/pageflow/entries_helper.rb +1 -1
  251. data/app/helpers/pageflow/entry_json_seed_helper.rb +6 -16
  252. data/app/helpers/pageflow/files_helper.rb +5 -2
  253. data/app/helpers/pageflow/folders_helper.rb +26 -2
  254. data/app/helpers/pageflow/page_background_asset_helper.rb +8 -0
  255. data/app/helpers/pageflow/quota_helper.rb +1 -1
  256. data/app/helpers/pageflow/video_files_helper.rb +0 -5
  257. data/app/jobs/pageflow/poll_zencoder_job.rb +1 -1
  258. data/app/jobs/pageflow/process_file_job.rb +18 -0
  259. data/app/mailers/pageflow/user_mailer.rb +4 -2
  260. data/app/models/concerns/pageflow/hosted_file.rb +9 -0
  261. data/app/models/concerns/pageflow/output_source.rb +60 -0
  262. data/app/models/concerns/pageflow/uploaded_file.rb +33 -5
  263. data/app/models/pageflow/account.rb +3 -1
  264. data/app/models/pageflow/audio_file_url_templates.rb +21 -0
  265. data/app/models/pageflow/draft_entry.rb +19 -9
  266. data/app/models/pageflow/entry.rb +2 -1
  267. data/app/models/pageflow/entry_duplicate.rb +2 -2
  268. data/app/models/pageflow/entry_role_query.rb +81 -0
  269. data/app/models/pageflow/file_reuse.rb +25 -0
  270. data/app/models/pageflow/file_usage.rb +7 -1
  271. data/app/models/pageflow/image_file.rb +7 -1
  272. data/app/models/pageflow/image_file_url_templates.rb +19 -0
  273. data/app/models/pageflow/invited_user.rb +2 -0
  274. data/app/models/pageflow/membership.rb +46 -3
  275. data/app/models/pageflow/published_entry.rb +2 -2
  276. data/app/models/pageflow/revision.rb +16 -5
  277. data/app/models/pageflow/roles.rb +36 -0
  278. data/app/models/pageflow/text_track_file.rb +45 -0
  279. data/app/models/pageflow/text_track_file_url_templates.rb +16 -0
  280. data/app/models/pageflow/thumbnail_file_resolver.rb +22 -2
  281. data/app/models/pageflow/url_template.rb +13 -0
  282. data/app/models/pageflow/used_file.rb +21 -0
  283. data/app/models/pageflow/video_file.rb +72 -27
  284. data/app/models/pageflow/video_file_url_templates.rb +34 -0
  285. data/app/policies/pageflow/account_policy.rb +145 -0
  286. data/app/policies/pageflow/admin/admin_only_tab_policy.rb +16 -0
  287. data/app/policies/pageflow/admin/entry_tab_policy.rb +25 -0
  288. data/app/policies/pageflow/application_policy.rb +11 -0
  289. data/app/policies/pageflow/entry_policy.rb +138 -0
  290. data/app/policies/pageflow/file_policy.rb +42 -0
  291. data/app/policies/pageflow/folder_policy.rb +54 -0
  292. data/app/policies/pageflow/membership_policy.rb +105 -0
  293. data/app/policies/pageflow/theming_policy.rb +57 -0
  294. data/app/policies/pageflow/user_policy.rb +69 -0
  295. data/app/state_machines/pageflow/encoded_file_state_machine.rb +4 -0
  296. data/app/state_machines/pageflow/image_file_state_machine.rb +5 -1
  297. data/app/views/admin/entries/_attributes_table.html.arb +21 -2
  298. data/app/views/admin/entries/_links.html.arb +1 -1
  299. data/app/views/admin/memberships/_entity_account_input.html.erb +5 -0
  300. data/app/views/admin/memberships/_entity_entry_input.html.erb +5 -0
  301. data/app/views/admin/memberships/_form.html.erb +16 -5
  302. data/app/views/admin/memberships/_role_hint.html.arb +2 -0
  303. data/app/views/admin/users/_form.html.erb +29 -20
  304. data/app/views/components/pageflow/admin/add_membership_button_if_needed.rb +62 -0
  305. data/app/views/components/pageflow/admin/embed_code_field.rb +15 -0
  306. data/app/views/components/pageflow/admin/entry_user_badge_list.rb +15 -7
  307. data/app/views/components/pageflow/admin/grouped_folder_list.rb +20 -16
  308. data/app/views/components/pageflow/admin/members_tab.rb +22 -11
  309. data/app/views/components/pageflow/admin/membership_role_with_tooltip.rb +21 -0
  310. data/app/views/components/pageflow/admin/tabs_view.rb +13 -13
  311. data/app/views/components/pageflow/admin/user_account_badge_list.rb +43 -0
  312. data/app/views/components/pageflow/admin/user_accounts_tab.rb +46 -0
  313. data/app/views/components/pageflow/admin/user_entries_tab.rb +50 -0
  314. data/app/views/components/pageflow/admin/users_tab.rb +32 -4
  315. data/app/views/layouts/pageflow/application.html.erb +3 -2
  316. data/app/views/pageflow/config/_editor_seeds.json.jbuilder +15 -2
  317. data/app/views/pageflow/editor/entries/_entry.json.jbuilder +1 -0
  318. data/app/views/pageflow/editor/files/_file.json.jbuilder +10 -2
  319. data/app/views/pageflow/entries/show.css.erb +4 -11
  320. data/app/views/pageflow/entries/show.json.jbuilder +1 -1
  321. data/app/views/pageflow/entry_json_seed/_entry.json.jbuilder +19 -0
  322. data/app/views/pageflow/file_types/_thumbnails.css.erb +1 -1
  323. data/app/views/pageflow/files/_file.json.jbuilder +12 -0
  324. data/app/views/pageflow/page_background_asset/_element.html.erb +3 -0
  325. data/app/views/pageflow/page_types/_page_type.json.jbuilder +7 -0
  326. data/app/views/pageflow/react/_widget.html.erb +1 -0
  327. data/app/views/pageflow/react/page.html.erb +6 -0
  328. data/app/views/pageflow/video_files/_video_file.json.jbuilder +2 -0
  329. data/config/initializers/admin_resource_tabs.rb +8 -1
  330. data/config/initializers/features.rb +1 -4
  331. data/config/initializers/help_entries.rb +2 -1
  332. data/config/initializers/paperclip.rb +4 -0
  333. data/config/initializers/zencoder.rb +5 -2
  334. data/config/locales/de.yml +370 -108
  335. data/config/locales/en.yml +333 -83
  336. data/config/routes.rb +18 -10
  337. data/db/migrate/20150825133449_update_audio_loop_pages_to_use_atmo.rb +24 -0
  338. data/db/migrate/20160304072911_rename_membership_entry_and_make_polymorphic.rb +19 -0
  339. data/db/migrate/20160304151327_add_role_to_membership.rb +19 -0
  340. data/db/migrate/20160504093145_replace_role_and_account_on_user.rb +42 -0
  341. data/db/migrate/20160531152500_update_users_count.rb +27 -0
  342. data/db/migrate/20160707125400_add_output_presences_to_video_files.rb +5 -0
  343. data/db/migrate/20160824115000_add_parent_file_to_video_files.rb +8 -0
  344. data/db/migrate/20160824115100_add_parent_file_to_audio_files.rb +8 -0
  345. data/db/migrate/20160824115200_add_parent_file_to_image_files.rb +8 -0
  346. data/db/migrate/20160929102700_add_configuration_to_files.rb +7 -0
  347. data/db/migrate/20161007144500_add_text_track_files.rb +31 -0
  348. data/db/migrate/20161216175734_move_configuration_from_file_to_file_usage.rb +27 -0
  349. data/db/migrate/20161230144429_add_processed_attachment_to_text_track_files.rb +8 -0
  350. data/db/migrate/20170222124848_update_video_file_output_presences.rb +12 -0
  351. data/db/migrate/20170421112300_turn_background_video_pages_into_background_image_pages.rb +22 -0
  352. data/lib/generators/pageflow/assets/assets_generator.rb +2 -0
  353. data/lib/generators/pageflow/assets/templates/components.js +4 -0
  354. data/lib/generators/pageflow/initializer/templates/pageflow.rb +23 -20
  355. data/lib/generators/pageflow/seeds/templates/seeds.rb +81 -15
  356. data/lib/pageflow.rb +8 -0
  357. data/lib/pageflow/ability_mixin.rb +196 -62
  358. data/lib/pageflow/admin/tab.rb +21 -0
  359. data/lib/pageflow/admin/tabs.rb +31 -6
  360. data/lib/pageflow/built_in_file_type.rb +39 -0
  361. data/lib/pageflow/built_in_page_types_plugin.rb +80 -0
  362. data/lib/pageflow/configuration.rb +13 -1
  363. data/lib/pageflow/engine.rb +6 -1
  364. data/lib/pageflow/file_type.rb +60 -15
  365. data/lib/pageflow/file_types.rb +20 -2
  366. data/lib/pageflow/page_type.rb +53 -4
  367. data/lib/pageflow/page_types.rb +4 -0
  368. data/lib/pageflow/paperclip_processors/vtt.rb +35 -0
  369. data/lib/pageflow/react.rb +11 -0
  370. data/lib/pageflow/react/page_type.rb +26 -0
  371. data/lib/pageflow/react/widget_type.rb +20 -0
  372. data/lib/pageflow/seeds.rb +59 -15
  373. data/lib/pageflow/user_mixin.rb +18 -25
  374. data/lib/pageflow/version.rb +1 -1
  375. data/lib/pageflow/zencoder_api.rb +18 -4
  376. data/lib/pageflow/zencoder_video_output_definition.rb +375 -127
  377. data/lib/tasks/pageflow_tasks.rake +7 -0
  378. data/spec/factories/accounts.rb +36 -3
  379. data/spec/factories/entries.rb +22 -4
  380. data/spec/factories/invited_user.rb +3 -4
  381. data/spec/factories/memberships.rb +34 -2
  382. data/spec/factories/text_track_files.rb +40 -0
  383. data/spec/factories/users.rb +32 -7
  384. data/spec/factories/video_files.rb +7 -1
  385. data/spec/fixtures/sample.srt +12 -0
  386. data/spec/fixtures/sample.vtt +40 -0
  387. data/vendor/assets/javascripts/dash.all.min.js +14 -0
  388. data/vendor/assets/javascripts/polyfills/bind.js +17 -11
  389. data/vendor/assets/javascripts/videojs-dash.js +302 -0
  390. data/vendor/assets/javascripts/videojs.js +26804 -0
  391. metadata +187 -49
  392. data/app/assets/images/pageflow/themes/default/page_type_pictograms/audio_loop/sprite.png +0 -0
  393. data/app/assets/images/pageflow/themes/default/page_type_pictograms/audio_loop/wide.png +0 -0
  394. data/app/assets/javascripts/pageflow/editor/collections/file_usages_collection.js +0 -21
  395. data/app/assets/javascripts/pageflow/editor/models/file_usage.js +0 -8
  396. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio_loop.js +0 -20
  397. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_video.js +0 -24
  398. data/app/assets/javascripts/pageflow/page_types/audio.js +0 -135
  399. data/app/assets/javascripts/pageflow/page_types/audio_loop.js +0 -102
  400. data/app/assets/javascripts/pageflow/page_types/background_image.js +0 -44
  401. data/app/assets/javascripts/pageflow/page_types/background_video.js +0 -137
  402. data/app/assets/javascripts/pageflow/page_types/video.js +0 -277
  403. data/app/assets/javascripts/pageflow/ui/views/inputs/file_input_view.js +0 -79
  404. data/app/assets/javascripts/pageflow/video_player/play_button_patch.js +0 -39
  405. data/app/assets/javascripts/pageflow/video_player/player_buffered_patch.js +0 -47
  406. data/app/assets/javascripts/pageflow/video_player/src_from_options_method.js +0 -31
  407. data/app/assets/stylesheets/pageflow/page_types/audio_loop.scss +0 -18
  408. data/app/assets/stylesheets/pageflow/page_types/background-video.scss +0 -50
  409. data/app/controllers/pageflow/editor/file_usages_controller.rb +0 -37
  410. data/app/jobs/pageflow/process_image_file_job.rb +0 -18
  411. data/app/views/pageflow/pages/templates/_audio.html.erb +0 -69
  412. data/app/views/pageflow/pages/templates/_audio_loop.html.erb +0 -34
  413. data/app/views/pageflow/pages/templates/_background_image.html.erb +0 -24
  414. data/app/views/pageflow/pages/templates/_background_video.html.erb +0 -32
  415. data/app/views/pageflow/pages/templates/_video.html.erb +0 -42
  416. 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: 35px;
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: 110px 12% 5% 8%;
223
+ padding-top: $page-scroller-first-page-mobile-padding-top;
210
224
  width: 100%;
211
225
 
212
226
  @media (orientation: landscape) {
213
- padding: 100px 12% 5% 8%;
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);
@@ -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: 0;
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,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
+ }
@@ -48,6 +48,10 @@
48
48
  }
49
49
  }
50
50
 
51
+ &-play_button-custom_icon:before {
52
+ display: none;
53
+ }
54
+
51
55
  &-progress_bar_handle {
52
56
  @include background-icon-center($color: $progress-bar-handle-icon-color, $font-size: 23px);
53
57
  @include fa-reorder-icon;
@@ -37,6 +37,10 @@
37
37
  }
38
38
  }
39
39
 
40
+ &-play_button-custom_icon {
41
+ background-image: image-url("#{$dir}/player_controls_sprite_custom.png");
42
+ }
43
+
40
44
  &-progress_bar_handle {
41
45
  background-position: center -240px;
42
46
  }
@@ -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 * 2;
82
+ margin-bottom: 60px + $classic-player-controls-border-width * 4;
83
83
  width: 434px;
84
- bottom: $classic-player-controls-border-width * 2;
84
+ bottom: 100%;
85
85
  position: absolute;
86
86
  left: 50%;
87
87
  @include transform(translate3d(-50%, 0, 0));
@@ -0,0 +1,5 @@
1
+ .player_controls {
2
+ &-menu_bar {
3
+ right: 10px;
4
+ }
5
+ }
@@ -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
+ }