j1-template 2021.1.2 → 2021.1.7

Sign up to get free protection for your applications and to get access to all the features.
Files changed (111) hide show
  1. checksums.yaml +4 -4
  2. data/_includes/themes/j1/layouts/layout_metadata_generator.html +23 -9
  3. data/_includes/themes/j1/modules/connectors/ad/google-adsense.html +7 -15
  4. data/_includes/themes/j1/modules/connectors/analytic/google-analytics.html +9 -5
  5. data/_includes/themes/j1/modules/navigator/generator.html +2 -2
  6. data/_includes/themes/j1/modules/navigator/procedures/topsearch.proc +2 -2
  7. data/_includes/themes/j1/procedures/posts/collate_timeline.proc +8 -7
  8. data/_layouts/default.html +4 -7
  9. data/assets/data/authclient.html +231 -229
  10. data/assets/data/banner.html +30 -32
  11. data/assets/data/cookieconsent.html +249 -0
  12. data/assets/data/fam.html +1 -1
  13. data/assets/data/footer.html +1 -1
  14. data/assets/data/gallery_customizer.html +10 -5
  15. data/assets/data/menu.html +3 -3
  16. data/assets/data/mmenu.html +4 -3
  17. data/assets/data/mmenu_sidebar.html +1 -1
  18. data/assets/data/mmenu_toc.html +1 -1
  19. data/assets/data/panel.html +11 -10
  20. data/assets/data/quicklinks.html +20 -18
  21. data/assets/data/themes.json +6 -6
  22. data/assets/themes/j1/adapter/js/{cookiebar.js → cookieConsent.js} +129 -55
  23. data/assets/themes/j1/adapter/js/j1.js +160 -151
  24. data/assets/themes/j1/adapter/js/justifiedGalleryCustomizer.js +3 -2
  25. data/assets/themes/j1/adapter/js/mmenu.js +8 -4
  26. data/assets/themes/j1/adapter/js/navigator.1.js +896 -0
  27. data/assets/themes/j1/adapter/js/navigator.2.js +928 -0
  28. data/assets/themes/j1/adapter/js/navigator.js +176 -209
  29. data/assets/themes/j1/adapter/js/themer.1.js +326 -0
  30. data/assets/themes/j1/adapter/js/themer.js +41 -57
  31. data/assets/themes/j1/adapter/js/toccer.js +4 -45
  32. data/assets/themes/j1/core/css/themes/uno-dark/bootstrap.css +17 -14
  33. data/assets/themes/j1/core/css/themes/uno-dark/bootstrap.min.css +1 -1
  34. data/assets/themes/j1/core/css/themes/uno-light/bootstrap.css +3859 -187
  35. data/assets/themes/j1/core/css/themes/uno-light/bootstrap.min.css +1 -1
  36. data/assets/themes/j1/core/js/template.js +3 -9
  37. data/assets/themes/j1/core/js/template.js.map +1 -1
  38. data/assets/themes/j1/core/js/template.min.js +3 -9
  39. data/assets/themes/j1/core/js/template.min.js.map +1 -1
  40. data/assets/themes/j1/modules/cookieConsent/LICENSE +21 -0
  41. data/assets/themes/j1/modules/cookieConsent/js/cookieConsent.js +286 -0
  42. data/assets/themes/j1/modules/cookieConsent/js/cookieConsent.min.js +28 -0
  43. data/assets/themes/j1/modules/fam/css/{uno → theme/uno}/fam.css +0 -0
  44. data/assets/themes/j1/modules/fam/css/theme/uno/fam.min.css +15 -0
  45. data/assets/themes/j1/modules/fam/js/fam.js +1 -6
  46. data/assets/themes/j1/modules/iframeResizer/examples/frame.absolute.html +4 -2
  47. data/assets/themes/j1/modules/iframeResizer/examples/frame.content.html +4 -3
  48. data/assets/themes/j1/modules/iframeResizer/examples/frame.hover.html +4 -2
  49. data/assets/themes/j1/modules/iframeResizer/examples/frame.nested.html +4 -2
  50. data/assets/themes/j1/modules/iframeResizer/examples/frame.textarea.html +4 -2
  51. data/assets/themes/j1/modules/iframeResizer/examples/frame.tolerance.html +4 -2
  52. data/assets/themes/j1/modules/iframeResizer/examples/index.html +2 -0
  53. data/assets/themes/j1/modules/iframeResizer/examples/two.html +4 -2
  54. data/assets/themes/j1/modules/mmenuLight/css/{mmenu.css → mmenu-light.css} +0 -0
  55. data/assets/themes/j1/modules/mmenuLight/css/{mmenu.min.css → mmenu-light.min.css} +0 -0
  56. data/assets/themes/j1/modules/mmenuLight/css/theme/{uno.css → uno/mmenu.css} +0 -0
  57. data/assets/themes/j1/modules/mmenuLight/css/theme/{uno.min.css → uno/mmenu.min.css} +0 -0
  58. data/assets/themes/j1/modules/rtable/css/theme/{uno.css → uno/rtable.css} +0 -0
  59. data/assets/themes/j1/modules/rtable/css/theme/{uno.min.css → uno/rtable.min.css} +0 -0
  60. data/assets/themes/j1/modules/themeSwitcher/js/switcher.js +33 -47
  61. data/assets/themes/j1/modules/themeSwitcher/js/switcher.min.js +410 -2
  62. data/assets/themes/j1/modules/util/js/domready.js +146 -0
  63. data/assets/themes/j1/modules/util/js/gtag-opt-in.js +1 -0
  64. data/lib/j1/version.rb +1 -1
  65. data/lib/j1_app/j1_auth_manager/auth_manager.rb +2 -3
  66. data/lib/starter_web/Gemfile +1 -1
  67. data/lib/starter_web/_config.yml +6 -5
  68. data/lib/starter_web/_data/_defaults/resources.yml +11 -8
  69. data/lib/starter_web/_data/apps/defaults/justifiedGalleryCustomizer.yml +1 -0
  70. data/lib/starter_web/_data/blocks/banner.yml +5 -3
  71. data/lib/starter_web/_data/blocks/panel.yml +9 -7
  72. data/lib/starter_web/_data/builder/blog_navigator.yml +1 -0
  73. data/lib/starter_web/_data/j1_config.yml +20 -17
  74. data/lib/starter_web/_data/layouts/default.yml +1 -1
  75. data/lib/starter_web/_data/layouts/home.yml +6 -5
  76. data/lib/starter_web/_data/layouts/page.yml +1 -1
  77. data/lib/starter_web/_data/modules/{cookiebar.yml → cookieconsent.yml} +4 -4
  78. data/lib/starter_web/_data/modules/defaults/authentication.yml +1 -0
  79. data/lib/starter_web/_data/modules/defaults/cookieconsent.yml +135 -0
  80. data/lib/starter_web/_data/modules/defaults/navigator.yml +5 -2
  81. data/lib/starter_web/_data/modules/defaults/themer.yml +2 -1
  82. data/lib/starter_web/_data/modules/navigator.yml +24 -21
  83. data/lib/starter_web/_data/pages/builder.yml +7 -7
  84. data/lib/starter_web/_data/private.default.yml +119 -0
  85. data/lib/starter_web/_data/private.yml +6 -6
  86. data/lib/starter_web/_data/resources.yml +15 -14
  87. data/lib/starter_web/_includes/attributes.asciidoc +10 -1
  88. data/lib/starter_web/_plugins/lunr_index.rb +1 -1
  89. data/lib/starter_web/assets/images/modules/attics/{cookies-1920x1200-bw.jpg → cookies-1920x1200.jpg} +0 -0
  90. data/lib/starter_web/assets/images/modules/attics/lianhao-1920x1280.jpg +0 -0
  91. data/lib/starter_web/collections/posts/public/featured/_posts/0000-00-00-welcome-to-j1.adoc.erb +3 -3
  92. data/lib/starter_web/collections/posts/public/featured/_posts/2020-01-01-about-cookies.adoc +4 -4
  93. data/lib/starter_web/collections/posts/public/featured/_posts/2021-03-01-site-generators.adoc +1 -7
  94. data/lib/starter_web/collections/posts/public/featured/_posts/2021-03-03-about-j1.adoc +2 -7
  95. data/lib/starter_web/dot.gitignore +1 -1
  96. data/lib/starter_web/index.html +1 -1
  97. data/lib/starter_web/package.json +1 -1
  98. data/lib/starter_web/pages/public/blog/navigator/archive.html +4 -3
  99. data/lib/starter_web/pages/public/blog/navigator/archive/categoryview.html +14 -8
  100. data/lib/starter_web/pages/public/blog/navigator/archive/dateview.html +11 -8
  101. data/lib/starter_web/pages/public/blog/navigator/archive/tagview.html +6 -5
  102. data/lib/starter_web/pages/public/cookieConsent.adoc +93 -0
  103. data/lib/starter_web/pages/public/learn/roundtrip/400_asciidoc_extensions.adoc +2 -1
  104. data/lib/starter_web/pages/public/legal/en/300_privacy.adoc +104 -209
  105. data/lib/starter_web/pages/public/panels/intro_panel/panel.adoc +6 -1
  106. data/lib/starter_web/utilsrv/_defaults/package.json +1 -1
  107. data/lib/starter_web/utilsrv/package.json +1 -1
  108. metadata +26 -15
  109. data/_includes/themes/j1/modules/navigator/generator.org.html +0 -232
  110. data/assets/data/cookiebar.html +0 -285
  111. data/lib/starter_web/_data/modules/defaults/cookiebar.yml +0 -132
@@ -152,8 +152,9 @@ j1.adapter['justifiedGalleryCustomizer'] = (function (j1, window) {
152
152
  // data loader
153
153
  // ---------------------------------------------------------------------
154
154
  j1.xhrData ({
155
- xhr_container_id: customizerOptions.xhr_container_id,
156
- xhr_data_path: customizerOptions.xhr_data_path },
155
+ xhr_container_id: customizerOptions.xhr_container_id,
156
+ xhr_data_path: customizerOptions.xhr_data_path,
157
+ xhr_data_element: customizerOptions.xhr_data_element },
157
158
  'j1.adapter.gallery_customizer',
158
159
  'null'
159
160
  );
@@ -209,13 +209,17 @@ j1.adapter['mmenu'] = (function (j1, window) {
209
209
  to
210
210
  {% if forloop.last %}'data_loaded'{% else %}'data_loaded'{% endif %}){% if forloop.last %}{% else %},{% endif %}
211
211
  -------------------------------------------------------------------------- {% endcomment %}
212
+
212
213
  {% for item in nav_mmenu_options.menus %} {% if item.menu.enabled %}
213
- {% assign menu_id = item.menu.xhr_container_id %}
214
- {% assign xhr_data_path = item.menu.xhr_data_path %}
214
+
215
+ {% assign menu_id = item.menu.xhr_container_id %}
216
+ {% assign xhr_data_path = item.menu.xhr_data_path %}
217
+ {% assign xhr_data_element = item.menu.xhr_data_element %}
215
218
 
216
219
  j1.xhrData ({
217
- xhr_container_id: '{{menu_id}}',
218
- xhr_data_path: '{{xhr_data_path}}'},
220
+ xhr_container_id: '{{menu_id}}',
221
+ xhr_data_path: '{{xhr_data_path}}',
222
+ xhr_data_element: '{{xhr_data_element}}' },
219
223
  'j1.adapter.mmenu',
220
224
  {% if forloop.last %}'data_loaded'{% else %}'null'{% endif %}){% if forloop.last %};{% else %};{% endif %}
221
225
 
@@ -0,0 +1,896 @@
1
+ ---
2
+ regenerate: true
3
+ ---
4
+
5
+ {% capture cache %}
6
+
7
+ {% comment %}
8
+ # -----------------------------------------------------------------------------
9
+ # ~/assets/themes/j1/adapter/js/navigator.js
10
+ # Liquid template to adapt Navigator Core functions
11
+ #
12
+ # Product/Info:
13
+ # https://jekyll.one
14
+ #
15
+ # Copyright (C) 2021 Juergen Adams
16
+ #
17
+ # J1 Template is licensed under the MIT License.
18
+ # For details, see https://jekyll.one
19
+ # -----------------------------------------------------------------------------
20
+ # Test data:
21
+ # {{ liquid_var | debug }}
22
+ # -----------------------------------------------------------------------------
23
+ # NOTE:
24
+ #
25
+ # JSON pretty print
26
+ # Example: var str = JSON.stringify(obj, null, 2); // spacing level = 2
27
+ # See: https://stackoverflow.com/questions/4810841/how-can-i-pretty-print-json-using-javascript
28
+ # -----------------------------------------------------------------------------
29
+ # NOTE:
30
+ # jadams, 2020-06-21:
31
+ # J1 Navigator needs a general revision on BS4 code and functionalities
32
+ # Current, only base function are tested with BS4 (was coded for BS3)
33
+ # -----------------------------------------------------------------------------
34
+ # NOTE:
35
+ # jadams, 2020-07-17:
36
+ # J1 Navigator can't be minfied for now. Uglifier fails on an ES6
37
+ # (most probably) structure that couldn't fixed by 'harmony' setting.
38
+ # Minifier fails by:
39
+ # Unexpected token: punc ())
40
+ # Current, minifying has been disabled
41
+ # -----------------------------------------------------------------------------
42
+ {% endcomment %}
43
+
44
+ {% comment %} Liquid procedures
45
+ -------------------------------------------------------------------------------- {% endcomment %}
46
+ {% capture select_color %}themes/{{site.template.name}}/procedures/global/select_color.proc{% endcapture %}
47
+
48
+ {% comment %} Set global settings
49
+ -------------------------------------------------------------------------------- {% endcomment %}
50
+ {% assign environment = site.environment %}
51
+ {% assign brand_image_height = site.brand.image_height %}
52
+
53
+ {% comment %} Process YML config data
54
+ ================================================================================ {% endcomment %}
55
+
56
+
57
+ {% comment %} Set config files
58
+ {% assign auth_manager_config = site.j1_auth %}
59
+ -------------------------------------------------------------------------------- {% endcomment %}
60
+ {% assign template_config = site.data.j1_config %}
61
+ {% assign blocks = site.data.blocks %}
62
+ {% assign modules = site.data.modules %}
63
+
64
+ {% assign themer_defaults = modules.defaults.themer.defaults %}
65
+ {% assign themer_settings = modules.themer.settings %}
66
+
67
+ {% assign authentication_defaults = modules.defaults.authentication.defaults %}
68
+ {% assign authentication_settings = modules.authentication.settings %}
69
+
70
+ {% assign template_config = site.data.template_settings %}
71
+ {% assign navigator_defaults = site.data.modules.defaults.navigator.defaults %}
72
+ {% assign navigator_settings = site.data.modules.navigator.settings %}
73
+
74
+ {% comment %} Set config data
75
+ -------------------------------------------------------------------------------- {% endcomment %}
76
+ {% assign nav_bar_defaults = navigator_defaults.nav_bar %}
77
+ {% assign nav_bar_settings = navigator_settings.nav_bar %}
78
+ {% assign nav_menu_defaults = navigator_defaults.nav_menu %}
79
+ {% assign nav_menu_settings = navigator_settings.nav_menu %}
80
+
81
+ {% assign nav_quicklinks_defaults = navigator_defaults.nav_quicklinks %}
82
+ {% assign nav_quicklinks_settings = navigator_settings.nav_quicklinks %}
83
+ {% assign nav_topsearch_defaults = navigator_defaults.nav_topsearch %}
84
+ {% assign nav_topsearch_settings = navigator_settings.nav_topsearch %}
85
+ {% assign nav_authclient_defaults = authentication_defaults.auth_client %}
86
+ {% assign nav_authclient_settings = authentication_settings.auth_client %}
87
+
88
+ {% comment %} Set config options
89
+ -------------------------------------------------------------------------------- {% endcomment %}
90
+ {% assign authentication_options = authentication_defaults | merge: authentication_settings %}
91
+ {% assign themer_options = themer_defaults | merge: themer_settings %}
92
+ {% assign nav_bar_options = nav_bar_defaults | merge: nav_bar_settings %}
93
+ {% assign nav_menu_options = nav_menu_defaults | merge: nav_menu_settings %}
94
+ {% assign quicklinks_options = nav_quicklinks_defaults | merge: nav_quicklinks_settings %}
95
+ {% assign topsearch_options = nav_topsearch_defaults | merge: nav_topsearch_settings %}
96
+ {% assign authclient_options = nav_authclient_defaults | merge: nav_authclient_settings %}
97
+
98
+ {% assign nav_bar_id = navigator_defaults.nav_bar.id %}
99
+ {% assign nav_menu_id = navigator_defaults.nav_menu.id %}
100
+ {% assign nav_quicklinks_id = navigator_defaults.nav_quicklinks.id %}
101
+ {% assign nav_navbar_media_breakpoint = navigator_defaults.nav_bar.media_breakpoint %}
102
+ {% assign authclient_modals_id = navigator_defaults.nav_authclient.xhr_container_id %}
103
+
104
+ {% if nav_bar_options.dropdown_animate_duration != null %}
105
+ {% assign animate_duration = nav_bar_options.dropdown_animate_duration %}
106
+ {% else %}
107
+ {% assign animate_duration = 1 %}
108
+ {% endif %}
109
+
110
+ {% assign production = false %}
111
+ {% if environment == 'prod' or environment == 'production' %}
112
+ {% assign production = true %}
113
+ {% endif %}
114
+
115
+ {% comment %}
116
+ --------------------------------------------------------------------------------
117
+ Set|Overload Liquid vars hardwired to NOT break the (MD) style
118
+ ToDo: Remove configuration from j1_navigator.yml
119
+ -------------------------------------------------------------------------------- {% endcomment %}
120
+ {% assign dropdown_border_height = "3" %}
121
+
122
+ /*
123
+ # -----------------------------------------------------------------------------
124
+ # ~/assets/themes/j1/adapter/js/navigator.js
125
+ # JS Adapter for J1 Navigator
126
+ #
127
+ # Product/Info:
128
+ # {{site.data.template_settings.theme_author_url}}
129
+ #
130
+ # Copyright (C) 2021 Juergen Adams
131
+ #
132
+ # J1 Template is licensed under the MIT License.
133
+ # For details, see {{site.data.template_settings.theme_author_url}}
134
+ # -----------------------------------------------------------------------------
135
+ # NOTE: For AJAX (XHR) loads see
136
+ # https://stackoverflow.com/questions/3709597/wait-until-all-jquery-ajax-requests-are-done
137
+ # -----------------------------------------------------------------------------
138
+ # NOTE: For getStyleValue helper see
139
+ # https://stackoverflow.com/questions/16965515/how-to-get-a-style-attribute-from-a-css-class-by-javascript-jquery
140
+ # -----------------------------------------------------------------------------
141
+ # Adapter generated: {{site.time}}
142
+ # -----------------------------------------------------------------------------
143
+ */
144
+
145
+ // -----------------------------------------------------------------------------
146
+ // ESLint shimming
147
+ // -----------------------------------------------------------------------------
148
+ /* eslint indent: "off" */
149
+ // -----------------------------------------------------------------------------
150
+ 'use strict';
151
+
152
+ j1.adapter['navigator'] = (function (j1, window) {
153
+
154
+ // ---------------------------------------------------------------------------
155
+ // globals
156
+ // ---------------------------------------------------------------------------
157
+ var environment = '{{environment}}';
158
+ var dclFinished = false;
159
+ var moduleOptions = {};
160
+
161
+ var nav_menu_id = '{{nav_menu_id}}';
162
+ var nav_quicklinks_id = '{{nav_quicklinks_id}}';
163
+
164
+ var authclient_modals_id = '{{authclient_modals_id}}';
165
+ var authclient_xhr_data_element = '{{authclient_options.xhr_data_element}}';
166
+ var authclient_modals_data_path = '{{authclient_options.xhr_data_path}}';
167
+
168
+ var nav_menu_data_path = '{{nav_menu_options.data_path}}';
169
+ var nav_quicklinks_data_path = '{{quicklinks_options.data_path}}';
170
+
171
+ var colors_data_path = '{{template_config.colors_data_path}}';
172
+ var font_size_data_path = '{{template_config.font_size_data_path}}';
173
+
174
+
175
+ var cookie_names = j1.getCookieNames();
176
+ var cookie_user_session_name = cookie_names.user_session;
177
+
178
+ var user_session = {};
179
+ var user_session_merged = {};
180
+ var session_state = {};
181
+
182
+ var themerEnabled = {{themer_options.enabled}}; //was (test): false;
183
+ var authClientEnabled;
184
+ var appDetected;
185
+ var json_data;
186
+ var _this;
187
+ var logger;
188
+ var logText;
189
+
190
+
191
+ // ---------------------------------------------------------------------------
192
+ // helper functions
193
+ // ---------------------------------------------------------------------------
194
+
195
+ // ---------------------------------------------------------------------------
196
+ // main object
197
+ // ---------------------------------------------------------------------------
198
+ return {
199
+
200
+ // -------------------------------------------------------------------------
201
+ // module initializer
202
+ // -------------------------------------------------------------------------
203
+ init: function (options) {
204
+
205
+ // -----------------------------------------------------------------------
206
+ // globals
207
+ // -----------------------------------------------------------------------
208
+ _this = j1.adapter.navigator;
209
+ logger = log4javascript.getLogger('j1.adapter.navigator');
210
+
211
+ // initialize state flag
212
+ _this.setState('started');
213
+ logger.info('state: ' + _this.getState());
214
+ logger.info('module is being initialized');
215
+
216
+ // -----------------------------------------------------------------------
217
+ // defaults
218
+ // -----------------------------------------------------------------------
219
+ var settings = $.extend({
220
+ module_name: 'j1.adapter.navigator',
221
+ generated: '{{site.time}}'
222
+ }, options);
223
+
224
+ // -----------------------------------------------------------------------
225
+ // options loader
226
+ // -----------------------------------------------------------------------
227
+ /* eslint-disable */
228
+ var authConfig = {};
229
+ var navDefaults = {};
230
+ var navBarConfig = {};
231
+ var navMenuConfig = {};
232
+ var navQuicklinksConfig = {};
233
+ var navTopsearchConfig = {};
234
+ var navAuthClientConfig = {};
235
+ var navBarOptions = {};
236
+ var navMenuOptions = {};
237
+ var navQuicklinksOptions = {};
238
+ var navTopsearchOptions = {};
239
+ var navAuthClientOptions = {};
240
+ var navAuthMAnagerConfig = {};
241
+
242
+ var user_state = {};
243
+ var cookie_names = j1.getCookieNames();
244
+ var cookie_user_state_name = cookie_names.user_state;
245
+
246
+ var themerOptions = {};
247
+ var interval_count = 0;
248
+ var user_state_detected;
249
+ var themes_count;
250
+ var max_count = 100;
251
+
252
+
253
+ navDefaults = $.extend({}, {{navigator_defaults | replace: '=>', ':' }});
254
+ navBarConfig = $.extend({}, {{nav_bar_options | replace: '=>', ':' }});
255
+ navMenuConfig = $.extend({}, {{nav_menu_options | replace: '=>', ':' }});
256
+ navQuicklinksConfig = $.extend({}, {{quicklinks_options | replace: '=>', ':' }});
257
+ navTopsearchConfig = $.extend({}, {{topsearch_options | replace: '=>', ':' }});
258
+ navAuthClientConfig = $.extend({}, {{authclient_options | replace: '=>', ':' }});
259
+
260
+ navAuthMAnagerConfig = $.extend({}, {{authentication_options | replace: '=>', ':' }});
261
+ authClientEnabled = navAuthMAnagerConfig.enabled;
262
+
263
+ themerOptions = $.extend({}, {{themer_options | replace: '=>', ':' | replace: 'nil', '""' }});
264
+
265
+ // Merge|Overload module CONFIG by DEFAULTS
266
+ //
267
+ navBarOptions = j1.mergeData(navBarConfig, navDefaults.nav_bar);
268
+ navMenuOptions = j1.mergeData(navMenuConfig, navDefaults.nav_menu);
269
+ navQuicklinksOptions = j1.mergeData(navQuicklinksConfig, navDefaults.nav_quicklinks);
270
+ navTopsearchOptions = j1.mergeData(navTopsearchConfig, navDefaults.nav_topsearch);
271
+ navAuthClientConfig = j1.mergeData(navAuthClientConfig, navDefaults.nav_authclient);
272
+
273
+ // save config settings into the adapter object for global access
274
+ //
275
+ _this['navDefaults'] = navDefaults;
276
+ _this['navBarOptions'] = navBarOptions;
277
+ _this['navMenuOptions'] = navMenuOptions;
278
+ _this['navQuicklinksOptions'] = navQuicklinksOptions;
279
+ _this['navTopsearchOptions'] = navTopsearchOptions;
280
+ _this['navAuthClientConfig'] = navAuthClientConfig;
281
+ _this['navAuthManagerConfig'] = navAuthMAnagerConfig;
282
+
283
+ // Load (individual) frontmatter options (currently NOT used)
284
+ if (options != null) { var frontmatterOptions = $.extend({}, options) }
285
+ /* eslint-enable */
286
+
287
+ // -----------------------------------------------------------------------
288
+ // Load HTML data (AJAX)
289
+ // -----------------------------------------------------------------------
290
+ // jadams, 202-06-24: Promise (chain) if $.when seems NOT to work correctly.
291
+ // It seems a chain using .then will be a better solution to make it sure
292
+ // that the last Deferred set the state to 'data_loaded'.
293
+ // Found the final state randomly set to 'null' what prevent the module
294
+ // to run mmenuInitializer.
295
+ // Workaround: Set 'data_loaded' to be returned by all Deferred in
296
+ // the chain.
297
+ // See: https://stackoverflow.com/questions/5436327/jquery-deferreds-and-promises-then-vs-done
298
+ // authclient_xhr_data_element
299
+ // -----------------------------------------------------------------------
300
+ // data loader
301
+ // -----------------------------------------------------------------------
302
+
303
+ j1.xhrData({
304
+ xhr_container_id: navQuicklinksOptions.xhr_container_id,
305
+ xhr_data_path: navQuicklinksOptions.xhr_data_path,
306
+ xhr_data_element: navQuicklinksOptions.xhr_data_element },
307
+ 'j1.adapter.navigator',
308
+ null);
309
+ j1.xhrData({
310
+ xhr_container_id: navAuthClientConfig.xhr_container_id,
311
+ xhr_data_path: navAuthClientConfig.xhr_data_path,
312
+ xhr_data_element: navAuthClientConfig.xhr_data_element },
313
+ 'j1.adapter.navigator',
314
+ null);
315
+ j1.xhrData({
316
+ xhr_container_id: navMenuOptions.xhr_container_id,
317
+ xhr_data_path: navMenuOptions.xhr_data_path,
318
+ xhr_data_element: navMenuOptions.xhr_data_element },
319
+ 'j1.adapter.navigator',
320
+ 'data_loaded');
321
+
322
+ var dependencies_met_load_menu_finished = setInterval (function () {
323
+ if (j1.xhrDOMState['#'+navQuicklinksOptions.xhr_container_id] == 'not loaded' ||
324
+ j1.xhrDOMState['#'+navAuthClientConfig.xhr_container_id] == 'not loaded' ||
325
+ j1.xhrDOMState['#'+navMenuOptions.xhr_container_id] == 'not loaded')
326
+ {
327
+ // load HTML data (AJAX) failed
328
+ logger.error('load HTML data (AJAX): failed');
329
+ _this.setState('finished');
330
+ logger.info('state: ' + _this.getState());
331
+ logger.info('initializing module: failed');
332
+ logger.info('met dependencies for: xhrData');
333
+ clearInterval(dependencies_met_load_menu_finished);
334
+ } else if (j1.xhrDOMState['#'+navQuicklinksOptions.xhr_container_id] == 'success' &&
335
+ j1.xhrDOMState['#'+navAuthClientConfig.xhr_container_id] == 'success' &&
336
+ j1.xhrDOMState['#'+navMenuOptions.xhr_container_id] == 'success' )
337
+ {
338
+ // AJAX loads (xhrData) has finished successfully
339
+ _this.setState('processing');
340
+ logger.info('status: ' + _this.getState());
341
+ logger.info('initialize navigator core');
342
+
343
+ // Detect|Set J1 App status
344
+ appDetected = j1.appDetected();
345
+ authClientEnabled = j1.authEnabled();
346
+ logger.info('application status detected: ' + appDetected);
347
+
348
+ j1.core.navigator.init (_this.navDefaults, _this.navMenuOptions);
349
+
350
+ // load themes (to menu) if themer is enabled
351
+ if (themerEnabled) {
352
+
353
+ logText = 'theme switcher: enabled';
354
+ logger.info(logText);
355
+
356
+ // Detect|Set J1 UserState
357
+ user_state_detected = j1.existsCookie(cookie_user_state_name);
358
+ if (user_state_detected) {
359
+ user_state = j1.readCookie(cookie_user_state_name);
360
+ }
361
+
362
+ logText = 'load themes';
363
+ logger.info(logText);
364
+
365
+ // load LOCAL themes from JSON data
366
+ logText = 'load local themes (json file)';
367
+ logger.info(logText);
368
+ $('#local_themes').bootstrapThemeSwitcher({
369
+ localFeed: themerOptions.localThemes
370
+ });
371
+
372
+ // load REMOTE themes from Bootswatch API (localFeed EMPTY!)
373
+ $('#remote_themes').bootstrapThemeSwitcher({
374
+ localFeed: '',
375
+ bootswatchApiVersion: themerOptions.bootswatchApiVersion
376
+ });
377
+
378
+ // jadams, 2021-04-22: Up to now, it is unclear why in some
379
+ // cases the menu bar is NOT fully loaded for THEMES
380
+ // TODO: Add additional checks to find the reason
381
+ var dependencies_met_remote_themes_loaded = setInterval(function() {
382
+ // jadams, 2021-07-03: check for themer get finished loading
383
+ interval_count += 1;
384
+ themes_count = document.getElementById("remote_themes").getElementsByTagName("li").length;
385
+ if ( themes_count > 0 ) {
386
+ logger.info('remote themes loaded: successfully');
387
+ logger.info('remote themes loaded: successfully after: ' + interval_count * 25 + ' ms');
388
+
389
+ clearInterval(dependencies_met_remote_themes_loaded);
390
+ } else {
391
+ logger.debug('wait for theme to be loaded: ' + user_state.theme_name);
392
+ }
393
+ if (interval_count > max_count) {
394
+ logger.warn('remote themes loading: failed');
395
+ logger.warn('continue processing');
396
+ clearInterval(dependencies_met_remote_themes_loaded);
397
+ }
398
+ clearInterval(dependencies_met_page_finished);
399
+ }, 25); // END dependencies_met_remote_themes_loaded
400
+ } else {
401
+ logger.info('theme switcher detected as: disabled');
402
+ } // END if themerEnabled
403
+
404
+ // -------------------------------------------------------------------
405
+ // event handler|css styles
406
+ // -------------------------------------------------------------------
407
+ // jadams, 2021-07-03: unclear why to wait for the themer ???
408
+ // continue to apply the theme CSS
409
+ if (themerEnabled) {
410
+ _this.setState('processing');
411
+
412
+ logger.info('initialize eventHandler');
413
+ j1.core.navigator.eventHandler();
414
+
415
+ logger.info('initializing dynamic CSS styles');
416
+ _this.setCSS (
417
+ navDefaults, navBarOptions, navMenuOptions,
418
+ navQuicklinksOptions, navTopsearchOptions
419
+ );
420
+
421
+ logger.info('init auth client');
422
+ _this.initAuthClient(_this.navAuthManagerConfig);
423
+
424
+ _this.setState('finished');
425
+ logger.info('state: ' + _this.getState());
426
+ logger.info('module initialized successfully');
427
+ logger.info('met dependencies for: j1');
428
+ clearInterval(dependencies_met_themer_finished);
429
+ } else {
430
+ _this.setState('processing');
431
+
432
+ logger.info('initialize eventHandler');
433
+ j1.core.navigator.eventHandler();
434
+
435
+ // set general|global theme colors
436
+ logger.info('apply dynamic CSS styles');
437
+ _this.setCSS (
438
+ navDefaults, navBarOptions, navMenuOptions,
439
+ navQuicklinksOptions, navTopsearchOptions
440
+ );
441
+
442
+ logger.info('init auth client');
443
+ _this.initAuthClient(_this.navAuthManagerConfig);
444
+ _this.setState('finished');
445
+ logger.info('state: ' + _this.getState());
446
+ clearInterval(dependencies_met_themer_finished);
447
+ }
448
+ } else {
449
+ // load HTML data (AJAX) failed for unknown reason
450
+ logger.error('initializing module: failed for unlnown reason');
451
+ _this.setState('finished');
452
+ logger.info('state: ' + _this.getState());
453
+ clearInterval(dependencies_met_load_menu_finished);
454
+ }
455
+ }, 25); // END dependencies_met_load_menu_finished
456
+
457
+ // -----------------------------------------------------------------------
458
+ // Register event 'reset on resize' to call j1.core.navigator on
459
+ // manageDropdownMenu to manage the (current) NAV menu for
460
+ // desktop or mobile
461
+ // -----------------------------------------------------------------------
462
+ $(window).on('resize', function() {
463
+ j1.core.navigator.manageDropdownMenu(navDefaults, navMenuOptions);
464
+
465
+ // jadams, 2020-07-10: cause severe trouble on mobile devices if
466
+ // OnScreen Kbd comes up and reduces the window size (resize event)
467
+ // DISABLED
468
+ // ---------------------------------------------------------------------
469
+ // Hide|Close topSearch on resize event
470
+ // $('.top-search').slideUp();
471
+
472
+ // Manage sticky NAV bars
473
+ setTimeout (function() {
474
+ j1.core.navigator.navbarSticky();
475
+ }, 500);
476
+
477
+ // Scroll the page one pixel back and forth to get
478
+ // the right position for Toccer (trigger) and SSM
479
+ $(window).scrollTop($(window).scrollTop()+1);
480
+ $(window).scrollTop($(window).scrollTop()-1);
481
+
482
+ // jadams, 2020-06-21: unclear|forgotten what I'm doing here!
483
+ // Looks like the old BS3 implementation
484
+ //
485
+ // $('.navbar-collapse').removeClass('in');
486
+ // $('.navbar-collapse').removeClass('on');
487
+ // $('.navbar-collapse').removeClass('bounceIn');
488
+ });
489
+ }, // END init
490
+
491
+ // -------------------------------------------------------------------------
492
+ // initialize JS portion for the dialogs (modals) used by J1AuthClient
493
+ // NOTE: Currently cookie updates NOT processed at the NAV module
494
+ // All updates on Cookies are managed by Cookie Consent.
495
+ // To be considered to re-add cookie updates for the auth state
496
+ // -------------------------------------------------------------------------
497
+ initAuthClient: function(auth_config) {
498
+ var logger = log4javascript.getLogger('j1.adapter.navigator.initAuthClient');
499
+ var user_session = j1.readCookie(cookie_user_session_name);
500
+
501
+ _this.modalEventHandler(auth_config);
502
+
503
+ if (j1.appDetected() && j1.authEnabled()) {
504
+ // Toggle/Set SignIn/SignOut icon|link in QuickLinks
505
+ // See: https://stackoverflow.com/questions/13524107/how-to-set-data-attributes-in-html-elements
506
+ if (user_session.authenticated === 'true') {
507
+ // Set SignOut
508
+ $('#navLinkSignInOut').attr('data-target', '#modalOmniSignOut');
509
+ $('#iconSignInOut').removeClass('mdi-login').addClass('mdi-logout');
510
+ } else {
511
+ // Set SignIn
512
+ $('#navLinkSignInOut').attr('data-target', '#modalOmniSignIn');
513
+ $('#iconSignInOut').removeClass('mdi-logout').addClass('mdi-login');
514
+ }
515
+ }
516
+
517
+ return true;
518
+ }, // END initAuthClient
519
+
520
+ // -------------------------------------------------------------------------
521
+ // modalEventHandler
522
+ // Manage button click events for all BS Modals
523
+ // See: https://www.nickang.com/add-event-listener-for-loop-problem-in-javascript/
524
+ // -------------------------------------------------------------------------
525
+ modalEventHandler: function (options) {
526
+ // var logger = log4javascript.getLogger('j1.adapter.navigator.EventHandler');
527
+ var authConfig = options.j1_auth;
528
+ var route;
529
+ var provider;
530
+ var provider_url;
531
+ var allowed_users;
532
+ var logText;
533
+
534
+ var signIn = {
535
+ provider: authConfig.providers.activated[0],
536
+ users: authConfig.providers[authConfig.providers['activated'][0]]['users'],
537
+ do: false
538
+ };
539
+
540
+ var signOut = {
541
+ provider: authConfig.providers.activated[0],
542
+ providerSignOut: false,
543
+ do: false
544
+ };
545
+
546
+ logText = 'initialize button click events';
547
+ logger.info(logText);
548
+
549
+ // Manage button click events for modal "signInOutButton"
550
+ // -----------------------------------------------------------------------
551
+ $('ul.nav-pills > li').click(function (e) {
552
+ e.preventDefault();
553
+ // jadams, 2019-07-30: To be checked if needed
554
+ signIn.provider = $(this).text().trim();
555
+ signIn.provider = signIn.provider.toLowerCase();
556
+ signIn.allowed_users = signIn.users.toString();
557
+ });
558
+
559
+ $('a.btn').click(function() {
560
+ if (this.id === 'signInButton') {
561
+ signIn.do = true;
562
+ } else {
563
+ signIn.do = false;
564
+ }
565
+ if (this.id === 'signOutButton') {
566
+ signOut.do = true;
567
+ } else {
568
+ signOut.do = false;
569
+ }
570
+ });
571
+
572
+ $('input:checkbox[name="providerSignOut"]').on('click', function (e) {
573
+ e.stopPropagation();
574
+ signOut.providerSignOut = $('input:checkbox[name="providerSignOut"]').is(':checked');
575
+ if(environment === 'development') {
576
+ logText = 'provider signout set to: ' + signOut.providerSignOut;
577
+ logger.info(logText);
578
+ }
579
+ });
580
+
581
+ // Manage pre events on modal "modalOmniSignIn"
582
+ // -----------------------------------------------------------------------
583
+ $('#modalOmniSignOut').on('show.bs.modal', function() {
584
+ var modal = $(this);
585
+ logger.info('place current user data');
586
+ user_session = j1.readCookie(cookie_user_session_name);
587
+ modal.find('.user-info').text('You are signed in to provider: ' + user_session.provider);
588
+ }); // END SHOW modalOmniSignOut
589
+
590
+ // Manage post events on modal "modalOmniSignIn"
591
+ // -----------------------------------------------------------------------
592
+ $('#modalOmniSignIn').on('hidden.bs.modal', function() {
593
+ if (signIn.do == true) {
594
+ provider = signIn.provider.toLowerCase();
595
+ allowed_users = signIn.users.toString();
596
+ logText = 'provider detected: ' + provider;
597
+ logger.info(logText);
598
+
599
+ var route = '/authentication?request=signin&provider=' +provider+ '&allowed_users=' +allowed_users;
600
+ logText = 'call middleware for signin on route: ' + route;
601
+ logger.info(logText);
602
+ window.location.href = route;
603
+ } else {
604
+ provider = signIn.provider.toLowerCase();
605
+ logText = 'provider detected: ' + provider;
606
+ logger.info(logText);
607
+ logText = 'login declined for provider: ' +provider;
608
+ logger.info(logText);
609
+ }
610
+ }); // END post events "modalOmniSignIn"
611
+
612
+ // Manage post events on modal "modalOmniSignOut"
613
+ // -----------------------------------------------------------------------
614
+ $('#modalOmniSignOut').on('hidden.bs.modal', function() {
615
+ if (signOut.do == true) {
616
+ logger.info('load active provider from cookie: ' + cookie_user_session_name);
617
+
618
+ user_session = j1.readCookie(cookie_user_session_name);
619
+ provider = user_session.provider;
620
+ provider_url = user_session.provider_site_url;
621
+
622
+ logText = 'provider detected: ' + provider;
623
+ logger.info(logText);
624
+ logText = 'initiate signout for provider: ' +provider;
625
+ logger.info(logText);
626
+
627
+ var route = '/authentication?request=signout&provider=' + provider + '&provider_signout=' + signOut.providerSignOut; // + '/logout/';
628
+ logText = 'call middleware on route : ' +route;
629
+ logger.info(logText);
630
+ window.location.href = route;
631
+ } else {
632
+ provider = signOut.provider.toLowerCase();
633
+ logText = 'provider detected: ' + provider;
634
+ logger.info(logText);
635
+ logText = 'signout declined for provider: ' +provider ;
636
+ logger.info(logText);
637
+ }
638
+ }); // END post events "modalSignOut"
639
+
640
+ logText = 'initialize button click events completed';
641
+ logger.info(logText);
642
+
643
+ return true;
644
+ }, // END modalEventHandler
645
+
646
+ // -------------------------------------------------------------------------
647
+ // setCSS
648
+ // Set dynamic CSS styles
649
+ // -------------------------------------------------------------------------
650
+ setCSS: function (navDefaults, navBarOptions, navMenuOptions, navQuicklinksOptions, navTopsearchOptions) {
651
+ var logger = log4javascript.getLogger('j1.adapter.navigator.setCSS');
652
+ var gridBreakpoint_lg = '992px';
653
+ var gridBreakpoint_md = '768px';
654
+ var gridBreakpoint_sm = '576px';
655
+ var navPrimaryColor = navDefaults.nav_primary_color;
656
+
657
+ {% comment %} Set|Resolve navMenuOptions
658
+ -------------------------------------------------------------------------- {% endcomment %}
659
+ navMenuOptions.dropdown_font_size = navMenuOptions.dropdown_font_size;
660
+ navMenuOptions.megamenu_font_size = navMenuOptions.megamenu_font_size;
661
+
662
+ {% comment %} Set|Resolve navBarOptions
663
+ -------------------------------------------------------------------------- {% endcomment %}
664
+ navBarOptions.background_color_full = navBarOptions.background_color_full;
665
+
666
+ {% comment %} Set|Resolve navMenuOptions
667
+ -------------------------------------------------------------------------- {% endcomment %}
668
+ navMenuOptions.menu_item_color = navMenuOptions.menu_item_color;
669
+ navMenuOptions.menu_item_color_hover = navMenuOptions.menu_item_color_hover;
670
+ navMenuOptions.menu_item_dropdown_color = navMenuOptions.menu_item_dropdown_color;
671
+ navMenuOptions.dropdown_item_color = navMenuOptions.dropdown_item_color;
672
+ navMenuOptions.dropdown_background_color_hover = navMenuOptions.dropdown_background_color_hover;
673
+ navMenuOptions.dropdown_background_color_active = navMenuOptions.dropdown_background_color_active;
674
+ navMenuOptions.dropdown_border_color = navMenuOptions.dropdown_border_color;
675
+
676
+ {% comment %} Set|Resolve navQuicklinksOptions
677
+ -------------------------------------------------------------------------- {% endcomment %}
678
+ navQuicklinksOptions.icon_color = navQuicklinksOptions.icon_color;
679
+ navQuicklinksOptions.icon_color_hover = navQuicklinksOptions.icon_color_hover;
680
+ navQuicklinksOptions.background_color = navQuicklinksOptions.background_color;
681
+
682
+ {% comment %} Set|Resolve navTopsearchOptions
683
+ -------------------------------------------------------------------------- {% endcomment %}
684
+ navTopsearchOptions.input_color = navTopsearchOptions.input_color;
685
+ navTopsearchOptions.background_color = navTopsearchOptions.background_color;
686
+
687
+ {% comment %} Set dymanic styles
688
+ -------------------------------------------------------------------------- {% endcomment %}
689
+ // $('nav-primary').css({"background-color": "navPrimaryColor"});
690
+
691
+
692
+ {% comment %} navBar styles
693
+ -------------------------------------------------------------------------- {% endcomment %}
694
+ var bg_primary = j1.getStyleValue('bg-primary', 'background-color');
695
+ var bg_scrolled = bg_primary;
696
+ var bg_collapsed = bg_primary;
697
+
698
+ $('head').append('<style>.mdi-bg-primary {color: ' +bg_scrolled+ ';}</style>');
699
+
700
+ // Size of brand image
701
+ $('head').append('<style>.navbar-brand > img { height: {{brand_image_height}}px !important; }</style>');
702
+
703
+ // Navbar transparent-light (light)
704
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator.navbar-transparent.light { background-color: ' +navBarOptions.background_color_full+ ' !important; border-bottom: solid 0px !important; } }</style>');
705
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator.navbar-scrolled.light { background-color: ' +bg_scrolled+ ' !important; } }</style>');
706
+
707
+ $('head').append('<style id="dynNav">@media (max-width: ' +gridBreakpoint_md+ ') { nav.navbar.navigator.navbar-transparent.light { background-color: ' +navBarOptions.background_color_full+ ' !important; border-bottom: solid 0px !important; } }</style>');
708
+ $('head').append('<style id="dynNav">@media (max-width: ' +gridBreakpoint_md+ ') { nav.navbar.navigator.navbar-scrolled.light { background-color: ' +bg_scrolled+ ' !important; } }</style>');
709
+ $('head').append('<style id="dynNav">@media (min-width: ' +gridBreakpoint_md+ ') { nav.navbar.navigator.navbar-transparent.light { background-color: ' +navBarOptions.background_color_full+ ' !important; border-bottom: solid 0px !important; } }</style>');
710
+ $('head').append('<style id="dynNav">@media (min-width: ' +gridBreakpoint_md+ ') { nav.navbar.navigator.navbar-scrolled.light { background-color: ' +bg_scrolled+ ' !important; } }</style>');
711
+
712
+ $('head').append('<style id="dynNav">@media (max-width: ' +gridBreakpoint_sm+ ') { nav.navbar.navigator.navbar-transparent.light { background-color: ' +navBarOptions.background_color_full+ ' !important; border-bottom: solid 0px !important; } }</style>');
713
+ $('head').append('<style id="dynNav">@media (max-width: ' +gridBreakpoint_sm+ ') { nav.navbar.navigator.navbar-scrolled.light { background-color: ' +bg_scrolled+ ' !important; } }</style>');
714
+
715
+ {% comment %} navQuicklinks styles
716
+ -------------------------------------------------------------------------- {% endcomment %}
717
+ $('head').append('<style>.attr-nav> ul > li > a { color: ' +navQuicklinksOptions.icon_color+ ' !important; }</style>');
718
+ $('head').append('<style>.attr-nav> ul > li > a:hover { color: ' +navQuicklinksOptions.icon_color_hover+ ' !important; }</style>');
719
+
720
+ {% comment %} navMenu styles
721
+ -------------------------------------------------------------------------- {% endcomment %}
722
+ // Remove background for anchor
723
+ $('head').append('<style>.dropdown-menu > .active > a { background-color: transparent !important; }</style>');
724
+ // hover menu-item|menu-sub-item
725
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator .dropdown-item:focus, nav.navbar.navigator .dropdown-item:hover, nav.navbar.navigator .nav-sub-item:focus, nav.navbar.navigator .nav-sub-item:hover { background: ' +navMenuOptions.dropdown_background_color_hover+ ' !important; }}</style>');
726
+
727
+ // Limit 1st dropdown item width
728
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator ul.nav.navbar-right .dropdown-menu .dropdown-menu { left: -' +navMenuOptions.dropdown_item_min_width+ 'rem !important; } }</style>');
729
+
730
+ // Limit last (2nd) dropdown in height (nav.navbar.navigator li.dropdown ul.dropdown-menu ul.dropdown-menu)
731
+ // !important
732
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator li.dropdown ul.dropdown-menu ul.dropdown-menu { top: -' +navMenuOptions.dropdown_border_top+ 'px !important; max-height: ' +navMenuOptions.dropdown_menu_max_height+ 'em; } }</style>');
733
+
734
+ // Set dropdown item colors
735
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator ul.nav > li > a { color: ' +navMenuOptions.menu_item_color+ ' !important; } }</style>');
736
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator ul.nav > li > a:hover { color: ' +navMenuOptions.menu_item_color_hover+ ' !important; } }</style>');
737
+
738
+ // Dropdown menu styles
739
+ // jadams, 2017-11-30: removed left padding from dropdown mwenu (for new j1nav style based on Navigator|Slate)
740
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator li.dropdown ul.dropdown-menu { animation-duration: ' +navMenuOptions.dropdown_animate_duration+ 's !important; color: ' +bg_scrolled+ ' !important; min-width: ' +navMenuOptions.dropdown_item_min_width+ 'rem !important; border-top: solid ' +navMenuOptions.dropdown_border_top+ 'px !important; border-radius: ' +navMenuOptions.dropdown_border_radius+ 'px !important; left: 0; } }</style>');
741
+
742
+ {% if dropdown_style == 'raised' %}
743
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator li.dropdown ul.dropdown-menu { box-shadow: 0 16px 38px -12px rgba(0, 0, 0, 0.56), 0 4px 25px 0px rgba(0, 0, 0, 0.12), 0 8px 10px -5px rgba(0, 0, 0, 0.2) !important; } }</style>');
744
+ {% endif %}
745
+
746
+ // jadams, 2017-11-22: configure dropdown_font_size|color
747
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator li.dropdown ul.dropdown-menu > li > a { color: ' +navMenuOptions.dropdown_item_color+ ' !important; font-size: ' +navMenuOptions.dropdown_font_size+ ' !important; font-weight: 400; } }</style>');
748
+ $('head').append('<style>@media (min-width: ' +gridBreakpoint_lg+ ') { nav.navbar.navigator ul.dropdown-menu.megamenu-content .content ul.menu-col li a { color: ' +navMenuOptions.dropdown_item_color+ ' !important; font-size: ' +navMenuOptions.megamenu_font_size+ ' !important; font-weight: 400; } }</style>');
749
+
750
+ {% comment %} navQuicklinks styles
751
+ -------------------------------------------------------------------------- {% endcomment %}
752
+
753
+ {% comment %} navTopSearch Styles
754
+ -------------------------------------------------------------------------- {% endcomment %}
755
+ // jadams, 2020-07-08: disabled because colors for icons set by the icon font settings
756
+ // $('head').append('<style>.top-search .input-group-addon { color: ' +navTopsearchOptions.input_color+ ' !important; }</style>');
757
+ $('head').append('<style>.top-search { background-color: ' +navTopsearchOptions.background_color+ ' !important; }</style>');
758
+ $('head').append('<style>.top-search input.form-control { color: ' +navTopsearchOptions.input_color+ ' !important; }</style>');
759
+
760
+ {% comment %} Timeline styles
761
+ -------------------------------------------------------------------------- {% endcomment %}
762
+ $('head').append('<style>.timeline > li > .timeline-panel:after {border-right-color: ' +bg_scrolled+ '; border-left-color: ' +bg_scrolled+ ';}</style>');
763
+ $('head').append('<style>.tmicon {background: ' +bg_scrolled+ ';}</style>');
764
+
765
+ {% comment %} Heading styles
766
+ -------------------------------------------------------------------------- {% endcomment %}
767
+ $('head').append('<style>.heading:after {background: ' +bg_scrolled+ ' !important;}</style>');
768
+
769
+ {% comment %} Tag Cloud styles
770
+ -------------------------------------------------------------------------- {% endcomment %}
771
+ $('head').append('<style>.tag-cloud ul li a {background-color: ' +bg_scrolled+ ' !important;}</style>');
772
+ // $('head').append('<style>.tag-cloud ul li a:hover {background-color: #212121 !important;}</style>');
773
+
774
+ {% comment %} Toccer styles
775
+ -------------------------------------------------------------------------- {% endcomment %}
776
+ $('head').append('<style>.is-active-link::before {background-color: ' +bg_scrolled+ ' !important;}</style>');
777
+
778
+ {% comment %} BS extended Modal styles
779
+ -------------------------------------------------------------------------- {% endcomment %}
780
+ $('head').append('<style>.modal-dialog.modal-notify.modal-primary .modal-header {background-color: ' +bg_scrolled+ ';}</style>');
781
+
782
+ {% comment %} BS nav|pills styles
783
+ -------------------------------------------------------------------------- {% endcomment %}
784
+ $('head').append('<style>.nav-pills .nav-link.active, .nav-pills .show > .nav-link {background-color: ' +bg_scrolled+ ' !important;}</style>');
785
+
786
+ return true;
787
+ }, // END setCSS
788
+
789
+ // -------------------------------------------------------------------------
790
+ // delayShowMenu
791
+ // delay all dropdown menu to open for "delay" time
792
+ // See: http://jsfiddle.net/AndreasPizsa/NzvKC/
793
+ // -------------------------------------------------------------------------
794
+ delayShowMenu: function ( menuOpenDelay ) {
795
+ var logger = log4javascript.getLogger('j1.adapter.navigator.delayShowMenu');
796
+ var theTimer = 0;
797
+ var theElement = null;
798
+ var theLastPosition = {x:0,y:0};
799
+
800
+ logText ='entered delayShowMenu';
801
+ logger.info(logText);
802
+
803
+ // $('#navigator_nav_menu')
804
+ // .find('li.dropdown.nav-item')
805
+
806
+ $('[data-toggle]').closest('li')
807
+ .on('mouseenter', function (inEvent) {
808
+ if (theElement) theElement.removeClass('open');
809
+ window.clearTimeout(theTimer);
810
+ theElement = $(this);
811
+
812
+ theTimer = window.setTimeout(function () {
813
+ theElement.addClass('open');
814
+ }, menuOpenDelay);
815
+ })
816
+ .on('mousemove', function (inEvent) {
817
+ if(Math.abs(theLastPosition.x - inEvent.ScreenX) > 4 ||
818
+ Math.abs(theLastPosition.y - inEvent.ScreenY) > 4) {
819
+ theLastPosition.x = inEvent.ScreenX;
820
+ theLastPosition.y = inEvent.ScreenY;
821
+ return;
822
+ }
823
+ if (theElement.hasClass('open')) return;
824
+ window.clearTimeout(theTimer);
825
+ theTimer = window.setTimeout(function () {
826
+ theElement.addClass('open');
827
+ }, menuOpenDelay);
828
+ })
829
+ .on('mouseleave', function (inEvent) {
830
+ window.clearTimeout(theTimer);
831
+ theElement = $(this);
832
+ theTimer = window.setTimeout(function () {
833
+ theElement.removeClass('open');
834
+ }, menuOpenDelay);
835
+ });
836
+
837
+ return true;
838
+ }, // END delayShowMenu
839
+
840
+ // -------------------------------------------------------------------------
841
+ // messageHandler
842
+ // Manage messages (paylods) send from other J1 modules
843
+ // -------------------------------------------------------------------------
844
+ messageHandler: function (sender, message) {
845
+ // var json_message = JSON.stringify(message, undefined, 2); // multiline
846
+ var json_message = JSON.stringify(message);
847
+
848
+ logText = 'received message from ' + sender + ': ' + json_message;
849
+ logger.debug(logText);
850
+
851
+ // -----------------------------------------------------------------------
852
+ // Process commands|actions
853
+ // -----------------------------------------------------------------------
854
+ if (message.type === 'command' && message.action === 'module_initialized') {
855
+ //
856
+ // Place handling of command|action here
857
+ //
858
+ logger.info(message.text);
859
+ }
860
+ if (message.type === 'command' && message.action === 'status') {
861
+ logger.info('messageHandler: received - ' + message.action);
862
+ }
863
+
864
+ //
865
+ // Place handling of other command|action here
866
+ //
867
+
868
+ return true;
869
+ }, // END messageHandler
870
+
871
+ // -------------------------------------------------------------------------
872
+ // setState()
873
+ // Sets the current (processing) state of the module
874
+ // -------------------------------------------------------------------------
875
+ setState: function (stat) {
876
+ _this.state = stat;
877
+ }, // END setState
878
+
879
+ // -------------------------------------------------------------------------
880
+ // getState()
881
+ // Returns the current (processing) state of the module
882
+ // -------------------------------------------------------------------------
883
+ getState: function () {
884
+ return _this.state;
885
+ } // END getState
886
+
887
+ }; // END return
888
+ })(j1, window);
889
+
890
+ {% endcapture %}
891
+ {% if production %}
892
+ {{ cache | minifyJS }}
893
+ {% else %}
894
+ {{ cache | strip_empty_lines }}
895
+ {% endif %}
896
+ {% assign cache = nil %}