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
@@ -1,8 +1,10 @@
1
1
  @import "./slim/container";
2
2
  @import "./slim/control_bar";
3
+ @import "./slim/menu_bar";
3
4
  @import "./slim/info_box";
4
5
  @import "./slim/close_button";
5
6
  @import "./slim/scroller";
7
+ @import "./slim/cue_margins";
6
8
 
7
9
  %player_controls-container {
8
10
  @include phone {
@@ -42,6 +42,8 @@ $slim-player-controls-typography: $player-controls-typography !default;
42
42
  visibility: hidden;
43
43
  }
44
44
 
45
+ .enable_focus_outline &-container-focused,
46
+ .enable_focus_outline &-background-focused::after,
45
47
  &-container-hover,
46
48
  &-background-hover::after {
47
49
  opacity: 1;
@@ -17,6 +17,15 @@ $slim-player-controls-progress-bar-color: $main-color !default;
17
17
  /// Color of the part of the progress bar indicating the load progress.
18
18
  $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2) !default;
19
19
 
20
+ /// Typography for text displayed next to play button
21
+ $slim-player-controls-control-bar-text-typography: () !default;
22
+
23
+ /// Typography for text displayed next to play button in desktop layout
24
+ $slim-player-controls-control-bar-text-desktop-typography: () !default;
25
+
26
+ /// Typography for text displayed next to play button in phone layout
27
+ $slim-player-controls-control-bar-text-phone-typography: () !default;
28
+
20
29
  %player_controls {
21
30
  &-control_bar {
22
31
  position: absolute;
@@ -31,6 +40,15 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
31
40
 
32
41
  @include phone {
33
42
  z-index: 2;
43
+
44
+ &.with_quality_menu_present,
45
+ &.with_text_tracks_menu_present {
46
+ padding-right: 60px;
47
+ }
48
+
49
+ &.with_quality_menu_present.with_text_tracks_menu_present {
50
+ padding-right: 110px;
51
+ }
34
52
  }
35
53
  }
36
54
 
@@ -50,7 +68,11 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
50
68
  color: $slim-player-controls-color;
51
69
  text-shadow: 1px 1px 4px $indicator-text-shadow-color;
52
70
 
53
- @include indicator-typography;
71
+ @include indicator-typography(
72
+ $overrides: $slim-player-controls-control-bar-text-typography,
73
+ $phone-overrides: $slim-player-controls-control-bar-text-phone-typography,
74
+ $desktop-overrides: $slim-player-controls-control-bar-text-desktop-typography
75
+ );
54
76
 
55
77
  @include phone {
56
78
  left: 50px;
@@ -78,14 +100,28 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
78
100
  z-index: 1;
79
101
  }
80
102
 
103
+ &-play_button-custom_icon {
104
+ &:before {
105
+ display: none;
106
+ }
107
+
108
+ svg {
109
+ fill: $slim-player-controls-color;
110
+ position: absolute;
111
+ left: 7px;
112
+ top: 50%;
113
+ @include transform(translateY(-50%));
114
+ width: 25px;
115
+ height: 25px;
116
+ }
117
+ }
118
+
81
119
  &-play_button-playing {
82
120
  @include background-icon-position($left: 20px);
83
121
  @include fa-pause-icon;
84
122
  }
85
123
 
86
124
  &-loading_spinner {
87
- @include background-icon-center($color: $slim-player-controls-loading-spinner-color, $font-size: 36px);
88
- @include fa-circle-o-notch-icon;
89
125
  @include animation(rotate_and_blink 0.5s linear infinite);
90
126
 
91
127
  position: absolute;
@@ -93,6 +129,15 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
93
129
  height: 60px;
94
130
  left: -5px;
95
131
  bottom: -4px;
132
+
133
+ svg {
134
+ fill: $slim-player-controls-loading-spinner-color;
135
+ position: absolute;
136
+ left: 12px;
137
+ top: 12px;
138
+ width: 36px;
139
+ height: 36px;
140
+ }
96
141
  }
97
142
 
98
143
  &-loading_spinner-on_underrun {
@@ -108,15 +153,21 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
108
153
  display: none;
109
154
  }
110
155
 
156
+ &-progress {
157
+ position: relative;
158
+ }
159
+
111
160
  &-progress_bar {
112
161
  position: absolute;
113
- bottom: 55px;
114
- left: 16px;
115
- right: 20px;
162
+ bottom: 40px;
163
+ left: -4px;
164
+ right: 0;
116
165
  height: 20px;
117
166
 
118
167
  @include phone {
119
- display: none;
168
+ bottom: 0;
169
+ left: 30px;
170
+ right: 80px;
120
171
  }
121
172
 
122
173
  &:before {
@@ -135,7 +186,7 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
135
186
  &-load_progress {
136
187
  position: absolute;
137
188
  left: 0;
138
- top: 10px;
189
+ top: 8px;
139
190
  height: 3px;
140
191
  }
141
192
 
@@ -150,7 +201,7 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
150
201
  &-progress_bar_handle {
151
202
  position: absolute;
152
203
  left: 0;
153
- top: 11px;
204
+ top: 9px;
154
205
  width: 0;
155
206
  height: 0;
156
207
  @include transform(scale(0));
@@ -172,7 +223,7 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
172
223
  %player_controls-progress_bar:before,
173
224
  %player_controls-play_progress,
174
225
  %player_controls-load_progress {
175
- top: 9px;
226
+ top: 7px;
176
227
  height: 5px;
177
228
  }
178
229
 
@@ -206,17 +257,28 @@ $slim-player-controls-progress-bar-load-progress-color: rgba(255, 255, 255, 0.2)
206
257
  &-time_separator,
207
258
  &-duration,
208
259
  &-skip_button,
209
- &-loading_spinner {
260
+ &-menu_bar {
210
261
  @include transition(opacity 0.2s linear, visibility 0.2s linear);
211
262
  }
212
263
 
264
+ .has_native_video_player &-container-video {
265
+ %player_controls-progress_bar,
266
+ %player_controls-current_time,
267
+ %player_controls-time_separator,
268
+ %player_controls-duration,
269
+ %player_controls-skip_button,
270
+ %player_controls-menu_bar {
271
+ display: none;
272
+ }
273
+ }
274
+
213
275
  &-container-paused {
214
276
  %player_controls-progress_bar,
215
277
  %player_controls-current_time,
216
278
  %player_controls-time_separator,
217
279
  %player_controls-duration,
218
280
  %player_controls-skip_button,
219
- %player_controls-loading_spinner {
281
+ %player_controls-menu_bar {
220
282
  opacity: 0;
221
283
  visibility: hidden;
222
284
  @include transition-delay(0.2s);
@@ -0,0 +1,3 @@
1
+ @include cue-margins(
2
+ $controls-offset: 80px
3
+ );
@@ -71,7 +71,6 @@ $slim-player-controls-info-box-header-typography: () !default;
71
71
 
72
72
  .js &-info_box {
73
73
  @include transition(opacity 0.2s linear, visibility 0.2s linear, transform 0.2s ease);
74
- @include transition-delay(0.2s);
75
74
  pointer-events: none;
76
75
 
77
76
  position: absolute;
@@ -80,6 +79,7 @@ $slim-player-controls-info-box-header-typography: () !default;
80
79
  z-index: 2;
81
80
 
82
81
  @include desktop {
82
+ @include transition-delay(0.2s);
83
83
  width: 100%;
84
84
  max-width: 700px;
85
85
  bottom: 80px;
@@ -96,17 +96,43 @@ $slim-player-controls-info-box-header-typography: () !default;
96
96
  }
97
97
  }
98
98
 
99
- .js &-container-has_been_faded %player_controls-info_box {
99
+ @mixin faded {
100
100
  opacity: 0;
101
101
  visibility: hidden;
102
102
  @include transform(translate3d(-50%, 10px, 0));
103
103
  }
104
104
 
105
- .js &-container:hover %player_controls-info_box,
106
- .js &-container-paused %player_controls-info_box {
107
- @include transition-delay(0);
105
+ @mixin visible {
108
106
  opacity: 1;
109
107
  visibility: visible;
110
108
  @include transform(translate3d(-50%, 0, 0));
111
109
  }
110
+
111
+ @include desktop {
112
+ .js &-container-has_been_faded %player_controls-info_box {
113
+ @include faded;
114
+ }
115
+
116
+ .js &-container:hover %player_controls-info_box,
117
+ .js &-container-paused %player_controls-info_box {
118
+ @include transition-delay(0);
119
+ @include visible;
120
+ }
121
+ }
122
+
123
+ @include phone {
124
+ .js.has_no_native_video_player &-container-fading %player_controls-info_box {
125
+ @include faded;
126
+ }
127
+
128
+ .js.has_no_native_video_player &-container-paused %player_controls-info_box {
129
+ @include visible;
130
+ }
131
+ }
132
+ }
133
+
134
+ &.widget_classic_player_controls_replaced {
135
+ %player_controls-info_box {
136
+ display: none;
137
+ }
112
138
  }
@@ -0,0 +1,13 @@
1
+ .player_controls {
2
+ &-menu_bar {
3
+ right: 90px;
4
+
5
+ @include phone {
6
+ right: 0;
7
+ }
8
+ }
9
+
10
+ &-menu_bar-stand_alone {
11
+ right: 20px;
12
+ }
13
+ }
@@ -0,0 +1,116 @@
1
+ $slim-player-controls-menu-popup-background-color: rgba(17, 17, 17, 0.9) !default;
2
+
3
+ $slim-player-controls-menu-popup-link-color: $slim-player-controls-color !default;
4
+
5
+ $slim-player-controls-menu-item-active-background-color: rgba(200, 200, 200, 0.8) !default;
6
+
7
+ $slim-player-controls-quality-menu-annotation-color: #ff0000 !default;
8
+
9
+ .player_controls {
10
+ &-menu_bar {
11
+ position: absolute;
12
+ bottom: 0;
13
+ right: 10px;
14
+ z-index: 10;
15
+ pointer-events: all;
16
+
17
+ @include transition(opacity 0.5s, visibility 0.5s);
18
+ }
19
+
20
+ &-menu_bar-stand_alone {
21
+ right: 20px;
22
+ bottom: 5px;
23
+ }
24
+
25
+ &-menu_bar-hidden_on_phone {
26
+ @include phone {
27
+ opacity: 0;
28
+ visibility: hidden;
29
+ pointer-events: none;
30
+ }
31
+ }
32
+
33
+ &-menu_bar_button {
34
+ display: inline-block;
35
+ position: relative;
36
+ bottom: 0;
37
+ right: 0;
38
+ width: 40px;
39
+ height: 40px;
40
+ margin-right: 10px;
41
+ }
42
+
43
+ &-menu_bar_button_link {
44
+ display: block;
45
+ height: 100%;
46
+ }
47
+
48
+ &-menu_bar_button_icon {
49
+ position: absolute;
50
+ top: 50%;
51
+ left: 50%;
52
+ @include transform(translate(-50%, -50%));
53
+ @include transition(transform 0.3s ease);
54
+ width: 25px;
55
+ height: 25px;
56
+
57
+ fill: $slim-player-controls-color;
58
+ }
59
+
60
+ &-menu_bar_button-sub_menu_visible .player_controls-quality_menu_button_icon {
61
+ @include transform(translate(-50%, -50%) rotate(40deg));
62
+ }
63
+
64
+ &-quality_menu_button_sub_menu_item_annotation {
65
+ color: $slim-player-controls-quality-menu-annotation-color;
66
+ font-size: 70%;
67
+ vertical-align: 5px;
68
+ padding-left: 3px;
69
+ }
70
+
71
+ &-menu_bar_button_sub_menu {
72
+ visibility: hidden;
73
+ opacity: 0;
74
+ pointer-events: none;
75
+ @include transition(opacity 0.5s, visibility 0.5s);
76
+
77
+ position: absolute;
78
+ right: 0;
79
+ bottom: 40px;
80
+ margin: 0;
81
+ padding: 5px;
82
+
83
+ background-color: $slim-player-controls-menu-popup-background-color;
84
+ border-radius: 2px;
85
+ text-align: right;
86
+ }
87
+
88
+ &-menu_bar_button-sub_menu_visible .player_controls-menu_bar_button_sub_menu {
89
+ visibility: visible;
90
+ opacity: 1;
91
+ pointer-events: all;
92
+ @include transition(none);
93
+ }
94
+
95
+ &-menu_bar_button_sub_menu_item {
96
+ position: relative;
97
+ list-style: none;
98
+ }
99
+
100
+ &-menu_bar_button_sub_menu_item_icon {
101
+ position: absolute;
102
+ top: 8px;
103
+ left: 5px;
104
+ width: 12px;
105
+ height: 12px;
106
+
107
+ fill: $slim-player-controls-color;
108
+ }
109
+
110
+ &-menu_bar_button_sub_menu_item_link {
111
+ display: block;
112
+ padding: 5px 10px 5px 25px;
113
+ color: $slim-player-controls-menu-popup-link-color;
114
+ text-decoration: none;
115
+ }
116
+ }
@@ -3,11 +3,12 @@
3
3
  $vjs-selector-mapping: (
4
4
  page_with_progress_bar: ".audioPage, .videoPage",
5
5
 
6
- background: ".videoWrapper, .audioPage .backgroundArea",
6
+ background: ".page_background-for_page_with_player_controls",
7
7
 
8
- background-idle: ".is_idle .videoWrapper, .audioPage.is_idle .backgroundArea",
8
+ background-idle: ".is_idle .page_background-for_page_with_player_controls",
9
9
 
10
- background-hover: ".is_control_bar_hovered .videoWrapper, .audioPage.is_control_bar_hovered .backgroundArea",
10
+ background-hover: ".is_control_bar_hovered .page_background-for_page_with_player_controls",
11
+ background-focused: ".is_control_bar_focused .page_background-for_page_with_player_controls",
11
12
 
12
13
  // Use playing class that is removed with delay to prevent
13
14
  // mask image on scroller from being removed too early in slim
@@ -27,6 +28,7 @@ $vjs-selector-mapping: (
27
28
  container-idle: ".is_idle .controls",
28
29
 
29
30
  container-hover: ".is_control_bar_hovered .controls",
31
+ container-focused: ".is_control_bar_focused .controls",
30
32
 
31
33
  // `has_been_faded` is set by the video page type after the user has
32
34
  // become inactive for the first time during video playback.
@@ -39,6 +41,9 @@ $vjs-selector-mapping: (
39
41
  // cursor leaves the control bar again.
40
42
  container-has_been_faded: ".controls.has_been_faded",
41
43
 
44
+ container-video: ".videoPage .controls",
45
+ container-fading: ".videoPage .controls",
46
+
42
47
  container-unplayed: ".unplayed .controls",
43
48
 
44
49
  info_box: ".add_info_box",
@@ -47,10 +52,13 @@ $vjs-selector-mapping: (
47
52
 
48
53
  play_button: ".vjs-play-control",
49
54
  play_button-playing: ".vjs-play-control.vjs-playing",
55
+ play_button-custom_icon: ".player_controls-play_button-custom_icon",
50
56
  skip_button: ".player_skip",
51
57
  loading_spinner: ".vjs-loading-spinner",
52
58
  loading_spinner-on_underrun: ".vjs-loading-spinner.showing-for-underrun",
53
59
 
60
+ progress: ".player_controls-progress",
61
+
54
62
  current_time: ".vjs-current-time",
55
63
  time_separator: ".vjs-time-divider",
56
64
  duration: ".vjs-duration",
@@ -61,6 +69,8 @@ $vjs-selector-mapping: (
61
69
  load_progress: ".vjs-load-progress",
62
70
  play_progress: ".vjs-play-progress",
63
71
 
72
+ menu_bar: ".player_controls-menu_bar",
73
+
64
74
  close_button: ".page .close_button",
65
75
  close_button_label: ".page .close_button .label",
66
76
  );