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.
- checksums.yaml +8 -8
- data/Rakefile +2 -1
- data/admins/pageflow/accounts.rb +20 -4
- data/admins/pageflow/entry.rb +4 -5
- data/app/assets/javascripts/pageflow/audio_player.js +16 -7
- data/app/assets/javascripts/pageflow/base.js +5 -0
- data/app/assets/javascripts/pageflow/built_in_widget_types.js +11 -0
- data/app/assets/javascripts/pageflow/cookies.js +43 -0
- data/app/assets/javascripts/pageflow/editor/base.js +2 -10
- data/app/assets/javascripts/pageflow/editor/collections/widgets_collection.js +16 -0
- data/app/assets/javascripts/pageflow/editor/controllers/sidebar_controller.js +3 -2
- data/app/assets/javascripts/pageflow/editor/edit_widget.jst.ejs +2 -0
- data/app/assets/javascripts/pageflow/editor/initializers/setup_widget_types.js +3 -0
- data/app/assets/javascripts/pageflow/editor/models/configuration.js +18 -9
- data/app/assets/javascripts/pageflow/editor/models/edit_lock_container.js +1 -0
- data/app/assets/javascripts/pageflow/editor/models/entry.js +13 -3
- data/app/assets/javascripts/pageflow/editor/models/entry_configuration.js +4 -0
- data/app/assets/javascripts/pageflow/editor/models/entry_configuration_file_selection_handler.js +11 -0
- data/app/assets/javascripts/pageflow/editor/models/image_file.js +4 -0
- data/app/assets/javascripts/pageflow/editor/models/mixins/widget_subject.js +37 -0
- data/app/assets/javascripts/pageflow/editor/models/page.js +1 -1
- data/app/assets/javascripts/pageflow/editor/models/page_configuration_file_selection_handler.js +1 -25
- data/app/assets/javascripts/pageflow/editor/models/theming.js +3 -0
- data/app/assets/javascripts/pageflow/editor/models/video_file.js +7 -0
- data/app/assets/javascripts/pageflow/editor/models/widget.js +19 -0
- data/app/assets/javascripts/pageflow/editor/routers/sidebar_router.js +1 -0
- data/app/assets/javascripts/pageflow/editor/templates/background_positioning.jst.ejs +18 -0
- data/app/assets/javascripts/pageflow/editor/templates/background_positioning_preview.jst.ejs +2 -0
- data/app/assets/javascripts/pageflow/editor/templates/background_positioning_sliders.jst.ejs +6 -0
- data/app/assets/javascripts/pageflow/editor/templates/edit_meta_data.jst.ejs +1 -1
- data/app/assets/javascripts/pageflow/editor/templates/edit_widget.jst.ejs +2 -0
- data/app/assets/javascripts/pageflow/editor/templates/edit_widgets.jst.ejs +2 -0
- data/app/assets/javascripts/pageflow/editor/templates/entry_preview.jst.ejs +1 -3
- data/app/assets/javascripts/pageflow/editor/views/background_positioning_preview_view.js +39 -0
- data/app/assets/javascripts/pageflow/editor/views/background_positioning_sliders_view.js +94 -0
- data/app/assets/javascripts/pageflow/editor/views/background_positioning_view.js +67 -0
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/audio_loop.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_image.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/background_video.js +4 -3
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/internal_links.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/configuration_editors/video.js +9 -2
- data/app/assets/javascripts/pageflow/editor/views/edit_meta_data_view.js +18 -2
- data/app/assets/javascripts/pageflow/editor/views/edit_widget_view.js +29 -0
- data/app/assets/javascripts/pageflow/editor/views/edit_widgets_view.js +20 -0
- data/app/assets/javascripts/pageflow/editor/views/embedded/background_image_embedded_view.js +8 -3
- data/app/assets/javascripts/pageflow/editor/views/entry_preview_view.js +53 -9
- data/app/assets/javascripts/pageflow/editor/views/page_item_view.js +1 -1
- data/app/assets/javascripts/pageflow/editor/views/page_preview_view.js +11 -3
- data/app/assets/javascripts/pageflow/events.js +1 -0
- data/app/assets/javascripts/pageflow/features/hashchange_support.js +8 -0
- data/app/assets/javascripts/pageflow/history.js +14 -2
- data/app/assets/javascripts/pageflow/page_types/audio.js +18 -6
- data/app/assets/javascripts/pageflow/page_types/audio_loop.js +19 -7
- data/app/assets/javascripts/pageflow/page_types/background_video.js +41 -33
- data/app/assets/javascripts/pageflow/page_types/mixins/video_helpers.js +7 -16
- data/app/assets/javascripts/pageflow/ready.js +12 -25
- data/app/assets/javascripts/pageflow/slideshow.js +5 -5
- data/app/assets/javascripts/pageflow/slideshow/hide_text_on_swipe.js +1 -1
- data/app/assets/javascripts/pageflow/slideshow/page_widget.js +11 -1
- data/app/assets/javascripts/pageflow/slideshow/scroll_indicator_widget.js +19 -2
- data/app/assets/javascripts/pageflow/slideshow/scroller_widget.js +31 -6
- data/app/assets/javascripts/pageflow/slideshow/swipe_gesture.js +6 -5
- data/app/assets/javascripts/pageflow/ui.js +16 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/object.js +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/renderer.js +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/check_box.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/file_input.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/page_reference.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/select_input.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/slider_input.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/text_area_input.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/text_input.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/inputs/url_input.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/templates/tabs_view.jst.ejs +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/views/collection_view.js +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/views/configuration_editor_tab_view.js +8 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/configuration_editor_view.js +3 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/check_box_input_view.js +1 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/file_input_view.js +10 -8
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/page_reference_input_view.js +1 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/proxy_url_input_view.js +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/select_input_view.js +41 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/slider_input_view.js +1 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/text_area_input_view.js +1 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/text_input_view.js +8 -2
- data/app/assets/javascripts/pageflow/{editor → ui}/views/inputs/url_input_view.js +9 -3
- data/app/assets/javascripts/pageflow/{editor/views → ui/views/mixins}/input_view.js +5 -1
- data/app/assets/javascripts/pageflow/{editor → ui}/views/mixins/subview_container.js +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/views/sortable_collection_view.js +0 -0
- data/app/assets/javascripts/pageflow/{editor → ui}/views/tabs_view.js +11 -2
- data/app/assets/javascripts/pageflow/video_player/lazy.js +4 -1
- data/app/assets/javascripts/pageflow/visited.js +56 -0
- data/app/assets/javascripts/pageflow/widget_types.js +27 -0
- data/app/assets/javascripts/pageflow/widgets/events.js +33 -0
- data/app/assets/javascripts/pageflow/widgets/navigation.js +42 -33
- data/app/assets/javascripts/pageflow/widgets/navigation_mobile.js +60 -38
- data/app/assets/javascripts/pageflow/widgets/overview.js +3 -3
- data/app/assets/javascripts/pageflow/widgets/page_navigation_list.js +34 -4
- data/app/assets/javascripts/pageflow/widgets/share_menu.js +60 -0
- data/app/assets/stylesheets/pageflow/admin.css.scss +1 -0
- data/app/assets/stylesheets/pageflow/admin/tabs_view.css.scss +50 -0
- data/app/assets/stylesheets/pageflow/application_with_simulated_media_queries.css.scss +2 -0
- data/app/assets/stylesheets/pageflow/base.css.scss +2 -1
- data/app/assets/stylesheets/pageflow/editor/{image_positioning.css.scss → background_positioning.css.scss} +66 -65
- data/app/assets/stylesheets/pageflow/editor/base.css.scss +7 -5
- data/app/assets/stylesheets/pageflow/editor/file_thumbnails.css.scss +7 -9
- data/app/assets/stylesheets/pageflow/editor/select_button.css.scss +4 -4
- data/app/assets/stylesheets/pageflow/editor/widgets.css.scss +4 -0
- data/app/assets/stylesheets/pageflow/entries.css.scss +5 -0
- data/app/assets/stylesheets/pageflow/mixins/breakpoints.css.scss +75 -10
- data/app/assets/stylesheets/pageflow/multimedia_alert.css.scss +31 -30
- data/app/assets/stylesheets/pageflow/navigation_bar.css.scss +4 -0
- data/app/assets/stylesheets/pageflow/navigation_mobile.css.scss +57 -58
- data/app/assets/stylesheets/pageflow/player_controls.css.scss +2 -2
- data/app/assets/stylesheets/pageflow/slideshow.css.scss +4 -1
- data/app/assets/stylesheets/pageflow/subshare.css.scss +28 -0
- data/app/assets/stylesheets/pageflow/ui.css.scss +7 -0
- data/app/assets/stylesheets/pageflow/{editor → ui}/forms.css.scss +1 -0
- data/app/assets/stylesheets/pageflow/{editor → ui}/tabs_view.css.scss +1 -0
- data/app/controllers/pageflow/editor/widgets_controller.rb +39 -0
- data/app/controllers/pageflow/entries_controller.rb +10 -1
- data/app/helpers/pageflow/entries_helper.rb +7 -0
- data/app/helpers/pageflow/page_types_helper.rb +7 -7
- data/app/helpers/pageflow/pages_helper.rb +36 -5
- data/app/helpers/pageflow/social_share_helper.rb +54 -0
- data/app/helpers/pageflow/widgets_helper.rb +43 -0
- data/app/models/pageflow/draft_entry.rb +4 -1
- data/app/models/pageflow/entry.rb +1 -0
- data/app/models/pageflow/published_entry.rb +6 -3
- data/app/models/pageflow/revision.rb +5 -0
- data/app/models/pageflow/theming.rb +3 -0
- data/app/models/pageflow/widget.rb +74 -0
- data/app/views/admin/accounts/_form.html.erb +10 -0
- data/app/views/components/pageflow/admin/entries_tab.rb +22 -0
- data/app/views/components/pageflow/admin/members_tab.rb +35 -0
- data/app/views/components/pageflow/admin/revisions_tab.rb +51 -0
- data/app/views/components/pageflow/admin/tabs_view.rb +78 -0
- data/app/views/components/pageflow/admin/users_tab.rb +22 -0
- data/app/views/layouts/pageflow/application.html.erb +5 -5
- data/app/views/pageflow/editor/entries/_entry.json.jbuilder +7 -4
- data/app/views/pageflow/editor/files/_file.json.jbuilder +2 -2
- data/app/views/pageflow/editor/widgets/_widget.json.jbuilder +2 -0
- data/app/views/pageflow/editor/widgets/index.json.jbuilder +1 -0
- data/app/views/pageflow/entries/_entry.html.erb +6 -2
- data/app/views/pageflow/entries/_mobile_navigation.html.erb +56 -0
- data/app/views/pageflow/entries/_navigation.html.erb +3 -53
- data/app/views/pageflow/entries/edit.html.erb +2 -0
- data/app/views/pageflow/entries/navigation/_bar_top.html.erb +7 -3
- data/app/views/pageflow/entries/navigation/_page.html.erb +2 -2
- data/app/views/pageflow/entries/partials.html.erb +1 -1
- data/app/views/pageflow/entries/show.html.erb +12 -4
- data/app/views/pageflow/files/show.html.erb +5 -0
- data/app/views/pageflow/pages/templates/_audio_loop.html.erb +1 -1
- data/app/views/pageflow/pages/templates/_background_video.html.erb +2 -2
- data/app/views/pageflow/pages/templates/_video.html.erb +4 -3
- data/app/views/pageflow/{entries/_social_meta_tags.html.erb → social_share/_entry_meta_tags.html.erb} +2 -2
- data/app/views/pageflow/social_share/_image_tags.html.erb +3 -0
- data/app/views/pageflow/social_share/_page_meta_tags.html.erb +9 -0
- data/config/initializers/admin_resource_tabs.rb +7 -0
- data/config/initializers/paperclip.rb +1 -1
- data/config/initializers/view_components.rb +9 -1
- data/config/initializers/widget_types.rb +4 -0
- data/config/locales/activerecord.de.yml +5 -1
- data/config/locales/admin/tabs.de.yml +8 -0
- data/config/locales/editor.de.yml +5 -4
- data/config/locales/pageflow/editor/background_positioning.de.yml +13 -0
- data/config/locales/pageflow/ui.de.yml +6 -0
- data/config/locales/pageflow/widgets.de.yml +14 -0
- data/config/routes.rb +6 -0
- data/config/spring.rb +2 -1
- data/db/migrate/20141027102310_create_widgets.rb +11 -0
- data/db/migrate/20141028125408_add_emphasize_chapter_beginning_to_revisions.rb +5 -0
- data/db/migrate/20141119164526_add_emphasize_new_pages_to_revisions.rb +5 -0
- data/db/migrate/20141119174032_add_sharing_image_to_revisions.rb +7 -0
- data/lib/pageflow/ability_mixin.rb +2 -0
- data/lib/pageflow/admin/tabs.rb +18 -0
- data/lib/pageflow/built_in_widget_type.rb +27 -0
- data/lib/pageflow/configuration.rb +17 -0
- data/lib/pageflow/engine.rb +2 -0
- data/lib/pageflow/version.rb +1 -1
- data/lib/pageflow/widget_type.rb +52 -0
- data/lib/pageflow/widget_types.rb +50 -0
- data/spec/factories/audio_files.rb +1 -1
- data/spec/factories/chapters.rb +1 -1
- data/spec/factories/entries.rb +2 -2
- data/spec/factories/image_files.rb +1 -1
- data/spec/factories/video_files.rb +1 -1
- data/spec/factories/widgets.rb +6 -0
- data/vendor/assets/javascripts/audio5.min.js +3 -0
- metadata +104 -44
- data/app/assets/javascripts/pageflow/editor/templates/image_positioning.jst.ejs +0 -26
- data/app/assets/javascripts/pageflow/editor/views/image_positioning_view.js +0 -153
- data/app/views/admin/accounts/_entries_panel.html.arb +0 -15
- data/app/views/admin/accounts/_users_panel.html.arb +0 -15
- data/app/views/admin/entries/_members.html.arb +0 -29
- 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, {
|
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
|
-
|
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:
|
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
|
+
});
|
data/app/assets/javascripts/pageflow/editor/views/embedded/background_image_embedded_view.js
CHANGED
@@ -10,9 +10,9 @@ pageflow.BackgroundImageEmbeddedView = Backbone.Marionette.View.extend({
|
|
10
10
|
|
11
11
|
update: function() {
|
12
12
|
this.$el.css({
|
13
|
-
backgroundImage:
|
14
|
-
backgroundPosition: this.model.
|
15
|
-
this.model.
|
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:
|
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(
|
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
|
-
|
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(
|
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.
|
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.
|
55
|
-
|
56
|
-
|
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.
|
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.
|
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.
|
39
|
-
|
40
|
-
|
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.
|
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
|