promethee 1.6.63 → 1.7.0

Sign up to get free protection for your applications and to get access to all the features.
checksums.yaml CHANGED
@@ -1,7 +1,7 @@
1
1
  ---
2
2
  SHA256:
3
- metadata.gz: 3dce055f4fbf6044f645b3757c3af8508909aba98135a0520d507965a352b00e
4
- data.tar.gz: 4f08baf43ef9f60c33c3e8a0af21233ae09ada1a0d6d28328c2419ce23b8ca0f
3
+ metadata.gz: d615539201ed702b072e8759debef564b7b8981068fa650b672c12c393bd1c82
4
+ data.tar.gz: 61afe497a197687435124bbf7cd19a894ed8db353d2a73dda701e1f7e0f3f847
5
5
  SHA512:
6
- metadata.gz: 7f7a2677637a9272dad36623910f89ea874d94f45b992aa4da1731784e68e5337a42c8f64c8f7031aabdcb2e912c48f2f1c6b43e3fabbf5cb2d7e4372faf96da
7
- data.tar.gz: 81f4937b7b7a33cfc0424a14205a48528ea306142339943025812f5e9eaf2b337f982639b3e36d370d7d5dea7b51cc649f876128f8c1c879c3c725644d39b948
6
+ metadata.gz: e29fb2e45cbc23eac0e068ff7bcb54cd0dd535abae2e913d3a5ea3eca49c30d6002094de6165354d5914008e4bb173c25988f3866f204b69f3080ac1b84670bb
7
+ data.tar.gz: 5686ecc9dcd36ffde59f8746e69511e437c545e86c6214ca494f8b7ccb20682f02f7cf1e82910f9765dd988bee4c4afaef0d603222f22c5f1fe2aaf626db1dac
@@ -1,5 +1,5 @@
1
1
  <%
2
- promethee_data = Promethee::Data.new master_data
2
+ promethee_data = Promethee::Data::Master.new master_data
3
3
  preview_url ||= promethee_preview_path
4
4
  back_url ||= nil
5
5
  logo = File.read "#{__dir__}/../../assets/images/icon-promethee.svg"
@@ -1,16 +1,43 @@
1
1
  <%
2
- promethee_data = Promethee::Data.new master_data, localization_data: localization_data
2
+ promethee_data = Promethee::Data::Localization.new localization_data, master_data
3
+ promethee_masters_multiple = Promethee::Data::MastersMultiple.new master_data, other_data
3
4
  %>
4
5
 
5
6
  <script type="text/javascript">
6
7
  var promethee = angular
7
8
  .module('PrometheeLocalizer', ['summernote'])
8
- .value('data', <%= promethee_data.localization_data_to_json.html_safe %>)
9
9
  .filter('htmlSafe', ['$sce', function($sce) {
10
10
  return function(val) {
11
11
  return $sce.trustAsHtml(val);
12
12
  };
13
- }]);
13
+ }])
14
+ .service('mastersMultiple', function() {
15
+ var all = [];
16
+ var current;
17
+ return {
18
+ set: function(masters) {
19
+ this.all = masters;
20
+ this.current = this.all[0];
21
+ },
22
+ choose: function(master) {
23
+ this.current = master;
24
+ },
25
+ masterForComponent: function(component) {
26
+ var componentFound;
27
+ this.current.components.forEach(function(masterComponent) {
28
+ if (masterComponent.id === component.id) {
29
+ componentFound = masterComponent;
30
+ }
31
+ });
32
+ return componentFound;
33
+ },
34
+ multiple: function() {
35
+ return this.all.length > 1;
36
+ },
37
+ all: all,
38
+ current: current
39
+ };
40
+ });
14
41
  </script>
15
42
 
16
43
  <% promethee_util_partials.each do |partial| %>
@@ -18,13 +45,12 @@ promethee_data = Promethee::Data.new master_data, localization_data: localizatio
18
45
  <% end %>
19
46
 
20
47
  <script type="text/javascript">
21
- promethee.controller('PrometheeLocalizerController', ['$scope', 'summernoteConfig', 'data', function($scope, summernoteConfig, data) {
22
-
23
- $scope.data = data;
24
- $scope.component = {children: data.components};
25
-
48
+ promethee.controller('PrometheeLocalizerController',
49
+ ['$scope', 'summernoteConfig', 'mastersMultiple', function($scope, summernoteConfig, mastersMultiple) {
26
50
  $scope.summernoteConfig = summernoteConfig;
27
-
51
+ $scope.data = <%= promethee_data.to_json.html_safe %>;
52
+ $scope.masters = mastersMultiple;
53
+ $scope.masters.set(<%= promethee_masters_multiple.to_json.html_safe %>);
28
54
  $scope.$watch('data', function(new_val, old_val) {
29
55
  if (old_val != new_val) {
30
56
  document.body.classList.add("promethee-page-locked");
@@ -33,30 +59,32 @@ promethee_data = Promethee::Data.new master_data, localization_data: localizatio
33
59
  }]);
34
60
  </script>
35
61
 
36
-
37
-
38
62
  <div id="prometheeLocalizer"
39
- class="promethee-localizer"
63
+ class="promethee-localizer ng-cloak"
40
64
  ng-app="PrometheeLocalizer"
41
65
  ng-controller="PrometheeLocalizerController as prometheeLocalizerController">
42
66
 
43
67
  <script type="text/ng-template" id="promethee/localize/component">
68
+ <span class="hidden">{{ master = masters.masterForComponent(component) }}</span>
44
69
  <ng-include src="'promethee/components/' + component.type + '/localize'"></ng-include>
45
70
  </script>
46
71
 
47
72
  <input type="hidden" name="<%= object_name %>[<%= method_name %>]" id="page_data" value="{{data}}" />
48
73
 
49
74
  <% promethee_localize_partials.each do |partial| %>
50
- <%= render partial %>
75
+ <%= render partial %>
51
76
  <% end %>
52
77
 
53
- <% #TODO override templates from current project %>
54
-
55
78
  <div class="row">
56
- <div class="col-md-6"><b>Master</b></div>
79
+ <div class="col-md-6">
80
+ <b ng-hide="masters.multiple()">Master</b>
81
+ <select ng-show="masters.multiple()" ng-model="masters.current" class="form-control ignore-lock">
82
+ <option ng-repeat="master in masters.all" ng-value="master">{{master.title}}</option>
83
+ </select>
84
+ </div>
57
85
  <div class="col-md-6"><b>Translation</b></div>
58
86
  </div>
59
- <div ng-repeat="component in component.children">
87
+ <div ng-repeat="component in data.components">
60
88
  <ng-include src="'promethee/localize/component'"></ng-include>
61
89
  </div>
62
90
  </div>
@@ -1,5 +1,5 @@
1
1
  <%
2
- promethee_data = Promethee::Data.new master_data, localization_data: localization_data
2
+ promethee_data = Promethee::Data::MasterLocalized.new master_data, localization_data
3
3
  %>
4
4
  <div class="promethee" class="ng-cloak">
5
5
  <%= render 'promethee/show/component', component: promethee_data %>
@@ -4,7 +4,7 @@
4
4
  <div class="row">
5
5
  <div class="col-md-6">
6
6
  <b>Aside visible content</b>
7
- <div ng-bind-html="component.master.attributes.searchable_visible_content | htmlSafe"></div>
7
+ <div ng-bind-html="master.attributes.searchable_visible_content | htmlSafe"></div>
8
8
  </div>
9
9
  <div class="col-md-6">
10
10
  <div class="form-group">
@@ -14,10 +14,10 @@
14
14
  </div>
15
15
  </div>
16
16
 
17
- <div class="row" ng-show="component.master.attributes.searchable_collapsed_content">
17
+ <div class="row" ng-show="master.attributes.searchable_collapsed_content">
18
18
  <div class="col-md-6">
19
19
  <b>Aside collapsed content</b>
20
- <div ng-bind-html="component.master.attributes.searchable_collapsed_content | htmlSafe"></div>
20
+ <div ng-bind-html="master.attributes.searchable_collapsed_content | htmlSafe"></div>
21
21
  </div>
22
22
  <div class="col-md-6">
23
23
  <div class="form-group">
@@ -27,10 +27,10 @@
27
27
  </div>
28
28
  </div>
29
29
 
30
- <div class="row" ng-show="component.master.attributes.searchable_collapsed_content">
30
+ <div class="row" ng-show="master.attributes.searchable_collapsed_content">
31
31
  <div class="col-md-6">
32
32
  <b>Button label</b>
33
- <div ng-bind-html="component.master.attributes.searchable_open_label | htmlSafe"></div>
33
+ <div ng-bind-html="master.attributes.searchable_open_label | htmlSafe"></div>
34
34
  </div>
35
35
  <div class="col-md-6">
36
36
  <div class="form-group">
@@ -1,10 +1,10 @@
1
1
  <script type="text/ng-template" id="promethee/components/blockquote/localize">
2
- <div ng-show="component.master.attributes.searchable_body">
2
+ <div ng-show="master.attributes.searchable_body">
3
3
  <hr>
4
4
  <div class="row">
5
5
  <div class="col-md-6">
6
6
  <b>Body</b>
7
- <div ng-bind-html="component.master.attributes.searchable_body | htmlSafe"></div>
7
+ <div ng-bind-html="master.attributes.searchable_body | htmlSafe"></div>
8
8
  </div>
9
9
  <div class="col-md-6">
10
10
  <div class="form-group">
@@ -15,10 +15,10 @@
15
15
  </div>
16
16
  </div>
17
17
 
18
- <div class="row" ng-show="component.master.attributes.searchable_author">
18
+ <div class="row" ng-show="master.attributes.searchable_author">
19
19
  <div class="col-md-6">
20
20
  <b>Author</b>
21
- <p>{{component.master.attributes.searchable_author}}</p>
21
+ <p>{{master.attributes.searchable_author}}</p>
22
22
  </div>
23
23
  <div class="col-md-6">
24
24
  <div class="form-group">
@@ -1,10 +1,10 @@
1
1
  <script type="text/ng-template" id="promethee/components/collection_item/localize">
2
- <div ng-show="component.master.attributes.searchable_caption !== ''">
2
+ <div ng-show="master.attributes.searchable_caption !== ''">
3
3
  <hr>
4
4
  <div class="row">
5
5
  <div class="col-md-6">
6
6
  <b>Collection Item Caption</b>
7
- <div class="promethee-edit__wrapper" ng-bind-html="component.master.attributes.searchable_caption | htmlSafe"></div>
7
+ <div class="promethee-edit__wrapper" ng-bind-html="master.attributes.searchable_caption | htmlSafe"></div>
8
8
  </div>
9
9
  <div class="col-md-6">
10
10
  <label class="label-control">Collection Item Caption</label>
@@ -1,5 +1,5 @@
1
1
  <script type="text/ng-template" id="promethee/components/cover/localize">
2
- <div ng-show="component.master.attributes.searchable_surtitle || component.master.attributes.searchable_title || component.master.attributes.searchable_subtitle">
2
+ <div ng-show="master.attributes.searchable_surtitle || master.attributes.searchable_title || master.attributes.searchable_subtitle">
3
3
  <hr>
4
4
 
5
5
  <div class="row">
@@ -8,10 +8,10 @@
8
8
  </div>
9
9
  </div>
10
10
 
11
- <div class="row" ng-show="component.master.attributes.searchable_surtitle">
11
+ <div class="row" ng-show="master.attributes.searchable_surtitle">
12
12
  <div class="col-md-6">
13
13
  <b>Surtitle</b>
14
- <p>{{component.master.attributes.searchable_surtitle}}</p>
14
+ <p>{{master.attributes.searchable_surtitle}}</p>
15
15
  </div>
16
16
  <div class="col-md-6">
17
17
  <div class="form-group">
@@ -21,10 +21,10 @@
21
21
  </div>
22
22
  </div>
23
23
 
24
- <div class="row" ng-show="component.master.attributes.searchable_title">
24
+ <div class="row" ng-show="master.attributes.searchable_title">
25
25
  <div class="col-md-6">
26
26
  <b>Title</b>
27
- <p>{{component.master.attributes.searchable_title}}</p>
27
+ <p>{{master.attributes.searchable_title}}</p>
28
28
  </div>
29
29
  <div class="col-md-6">
30
30
  <div class="form-group">
@@ -34,10 +34,10 @@
34
34
  </div>
35
35
  </div>
36
36
 
37
- <div class="row" ng-show="component.master.attributes.searchable_subtitle">
37
+ <div class="row" ng-show="master.attributes.searchable_subtitle">
38
38
  <div class="col-md-6">
39
39
  <b>Subtitle</b>
40
- <p>{{component.master.attributes.searchable_subtitle}}</p>
40
+ <p>{{master.attributes.searchable_subtitle}}</p>
41
41
  </div>
42
42
  <div class="col-md-6">
43
43
  <div class="form-group">
@@ -1,10 +1,10 @@
1
1
  <script type="text/ng-template" id="promethee/components/faq_item/localize">
2
- <div ng-show="component.master.attributes.searchable_title">
2
+ <div ng-show="master.attributes.searchable_title">
3
3
  <hr>
4
4
  <div class="row">
5
5
  <div class="col-md-6">
6
6
  <b>Title</b>
7
- <p>{{component.master.attributes.searchable_title}}</p>
7
+ <p>{{master.attributes.searchable_title}}</p>
8
8
  </div>
9
9
  <div class="col-md-6">
10
10
  <div class="form-group">
@@ -16,7 +16,7 @@
16
16
  <div class="row">
17
17
  <div class="col-md-6">
18
18
  <b>Body</b>
19
- <p>{{component.master.attributes.searchable_body}}</p>
19
+ <p>{{master.attributes.searchable_body}}</p>
20
20
  </div>
21
21
  <div class="col-md-6">
22
22
  <div class="form-group">
@@ -1,5 +1,5 @@
1
1
  <script type="text/ng-template" id="promethee/components/image/localize">
2
- <div ng-show="component.master.attributes.searchable_alt || component.master.attributes.searchable_caption">
2
+ <div ng-show="master.attributes.searchable_alt || master.attributes.searchable_caption">
3
3
  <hr>
4
4
 
5
5
  <div class="row">
@@ -8,10 +8,10 @@
8
8
  </div>
9
9
  </div>
10
10
 
11
- <div class="row" ng-show="component.master.attributes.searchable_alt">
11
+ <div class="row" ng-show="master.attributes.searchable_alt">
12
12
  <div class="col-md-6">
13
13
  <b>Alt</b>
14
- <p>{{component.master.attributes.searchable_alt}}</p>
14
+ <p>{{master.attributes.searchable_alt}}</p>
15
15
  </div>
16
16
  <div class="col-md-6">
17
17
  <div class="form-group">
@@ -21,10 +21,10 @@
21
21
  </div>
22
22
  </div>
23
23
 
24
- <div class="row" ng-show="component.master.attributes.searchable_caption">
24
+ <div class="row" ng-show="master.attributes.searchable_caption">
25
25
  <div class="col-md-6">
26
26
  <b>Caption</b>
27
- <p>{{component.master.attributes.searchable_caption}}</p>
27
+ <p>{{master.attributes.searchable_caption}}</p>
28
28
  </div>
29
29
  <div class="col-md-6">
30
30
  <div class="form-group">
@@ -4,7 +4,7 @@
4
4
  <div class="row">
5
5
  <div class="col-md-6">
6
6
  <b>Page title</b>
7
- <p>{{component.master.attributes.searchable_title}}</p><br>
7
+ <p>{{master.attributes.searchable_title}}</p><br>
8
8
  </div>
9
9
  <div class="col-md-6">
10
10
  <div class="form-group">
@@ -14,11 +14,11 @@
14
14
  </div>
15
15
  </div>
16
16
 
17
- <div class="row" ng-show="component.master.attributes.searchable_description">
17
+ <div class="row" ng-show="master.attributes.searchable_description">
18
18
  <div class="col-md-6">
19
19
  <div>
20
20
  <b>Page description</b>
21
- <p>{{component.master.attributes.searchable_description}}</p>
21
+ <p>{{master.attributes.searchable_description}}</p>
22
22
  </div>
23
23
  </div>
24
24
  <div class="col-md-6">
@@ -1,10 +1,10 @@
1
1
  <script type="text/ng-template" id="promethee/components/slider_item/localize">
2
- <div ng-show="component.master.attributes.text !== ''">
2
+ <div ng-show="master.attributes.text !== ''">
3
3
  <hr>
4
4
  <div class="row">
5
5
  <div class="col-md-6">
6
6
  <b>Slider Item Caption</b>
7
- <div class="promethee-edit__wrapper" ng-bind-html="component.master.attributes.searchable_caption | htmlSafe"></div>
7
+ <div class="promethee-edit__wrapper" ng-bind-html="master.attributes.searchable_caption | htmlSafe"></div>
8
8
  </div>
9
9
  <div class="col-md-6">
10
10
  <label class="label-control">Slider Item Caption</label>
@@ -1,10 +1,10 @@
1
1
  <script type="text/ng-template" id="promethee/components/text/localize">
2
- <div ng-show="component.master.attributes.searchable_body">
2
+ <div ng-show="master.attributes.searchable_body">
3
3
  <hr>
4
4
  <div class="row">
5
5
  <div class="col-md-6">
6
6
  <b>Text</b>
7
- <div ng-bind-html="component.master.attributes.searchable_body | htmlSafe"></div>
7
+ <div ng-bind-html="master.attributes.searchable_body | htmlSafe"></div>
8
8
  </div>
9
9
  <div class="col-md-6">
10
10
  <b>Text</b>
@@ -22,4 +22,8 @@ module Promethee
22
22
  require 'promethee/core_ext/tags'
23
23
 
24
24
  require 'promethee/data'
25
+ require 'promethee/data/master'
26
+ require 'promethee/data/master_localized'
27
+ require 'promethee/data/masters_multiple'
28
+ require 'promethee/data/localization'
25
29
  end
@@ -16,13 +16,13 @@ module ActionView
16
16
  def render
17
17
  localization_data = object.send @method_name unless object.nil?
18
18
  localization_data = @options[:value] if @options.include? :value
19
- master_data = @options[:master]
20
19
  ApplicationController.renderer.render partial: 'promethee/localize',
21
20
  locals: {
22
21
  object_name: @object_name,
23
22
  method_name: @method_name,
24
23
  localization_data: localization_data,
25
- master_data: master_data
24
+ master_data: @options[:master],
25
+ other_data: @options[:other]
26
26
  }
27
27
  end
28
28
  end
@@ -1,104 +1,34 @@
1
- # The data class can be used for any level: the page, or one of the components
2
- module Promethee
3
- class Data
4
- def initialize(data, options = {})
5
- @master_data = hashify data
6
- @localization_data_raw = hashify(options[:localization_data]) if options.include? :localization_data
7
- check_master_integrity
8
- prepare_localization_data
9
- localize_master_data
10
- end
11
-
12
- def localization_data_to_json
13
- @localization_data.to_json
14
- end
15
-
16
- def to_json
17
- @master_data.to_json
18
- end
19
-
20
- # The data acts as a hash
21
- def [](value)
22
- @master_data[value]
23
- end
24
-
25
- protected
26
-
27
- def hashify(data)
28
- # https://github.com/bbatsov/ruby-style-guide#indent-conditional-assignment
29
- h = case data.class.to_s
30
- when 'Hash', 'ActiveSupport::HashWithIndifferentAccess' then data
31
- when 'String' then JSON.parse data
32
- else {}
33
- end
34
-
35
- h.deep_symbolize_keys
36
- end
37
-
38
- def check_master_integrity
39
- @master_data[:version] = 1 unless @master_data.include? :version
40
- @master_data[:children] = [] unless @master_data.include? :children
41
- end
42
-
43
- # We merge the localization data in the components from the master data.
44
- # This will :
45
- # 1 get what's already localized, based on the component id
46
- # 2 add new components
47
- # 3 remove components not in the master anymore
48
- # 4 take the order from the master
49
- def prepare_localization_data
50
- @localization_data = {
51
- version: @master_data[:version],
52
- components: []
53
- }
54
- # We create a flat list of the children and all their child, in the master's order
55
- master_components_flat = Promethee::Data.flatten_components @master_data.deep_dup
56
- master_components_flat.each do |component|
57
- localized_component = Promethee::Data.find_localized_component component[:id], @localization_data_raw
58
- # We take either the localized, or the master component
59
- data = localized_component || component
60
- # We add master reference
61
- data[:master] = component.deep_dup
62
- # We add it to the list of localized components
63
- @localization_data[:components] << data
64
- end
65
- end
1
+ class Promethee::Data
2
+ def initialize(data)
3
+ @data = hashify data
4
+ end
66
5
 
67
- # Recursively merge the localization_data into the master_data
68
- def localize_master_data
69
- Promethee::Data.localize_component @master_data, @localization_data
70
- end
6
+ def data
7
+ @data
8
+ end
71
9
 
72
- def self.find_localized_component(id, array)
73
- return nil if array.nil?
74
- return nil unless array.include? :components
75
- array[:components].find { |component| component[:id] == id }
76
- end
10
+ # The class creates a facade in front of the real hash, therefore include?, [] and to_json are delegated
11
+ def include?(value)
12
+ @data.include? value
13
+ end
77
14
 
78
- def self.localize_component(component, localization_data)
79
- localize_component_attributes component, localization_data
80
- localize_component_children component, localization_data
81
- end
15
+ def [](value)
16
+ @data[value]
17
+ end
82
18
 
83
- def self.localize_component_attributes(component, localization_data)
84
- return unless component.include? :attributes
85
- localized_component = Promethee::Data.find_localized_component component[:id], localization_data
86
- return if localized_component.nil?
87
- return unless localized_component.include? :attributes
88
- component[:attributes].merge! localized_component[:attributes]
89
- end
19
+ def to_json
20
+ @data.to_json
21
+ end
90
22
 
91
- def self.localize_component_children(component, localization_data)
92
- return unless component.include? :children
93
- component[:children].each { |child| localize_component child, localization_data }
94
- end
23
+ protected
95
24
 
96
- # Takes an array of components and puts every component and their children into a unique flat array
97
- def self.flatten_components(component)
98
- flat_components = [component.except(:children)]
99
- (component[:children] || []).reduce flat_components do |flat_components, component|
100
- flat_components + flatten_components(component)
101
- end
102
- end
25
+ def hashify(data)
26
+ # https://github.com/bbatsov/ruby-style-guide#indent-conditional-assignment
27
+ h = case data.class.to_s
28
+ when 'Hash', 'ActiveSupport::HashWithIndifferentAccess' then data
29
+ when 'String' then JSON.parse data
30
+ else {}
31
+ end
32
+ h.deep_symbolize_keys
103
33
  end
104
34
  end
@@ -0,0 +1,39 @@
1
+ class Promethee::Data::Localization < Promethee::Data
2
+ def initialize(data, master_data = nil)
3
+ super data
4
+ if master_data
5
+ @master_data = Master.new master_data
6
+ merge
7
+ end
8
+ end
9
+
10
+ protected
11
+
12
+ # We want to be up to date with the master, so this method will:
13
+ # 1.take the master's components flattened
14
+ # 2 substitute what's already localized, based on the component id
15
+ # Consequences of step 1 are:
16
+ # 1 it adds new components from the master
17
+ # 2 it removes components not in the master anymore
18
+ # 3 it takes the order from the master
19
+ def merge
20
+ @data_before_merge = @data.deep_dup
21
+ @data = {
22
+ version: @master_data[:version],
23
+ components: []
24
+ }
25
+ @master_data.flat.each do |master_component|
26
+ localized_component = find_localized_component master_component[:id]
27
+ # We take the localized component if it exists, the master component otherwise
28
+ component = localized_component || master_component
29
+ # We add it to the list of localized components
30
+ @data[:components] << component
31
+ end
32
+ end
33
+
34
+ def find_localized_component(id)
35
+ return unless @data_before_merge
36
+ return unless @data_before_merge.include? :components
37
+ @data_before_merge[:components].find { |component| component[:id] == id }
38
+ end
39
+ end
@@ -0,0 +1,25 @@
1
+ class Promethee::Data::Master < Promethee::Data
2
+ def initialize(data)
3
+ super data
4
+ fix_master_integrity
5
+ end
6
+
7
+ def flat
8
+ flatten_components @data
9
+ end
10
+
11
+ protected
12
+
13
+ def fix_master_integrity
14
+ @data[:version] = 1 unless @data.include? :version
15
+ @data[:children] = [] unless @data.include? :children
16
+ end
17
+
18
+ # Takes an array of components and puts every component and their children into a unique flat array
19
+ def flatten_components(component)
20
+ flat_components = [component.except(:children)]
21
+ (component[:children] || []).reduce flat_components do |flat_components, component|
22
+ flat_components + flatten_components(component)
23
+ end
24
+ end
25
+ end
@@ -0,0 +1,36 @@
1
+ # Injects localization data into master data, so the page can be showed in the correct localization
2
+ class Promethee::Data::MasterLocalized < Promethee::Data
3
+ def initialize(master, localization = nil)
4
+ @data = hashify master
5
+ if localization
6
+ @localization = Localization.new localization
7
+ localize_component @data
8
+ end
9
+ end
10
+
11
+ protected
12
+
13
+ def localize_component(component)
14
+ localize_component_attributes component
15
+ localize_component_children component
16
+ end
17
+
18
+ def localize_component_attributes(component)
19
+ return unless component.include? :attributes
20
+ localized_component = find_localized_component component[:id]
21
+ return unless localized_component
22
+ return unless localized_component.include? :attributes
23
+ component[:attributes].merge! localized_component[:attributes]
24
+ end
25
+
26
+ def localize_component_children(component)
27
+ return unless component.include? :children
28
+ component[:children].each { |child| localize_component child }
29
+ end
30
+
31
+ def find_localized_component(id)
32
+ return if @localization.nil?
33
+ return unless @localization.include? :components
34
+ @localization[:components].find { |component| component[:id] == id }
35
+ end
36
+ end
@@ -0,0 +1,21 @@
1
+ # List of master version and other localizations, flattened
2
+ class Promethee::Data::MastersMultiple < Promethee::Data
3
+ def initialize(master, localizations = nil)
4
+ @data = []
5
+ @master = Master.new master
6
+ title = 'Master'
7
+ components = @master.flat
8
+ add_data title, components
9
+ localizations.each do |key, value|
10
+ title = key
11
+ components = Localization.new(value, master).data[:components]
12
+ add_data title, components
13
+ end unless localizations.nil?
14
+ end
15
+
16
+ protected
17
+
18
+ def add_data(title, components)
19
+ @data << { title: title, components: components }
20
+ end
21
+ end
@@ -1,5 +1,5 @@
1
1
  module Promethee
2
2
  module Rails
3
- VERSION = '1.6.63'
3
+ VERSION = '1.7.0'
4
4
  end
5
5
  end
@@ -55,7 +55,7 @@
55
55
  max-height: 100%; }
56
56
 
57
57
  #fancybox-loading, .fancybox-close, .fancybox-prev span, .fancybox-next span {
58
- background-image: url(''); }
58
+ background-image: url("../img/fancybox_sprite.png"); }
59
59
 
60
60
  #fancybox-loading {
61
61
  position: fixed;
@@ -71,7 +71,7 @@
71
71
  #fancybox-loading div {
72
72
  width: 44px;
73
73
  height: 44px;
74
- background: url('') center center no-repeat; }
74
+ background: url("../img/fancybox_loading.gif") center center no-repeat; }
75
75
 
76
76
  .fancybox-close {
77
77
  position: absolute;
@@ -89,7 +89,7 @@
89
89
  height: 100%;
90
90
  cursor: pointer;
91
91
  text-decoration: none;
92
- background: transparent url('');
92
+ background: transparent url("../img/blank.gif");
93
93
  /* helps IE */
94
94
  -webkit-tap-highlight-color: transparent;
95
95
  z-index: 8040; }
@@ -147,7 +147,7 @@
147
147
  overflow: hidden;
148
148
  display: none;
149
149
  z-index: 8010;
150
- background: url(''); }
150
+ background: url("../img/fancybox_overlay.png"); }
151
151
 
152
152
  .fancybox-overlay-fixed {
153
153
  position: fixed;
@@ -213,10 +213,10 @@
213
213
  /*Retina graphics!*/
214
214
  @media only screen and (-webkit-min-device-pixel-ratio: 1.5), only screen and (min--moz-device-pixel-ratio: 1.5), only screen and (min-device-pixel-ratio: 1.5) {
215
215
  #fancybox-loading, .fancybox-close, .fancybox-prev span, .fancybox-next span {
216
- background-image: url('');
216
+ background-image: url("../img/fancybox_sprite@2x.png");
217
217
  background-size: 44px 152px;
218
218
  /*The size of the normal image, half the size of the hi-res image*/ }
219
219
  #fancybox-loading div {
220
- background-image: url('');
220
+ background-image: url("../img/fancybox_loading@2x.gif");
221
221
  background-size: 24px 24px;
222
222
  /*The size of the normal image, half the size of the hi-res image*/ } }
@@ -1,61 +1,32 @@
1
1
  {
2
- "_from": "fancybox",
3
- "_id": "fancybox@3.0.1",
4
- "_inBundle": false,
5
- "_integrity": "sha512-HZ57O6j5Zk4Uvusd5pNUgWi7CCjKx+HFlCzjMPeRJ//0bQWUK+xVpkn3EzXWJate4ZSKNFP9kU2l49MP1g+oow==",
6
- "_location": "/fancybox",
7
- "_phantomChildren": {},
8
- "_requested": {
9
- "type": "tag",
10
- "registry": true,
11
- "raw": "fancybox",
12
- "name": "fancybox",
13
- "escapedName": "fancybox",
14
- "rawSpec": "",
15
- "saveSpec": null,
16
- "fetchSpec": "latest"
17
- },
18
- "_requiredBy": [
19
- "#USER",
20
- "/"
21
- ],
22
- "_resolved": "https://registry.npmjs.org/fancybox/-/fancybox-3.0.1.tgz",
23
- "_shasum": "13f6927449157ed026c69e78c2ba5bf0f1da9af7",
24
- "_spec": "fancybox",
25
- "_where": "/mnt/SharedPart/WebApps/RailsProjects/promethee",
26
- "author": {
27
- "name": "fancyapps",
28
- "url": "https://github.com/fancyapps"
29
- },
30
- "bugs": {
31
- "url": "https://github.com/olsonpm/fancybox/issues"
32
- },
33
- "bundleDependencies": false,
34
- "deprecated": false,
2
+ "name": "fancybox",
3
+ "original-version": "2.1.5",
4
+ "version": "3.0.1",
35
5
  "description": "fancyBox is a tool that offers a nice and elegant way to add zooming functionality for images, html content and multi-media on your webpages. It is built on the top of the popular JavaScript framework jQuery and is both easy to implement and a snap to customize.",
36
- "devDependencies": {
37
- "chai": "^1.10.0",
38
- "jquery": "^2.1.3",
39
- "node-sass": "^2.0.0-beta",
40
- "phantomjs": "^1.9.13"
6
+ "main": "dist/js/jquery.fancybox.cjs.js",
7
+ "scripts": {
8
+ "test": "./node_modules/phantomjs/lib/phantom/bin/phantomjs ./test.js"
9
+ },
10
+ "repository": {
11
+ "type": "git",
12
+ "url": "https://github.com/olsonpm/fancybox.git"
41
13
  },
42
- "homepage": "https://github.com/olsonpm/fancybox",
43
14
  "keywords": [
44
15
  "fancybox",
45
16
  "fancy",
46
17
  "box",
47
18
  "lightbox"
48
19
  ],
20
+ "author": "fancyapps (https://github.com/fancyapps)",
49
21
  "license": "CC BY-NC 3.0 (http://creativecommons.org/licenses/by-nc/3.0/)",
50
- "main": "dist/js/jquery.fancybox.cjs.js",
51
- "name": "fancybox",
52
- "original-version": "2.1.5",
53
- "repository": {
54
- "type": "git",
55
- "url": "git+https://github.com/olsonpm/fancybox.git"
56
- },
57
- "scripts": {
58
- "test": "./node_modules/phantomjs/lib/phantom/bin/phantomjs ./test.js"
22
+ "bugs": {
23
+ "url": "https://github.com/olsonpm/fancybox/issues"
59
24
  },
60
- "version": "3.0.1"
25
+ "homepage": "https://github.com/olsonpm/fancybox",
26
+ "devDependencies": {
27
+ "chai": "^1.10.0",
28
+ "jquery": "^2.1.3",
29
+ "node-sass": "^2.0.0-beta",
30
+ "phantomjs": "^1.9.13"
31
+ }
61
32
  }
metadata CHANGED
@@ -1,7 +1,7 @@
1
1
  --- !ruby/object:Gem::Specification
2
2
  name: promethee
3
3
  version: !ruby/object:Gem::Version
4
- version: 1.6.63
4
+ version: 1.7.0
5
5
  platform: ruby
6
6
  authors:
7
7
  - Sébastien Gaya
@@ -14,7 +14,7 @@ authors:
14
14
  autorequire:
15
15
  bindir: bin
16
16
  cert_chain: []
17
- date: 2018-07-30 00:00:00.000000000 Z
17
+ date: 2018-07-31 00:00:00.000000000 Z
18
18
  dependencies:
19
19
  - !ruby/object:Gem::Dependency
20
20
  name: rails
@@ -305,6 +305,10 @@ files:
305
305
  - lib/promethee/core_ext/mapper.rb
306
306
  - lib/promethee/core_ext/tags.rb
307
307
  - lib/promethee/data.rb
308
+ - lib/promethee/data/localization.rb
309
+ - lib/promethee/data/master.rb
310
+ - lib/promethee/data/master_localized.rb
311
+ - lib/promethee/data/masters_multiple.rb
308
312
  - lib/promethee/rails/engine.rb
309
313
  - lib/promethee/rails/helper.rb
310
314
  - lib/promethee/rails/version.rb