pageflow 0.5.0 → 0.6.0

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 (197) hide show
  1. checksums.yaml +8 -8
  2. data/Rakefile +2 -1
  3. data/admins/pageflow/accounts.rb +20 -4
  4. data/admins/pageflow/entry.rb +4 -5
  5. data/app/assets/javascripts/pageflow/audio_player.js +16 -7
  6. data/app/assets/javascripts/pageflow/base.js +5 -0
  7. data/app/assets/javascripts/pageflow/built_in_widget_types.js +11 -0
  8. data/app/assets/javascripts/pageflow/cookies.js +43 -0
  9. data/app/assets/javascripts/pageflow/editor/base.js +2 -10
  10. data/app/assets/javascripts/pageflow/editor/collections/widgets_collection.js +16 -0
  11. data/app/assets/javascripts/pageflow/editor/controllers/sidebar_controller.js +3 -2
  12. data/app/assets/javascripts/pageflow/editor/edit_widget.jst.ejs +2 -0
  13. data/app/assets/javascripts/pageflow/editor/initializers/setup_widget_types.js +3 -0
  14. data/app/assets/javascripts/pageflow/editor/models/configuration.js +18 -9
  15. data/app/assets/javascripts/pageflow/editor/models/edit_lock_container.js +1 -0
  16. data/app/assets/javascripts/pageflow/editor/models/entry.js +13 -3
  17. data/app/assets/javascripts/pageflow/editor/models/entry_configuration.js +4 -0
  18. data/app/assets/javascripts/pageflow/editor/models/entry_configuration_file_selection_handler.js +11 -0
  19. data/app/assets/javascripts/pageflow/editor/models/image_file.js +4 -0
  20. data/app/assets/javascripts/pageflow/editor/models/mixins/widget_subject.js +37 -0
  21. data/app/assets/javascripts/pageflow/editor/models/page.js +1 -1
  22. data/app/assets/javascripts/pageflow/editor/models/page_configuration_file_selection_handler.js +1 -25
  23. data/app/assets/javascripts/pageflow/editor/models/theming.js +3 -0
  24. data/app/assets/javascripts/pageflow/editor/models/video_file.js +7 -0
  25. data/app/assets/javascripts/pageflow/editor/models/widget.js +19 -0
  26. data/app/assets/javascripts/pageflow/editor/routers/sidebar_router.js +1 -0
  27. data/app/assets/javascripts/pageflow/editor/templates/background_positioning.jst.ejs +18 -0
  28. data/app/assets/javascripts/pageflow/editor/templates/background_positioning_preview.jst.ejs +2 -0
  29. data/app/assets/javascripts/pageflow/editor/templates/background_positioning_sliders.jst.ejs +6 -0
  30. data/app/assets/javascripts/pageflow/editor/templates/edit_meta_data.jst.ejs +1 -1
  31. data/app/assets/javascripts/pageflow/editor/templates/edit_widget.jst.ejs +2 -0
  32. data/app/assets/javascripts/pageflow/editor/templates/edit_widgets.jst.ejs +2 -0
  33. data/app/assets/javascripts/pageflow/editor/templates/entry_preview.jst.ejs +1 -3
  34. data/app/assets/javascripts/pageflow/editor/views/background_positioning_preview_view.js +39 -0
  35. data/app/assets/javascripts/pageflow/editor/views/background_positioning_sliders_view.js +94 -0
  36. data/app/assets/javascripts/pageflow/editor/views/background_positioning_view.js +67 -0
  37. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio.js +1 -1
  38. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio_loop.js +1 -1
  39. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_image.js +1 -1
  40. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_video.js +4 -3
  41. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/internal_links.js +1 -1
  42. data/app/assets/javascripts/pageflow/editor/views/configuration_editors/video.js +9 -2
  43. data/app/assets/javascripts/pageflow/editor/views/edit_meta_data_view.js +18 -2
  44. data/app/assets/javascripts/pageflow/editor/views/edit_widget_view.js +29 -0
  45. data/app/assets/javascripts/pageflow/editor/views/edit_widgets_view.js +20 -0
  46. data/app/assets/javascripts/pageflow/editor/views/embedded/background_image_embedded_view.js +8 -3
  47. data/app/assets/javascripts/pageflow/editor/views/entry_preview_view.js +53 -9
  48. data/app/assets/javascripts/pageflow/editor/views/page_item_view.js +1 -1
  49. data/app/assets/javascripts/pageflow/editor/views/page_preview_view.js +11 -3
  50. data/app/assets/javascripts/pageflow/events.js +1 -0
  51. data/app/assets/javascripts/pageflow/features/hashchange_support.js +8 -0
  52. data/app/assets/javascripts/pageflow/history.js +14 -2
  53. data/app/assets/javascripts/pageflow/page_types/audio.js +18 -6
  54. data/app/assets/javascripts/pageflow/page_types/audio_loop.js +19 -7
  55. data/app/assets/javascripts/pageflow/page_types/background_video.js +41 -33
  56. data/app/assets/javascripts/pageflow/page_types/mixins/video_helpers.js +7 -16
  57. data/app/assets/javascripts/pageflow/ready.js +12 -25
  58. data/app/assets/javascripts/pageflow/slideshow.js +5 -5
  59. data/app/assets/javascripts/pageflow/slideshow/hide_text_on_swipe.js +1 -1
  60. data/app/assets/javascripts/pageflow/slideshow/page_widget.js +11 -1
  61. data/app/assets/javascripts/pageflow/slideshow/scroll_indicator_widget.js +19 -2
  62. data/app/assets/javascripts/pageflow/slideshow/scroller_widget.js +31 -6
  63. data/app/assets/javascripts/pageflow/slideshow/swipe_gesture.js +6 -5
  64. data/app/assets/javascripts/pageflow/ui.js +16 -0
  65. data/app/assets/javascripts/pageflow/{editor → ui}/object.js +0 -0
  66. data/app/assets/javascripts/pageflow/{editor → ui}/renderer.js +0 -0
  67. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/check_box.jst.ejs +0 -0
  68. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/file_input.jst.ejs +0 -0
  69. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/page_reference.jst.ejs +0 -0
  70. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/select_input.jst.ejs +0 -0
  71. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/slider_input.jst.ejs +0 -0
  72. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/text_area_input.jst.ejs +0 -0
  73. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/text_input.jst.ejs +0 -0
  74. data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/url_input.jst.ejs +0 -0
  75. data/app/assets/javascripts/pageflow/{editor → ui}/templates/tabs_view.jst.ejs +0 -0
  76. data/app/assets/javascripts/pageflow/{editor → ui}/views/collection_view.js +0 -0
  77. data/app/assets/javascripts/pageflow/{editor → ui}/views/configuration_editor_tab_view.js +8 -1
  78. data/app/assets/javascripts/pageflow/{editor → ui}/views/configuration_editor_view.js +3 -1
  79. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/check_box_input_view.js +1 -1
  80. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/file_input_view.js +10 -8
  81. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/page_reference_input_view.js +1 -1
  82. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/proxy_url_input_view.js +0 -0
  83. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/select_input_view.js +41 -1
  84. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/slider_input_view.js +1 -1
  85. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/text_area_input_view.js +1 -1
  86. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/text_input_view.js +8 -2
  87. data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/url_input_view.js +9 -3
  88. data/app/assets/javascripts/pageflow/{editor/views → ui/views/mixins}/input_view.js +5 -1
  89. data/app/assets/javascripts/pageflow/{editor → ui}/views/mixins/subview_container.js +0 -0
  90. data/app/assets/javascripts/pageflow/{editor → ui}/views/sortable_collection_view.js +0 -0
  91. data/app/assets/javascripts/pageflow/{editor → ui}/views/tabs_view.js +11 -2
  92. data/app/assets/javascripts/pageflow/video_player/lazy.js +4 -1
  93. data/app/assets/javascripts/pageflow/visited.js +56 -0
  94. data/app/assets/javascripts/pageflow/widget_types.js +27 -0
  95. data/app/assets/javascripts/pageflow/widgets/events.js +33 -0
  96. data/app/assets/javascripts/pageflow/widgets/navigation.js +42 -33
  97. data/app/assets/javascripts/pageflow/widgets/navigation_mobile.js +60 -38
  98. data/app/assets/javascripts/pageflow/widgets/overview.js +3 -3
  99. data/app/assets/javascripts/pageflow/widgets/page_navigation_list.js +34 -4
  100. data/app/assets/javascripts/pageflow/widgets/share_menu.js +60 -0
  101. data/app/assets/stylesheets/pageflow/admin.css.scss +1 -0
  102. data/app/assets/stylesheets/pageflow/admin/tabs_view.css.scss +50 -0
  103. data/app/assets/stylesheets/pageflow/application_with_simulated_media_queries.css.scss +2 -0
  104. data/app/assets/stylesheets/pageflow/base.css.scss +2 -1
  105. data/app/assets/stylesheets/pageflow/editor/{image_positioning.css.scss → background_positioning.css.scss} +66 -65
  106. data/app/assets/stylesheets/pageflow/editor/base.css.scss +7 -5
  107. data/app/assets/stylesheets/pageflow/editor/file_thumbnails.css.scss +7 -9
  108. data/app/assets/stylesheets/pageflow/editor/select_button.css.scss +4 -4
  109. data/app/assets/stylesheets/pageflow/editor/widgets.css.scss +4 -0
  110. data/app/assets/stylesheets/pageflow/entries.css.scss +5 -0
  111. data/app/assets/stylesheets/pageflow/mixins/breakpoints.css.scss +75 -10
  112. data/app/assets/stylesheets/pageflow/multimedia_alert.css.scss +31 -30
  113. data/app/assets/stylesheets/pageflow/navigation_bar.css.scss +4 -0
  114. data/app/assets/stylesheets/pageflow/navigation_mobile.css.scss +57 -58
  115. data/app/assets/stylesheets/pageflow/player_controls.css.scss +2 -2
  116. data/app/assets/stylesheets/pageflow/slideshow.css.scss +4 -1
  117. data/app/assets/stylesheets/pageflow/subshare.css.scss +28 -0
  118. data/app/assets/stylesheets/pageflow/ui.css.scss +7 -0
  119. data/app/assets/stylesheets/pageflow/{editor → ui}/forms.css.scss +1 -0
  120. data/app/assets/stylesheets/pageflow/{editor → ui}/tabs_view.css.scss +1 -0
  121. data/app/controllers/pageflow/editor/widgets_controller.rb +39 -0
  122. data/app/controllers/pageflow/entries_controller.rb +10 -1
  123. data/app/helpers/pageflow/entries_helper.rb +7 -0
  124. data/app/helpers/pageflow/page_types_helper.rb +7 -7
  125. data/app/helpers/pageflow/pages_helper.rb +36 -5
  126. data/app/helpers/pageflow/social_share_helper.rb +54 -0
  127. data/app/helpers/pageflow/widgets_helper.rb +43 -0
  128. data/app/models/pageflow/draft_entry.rb +4 -1
  129. data/app/models/pageflow/entry.rb +1 -0
  130. data/app/models/pageflow/published_entry.rb +6 -3
  131. data/app/models/pageflow/revision.rb +5 -0
  132. data/app/models/pageflow/theming.rb +3 -0
  133. data/app/models/pageflow/widget.rb +74 -0
  134. data/app/views/admin/accounts/_form.html.erb +10 -0
  135. data/app/views/components/pageflow/admin/entries_tab.rb +22 -0
  136. data/app/views/components/pageflow/admin/members_tab.rb +35 -0
  137. data/app/views/components/pageflow/admin/revisions_tab.rb +51 -0
  138. data/app/views/components/pageflow/admin/tabs_view.rb +78 -0
  139. data/app/views/components/pageflow/admin/users_tab.rb +22 -0
  140. data/app/views/layouts/pageflow/application.html.erb +5 -5
  141. data/app/views/pageflow/editor/entries/_entry.json.jbuilder +7 -4
  142. data/app/views/pageflow/editor/files/_file.json.jbuilder +2 -2
  143. data/app/views/pageflow/editor/widgets/_widget.json.jbuilder +2 -0
  144. data/app/views/pageflow/editor/widgets/index.json.jbuilder +1 -0
  145. data/app/views/pageflow/entries/_entry.html.erb +6 -2
  146. data/app/views/pageflow/entries/_mobile_navigation.html.erb +56 -0
  147. data/app/views/pageflow/entries/_navigation.html.erb +3 -53
  148. data/app/views/pageflow/entries/edit.html.erb +2 -0
  149. data/app/views/pageflow/entries/navigation/_bar_top.html.erb +7 -3
  150. data/app/views/pageflow/entries/navigation/_page.html.erb +2 -2
  151. data/app/views/pageflow/entries/partials.html.erb +1 -1
  152. data/app/views/pageflow/entries/show.html.erb +12 -4
  153. data/app/views/pageflow/files/show.html.erb +5 -0
  154. data/app/views/pageflow/pages/templates/_audio_loop.html.erb +1 -1
  155. data/app/views/pageflow/pages/templates/_background_video.html.erb +2 -2
  156. data/app/views/pageflow/pages/templates/_video.html.erb +4 -3
  157. data/app/views/pageflow/{entries/_social_meta_tags.html.erb → social_share/_entry_meta_tags.html.erb} +2 -2
  158. data/app/views/pageflow/social_share/_image_tags.html.erb +3 -0
  159. data/app/views/pageflow/social_share/_page_meta_tags.html.erb +9 -0
  160. data/config/initializers/admin_resource_tabs.rb +7 -0
  161. data/config/initializers/paperclip.rb +1 -1
  162. data/config/initializers/view_components.rb +9 -1
  163. data/config/initializers/widget_types.rb +4 -0
  164. data/config/locales/activerecord.de.yml +5 -1
  165. data/config/locales/admin/tabs.de.yml +8 -0
  166. data/config/locales/editor.de.yml +5 -4
  167. data/config/locales/pageflow/editor/background_positioning.de.yml +13 -0
  168. data/config/locales/pageflow/ui.de.yml +6 -0
  169. data/config/locales/pageflow/widgets.de.yml +14 -0
  170. data/config/routes.rb +6 -0
  171. data/config/spring.rb +2 -1
  172. data/db/migrate/20141027102310_create_widgets.rb +11 -0
  173. data/db/migrate/20141028125408_add_emphasize_chapter_beginning_to_revisions.rb +5 -0
  174. data/db/migrate/20141119164526_add_emphasize_new_pages_to_revisions.rb +5 -0
  175. data/db/migrate/20141119174032_add_sharing_image_to_revisions.rb +7 -0
  176. data/lib/pageflow/ability_mixin.rb +2 -0
  177. data/lib/pageflow/admin/tabs.rb +18 -0
  178. data/lib/pageflow/built_in_widget_type.rb +27 -0
  179. data/lib/pageflow/configuration.rb +17 -0
  180. data/lib/pageflow/engine.rb +2 -0
  181. data/lib/pageflow/version.rb +1 -1
  182. data/lib/pageflow/widget_type.rb +52 -0
  183. data/lib/pageflow/widget_types.rb +50 -0
  184. data/spec/factories/audio_files.rb +1 -1
  185. data/spec/factories/chapters.rb +1 -1
  186. data/spec/factories/entries.rb +2 -2
  187. data/spec/factories/image_files.rb +1 -1
  188. data/spec/factories/video_files.rb +1 -1
  189. data/spec/factories/widgets.rb +6 -0
  190. data/vendor/assets/javascripts/audio5.min.js +3 -0
  191. metadata +104 -44
  192. data/app/assets/javascripts/pageflow/editor/templates/image_positioning.jst.ejs +0 -26
  193. data/app/assets/javascripts/pageflow/editor/views/image_positioning_view.js +0 -153
  194. data/app/views/admin/accounts/_entries_panel.html.arb +0 -15
  195. data/app/views/admin/accounts/_users_panel.html.arb +0 -15
  196. data/app/views/admin/entries/_members.html.arb +0 -29
  197. data/app/views/admin/entries/_revisions.html.arb +0 -45
@@ -8,12 +8,19 @@ pageflow.ConfigurationEditorView.register('video', {
8
8
  });
9
9
 
10
10
  this.tab('files', function() {
11
- this.input('video_file_id', pageflow.FileInputView, {collection: pageflow.videoFiles});
11
+ this.input('video_file_id', pageflow.FileInputView, {
12
+ collection: pageflow.videoFiles,
13
+ positioning: false
14
+ });
12
15
  this.input('poster_image_id', pageflow.FileInputView, {
13
16
  collection: pageflow.imageFiles,
14
- imagePositioning: false
17
+ positioning: false
15
18
  });
16
19
  this.input('thumbnail_image_id', pageflow.FileInputView, {
20
+ collection: pageflow.imageFiles,
21
+ positioning: false
22
+ });
23
+ this.input('mobile_poster_image_id', pageflow.FileInputView, {
17
24
  collection: pageflow.imageFiles,
18
25
  imagePositioning: false
19
26
  });
@@ -15,18 +15,22 @@ pageflow.EditMetaDataView = Backbone.Marionette.Layout.extend({
15
15
  },
16
16
 
17
17
  onRender: function() {
18
+ var entry = this.model;
19
+
18
20
  var configurationEditor = new pageflow.ConfigurationEditorView({
19
- model: this.model
21
+ model: entry.configuration,
22
+ tab: this.options.tab
20
23
  });
21
24
 
22
25
  configurationEditor.tab('general', function() {
23
26
  this.input('title', pageflow.TextInputView);
24
- this.input('summary', pageflow.TextAreaInputView);
25
27
  this.input('credits', pageflow.TextAreaInputView);
26
28
  });
27
29
 
28
30
  configurationEditor.tab('widgets', function() {
29
31
  this.input('manual_start', pageflow.CheckBoxInputView);
32
+ this.input('emphasize_chapter_beginning', pageflow.CheckBoxInputView);
33
+ this.input('emphasize_new_pages', pageflow.CheckBoxInputView);
30
34
  this.input('home_button_enabled', pageflow.CheckBoxInputView, {
31
35
  disabled: !pageflow.theming.hasHomeButton(),
32
36
  displayUncheckedIfDisabled: true
@@ -37,6 +41,18 @@ pageflow.EditMetaDataView = Backbone.Marionette.Layout.extend({
37
41
  visibleBinding: 'home_button_enabled'
38
42
  });
39
43
  }
44
+ this.view(pageflow.EditWidgetsView, {
45
+ model: entry,
46
+ widgetTypes: pageflow.editor.widgetTypes
47
+ });
48
+ });
49
+
50
+ configurationEditor.tab('social', function() {
51
+ this.input('share_image_id', pageflow.FileInputView, {
52
+ collection: pageflow.imageFiles,
53
+ fileSelectionHandler: 'entryConfiguration'
54
+ });
55
+ this.input('summary', pageflow.TextAreaInputView);
40
56
  });
41
57
 
42
58
  this.formContainer.show(configurationEditor);
@@ -0,0 +1,29 @@
1
+ pageflow.EditWidgetView = Backbone.Marionette.Layout.extend({
2
+ template: 'templates/edit_widget',
3
+ tagName: 'li',
4
+ className: 'edit_widget',
5
+
6
+ regions: {
7
+ widgetTypeContainer: '.widget_type'
8
+ },
9
+
10
+ ui: {
11
+ role: 'h2'
12
+ },
13
+
14
+ onRender: function() {
15
+ var widgetTypes = this.options.widgetTypes[this.model.role()];
16
+
17
+ this.widgetTypeContainer.show(new pageflow.SelectInputView({
18
+ model: this.model,
19
+ propertyName: 'type_name',
20
+ label: I18n.t('pageflow.widgets.roles.' + this.model.role()),
21
+ collection: widgetTypes,
22
+ valueProperty: 'name',
23
+ translationKeyProperty: 'translationKey',
24
+ includeBlank: true
25
+ }));
26
+
27
+ this.$el.toggle(widgetTypes.length > 1);
28
+ }
29
+ });
@@ -0,0 +1,20 @@
1
+ pageflow.EditWidgetsView = Backbone.Marionette.Layout.extend({
2
+ template: 'templates/edit_widgets',
3
+
4
+ ui: {
5
+ widgets: '.widgets'
6
+ },
7
+
8
+ onRender: function() {
9
+ this.subview(new pageflow.CollectionView({
10
+ el: this.ui.widgets,
11
+ collection: this.model.widgets,
12
+ itemViewConstructor: pageflow.EditWidgetView,
13
+ itemViewOptions: {
14
+ widgetTypes: this.options.widgetTypes
15
+ }
16
+ }).render());
17
+
18
+ this.model.fetchWidgets();
19
+ }
20
+ });
@@ -10,9 +10,9 @@ pageflow.BackgroundImageEmbeddedView = Backbone.Marionette.View.extend({
10
10
 
11
11
  update: function() {
12
12
  this.$el.css({
13
- backgroundImage: 'url("' + this.model.getImageFileUrl(this.options.propertyName) + '")',
14
- backgroundPosition: this.model.getImageFilePosition(this.options.propertyName, 'x') + '% ' +
15
- this.model.getImageFilePosition(this.options.propertyName, 'y') + '%',
13
+ backgroundImage: this.imageValue(),
14
+ backgroundPosition: this.model.getFilePosition(this.options.propertyName, 'x') + '% ' +
15
+ this.model.getFilePosition(this.options.propertyName, 'y') + '%'
16
16
  });
17
17
 
18
18
  if (this.options.dataSizeAttributes) {
@@ -28,5 +28,10 @@ pageflow.BackgroundImageEmbeddedView = Backbone.Marionette.View.extend({
28
28
  }
29
29
  this.$el.css({backgroundPosition:'0 0'});
30
30
  }
31
+ },
32
+
33
+ imageValue: function() {
34
+ var url = this.model.getImageFileUrl(this.options.propertyName);
35
+ return url ? 'url("' + url + '")' : 'none';
31
36
  }
32
37
  });
@@ -5,11 +5,13 @@ pageflow.EntryPreviewView = Backbone.Marionette.ItemView.extend({
5
5
  ui: {
6
6
  header: '.header',
7
7
  entry: '.entry',
8
- navigation: '.navigation',
9
- navigationMobile: '.navigation_mobile',
10
8
  overview: '.overview'
11
9
  },
12
10
 
11
+ initialize: function() {
12
+ this.widgets = $();
13
+ },
14
+
13
15
  onRender: function() {
14
16
  this.pageViews = this.subview(new pageflow.CollectionView({
15
17
  el: this.ui.entry,
@@ -22,8 +24,8 @@ pageflow.EntryPreviewView = Backbone.Marionette.ItemView.extend({
22
24
 
23
25
  this.update();
24
26
 
25
- this.listenTo(pageflow.entry, 'sync:order', this.update);
26
- this.listenTo(pageflow.entry, 'change:credits change:home_url change:home_button_enabled', function() {
27
+ this.listenTo(pageflow.entry, 'sync:order sync:widgets', this.update);
28
+ this.listenTo(pageflow.entry, 'change:configuration', function() {
27
29
  pageflow.entry.once('sync', this.update, this);
28
30
  });
29
31
 
@@ -37,6 +39,7 @@ pageflow.EntryPreviewView = Backbone.Marionette.ItemView.extend({
37
39
 
38
40
  onShow: function() {
39
41
  var slideshow = pageflow.slides = new pageflow.Slideshow(this.ui.entry);
42
+ slideshow.update();
40
43
 
41
44
  this.listenTo(this.model.pages, 'add', function() {
42
45
  slideshow.update();
@@ -52,7 +55,24 @@ pageflow.EntryPreviewView = Backbone.Marionette.ItemView.extend({
52
55
 
53
56
  this.listenTo(pageflow.app, 'resize', function() {
54
57
  slideshow.triggerResizeHooks();
58
+ this.updateSimulatedMediaQueryClasses();
55
59
  });
60
+
61
+ this.updateSimulatedMediaQueryClasses();
62
+ },
63
+
64
+ updateSimulatedMediaQueryClasses: function() {
65
+ var width = this.$el.width();
66
+ var portrait = this.$el.width() < this.$el.height();
67
+
68
+ $('html')
69
+ .toggleClass('simulate_mobile', width <= 900)
70
+ .toggleClass('simulate_phone', width <= 700)
71
+ .toggleClass('simulate_desktop', width > 700)
72
+ .toggleClass('simulate_narrow_desktop', width <= 1200)
73
+ .toggleClass('simulate_wide_desktop', width > 1600)
74
+ .toggleClass('simulate_pad_portrait', width <= 768 && portrait)
75
+ .toggleClass('simulate_phone_portrait', width <= 500 && portrait);
56
76
  },
57
77
 
58
78
  update: function() {
@@ -62,18 +82,42 @@ pageflow.EntryPreviewView = Backbone.Marionette.ItemView.extend({
62
82
  var partials = $('<div />').html(response);
63
83
 
64
84
  view.ui.header.replaceWith(partials.find('.header'));
65
- view.ui.navigation.replaceWith(partials.find('.navigation'));
66
- view.ui.navigationMobile.replaceWith(partials.find('.navigation_mobile'));
67
85
  view.ui.overview.replaceWith(partials.find('.overview'));
68
-
69
86
  view.bindUIElements();
70
87
 
88
+ view.updateWidgets(partials);
89
+
71
90
  view.ui.header.header({
72
91
  slideshow: pageflow.slides
73
92
  });
74
- view.ui.navigation.navigation();
75
- view.ui.navigationMobile.navigationMobile();
76
93
  view.ui.overview.overview();
77
94
  });
95
+
96
+ this.$el.toggleClass('emphasize_chapter_beginning', !!this.model.configuration.get('emphasize_chapter_beginning'));
97
+ },
98
+
99
+ updateWidgets: function(partials) {
100
+ var widgets = partials.find('[data-widget]');
101
+ this.updatePresentWidgetsCssClasses(widgets);
102
+
103
+ this.widgets.remove();
104
+ this.widgets = widgets;
105
+ this.ui.entry.before(this.widgets);
106
+
107
+ pageflow.widgetTypes.enhance(this.$el);
108
+ },
109
+
110
+ updatePresentWidgetsCssClasses: function(newWidgets) {
111
+ var previousClasses = this.widgetNames(this.widgets);
112
+ var newClasses = this.widgetNames(newWidgets);
113
+
114
+ this.$el.removeClass(_.difference(previousClasses, newClasses).join(' '));
115
+ this.$el.addClass(newClasses.join(' '));
116
+ },
117
+
118
+ widgetNames: function(widgets) {
119
+ return widgets.map(function() {
120
+ return 'widget_' + $(this).data('widget') + '_present';
121
+ }).get();
78
122
  }
79
123
  });
@@ -37,7 +37,7 @@ pageflow.PageItemView = Backbone.Marionette.ItemView.extend({
37
37
  },
38
38
 
39
39
  _getPictogramTitle: function() {
40
- var result = I18n.t('activerecord.values.page.template.' + this.model.get('template'));
40
+ var result = I18n.t(this.model.pageType().translation_key);
41
41
  result += ' Seite';
42
42
 
43
43
  if (this.options.displayInNavigationHint && !this.model.configuration.get('display_in_navigation')) {
@@ -7,6 +7,8 @@ pageflow.PagePreviewView = Backbone.Marionette.View.extend({
7
7
 
8
8
  'change:configuration': 'update',
9
9
 
10
+ 'change:position': 'updateChapterBeginningClass',
11
+
10
12
  'sync': function() {
11
13
  this.$el.attr('data-id', this.model.id);
12
14
  this.$el.attr('data-perma-id', this.model.get('perma_id'));
@@ -31,6 +33,7 @@ pageflow.PagePreviewView = Backbone.Marionette.View.extend({
31
33
  this.$el.data('configuration', this.model.get('configuration'));
32
34
 
33
35
  this.$el.page();
36
+ this.updateChapterBeginningClass();
34
37
  this.update();
35
38
  this.$el.page('reactivate');
36
39
 
@@ -40,13 +43,13 @@ pageflow.PagePreviewView = Backbone.Marionette.View.extend({
40
43
  },
41
44
 
42
45
  updateTemplate: function() {
46
+ this.$el.page('cleanup');
47
+
43
48
  this.$el.html(this.pageTemplate());
44
- this.$el.attr('data-id', this.model.id);
45
- this.$el.attr('data-perma-id', this.model.get('perma_id'));
46
49
  this.$el.data('template', this.model.get('template'));
47
- this.$el.data('configuration', this.model.get('configuration'));
48
50
 
49
51
  this.$el.page('reinit');
52
+ this.updateChapterBeginningClass();
50
53
  this.update();
51
54
  this.$el.page('reactivate');
52
55
 
@@ -60,6 +63,11 @@ pageflow.PagePreviewView = Backbone.Marionette.View.extend({
60
63
  this.refreshScroller();
61
64
  },
62
65
 
66
+ updateChapterBeginningClass: function() {
67
+ var chapterBeginning = this.model.get('position') === 0;
68
+ this.$el.toggleClass('chapter_beginning', chapterBeginning);
69
+ },
70
+
63
71
  pageType: function() {
64
72
  return this.$el.data('pageType');
65
73
  },
@@ -0,0 +1 @@
1
+ pageflow.events = _.extend({}, Backbone.Events);
@@ -0,0 +1,8 @@
1
+ pageflow.features.add('hashchange support', function() {
2
+ var iOS = parseFloat(
3
+ ('' + (/CPU.*OS ([0-9_]{1,5})|(CPU like).*AppleWebKit.*Mobile/i.exec(navigator.userAgent) || [0,''])[1])
4
+ .replace('undefined', '3_2').replace('_', '.').replace('_', '')
5
+ ) || false;
6
+
7
+ return !(iOS >=8);
8
+ });
@@ -1,16 +1,28 @@
1
1
  pageflow.History = function(slideshow) {
2
2
  slideshow.on('slideshowchangepage', function() {
3
- window.location.hash = '#' + slideshow.currentPage().attr('id');
3
+ if(pageflow.features.has('hashchange support')) {
4
+ window.location.hash = '#' + slideshow.currentPage().attr('id');
5
+ }
4
6
  });
5
7
 
6
8
  $(window).on('hashchange', function() {
7
9
  slideshow.goToByPermaId(getHash());
8
10
  });
9
11
 
10
- slideshow.goToByPermaId(getHash());
12
+ slideshow.goToByPermaId(getPermaId());
11
13
 
12
14
  function getHash() {
13
15
  var match = window.location.href.match(/#(.*)$/);
14
16
  return match ? match[1] : '';
15
17
  }
18
+
19
+ function getPermaId() {
20
+ if (getHash().length) {
21
+ return getHash();
22
+ }
23
+ else {
24
+ var match = window.location.href.match(/page=([^&]*)/);
25
+ return match ? match[1] : '';
26
+ }
27
+ }
16
28
  };
@@ -26,7 +26,9 @@ pageflow.pageType.register('audio', _.extend({
26
26
  this.audioPlayer.readyPromise.then(function() {
27
27
  that.audioPlayer.volume(pageflow.settings.get('volume'));
28
28
  that.listenTo(pageflow.settings, "change:volume", function(model, value) {
29
- that.fadeSound(that.audioPlayer, value, 40);
29
+ that.audioPlayer.loadedPromise.then(function() {
30
+ that.fadeSound(that.audioPlayer, value, 40);
31
+ });
30
32
  });
31
33
  });
32
34
 
@@ -43,17 +45,22 @@ pageflow.pageType.register('audio', _.extend({
43
45
  },
44
46
 
45
47
  activated: function(pageElement, configuration) {
48
+ this.active = true;
46
49
  var that = this;
47
- if(!pageflow.features.has('mobile platform')) {
48
50
 
51
+ if(!pageflow.features.has('mobile platform')) {
49
52
  if (configuration.autoplay === false) {
50
53
  that.audioPlayer.volume(pageflow.settings.get('volume'));
51
54
  } else {
52
55
  this.fadeInTimeout = setTimeout(function() {
53
56
  that.audioPlayer.readyPromise.then(function() {
54
- that.audioPlayer.volume(0);
55
- that.audioPlayer.play();
56
- that.fadeSound(that.audioPlayer, pageflow.settings.get('volume'), 1000);
57
+ if (that.active) {
58
+ that.audioPlayer.volume(0);
59
+ that.audioPlayer.play();
60
+ that.audioPlayer.loadedPromise.then(function() {
61
+ that.fadeSound(that.audioPlayer, pageflow.settings.get('volume'), 1000);
62
+ });
63
+ }
57
64
  });
58
65
  }, 1000);
59
66
  }
@@ -61,8 +68,13 @@ pageflow.pageType.register('audio', _.extend({
61
68
  },
62
69
 
63
70
  deactivating: function(pageElement, configuration) {
71
+ this.active = false;
72
+ var that = this;
73
+
64
74
  clearTimeout(this.fadeInTimeout);
65
- this.fadeSound(this.audioPlayer, 0, 400);
75
+ this.audioPlayer.loadedPromise.then(function() {
76
+ that.fadeSound(that.audioPlayer, 0, 400);
77
+ });
66
78
  this.stopListening();
67
79
  $('body').off('keyup');
68
80
  },
@@ -26,27 +26,39 @@ pageflow.pageType.register('audio_loop', _.extend({
26
26
  this.audioPlayer.readyPromise.then(function() {
27
27
  that.audioPlayer.volume(pageflow.settings.get('volume'));
28
28
  that.listenTo(pageflow.settings, "change:volume", function(model, value) {
29
- that.fadeSound(that.audioPlayer, value, 40);
29
+ that.audioPlayer.loadedPromise.then(function() {
30
+ that.fadeSound(that.audioPlayer, value, 40);
31
+ });
30
32
  });
31
33
  });
32
34
  },
33
35
 
34
36
  activated: function(pageElement, configuration) {
37
+ this.active = true;
35
38
  var that = this;
39
+
36
40
  this.fadeInTimeout = setTimeout(function() {
37
41
  that.audioPlayer.readyPromise.then(function() {
38
- that.audioPlayer.volume(0);
39
- that.audioPlayer.play();
40
- that.fadeSound(that.audioPlayer, pageflow.settings.get('volume'), 1000);
42
+ if (that.active) {
43
+ that.audioPlayer.volume(0);
44
+ that.audioPlayer.play();
45
+ that.audioPlayer.loadedPromise.then(function() {
46
+ that.fadeSound(that.audioPlayer, pageflow.settings.get('volume'), 1000);
47
+ });
48
+ }
41
49
  });
42
50
  }, 1000);
43
51
  },
44
52
 
45
53
  deactivating: function(pageElement, configuration) {
54
+ this.active = false;
55
+ var that = this;
56
+
46
57
  clearTimeout(this.fadeInTimeout);
47
- this.fadeSound(this.audioPlayer, 0, 400);
58
+ this.audioPlayer.loadedPromise.then(function() {
59
+ that.fadeSound(that.audioPlayer, 0, 400);
60
+ });
48
61
  this.stopListening();
49
- $('body').off('keyup');
50
62
  },
51
63
 
52
64
  deactivated: function(pageElement, configuration) {
@@ -81,7 +93,7 @@ pageflow.pageType.register('audio_loop', _.extend({
81
93
  },
82
94
 
83
95
  _ensureAudioPlayer: function(pageElement) {
84
- this.audioPlayer = this.audioPlayer || pageflow.AudioPlayer.fromScriptTag(pageElement.find('script[data-audio]'));
96
+ this.audioPlayer = this.audioPlayer || pageflow.AudioPlayer.fromScriptTag(pageElement.find('script[data-audio]'), {loop: true});
85
97
 
86
98
  pageElement.find('.vjs-controls').playerControls({
87
99
  player: this.audioPlayer