j1-template 2021.1.9 → 2021.1.13

Sign up to get free protection for your applications and to get access to all the features.
Files changed (102) hide show
  1. checksums.yaml +4 -4
  2. data/_includes/themes/j1/layouts/content_generator_app.html +1 -1
  3. data/_includes/themes/j1/layouts/content_generator_blog_archive.html +1 -1
  4. data/_includes/themes/j1/layouts/content_generator_collection.html +1 -1
  5. data/_includes/themes/j1/layouts/content_generator_page.html +4 -1
  6. data/_includes/themes/j1/layouts/content_generator_post.html +1 -1
  7. data/_includes/themes/j1/layouts/content_generator_raw.html +1 -1
  8. data/_includes/themes/j1/layouts/layout_metadata_generator.html +55 -0
  9. data/_includes/themes/j1/modules/connectors/comment/commento.html +31 -0
  10. data/_includes/themes/j1/modules/connectors/comment/custom-provider.html +7 -8
  11. data/_includes/themes/j1/modules/connectors/comment/disqus.html +12 -54
  12. data/_includes/themes/j1/modules/connectors/comment/facebook.html +7 -8
  13. data/_includes/themes/j1/modules/connectors/comment/hyvor.html +33 -0
  14. data/_includes/themes/j1/modules/connectors/comment/just-comments.html +31 -0
  15. data/_includes/themes/j1/modules/connectors/comments +3 -0
  16. data/_layouts/default.html +51 -0
  17. data/assets/data/disqus.js +81 -0
  18. data/assets/data/hyvor.js +72 -0
  19. data/assets/error_pages/HTTP204.html +5 -1
  20. data/assets/error_pages/HTTP400.html +4 -0
  21. data/assets/error_pages/HTTP401.html +4 -0
  22. data/assets/error_pages/HTTP403.html +4 -0
  23. data/assets/error_pages/HTTP404.html +4 -0
  24. data/assets/error_pages/HTTP444.html +93 -0
  25. data/assets/error_pages/HTTP500.html +4 -0
  26. data/assets/error_pages/HTTP501.html +4 -0
  27. data/assets/error_pages/HTTP502.html +4 -0
  28. data/assets/error_pages/HTTP503.html +4 -0
  29. data/assets/themes/j1/adapter/js/algolia.js +10 -10
  30. data/assets/themes/j1/adapter/js/asciidoctor.js +6 -6
  31. data/assets/themes/j1/adapter/js/attic.js +17 -17
  32. data/assets/themes/j1/adapter/js/bmd.js +6 -6
  33. data/assets/themes/j1/adapter/js/carousel.js +10 -10
  34. data/assets/themes/j1/adapter/js/clipboard.js +10 -10
  35. data/assets/themes/j1/adapter/js/cookieConsent.js +68 -41
  36. data/assets/themes/j1/adapter/js/fam.js +34 -34
  37. data/assets/themes/j1/adapter/js/framer.js +6 -6
  38. data/assets/themes/j1/adapter/js/j1.js +531 -231
  39. data/assets/themes/j1/adapter/js/justifiedGallery.js +11 -11
  40. data/assets/themes/j1/adapter/js/justifiedGalleryCustomizer.js +19 -19
  41. data/assets/themes/j1/adapter/js/lightbox.js +6 -6
  42. data/assets/themes/j1/adapter/js/logger.js +7 -7
  43. data/assets/themes/j1/adapter/js/mmenu.js +25 -25
  44. data/assets/themes/j1/adapter/js/navigator.js +52 -49
  45. data/assets/themes/j1/adapter/js/quicksearch.js +6 -6
  46. data/assets/themes/j1/adapter/js/rouge.js +7 -7
  47. data/assets/themes/j1/adapter/js/rtable.js +6 -6
  48. data/assets/themes/j1/adapter/js/themer.js +145 -94
  49. data/assets/themes/j1/adapter/js/toccer.js +9 -9
  50. data/assets/themes/j1/core/js/template.js +24 -4
  51. data/assets/themes/j1/core/js/template.js.map +1 -1
  52. data/assets/themes/j1/core/js/template.min.js +24 -4
  53. data/assets/themes/j1/core/js/template.min.js.map +1 -1
  54. data/assets/themes/j1/modules/backstretch/js/backstretch.js +3 -3
  55. data/assets/themes/j1/modules/cookieConsent/js/cookieConsent.js +35 -23
  56. data/assets/themes/j1/modules/cookieConsent/js/cookieConsent.min.js +35 -23
  57. data/assets/themes/j1/modules/lunrSearch/js/quicksearch.js +1 -1
  58. data/assets/themes/j1/modules/themeSwitcher/js/switcher.js +19 -19
  59. data/lib/j1/version.rb +1 -1
  60. data/lib/starter_web/Gemfile +1 -1
  61. data/lib/starter_web/_config.yml +42 -24
  62. data/lib/starter_web/_data/_defaults/private.default.yml +119 -0
  63. data/lib/starter_web/_data/j1_config.yml +22 -11
  64. data/lib/starter_web/_data/modules/defaults/cookieconsent.yml +2 -1
  65. data/lib/starter_web/_data/resources.yml +0 -4
  66. data/lib/starter_web/_includes/attributes.asciidoc +1 -1
  67. data/lib/starter_web/_plugins/lunr_index.rb +1 -1
  68. data/lib/starter_web/dot.gitignore +1 -1
  69. data/lib/starter_web/index.html +3 -3
  70. data/lib/starter_web/package.json +1 -1
  71. data/lib/starter_web/pages/public/asciidoc_skeletons/book/book.adoc +3 -0
  72. data/lib/starter_web/pages/public/asciidoc_skeletons/multi-document/multi.adoc +3 -0
  73. data/lib/starter_web/pages/public/asciidoc_skeletons/simple-document/simple.adoc +3 -0
  74. data/lib/starter_web/pages/public/blog/navigator/archive.html +4 -0
  75. data/lib/starter_web/pages/public/blog/navigator/archive/categoryview.html +4 -0
  76. data/lib/starter_web/pages/public/blog/navigator/archive/dateview.html +4 -0
  77. data/lib/starter_web/pages/public/blog/navigator/archive/tagview.html +5 -1
  78. data/lib/starter_web/pages/public/blog/navigator/index.html +4 -0
  79. data/lib/starter_web/pages/public/cookieConsent.adoc +3 -0
  80. data/lib/starter_web/pages/public/learn/roundtrip/100_present_images.adoc +0 -1
  81. data/lib/starter_web/pages/public/learn/roundtrip/100_present_videos.adoc +2 -1
  82. data/lib/starter_web/pages/public/learn/roundtrip/200_typography.adoc +0 -2
  83. data/lib/starter_web/pages/public/learn/roundtrip/300_icon_fonts.adoc +0 -2
  84. data/lib/starter_web/pages/public/learn/roundtrip/400_asciidoc_extensions.adoc +0 -1
  85. data/lib/starter_web/pages/public/learn/roundtrip/410_bs_modals_extentions.adoc +0 -1
  86. data/lib/starter_web/pages/public/learn/roundtrip/420_responsive_tables_extensions.adoc +0 -1
  87. data/lib/starter_web/pages/public/learn/roundtrip/500_themes.adoc +0 -1
  88. data/lib/starter_web/pages/public/learn/roundtrip/600_quicksearch.adoc +0 -1
  89. data/lib/starter_web/pages/public/learn/where_to_go.adoc +0 -1
  90. data/lib/starter_web/pages/public/legal/en/100_copyright.adoc +3 -1
  91. data/lib/starter_web/pages/public/legal/en/200_impress.adoc +3 -1
  92. data/lib/starter_web/pages/public/legal/en/300_privacy.adoc +78 -17
  93. data/lib/starter_web/pages/public/legal/en/400_comment_policy.adoc +3 -1
  94. data/lib/starter_web/utilsrv/_defaults/package.json +1 -1
  95. data/lib/starter_web/utilsrv/package.json +1 -1
  96. metadata +9 -8
  97. data/assets/themes/j1/adapter/js/themer.1.js +0 -326
  98. data/assets/themes/j1/modules/util/js/js.cookie.js +0 -163
  99. data/assets/themes/j1/modules/util/js/lite-url.js +0 -203
  100. data/assets/themes/j1/modules/util/js/lite-url.min.js +0 -7
  101. data/assets/themes/j1/modules/util/js/platform.js +0 -1260
  102. data/lib/starter_web/pages/public/learn/roundtrip/100_present_images.org.asciidoc +0 -244
@@ -210,8 +210,8 @@ j1.adapter['navigator'] = (function (j1, window) {
210
210
 
211
211
  // initialize state flag
212
212
  _this.setState('started');
213
- logger.info('state: ' + _this.getState());
214
- logger.info('module is being initialized');
213
+ logger.info('\n' + 'state: ' + _this.getState());
214
+ logger.info('\n' + 'module is being initialized');
215
215
 
216
216
  // -----------------------------------------------------------------------
217
217
  // defaults
@@ -249,7 +249,6 @@ j1.adapter['navigator'] = (function (j1, window) {
249
249
  var themes_count;
250
250
  var max_count = 100;
251
251
 
252
-
253
252
  navDefaults = $.extend({}, {{navigator_defaults | replace: '=>', ':' }});
254
253
  navBarConfig = $.extend({}, {{nav_bar_options | replace: '=>', ':' }});
255
254
  navMenuConfig = $.extend({}, {{nav_menu_options | replace: '=>', ':' }});
@@ -299,19 +298,19 @@ j1.adapter['navigator'] = (function (j1, window) {
299
298
  // -----------------------------------------------------------------------
300
299
  // data loader
301
300
  // -----------------------------------------------------------------------
302
- j1.xhrData({
301
+ j1.loadHTML({
303
302
  xhr_container_id: navQuicklinksOptions.xhr_container_id,
304
303
  xhr_data_path: navQuicklinksOptions.xhr_data_path,
305
304
  xhr_data_element: navQuicklinksOptions.xhr_data_element },
306
305
  'j1.adapter.navigator',
307
306
  null);
308
- j1.xhrData({
307
+ j1.loadHTML({
309
308
  xhr_container_id: navAuthClientConfig.xhr_container_id,
310
309
  xhr_data_path: navAuthClientConfig.xhr_data_path,
311
310
  xhr_data_element: navAuthClientConfig.xhr_data_element },
312
311
  'j1.adapter.navigator',
313
312
  null);
314
- j1.xhrData({
313
+ j1.loadHTML({
315
314
  xhr_container_id: navMenuOptions.xhr_container_id,
316
315
  xhr_data_path: navMenuOptions.xhr_data_path,
317
316
  xhr_data_element: navMenuOptions.xhr_data_element },
@@ -322,37 +321,41 @@ j1.adapter['navigator'] = (function (j1, window) {
322
321
  if (j1.xhrDOMState['#'+navQuicklinksOptions.xhr_container_id] === 'success' &&
323
322
  j1.xhrDOMState['#'+navAuthClientConfig.xhr_container_id] === 'success' &&
324
323
  j1.xhrDOMState['#'+navMenuOptions.xhr_container_id] === 'success' ) {
325
- // continue if all AJAX loads (xhrData) has finished
324
+ // continue if all AJAX loads (loadHTML) has finished
326
325
  _this.setState('processing');
327
- logger.info('status: ' + _this.getState());
328
- logger.info('initialize navigator core');
326
+ logger.info('\n' + 'status: ' + _this.getState());
327
+ logger.info('\n' + 'initialize navigator core');
329
328
 
330
329
  // Detect|Set J1 App status
331
330
  appDetected = j1.appDetected();
332
331
  authClientEnabled = j1.authEnabled();
333
- logger.info('application status detected: ' + appDetected);
332
+ logger.info('\n' + 'application status detected: ' + appDetected);
334
333
 
335
334
  j1.core.navigator.init (_this.navDefaults, _this.navMenuOptions);
336
335
 
337
336
  // load themes (to menu) if themer is enabled|finished
338
337
  if (themerEnabled) {
339
- logText = 'theme switcher: enabled';
338
+ logText = '\n' + 'theme switcher: enabled';
340
339
  logger.info(logText);
341
340
 
342
- // Detect|Set J1 UserState
341
+ // detect j1 user state cookie
343
342
  user_state_detected = j1.existsCookie(cookie_user_state_name);
343
+
344
+
344
345
  if (user_state_detected) {
345
346
  user_state = j1.readCookie(cookie_user_state_name);
347
+ } else {
348
+ logger.error('\n' + 'cookie not found: j1.user.state');
346
349
  }
347
350
 
348
351
  // jadams, 2021-07-03: wait until navigator CORE get finished
349
352
  var dependencies_met_page_finished = setInterval(function() {
350
353
  if (j1.adapter.navigator.getState() == 'core_initialized') {
351
- logText = 'load themes';
354
+ logText = '\n' + 'load themes';
352
355
  logger.info(logText);
353
356
 
354
357
  // load LOCAL themes from JSON data
355
- logText = 'load local themes (json file)';
358
+ logText = '\n' + 'load local themes (json file)';
356
359
  logger.info(logText);
357
360
  $('#local_themes').bootstrapThemeSwitcher({
358
361
  localFeed: themerOptions.localThemes
@@ -375,16 +378,16 @@ j1.adapter['navigator'] = (function (j1, window) {
375
378
  interval_count += 1;
376
379
  themes_count = document.getElementById("remote_themes").getElementsByTagName("li").length;
377
380
  if ( themes_count > 0 ) {
378
- logger.info('remote themes loaded: successfully');
379
- logger.info('remote themes loaded: successfully after: ' + interval_count * 25 + ' ms');
381
+ logger.info('\n' + 'remote themes loaded: successfully');
382
+ logger.info('\n' + 'remote themes loaded: successfully after: ' + interval_count * 25 + ' ms');
380
383
 
381
384
  clearInterval(dependencies_met_remote_themes_loaded);
382
385
  } else {
383
- logger.debug('wait for theme to be loaded: ' + user_state.theme_name);
386
+ logger.debug('\n' + 'wait for theme to be loaded: ' + user_state.theme_name);
384
387
  }
385
388
  if (interval_count > max_count) {
386
- logger.warn('remote themes loading: failed');
387
- logger.warn('continue processing');
389
+ logger.warn('\n' + 'remote themes loading: failed');
390
+ logger.warn('\n' + 'continue processing');
388
391
  clearInterval(dependencies_met_remote_themes_loaded);
389
392
  }
390
393
  clearInterval(dependencies_met_page_finished);
@@ -393,7 +396,7 @@ j1.adapter['navigator'] = (function (j1, window) {
393
396
  _this.setState('initialized');
394
397
  }, 25); // END 'dependencies_met_page_finished'
395
398
  } else {
396
- logText = 'theme switcher detected as: disabled';
399
+ logText = '\n' + 'theme switcher detected as: disabled';
397
400
  logger.info(logText);
398
401
  }
399
402
 
@@ -407,39 +410,39 @@ j1.adapter['navigator'] = (function (j1, window) {
407
410
  _this.setState('processing');
408
411
 
409
412
  // set general|global theme colors
410
- logger.info('initializing dynamic CSS styles');
413
+ logger.info('\n' + 'initializing dynamic CSS styles');
411
414
  _this.setCSS (
412
415
  navDefaults, navBarOptions, navMenuOptions,
413
416
  navQuicklinksOptions, navTopsearchOptions
414
417
  );
415
418
 
416
- logger.info('init auth client');
419
+ logger.info('\n' + 'init auth client');
417
420
  _this.initAuthClient(_this.navAuthManagerConfig);
418
421
 
419
422
  _this.setState('finished');
420
- logger.info('state: ' + _this.getState());
421
- logger.info('module initialized successfully');
422
- logger.info('met dependencies for: j1');
423
+ logger.info('\n' + 'state: ' + _this.getState());
424
+ logger.info('\n' + 'module initialized successfully');
425
+ logger.info('\n' + 'met dependencies for: j1');
423
426
  clearInterval(dependencies_met_initialized);
424
427
  }
425
428
  } else {
426
429
  _this.setState('processing');
427
430
 
428
431
  // set general|global theme colors
429
- logger.info('apply dynamic CSS styles');
432
+ logger.info('\n' + 'apply dynamic CSS styles');
430
433
  _this.setCSS (
431
434
  navDefaults, navBarOptions, navMenuOptions,
432
435
  navQuicklinksOptions, navTopsearchOptions
433
436
  );
434
437
 
435
- logger.info('init auth client');
438
+ logger.info('\n' + 'init auth client');
436
439
  _this.initAuthClient(_this.navAuthManagerConfig);
437
440
  _this.setState('finished');
438
- logger.info('state: ' + _this.getState());
441
+ logger.info('\n' + 'state: ' + _this.getState());
439
442
  clearInterval(dependencies_met_initialized);
440
443
  }
441
444
  }, 25); // END 'dependencies_met_initialized'
442
- logger.info('met dependencies for: themer');
445
+ logger.info('\n' + 'met dependencies for: themer');
443
446
  clearInterval(dependencies_met_load_menu_finished);
444
447
  }
445
448
  }, 25); // END 'dependencies_met_load_menu_finished'
@@ -526,7 +529,7 @@ j1.adapter['navigator'] = (function (j1, window) {
526
529
  do: false
527
530
  };
528
531
 
529
- logText = 'initialize button click events';
532
+ logText = '\n' + 'initialize button click events';
530
533
  logger.info(logText);
531
534
 
532
535
  // Manage button click events for modal "signInOutButton"
@@ -556,7 +559,7 @@ j1.adapter['navigator'] = (function (j1, window) {
556
559
  e.stopPropagation();
557
560
  signOut.providerSignOut = $('input:checkbox[name="providerSignOut"]').is(':checked');
558
561
  if(environment === 'development') {
559
- logText = 'provider signout set to: ' + signOut.providerSignOut;
562
+ logText = '\n' + 'provider signout set to: ' + signOut.providerSignOut;
560
563
  logger.info(logText);
561
564
  }
562
565
  });
@@ -565,7 +568,7 @@ j1.adapter['navigator'] = (function (j1, window) {
565
568
  // -----------------------------------------------------------------------
566
569
  $('#modalOmniSignOut').on('show.bs.modal', function() {
567
570
  var modal = $(this);
568
- logger.info('place current user data');
571
+ logger.info('\n' + 'place current user data');
569
572
  user_session = j1.readCookie(cookie_user_session_name);
570
573
  modal.find('.user-info').text('You are signed in to provider: ' + user_session.provider);
571
574
  }); // END SHOW modalOmniSignOut
@@ -576,18 +579,18 @@ j1.adapter['navigator'] = (function (j1, window) {
576
579
  if (signIn.do == true) {
577
580
  provider = signIn.provider.toLowerCase();
578
581
  allowed_users = signIn.users.toString();
579
- logText = 'provider detected: ' + provider;
582
+ logText = '\n' + 'provider detected: ' + provider;
580
583
  logger.info(logText);
581
584
 
582
585
  var route = '/authentication?request=signin&provider=' +provider+ '&allowed_users=' +allowed_users;
583
- logText = 'call middleware for signin on route: ' + route;
586
+ logText = '\n' + 'call middleware for signin on route: ' + route;
584
587
  logger.info(logText);
585
588
  window.location.href = route;
586
589
  } else {
587
590
  provider = signIn.provider.toLowerCase();
588
- logText = 'provider detected: ' + provider;
591
+ logText = '\n' + 'provider detected: ' + provider;
589
592
  logger.info(logText);
590
- logText = 'login declined for provider: ' +provider;
593
+ logText = '\n' + 'login declined for provider: ' +provider;
591
594
  logger.info(logText);
592
595
  }
593
596
  }); // END post events "modalOmniSignIn"
@@ -596,31 +599,31 @@ j1.adapter['navigator'] = (function (j1, window) {
596
599
  // -----------------------------------------------------------------------
597
600
  $('#modalOmniSignOut').on('hidden.bs.modal', function() {
598
601
  if (signOut.do == true) {
599
- logger.info('load active provider from cookie: ' + cookie_user_session_name);
602
+ logger.info('\n' + 'load active provider from cookie: ' + cookie_user_session_name);
600
603
 
601
604
  user_session = j1.readCookie(cookie_user_session_name);
602
605
  provider = user_session.provider;
603
606
  provider_url = user_session.provider_site_url;
604
607
 
605
- logText = 'provider detected: ' + provider;
608
+ logText = '\n' + 'provider detected: ' + provider;
606
609
  logger.info(logText);
607
- logText = 'initiate signout for provider: ' +provider;
610
+ logText = '\n' + 'initiate signout for provider: ' +provider;
608
611
  logger.info(logText);
609
612
 
610
613
  var route = '/authentication?request=signout&provider=' + provider + '&provider_signout=' + signOut.providerSignOut; // + '/logout/';
611
- logText = 'call middleware on route : ' +route;
614
+ logText = '\n' + 'call middleware on route : ' +route;
612
615
  logger.info(logText);
613
616
  window.location.href = route;
614
617
  } else {
615
618
  provider = signOut.provider.toLowerCase();
616
- logText = 'provider detected: ' + provider;
619
+ logText = '\n' + 'provider detected: ' + provider;
617
620
  logger.info(logText);
618
- logText = 'signout declined for provider: ' +provider ;
621
+ logText = '\n' + 'signout declined for provider: ' +provider ;
619
622
  logger.info(logText);
620
623
  }
621
624
  }); // END post events "modalSignOut"
622
625
 
623
- logText = 'initialize button click events completed';
626
+ logText = '\n' + 'initialize button click events completed';
624
627
  logger.info(logText);
625
628
 
626
629
  return true;
@@ -637,7 +640,7 @@ j1.adapter['navigator'] = (function (j1, window) {
637
640
  var gridBreakpoint_sm = '576px';
638
641
  var navPrimaryColor = navDefaults.nav_primary_color;
639
642
 
640
- logger.info('set dynamic styles for the theme loaded');
643
+ logger.info('\n' + 'set dynamic styles for the theme loaded');
641
644
 
642
645
  // Set|Resolve navMenuOptions
643
646
  // ------------------------------------------------------------------------
@@ -781,7 +784,7 @@ j1.adapter['navigator'] = (function (j1, window) {
781
784
  var theElement = null;
782
785
  var theLastPosition = {x:0,y:0};
783
786
 
784
- logText ='entered delayShowMenu';
787
+ logText = '\n' + 'entered delayShowMenu';
785
788
  logger.info(logText);
786
789
 
787
790
  // $('#navigator_nav_menu')
@@ -830,10 +833,10 @@ j1.adapter['navigator'] = (function (j1, window) {
830
833
  var json_message = JSON.stringify(message);
831
834
  _this.setState(message.action);
832
835
 
833
- logText = 'received message from ' + sender + ': ' + json_message;
836
+ logText = '\n' + 'received message from ' + sender + ': ' + json_message;
834
837
  logger.info(logText);
835
838
 
836
- logText = 'set state to: ' + message.action;
839
+ logText = '\n' + 'set state to: ' + message.action;
837
840
  logger.info(logText);
838
841
 
839
842
  // -----------------------------------------------------------------------
@@ -843,10 +846,10 @@ j1.adapter['navigator'] = (function (j1, window) {
843
846
  //
844
847
  // Place handling of command|action here
845
848
  //
846
- logger.info(message.text);
849
+ logger.info('\n' + message.text);
847
850
  }
848
851
  if (message.type === 'command' && message.action === 'status') {
849
- logger.info('messageHandler: received - ' + message.action);
852
+ logger.info('\n' + 'messageHandler: received - ' + message.action);
850
853
  }
851
854
 
852
855
  //
@@ -108,8 +108,8 @@ j1.adapter['quicksearch'] = (function (j1, window) {
108
108
 
109
109
  // initialize state flag
110
110
  _this.setState('started');
111
- logger.info('state: ' + _this.getState());
112
- logger.info('module is being initialized');
111
+ logger.info('\n' + 'state: ' + _this.getState());
112
+ logger.info('\n' + 'module is being initialized');
113
113
 
114
114
  // -----------------------------------------------------------------------
115
115
  // defaults
@@ -128,7 +128,7 @@ j1.adapter['quicksearch'] = (function (j1, window) {
128
128
  // -----------------------------------------------------------------------
129
129
  // lunr_search initializer
130
130
  // -----------------------------------------------------------------------
131
- var log_text = 'module is being initialized';
131
+ var log_text = '\n' + 'module is being initialized';
132
132
  logger.info(log_text);
133
133
 
134
134
  var dependencies_met_j1_finished = setInterval(function() {
@@ -143,7 +143,7 @@ j1.adapter['quicksearch'] = (function (j1, window) {
143
143
  });
144
144
 
145
145
  _this.setState('finished');
146
- logger.info('state: ' + _this.getState());
146
+ logger.info('\n' + 'state: ' + _this.getState());
147
147
 
148
148
  clearInterval(dependencies_met_j1_finished);
149
149
  } // END dependencies_met_j1_finished
@@ -172,7 +172,7 @@ j1.adapter['quicksearch'] = (function (j1, window) {
172
172
  messageHandler: function (sender, message) {
173
173
  var json_message = JSON.stringify(message, undefined, 2);
174
174
 
175
- logText = 'received message from ' + sender + ': ' + json_message;
175
+ logText = '\n' + 'received message from ' + sender + ': ' + json_message;
176
176
  logger.debug(logText);
177
177
 
178
178
  // -----------------------------------------------------------------------
@@ -182,7 +182,7 @@ j1.adapter['quicksearch'] = (function (j1, window) {
182
182
  //
183
183
  // Place handling of command|action here
184
184
  //
185
- logger.info(message.text);
185
+ logger.info('\n' + message.text);
186
186
  }
187
187
 
188
188
  //
@@ -111,8 +111,8 @@ j1.adapter['rouge'] = (function (j1, window) {
111
111
 
112
112
  // initialize state flag
113
113
  _this.setState('started');
114
- logger.info('state: ' + _this.getState());
115
- logger.info('module is being initialized');
114
+ logger.info('\n' + 'state: ' + _this.getState());
115
+ logger.info('\n' + 'module is being initialized');
116
116
 
117
117
  // -----------------------------------------------------------------------
118
118
  // Default module settings
@@ -125,7 +125,7 @@ j1.adapter['rouge'] = (function (j1, window) {
125
125
  // -----------------------------------------------------------------------
126
126
  // rouge initializer
127
127
  // -----------------------------------------------------------------------
128
- var log_text = 'Rouge is being initialized';
128
+ var log_text = '\n' + 'module is being initialized';
129
129
  logger.info(log_text);
130
130
 
131
131
  // Detect|Set J1 UserState
@@ -139,7 +139,7 @@ j1.adapter['rouge'] = (function (j1, window) {
139
139
  themeCss.includes('slate') ||
140
140
  themeCss.includes('superhero');
141
141
  } else {
142
- log_text = 'user_state cookie not found';
142
+ log_text = '\n' + 'user_state cookie not found';
143
143
  logger.warn(log_text);
144
144
  }
145
145
 
@@ -149,7 +149,7 @@ j1.adapter['rouge'] = (function (j1, window) {
149
149
  $('#selected').html("Current Selection: <div class='bg-primary mt-1 p-2'>"+$(this).text()+"</div>");
150
150
  });
151
151
  _this.setState('finished');
152
- logger.info('state: ' + _this.getState());
152
+ logger.info('\n' + 'state: ' + _this.getState());
153
153
  clearInterval(dependencies_met_j1_finished);
154
154
  } // END dependencies_met_j1_finished
155
155
  }, 25);
@@ -200,7 +200,7 @@ j1.adapter['rouge'] = (function (j1, window) {
200
200
  messageHandler: function (sender, message) {
201
201
  var json_message = JSON.stringify(message, undefined, 2);
202
202
 
203
- logText = 'received message from ' + sender + ': ' + json_message;
203
+ logText = '\n' + 'received message from ' + sender + ': ' + json_message;
204
204
  logger.debug(logText);
205
205
 
206
206
  // -----------------------------------------------------------------------
@@ -210,7 +210,7 @@ j1.adapter['rouge'] = (function (j1, window) {
210
210
  //
211
211
  // Place handling of command|action here
212
212
  //
213
- logger.info(message.text);
213
+ logger.info('\n' + message.text);
214
214
  }
215
215
 
216
216
  //
@@ -79,8 +79,8 @@ j1.adapter['rtable'] = (function (j1, window) {
79
79
 
80
80
  // initialize state flag
81
81
  _this.setState('started');
82
- logger.info('state: ' + _this.getState());
83
- logger.info('module is being initialized');
82
+ logger.info('\n' + 'state: ' + _this.getState());
83
+ logger.info('\n' + 'module is being initialized');
84
84
 
85
85
  // -----------------------------------------------------------------------
86
86
  // Default module settings
@@ -93,7 +93,7 @@ j1.adapter['rtable'] = (function (j1, window) {
93
93
  // -----------------------------------------------------------------------
94
94
  // rtable initializer
95
95
  // -----------------------------------------------------------------------
96
- var log_text = 'rtable is being initialized';
96
+ var log_text = '\n' + 'rtable is being initialized';
97
97
  logger.info(log_text);
98
98
 
99
99
  // Add data attribute for tablesaw to all tables of a page
@@ -120,7 +120,7 @@ j1.adapter['rtable'] = (function (j1, window) {
120
120
  Tablesaw.init();
121
121
 
122
122
  _this.setState('finished');
123
- logger.info('state: ' + _this.getState());
123
+ logger.info('\n' + 'state: ' + _this.getState());
124
124
 
125
125
  clearInterval(dependencies_met_j1_finished);
126
126
  } // END dependencies_met_j1_finished
@@ -135,7 +135,7 @@ j1.adapter['rtable'] = (function (j1, window) {
135
135
  messageHandler: function (sender, message) {
136
136
  var json_message = JSON.stringify(message, undefined, 2);
137
137
 
138
- logText = 'received message from ' + sender + ': ' + json_message;
138
+ logText = '\n' + 'received message from ' + sender + ': ' + json_message;
139
139
  logger.debug(logText);
140
140
 
141
141
  // -----------------------------------------------------------------------
@@ -145,7 +145,7 @@ j1.adapter['rtable'] = (function (j1, window) {
145
145
  //
146
146
  // Place handling of command|action here
147
147
  //
148
- logger.info(message.text);
148
+ logger.info('\n' + message.text);
149
149
  }
150
150
 
151
151
  //
@@ -103,6 +103,8 @@ j1.adapter['themer'] = (function (j1, window) {
103
103
  // ---------------------------------------------------------------------------
104
104
  var environment = '{{environment}}';
105
105
  var themerOptions = $.extend({}, {{themer_options | replace: '=>', ':' | replace: 'nil', '""' }});
106
+ var url = new liteURL(window.location.href);
107
+ var secure = (url.protocol.includes('https')) ? true : false;
106
108
  var user_state = {};
107
109
  var user_consent = {};
108
110
  var cookie_names = j1.getCookieNames();
@@ -114,6 +116,7 @@ j1.adapter['themer'] = (function (j1, window) {
114
116
  var _this;
115
117
  var logger;
116
118
  var logText;
119
+ var cookie_written;
117
120
 
118
121
  var cssExtension = (environment === 'production')
119
122
  ? '.min.css'
@@ -125,6 +128,16 @@ j1.adapter['themer'] = (function (j1, window) {
125
128
  var default_theme_css_name = default_theme_name.toLowerCase().replace(' ', '-');
126
129
  var default_theme_css = '{{asset_path}}/{{theme_base}}/' + default_theme_css_name + '/bootstrap' + cssExtension;
127
130
 
131
+ var interval_count = 0;
132
+ var max_count = themerOptions.retries;
133
+
134
+ var j1Cookies;
135
+ var gaCookies;
136
+
137
+ var url;
138
+ var baseUrl;
139
+ var error_page;
140
+
128
141
  // ---------------------------------------------------------------------------
129
142
  // helper functions
130
143
  // ---------------------------------------------------------------------------
@@ -152,105 +165,143 @@ j1.adapter['themer'] = (function (j1, window) {
152
165
  // -----------------------------------------------------------------------
153
166
  // globals
154
167
  // -----------------------------------------------------------------------
155
- _this = j1.adapter.themer;
156
- logger = log4javascript.getLogger('j1.adapter.themer');
168
+ _this = j1.adapter.themer;
169
+ url = new liteURL(window.location.href);
170
+ baseUrl = url.origin;
171
+ error_page = url.origin + '/204.html';
172
+ j1Cookies = j1.findCookie('j1');
173
+ gaCookies = j1.findCookie('_ga');
174
+ logger = log4javascript.getLogger('j1.adapter.themer');
157
175
 
158
176
  // initialize state flag
159
177
  _this.state = 'started';
160
- logger.info('state: ' + _this.getState());
161
-
162
- // detect|set user state cookie
163
- user_state_detected = j1.existsCookie(cookie_names.user_state);
164
- if (user_state_detected) {
165
- user_state = j1.readCookie(cookie_names.user_state);
166
- user_consent = j1.readCookie(cookie_names.user_consent);
167
- }
168
-
169
- // initial theme data
170
- if (user_state.theme_css === '') {
171
- user_state.theme_name = default_theme_name;
172
- user_state.theme_css = default_theme_css;
173
- user_state.theme_author = default_theme_author;
174
- user_state.theme_author_url = default_theme_author_url;
175
- }
176
-
177
- styleLoaded = styleSheetLoaded(user_state.theme_css);
178
- theme_css_html = '<link rel="stylesheet" id="' + id + '" href="' + user_state.theme_css + '" type="text/css" />';
179
-
180
- // skip loading theme UNO css file except NOT loaded
181
- if (!user_state.theme_name.includes('Uno') || !styleLoaded) {
182
- $('head').append(theme_css_html);
183
- }
178
+ logger.info('\n' + 'state: ' + _this.getState());
179
+
180
+ // jadams, 2021-07-11: added dependecy on the user state cookie
181
+ // Found timing issues testing mobile devices (iPad)
182
+ var dependencies_met_user_state_available = setInterval (function () {
183
+ user_state_detected = j1.existsCookie(cookie_names.user_state);
184
+
185
+ // counter how often the check should be done for the existence
186
+ // of the user state cookie
187
+ interval_count += 1;
188
+ if (user_state_detected) {
189
+ user_state = j1.readCookie(cookie_names.user_state);
190
+ user_consent = j1.readCookie(cookie_names.user_consent);
191
+
192
+ logger.info('\n' + 'cookie ' + cookie_names.user_state + ' successfully loaded after: ' + interval_count * 25 + ' ms');
193
+
194
+ // initial theme data
195
+ if (user_state.theme_css === '') {
196
+ user_state.theme_name = default_theme_name;
197
+ user_state.theme_css = default_theme_css;
198
+ user_state.theme_author = default_theme_author;
199
+ user_state.theme_author_url = default_theme_author_url;
200
+ }
201
+
202
+ styleLoaded = styleSheetLoaded(user_state.theme_css);
203
+ theme_css_html = '<link rel="stylesheet" id="' + id + '" href="' + user_state.theme_css + '" type="text/css" />';
204
+
205
+ // check cookie consistency
206
+ if (Object.keys(user_state).length > 2) {
207
+ // loading theme CSS file except on UNO
208
+ if (!user_state.theme_name.includes('Uno') || !styleLoaded) {
209
+ $('head').append(theme_css_html);
210
+ }
211
+ } else {
212
+ logger.fatal('\n' + 'inconsistent state detected for cookie: ' + cookie_names.user_state);
213
+ }
214
+
215
+ // set the theme switcher state
216
+ user_state.theme_switcher = themerOptions.enabled;
217
+
218
+ // jadams, 2021-07-11: unclear why the cookie consent is checked here
219
+ if (!user_consent.analyses || !user_consent.personalization) {
220
+ // expire state cookie to session
221
+ cookie_written = j1.writeCookie({
222
+ name: cookie_names.user_state,
223
+ data: user_state,
224
+ samesite: 'Strict',
225
+ secure: secure
226
+ });
227
+ if (!cookie_written) {
228
+ logger.error('\n' + 'failed to write cookie: ' + cookie_names.user_state);
229
+ }
230
+ } else {
231
+ cookie_written = j1.writeCookie({
232
+ name: cookie_names.user_state,
233
+ data: user_state,
234
+ samesite: 'Strict',
235
+ secure: secure,
236
+ expires: 365
237
+ });
238
+ if (!cookie_written) {
239
+ logger.error('\n' + 'failed to write cookie: ' + cookie_names.user_state);
240
+ }
241
+ }
242
+
243
+ if (themerOptions.enabled) {
244
+ // enable BS ThemeSwitcher
245
+ logger.info('\n' + 'themes detected as: enabled');
246
+ logger.info('\n' + 'theme is being initialized: ' + user_state.theme_name);
247
+
248
+ /* eslint-disable */
249
+ // load list of remote themes
250
+ $('#remote_themes').bootstrapThemeSwitcher.defaults = {
251
+ debug: themerOptions.debug,
252
+ saveToCookie: themerOptions.saveToCookie,
253
+ cssThemeLink: themerOptions.cssThemeLink,
254
+ cookieThemeName: themerOptions.cookieThemeName,
255
+ cookieDefaultThemeName: themerOptions.cookieDefaultThemeName,
256
+ cookieThemeCss: themerOptions.cookieThemeCss,
257
+ cookieThemeExtensionCss: themerOptions.cookieThemeExtensionCss,
258
+ cookieExpiration: themerOptions.cookieExpiration,
259
+ cookiePath: themerOptions.cookiePath,
260
+ defaultCssFile: themerOptions.defaultCssFile,
261
+ bootswatchApiUrl: themerOptions.bootswatchApiUrl,
262
+ bootswatchApiVersion: themerOptions.bootswatchApiVersion,
263
+ loadFromBootswatch: themerOptions.loadFromBootswatch,
264
+ localFeed: themerOptions.localThemes,
265
+ excludeBootswatch: themerOptions.excludeBootswatch,
266
+ includeBootswatch: themerOptions.includeBootswatch,
267
+ skipIncludeBootswatch: themerOptions.skipIncludeBootswatch
268
+ };
269
+ /* eslint-enable */
270
+
271
+ logger.info('\n' + 'theme loaded: ' + user_state.theme_name);
272
+ logger.info('\n' + 'theme css file: ' + user_state.theme_css);
273
+ _this.setState('finished');
274
+ logger.info('\n' + 'state: ' + _this.getState());
275
+ logger.info('\n' + 'module initialized successfully');
276
+ } else {
277
+ _this.setState('finished');
278
+ logger.info('\n' + 'state: ' + _this.getState());
279
+ logger.info('\n' + 'themes detected as: disabled');
280
+ }
281
+ clearInterval(dependencies_met_user_state_available);
282
+ }
184
283
 
185
- // store if theme_switcher is enabled
186
- user_state.theme_switcher = themerOptions.enabled;
187
-
188
- if (!user_consent.analyses || !user_consent.personalization) {
189
- // expire state cookie to session
190
- j1.writeCookie({
191
- name: cookie_names.user_state,
192
- data: user_state,
193
- samesite: 'Strict'
194
- });
195
- } else {
196
- j1.writeCookie({
197
- name: cookie_names.user_state,
198
- data: user_state,
199
- samesite: 'Strict',
200
- expires: 365
201
- });
202
- }
284
+ if (interval_count > max_count) {
285
+ logger.error('\n' + 'interval max count reached: ' + max_count);
286
+ logger.error('\n' + 'check failed after: ' + max_count * 25 + ' ms');
287
+ logger.error('\n' + 'loading cookie failed: ' + cookie_names.user_state);
203
288
 
204
- var dependencies_met_j1_finished = setInterval (function () {
205
- // jadams, 2021-01-03: dependency has to be checked in more detail
206
- // if (j1.getState() == 'finished') {
207
- if (true) {
208
- if (themerOptions.enabled) {
209
- // enable BS ThemeSwitcher
210
- logger.info('themes detected as: enabled');
211
- logger.info('theme is being initialized: ' + user_state.theme_name);
212
-
213
- // load list of remote themes
214
- //
215
- if ($('#remote_themes').length) {
216
- /* eslint-disable */
217
- // initialize Bootswatch Theme Switcher
218
- $('#remote_themes').bootstrapThemeSwitcher.defaults = {
219
- debug: themerOptions.debug,
220
- saveToCookie: themerOptions.saveToCookie,
221
- cssThemeLink: themerOptions.cssThemeLink,
222
- cookieThemeName: themerOptions.cookieThemeName,
223
- cookieDefaultThemeName: themerOptions.cookieDefaultThemeName,
224
- cookieThemeCss: themerOptions.cookieThemeCss,
225
- cookieThemeExtensionCss: themerOptions.cookieThemeExtensionCss,
226
- cookieExpiration: themerOptions.cookieExpiration,
227
- cookiePath: themerOptions.cookiePath,
228
- defaultCssFile: themerOptions.defaultCssFile,
229
- bootswatchApiUrl: themerOptions.bootswatchApiUrl,
230
- bootswatchApiVersion: themerOptions.bootswatchApiVersion,
231
- loadFromBootswatch: themerOptions.loadFromBootswatch,
232
- localFeed: themerOptions.localThemes,
233
- excludeBootswatch: themerOptions.excludeBootswatch,
234
- includeBootswatch: themerOptions.includeBootswatch,
235
- skipIncludeBootswatch: themerOptions.skipIncludeBootswatch
236
- }
237
- /* eslint-enable */
238
-
239
- logger.info('theme loaded: ' + user_state.theme_name);
240
- logger.info('theme css file: ' + user_state.theme_css);
241
- _this.setState('finished');
242
- logger.info('state: ' + _this.getState());
243
- logger.info('module initialized successfully');
244
- logger.info('met dependencies for: j1.adapter');
245
- }
246
- } else {
247
- _this.setState('finished');
248
- logger.info('state: ' + _this.getState());
249
- logger.info('themes detected as: disabled');
289
+ // for development only
290
+ if (environment === 'development') {
291
+ gaCookies.forEach(item => console.log('cookieConsent: ' + item));
292
+ j1Cookies.forEach(item => console.log('cookieConsent: ' + item));
250
293
  }
251
- clearInterval(dependencies_met_j1_finished);
294
+
295
+ // jadams, 2021-07-15: redirect to homepage
296
+ // NOTE: UNCLEAR why it is needed to create the user state
297
+ // cookie THIS way
298
+ //
299
+ logger.warn('\n' + 'redirect to home page');
300
+ // window.location.href = error_page;
301
+ window.location.href = '/';
302
+ clearInterval(dependencies_met_user_state_available);
252
303
  }
253
- }, 25); // END 'dependencies_met_j1_finished'
304
+ }, 25); // END dependencies_met_user_state_available
254
305
  }, // END init
255
306
 
256
307
  // -------------------------------------------------------------------------
@@ -260,14 +311,14 @@ j1.adapter['themer'] = (function (j1, window) {
260
311
  messageHandler: function (sender, message) {
261
312
  var json_message = JSON.stringify(message, undefined, 2);
262
313
 
263
- logText = 'received message from ' + sender + ': ' + json_message;
314
+ logText = '\n' + 'received message from ' + sender + ': ' + json_message;
264
315
  logger.info(logText);
265
316
 
266
317
  // -----------------------------------------------------------------------
267
318
  // Process commands|actions
268
319
  // -----------------------------------------------------------------------
269
320
  if (message.type === 'command' && message.action === 'module_initialized') {
270
- logger.info(message.text);
321
+ logger.info('\n' + message.text);
271
322
  //
272
323
  // Place handling of other command|action here
273
324
  //