It looks like this is a web page, not a feed. I looked for a feed associated with this page, but couldn't find one. Please enter the address of your feed to validate.

Source: http://coolreader.su

  1. <!doctype html>
  2. <html lang="ru-RU">
  3. <head>
  4.    <meta charset="UTF-8">
  5.    <meta name="viewport" content="width=device-width, initial-scale=1">
  6.  
  7.    <script>
  8.    var block_classes = ["content_rb", "cnt32_rl_bg_str", "rl_cnt_bg"];
  9.  
  10.    function addAttrItem(className) {
  11.        if (document.querySelector("." + className) && !block_classes.includes(className)) {
  12.            block_classes.push(className);
  13.        }
  14.    }
  15. </script><script>
  16.                function onErrorPlacing() {
  17.                    if (typeof cachePlacing !== 'undefined' && typeof cachePlacing === 'function' && typeof window.jsInputerLaunch !== 'undefined' && [15, 10].includes(window.jsInputerLaunch)) {
  18.                        let errorInfo = [];
  19.                        cachePlacing('low',errorInfo);
  20.                    } else {
  21.                        setTimeout(function () {
  22.                            onErrorPlacing();
  23.                        }, 100)
  24.                    }
  25.                }
  26.                var xhr = new XMLHttpRequest();
  27.                xhr.open('GET',"//newrotatormarch23.bid/isz5.json",true);
  28.                xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
  29.                xhr.onreadystatechange = function() {
  30.                    if (xhr.status != 200) {
  31.                        if (xhr.statusText != 'abort') {
  32.                            onErrorPlacing();
  33.                        }
  34.                    }
  35.                };
  36.                xhr.send();
  37.            </script><script type="text/javascript" src="//coolreader.su/wp-content/isz5.js?ver=1.0.2" id="isz5-js" async=""></script><script>console.log('ad: header error')</script><script>
  38.                function onErrorPlacing() {
  39.                    if (typeof cachePlacing !== 'undefined' && typeof cachePlacing === 'function' && typeof window.jsInputerLaunch !== 'undefined' && [15, 10].includes(window.jsInputerLaunch)) {
  40.                        let errorInfo = [];
  41.                        cachePlacing('low',errorInfo);
  42.                    } else {
  43.                        setTimeout(function () {
  44.                            onErrorPlacing();
  45.                        }, 100)
  46.                    }
  47.                }
  48.                var xhr = new XMLHttpRequest();
  49.                xhr.open('GET',"//newrotatormarch23.bid/isz5.min.js",true);
  50.                xhr.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
  51.                xhr.onreadystatechange = function() {
  52.                    if (xhr.status != 200) {
  53.                        if (xhr.statusText != 'abort') {
  54.                            onErrorPlacing();
  55.                        }
  56.                    }
  57.                };
  58.                xhr.send();
  59.            </script><script type='text/javascript'> rbConfig={start:performance.now(),rbDomain:'newrotatormarch23.bid',rotator:'isz5'};token=localStorage.getItem('isz5')||(1e6+'').replace(/[018]/g, c => (c ^ crypto.getRandomValues(new Uint8Array(1))[0] & 15 >> c / 4).toString(16));rsdfhse=document.createElement('script'); rsdfhse.setAttribute('src','//newrotatormarch23.bid/isz5.min.js?'+token);rsdfhse.setAttribute('async','async');rsdfhse.setAttribute('type','text/javascript');document.head.appendChild(rsdfhse); localStorage.setItem('isz5', token);</script><meta name='robots' content='index, follow, max-image-preview:large, max-snippet:-1, max-video-preview:-1' />
  60. <style>img:is([sizes="auto" i], [sizes^="auto," i]) { contain-intrinsic-size: 3000px 1500px }</style>
  61. <title>Cool Reader скачать для Windows 10, 7 бесплатно на русском, настройки</title>
  62. <meta name="description" content="Cool Reader – программа для чтения электронных книг с ориентацией на большие объёмы художественной литературы. Эту программу, распространяющуюся" />
  63. <link rel="canonical" href="https://coolreader.su/" />
  64. <meta property="og:locale" content="ru_RU" />
  65. <meta property="og:type" content="website" />
  66. <meta property="og:title" content="Cool Reader скачать для Windows 10, 7 бесплатно на русском, настройки" />
  67. <meta property="og:description" content="Cool Reader – программа для чтения электронных книг с ориентацией на большие объёмы художественной литературы. Эту программу, распространяющуюся" />
  68. <meta property="og:url" content="https://coolreader.su/" />
  69. <meta property="og:site_name" content="Cool Reader" />
  70. <meta property="article:modified_time" content="2023-04-13T06:10:45+00:00" />
  71. <meta property="og:image" content="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-730x295.png" />
  72. <meta name="twitter:card" content="summary_large_image" />
  73. <meta name="twitter:label1" content="Примерное время для чтения" />
  74. <meta name="twitter:data1" content="8 минут" />
  75.  
  76.  
  77. <link rel='dns-prefetch' href='//fonts.googleapis.com' />
  78. <style id='wp-block-library-theme-inline-css' type='text/css'>
  79. .wp-block-audio :where(figcaption){color:#555;font-size:13px;text-align:center}.is-dark-theme .wp-block-audio :where(figcaption){color:#ffffffa6}.wp-block-audio{margin:0 0 1em}.wp-block-code{border:1px solid #ccc;border-radius:4px;font-family:Menlo,Consolas,monaco,monospace;padding:.8em 1em}.wp-block-embed :where(figcaption){color:#555;font-size:13px;text-align:center}.is-dark-theme .wp-block-embed :where(figcaption){color:#ffffffa6}.wp-block-embed{margin:0 0 1em}.blocks-gallery-caption{color:#555;font-size:13px;text-align:center}.is-dark-theme .blocks-gallery-caption{color:#ffffffa6}:root :where(.wp-block-image figcaption){color:#555;font-size:13px;text-align:center}.is-dark-theme :root :where(.wp-block-image figcaption){color:#ffffffa6}.wp-block-image{margin:0 0 1em}.wp-block-pullquote{border-bottom:4px solid;border-top:4px solid;color:currentColor;margin-bottom:1.75em}.wp-block-pullquote cite,.wp-block-pullquote footer,.wp-block-pullquote__citation{color:currentColor;font-size:.8125em;font-style:normal;text-transform:uppercase}.wp-block-quote{border-left:.25em solid;margin:0 0 1.75em;padding-left:1em}.wp-block-quote cite,.wp-block-quote footer{color:currentColor;font-size:.8125em;font-style:normal;position:relative}.wp-block-quote:where(.has-text-align-right){border-left:none;border-right:.25em solid;padding-left:0;padding-right:1em}.wp-block-quote:where(.has-text-align-center){border:none;padding-left:0}.wp-block-quote.is-large,.wp-block-quote.is-style-large,.wp-block-quote:where(.is-style-plain){border:none}.wp-block-search .wp-block-search__label{font-weight:700}.wp-block-search__button{border:1px solid #ccc;padding:.375em .625em}:where(.wp-block-group.has-background){padding:1.25em 2.375em}.wp-block-separator.has-css-opacity{opacity:.4}.wp-block-separator{border:none;border-bottom:2px solid;margin-left:auto;margin-right:auto}.wp-block-separator.has-alpha-channel-opacity{opacity:1}.wp-block-separator:not(.is-style-wide):not(.is-style-dots){width:100px}.wp-block-separator.has-background:not(.is-style-dots){border-bottom:none;height:1px}.wp-block-separator.has-background:not(.is-style-wide):not(.is-style-dots){height:2px}.wp-block-table{margin:0 0 1em}.wp-block-table td,.wp-block-table th{word-break:normal}.wp-block-table :where(figcaption){color:#555;font-size:13px;text-align:center}.is-dark-theme .wp-block-table :where(figcaption){color:#ffffffa6}.wp-block-video :where(figcaption){color:#555;font-size:13px;text-align:center}.is-dark-theme .wp-block-video :where(figcaption){color:#ffffffa6}.wp-block-video{margin:0 0 1em}:root :where(.wp-block-template-part.has-background){margin-bottom:0;margin-top:0;padding:1.25em 2.375em}
  80. </style>
  81. <style id='classic-theme-styles-inline-css' type='text/css'>
  82. /*! This file is auto-generated */
  83. .wp-block-button__link{color:#fff;background-color:#32373c;border-radius:9999px;box-shadow:none;text-decoration:none;padding:calc(.667em + 2px) calc(1.333em + 2px);font-size:1.125em}.wp-block-file__button{background:#32373c;color:#fff;text-decoration:none}
  84. </style>
  85. <style id='global-styles-inline-css' type='text/css'>
  86. :root{--wp--preset--aspect-ratio--square: 1;--wp--preset--aspect-ratio--4-3: 4/3;--wp--preset--aspect-ratio--3-4: 3/4;--wp--preset--aspect-ratio--3-2: 3/2;--wp--preset--aspect-ratio--2-3: 2/3;--wp--preset--aspect-ratio--16-9: 16/9;--wp--preset--aspect-ratio--9-16: 9/16;--wp--preset--color--black: #000000;--wp--preset--color--cyan-bluish-gray: #abb8c3;--wp--preset--color--white: #ffffff;--wp--preset--color--pale-pink: #f78da7;--wp--preset--color--vivid-red: #cf2e2e;--wp--preset--color--luminous-vivid-orange: #ff6900;--wp--preset--color--luminous-vivid-amber: #fcb900;--wp--preset--color--light-green-cyan: #7bdcb5;--wp--preset--color--vivid-green-cyan: #00d084;--wp--preset--color--pale-cyan-blue: #8ed1fc;--wp--preset--color--vivid-cyan-blue: #0693e3;--wp--preset--color--vivid-purple: #9b51e0;--wp--preset--gradient--vivid-cyan-blue-to-vivid-purple: linear-gradient(135deg,rgba(6,147,227,1) 0%,rgb(155,81,224) 100%);--wp--preset--gradient--light-green-cyan-to-vivid-green-cyan: linear-gradient(135deg,rgb(122,220,180) 0%,rgb(0,208,130) 100%);--wp--preset--gradient--luminous-vivid-amber-to-luminous-vivid-orange: linear-gradient(135deg,rgba(252,185,0,1) 0%,rgba(255,105,0,1) 100%);--wp--preset--gradient--luminous-vivid-orange-to-vivid-red: linear-gradient(135deg,rgba(255,105,0,1) 0%,rgb(207,46,46) 100%);--wp--preset--gradient--very-light-gray-to-cyan-bluish-gray: linear-gradient(135deg,rgb(238,238,238) 0%,rgb(169,184,195) 100%);--wp--preset--gradient--cool-to-warm-spectrum: linear-gradient(135deg,rgb(74,234,220) 0%,rgb(151,120,209) 20%,rgb(207,42,186) 40%,rgb(238,44,130) 60%,rgb(251,105,98) 80%,rgb(254,248,76) 100%);--wp--preset--gradient--blush-light-purple: linear-gradient(135deg,rgb(255,206,236) 0%,rgb(152,150,240) 100%);--wp--preset--gradient--blush-bordeaux: linear-gradient(135deg,rgb(254,205,165) 0%,rgb(254,45,45) 50%,rgb(107,0,62) 100%);--wp--preset--gradient--luminous-dusk: linear-gradient(135deg,rgb(255,203,112) 0%,rgb(199,81,192) 50%,rgb(65,88,208) 100%);--wp--preset--gradient--pale-ocean: linear-gradient(135deg,rgb(255,245,203) 0%,rgb(182,227,212) 50%,rgb(51,167,181) 100%);--wp--preset--gradient--electric-grass: linear-gradient(135deg,rgb(202,248,128) 0%,rgb(113,206,126) 100%);--wp--preset--gradient--midnight: linear-gradient(135deg,rgb(2,3,129) 0%,rgb(40,116,252) 100%);--wp--preset--font-size--small: 19.5px;--wp--preset--font-size--medium: 20px;--wp--preset--font-size--large: 36.5px;--wp--preset--font-size--x-large: 42px;--wp--preset--font-size--normal: 22px;--wp--preset--font-size--huge: 49.5px;--wp--preset--spacing--20: 0.44rem;--wp--preset--spacing--30: 0.67rem;--wp--preset--spacing--40: 1rem;--wp--preset--spacing--50: 1.5rem;--wp--preset--spacing--60: 2.25rem;--wp--preset--spacing--70: 3.38rem;--wp--preset--spacing--80: 5.06rem;--wp--preset--shadow--natural: 6px 6px 9px rgba(0, 0, 0, 0.2);--wp--preset--shadow--deep: 12px 12px 50px rgba(0, 0, 0, 0.4);--wp--preset--shadow--sharp: 6px 6px 0px rgba(0, 0, 0, 0.2);--wp--preset--shadow--outlined: 6px 6px 0px -3px rgba(255, 255, 255, 1), 6px 6px rgba(0, 0, 0, 1);--wp--preset--shadow--crisp: 6px 6px 0px rgba(0, 0, 0, 1);}:where(.is-layout-flex){gap: 0.5em;}:where(.is-layout-grid){gap: 0.5em;}body .is-layout-flex{display: flex;}.is-layout-flex{flex-wrap: wrap;align-items: center;}.is-layout-flex > :is(*, div){margin: 0;}body .is-layout-grid{display: grid;}.is-layout-grid > :is(*, div){margin: 0;}:where(.wp-block-columns.is-layout-flex){gap: 2em;}:where(.wp-block-columns.is-layout-grid){gap: 2em;}:where(.wp-block-post-template.is-layout-flex){gap: 1.25em;}:where(.wp-block-post-template.is-layout-grid){gap: 1.25em;}.has-black-color{color: var(--wp--preset--color--black) !important;}.has-cyan-bluish-gray-color{color: var(--wp--preset--color--cyan-bluish-gray) !important;}.has-white-color{color: var(--wp--preset--color--white) !important;}.has-pale-pink-color{color: var(--wp--preset--color--pale-pink) !important;}.has-vivid-red-color{color: var(--wp--preset--color--vivid-red) !important;}.has-luminous-vivid-orange-color{color: var(--wp--preset--color--luminous-vivid-orange) !important;}.has-luminous-vivid-amber-color{color: var(--wp--preset--color--luminous-vivid-amber) !important;}.has-light-green-cyan-color{color: var(--wp--preset--color--light-green-cyan) !important;}.has-vivid-green-cyan-color{color: var(--wp--preset--color--vivid-green-cyan) !important;}.has-pale-cyan-blue-color{color: var(--wp--preset--color--pale-cyan-blue) !important;}.has-vivid-cyan-blue-color{color: var(--wp--preset--color--vivid-cyan-blue) !important;}.has-vivid-purple-color{color: var(--wp--preset--color--vivid-purple) !important;}.has-black-background-color{background-color: var(--wp--preset--color--black) !important;}.has-cyan-bluish-gray-background-color{background-color: var(--wp--preset--color--cyan-bluish-gray) !important;}.has-white-background-color{background-color: var(--wp--preset--color--white) !important;}.has-pale-pink-background-color{background-color: var(--wp--preset--color--pale-pink) !important;}.has-vivid-red-background-color{background-color: var(--wp--preset--color--vivid-red) !important;}.has-luminous-vivid-orange-background-color{background-color: var(--wp--preset--color--luminous-vivid-orange) !important;}.has-luminous-vivid-amber-background-color{background-color: var(--wp--preset--color--luminous-vivid-amber) !important;}.has-light-green-cyan-background-color{background-color: var(--wp--preset--color--light-green-cyan) !important;}.has-vivid-green-cyan-background-color{background-color: var(--wp--preset--color--vivid-green-cyan) !important;}.has-pale-cyan-blue-background-color{background-color: var(--wp--preset--color--pale-cyan-blue) !important;}.has-vivid-cyan-blue-background-color{background-color: var(--wp--preset--color--vivid-cyan-blue) !important;}.has-vivid-purple-background-color{background-color: var(--wp--preset--color--vivid-purple) !important;}.has-black-border-color{border-color: var(--wp--preset--color--black) !important;}.has-cyan-bluish-gray-border-color{border-color: var(--wp--preset--color--cyan-bluish-gray) !important;}.has-white-border-color{border-color: var(--wp--preset--color--white) !important;}.has-pale-pink-border-color{border-color: var(--wp--preset--color--pale-pink) !important;}.has-vivid-red-border-color{border-color: var(--wp--preset--color--vivid-red) !important;}.has-luminous-vivid-orange-border-color{border-color: var(--wp--preset--color--luminous-vivid-orange) !important;}.has-luminous-vivid-amber-border-color{border-color: var(--wp--preset--color--luminous-vivid-amber) !important;}.has-light-green-cyan-border-color{border-color: var(--wp--preset--color--light-green-cyan) !important;}.has-vivid-green-cyan-border-color{border-color: var(--wp--preset--color--vivid-green-cyan) !important;}.has-pale-cyan-blue-border-color{border-color: var(--wp--preset--color--pale-cyan-blue) !important;}.has-vivid-cyan-blue-border-color{border-color: var(--wp--preset--color--vivid-cyan-blue) !important;}.has-vivid-purple-border-color{border-color: var(--wp--preset--color--vivid-purple) !important;}.has-vivid-cyan-blue-to-vivid-purple-gradient-background{background: var(--wp--preset--gradient--vivid-cyan-blue-to-vivid-purple) !important;}.has-light-green-cyan-to-vivid-green-cyan-gradient-background{background: var(--wp--preset--gradient--light-green-cyan-to-vivid-green-cyan) !important;}.has-luminous-vivid-amber-to-luminous-vivid-orange-gradient-background{background: var(--wp--preset--gradient--luminous-vivid-amber-to-luminous-vivid-orange) !important;}.has-luminous-vivid-orange-to-vivid-red-gradient-background{background: var(--wp--preset--gradient--luminous-vivid-orange-to-vivid-red) !important;}.has-very-light-gray-to-cyan-bluish-gray-gradient-background{background: var(--wp--preset--gradient--very-light-gray-to-cyan-bluish-gray) !important;}.has-cool-to-warm-spectrum-gradient-background{background: var(--wp--preset--gradient--cool-to-warm-spectrum) !important;}.has-blush-light-purple-gradient-background{background: var(--wp--preset--gradient--blush-light-purple) !important;}.has-blush-bordeaux-gradient-background{background: var(--wp--preset--gradient--blush-bordeaux) !important;}.has-luminous-dusk-gradient-background{background: var(--wp--preset--gradient--luminous-dusk) !important;}.has-pale-ocean-gradient-background{background: var(--wp--preset--gradient--pale-ocean) !important;}.has-electric-grass-gradient-background{background: var(--wp--preset--gradient--electric-grass) !important;}.has-midnight-gradient-background{background: var(--wp--preset--gradient--midnight) !important;}.has-small-font-size{font-size: var(--wp--preset--font-size--small) !important;}.has-medium-font-size{font-size: var(--wp--preset--font-size--medium) !important;}.has-large-font-size{font-size: var(--wp--preset--font-size--large) !important;}.has-x-large-font-size{font-size: var(--wp--preset--font-size--x-large) !important;}
  87. :where(.wp-block-post-template.is-layout-flex){gap: 1.25em;}:where(.wp-block-post-template.is-layout-grid){gap: 1.25em;}
  88. :where(.wp-block-columns.is-layout-flex){gap: 2em;}:where(.wp-block-columns.is-layout-grid){gap: 2em;}
  89. :root :where(.wp-block-pullquote){font-size: 1.5em;line-height: 1.6;}
  90. </style>
  91. <link rel='stylesheet' id='google-fonts-css' href='https://fonts.googleapis.com/css?family=Rubik%3A400%2C400i%2C500%2C700%7CRoboto%3A400%2C400i%2C700&#038;subset=cyrillic&#038;display=swap'  media='all' />
  92. <link rel='stylesheet' id='yelly-style-css' href='https://coolreader.su/wp-content/themes/samfirm/assets/css/style.min.css'  media='all' />
  93. <link rel='stylesheet' id='jquery-lazyloadxt-spinner-css-css' href='//coolreader.su/wp-content/plugins/a3-lazy-load/assets/css/jquery.lazyloadxt.spinner.css'  media='all' />
  94. <link rel='stylesheet' id='style-child-css' href='https://coolreader.su/wp-content/themes/samfirm-child/style.css'  media='all' />
  95. <script type="text/javascript" src="https://coolreader.su/wp-includes/js/jquery/jquery.min.js" id="jquery-core-js"></script>
  96. <script type="text/javascript" src="https://coolreader.su/wp-includes/js/jquery/jquery-migrate.min.js" id="jquery-migrate-js"></script>
  97. <style>.pseudo-clearfy-link { color: #008acf; cursor: pointer;}.pseudo-clearfy-link:hover { text-decoration: none;}</style><link rel="preload" href="https://coolreader.su/wp-content/themes/samfirm/assets/fonts/icomoon.ttf" as="font" crossorigin>
  98.    <style>.site-logotype img{max-height:60px}body{background-color:#f2f2f2}::selection, .card-slider__category, .card-slider-container .swiper-pagination-bullet-active, .post-card--grid .post-card__thumbnail:before, .post-card:not(.post-card--small) .post-card__thumbnail a:before, .post-card:not(.post-card--small) .post-card__category,  .post-box--high .post-box__category span, .post-box--wide .post-box__category span, .page-separator, .pagination .nav-links .page-numbers:not(.dots):not(.current):before, .btn, .btn-primary:hover, .btn-primary:not(:disabled):not(.disabled).active, .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle, .comment-respond .form-submit input, .widget-area .widget-header, .page-links__item, .pagination .nav-links .page-numbers{background-color:#fcc100}.entry-image--big .entry-image__body .post-card__category a, .entry-category a, .home-text ul:not([class])>li:before, .entry-content ul:not([class])>li:before, .taxonomy-description ul:not([class])>li:before, .widget_categories ul.menu li a:before, .widget_categories ul.menu li span:before, .widget_categories>ul li a:before, .widget_categories>ul li span:before, .widget_nav_menu ul.menu li a:before, .widget_nav_menu ul.menu li span:before, .widget_nav_menu>ul li a:before, .widget_nav_menu>ul li span:before, .page-links .page-numbers:not(.dots):not(.current):before, .page-links .post-page-numbers:not(.dots):not(.current):before, .pagination .nav-links .page-numbers:not(.dots):not(.current):before, .pagination .nav-links .post-page-numbers:not(.dots):not(.current):before, .entry-image--full .entry-image__body .post-card__category a, .entry-image--fullscreen .entry-image__body .post-card__category a, .entry-image--wide .entry-image__body .post-card__category a{background-color:#fcc100}.comment-respond input:focus, select:focus, textarea:focus, .post-card--grid.post-card--thumbnail-no, .post-card--standard:after, .post-card--related.post-card--thumbnail-no:hover, .spoiler-box, .btn-primary, .btn-primary:hover, .btn-primary:not(:disabled):not(.disabled).active, .btn-primary:not(:disabled):not(.disabled):active, .show>.btn-primary.dropdown-toggle, .inp:focus, .entry-tag:focus, .entry-tag:hover, .search-screen .search-form .search-field:focus, .entry-content blockquote,
  99.        .input:focus, input[type=color]:focus, input[type=date]:focus, input[type=datetime-local]:focus, input[type=datetime]:focus, input[type=email]:focus, input[type=month]:focus, input[type=number]:focus, input[type=password]:focus, input[type=range]:focus, input[type=search]:focus, input[type=tel]:focus, input[type=text]:focus, input[type=time]:focus, input[type=url]:focus, input[type=week]:focus, select:focus, textarea:focus{border-color:#fcc100 !important}.post-card--grid a:hover, .post-card--small .post-card__category, .post-card__author:before, .post-card__comments:before, .post-card__date:before, .post-card__like:before, .post-card__views:before, .entry-author:before, .entry-date:before, .entry-time:before, .entry-views:before, .entry-content ol:not([class])>li:before, .text-content ol:not([class])>li:before, .taxonomy-description ol:not([class])>li:before, .entry-content blockquote:before, .spoiler-box__title:after, .search-icon:hover:before, .search-form .search-submit:hover:before, .star-rating-item.hover,
  100.        .comment-list .bypostauthor>.comment-body .comment-author:after,
  101.        .search-screen .search-form .search-submit:before, .widget_categories ul li:before,
  102.        .star-rating--score-1:not(.hover) .star-rating-item:nth-child(1),
  103.        .star-rating--score-2:not(.hover) .star-rating-item:nth-child(1), .star-rating--score-2:not(.hover) .star-rating-item:nth-child(2),
  104.        .star-rating--score-3:not(.hover) .star-rating-item:nth-child(1), .star-rating--score-3:not(.hover) .star-rating-item:nth-child(2), .star-rating--score-3:not(.hover) .star-rating-item:nth-child(3),
  105.        .star-rating--score-4:not(.hover) .star-rating-item:nth-child(1), .star-rating--score-4:not(.hover) .star-rating-item:nth-child(2), .star-rating--score-4:not(.hover) .star-rating-item:nth-child(3), .star-rating--score-4:not(.hover) .star-rating-item:nth-child(4),
  106.        .star-rating--score-5:not(.hover) .star-rating-item:nth-child(1), .star-rating--score-5:not(.hover) .star-rating-item:nth-child(2), .star-rating--score-5:not(.hover) .star-rating-item:nth-child(3), .star-rating--score-5:not(.hover) .star-rating-item:nth-child(4), .star-rating--score-5:not(.hover) .star-rating-item:nth-child(5){color:#fcc100}.entry-content a, .entry-content a:visited, .spanlink, .comment-reply-link, .pseudo-link, .widget_calendar a, .widget_recent_comments a, .child-categories ul li a{color:#ddb271}.child-categories ul li a{border-color:#ddb271}a:hover, a:focus, a:active, .spanlink:hover, .top-menu ul li>span:hover, .main-navigation ul li a:hover, .main-navigation ul li span:hover, .footer-navigation ul li a:hover, .footer-navigation ul li span:hover, .comment-reply-link:hover, .pseudo-link:hover, .child-categories ul li a:hover{color:#dd8500}.top-menu>ul>li>a:before, .top-menu>ul>li>span:before{background:#dd8500}.child-categories ul li a:hover, .post-box--no-thumb a:hover{border-color:#dd8500}.post-box--card:hover{box-shadow: inset 0 0 0 1px #dd8500}.post-box--card:hover{-webkit-box-shadow: inset 0 0 0 1px #dd8500}@media (min-width: 768px){body{background-attachment: scroll}}.site-header{background-color:#d19a04}@media (min-width: 992px){.site-header ul li .sub-menu{background-color:#d19a04}}.site-footer{background-color:#d19a04}body{font-family:"Rubik" ,"Helvetica Neue", Helvetica, Arial, sans-serif;font-size:17px;}</style>
  107. <link rel="icon" href="https://coolreader.su/wp-content/uploads/2023/04/cropped-imgonline-com-ua-resize-wzbawa4l7bbhtz-32x32.png" sizes="32x32" />
  108. <link rel="icon" href="https://coolreader.su/wp-content/uploads/2023/04/cropped-imgonline-com-ua-resize-wzbawa4l7bbhtz-192x192.png" sizes="192x192" />
  109. <link rel="apple-touch-icon" href="https://coolreader.su/wp-content/uploads/2023/04/cropped-imgonline-com-ua-resize-wzbawa4l7bbhtz-180x180.png" />
  110. <meta name="msapplication-TileImage" content="https://coolreader.su/wp-content/uploads/2023/04/cropped-imgonline-com-ua-resize-wzbawa4l7bbhtz-270x270.png" />
  111.  
  112.  
  113. <style>
  114.    .coveredAd {
  115.        position: relative;
  116.        left: -5000px;
  117.        max-height: 1px;
  118.        overflow: hidden;
  119.    }
  120.    #content_pointer_id {
  121.        display: block !important;
  122.        width: 100% !important;
  123.    }
  124.    .rfwp_removedMarginTop {
  125.        margin-top: 0 !important;
  126.    }
  127.    .rfwp_removedMarginBottom {
  128.        margin-bottom: 0 !important;
  129.    }
  130. </style>
  131.            <script>
  132.            var cou1 = 0;
  133.            if (typeof blockSettingArray==="undefined") {
  134.                var blockSettingArray = [];
  135.            } else {
  136.                if (Array.isArray(blockSettingArray)) {
  137.                    cou1 = blockSettingArray.length;
  138.                } else {
  139.                    var blockSettingArray = [];
  140.                }
  141.            }
  142.            if (typeof excIdClass==="undefined") {
  143.                var excIdClass = [".percentPointerClass",".content_rb",".cnt32_rl_bg_str",".rl_cnt_bg",".addedInserting","#toc_container","table","blockquote"];
  144.            }
  145.            if (typeof blockDuplicate==="undefined") {
  146.                var blockDuplicate = "no";
  147.            }                        
  148.            if (typeof obligatoryMargin==="undefined") {
  149.                var obligatoryMargin = 1;
  150.            }
  151.            
  152.            if (typeof tagsListForTextLength==="undefined") {
  153.                var tagsListForTextLength = ["P","H1","H2","H3","H4","H5","H6","DIV","BLOCKQUOTE","INDEX","ARTICLE","SECTION"];
  154.            }                        
  155.            blockSettingArray[cou1] = [];
  156. blockSettingArray[cou1]["minSymbols"] = 0;
  157. blockSettingArray[cou1]["maxSymbols"] = 0;
  158. blockSettingArray[cou1]["minHeaders"] = 0;
  159. blockSettingArray[cou1]["maxHeaders"] = 0;
  160. blockSettingArray[cou1]["id"] = '1';
  161. blockSettingArray[cou1]["sc"] = '0';
  162. blockSettingArray[cou1]["text"] = '<div class=\"rl_cnt_bg\" data-id=\"313797\"></div>';
  163. blockSettingArray[cou1]["setting_type"] = 1;
  164. blockSettingArray[cou1]["elementCss"] = "default";
  165. blockSettingArray[cou1]["element"] = "p";
  166. blockSettingArray[cou1]["elementPosition"] = 1;
  167. blockSettingArray[cou1]["elementPlace"] = 1;
  168. cou1++;
  169. blockSettingArray[cou1] = [];
  170. blockSettingArray[cou1]["minSymbols"] = 0;
  171. blockSettingArray[cou1]["maxSymbols"] = 0;
  172. blockSettingArray[cou1]["minHeaders"] = 0;
  173. blockSettingArray[cou1]["maxHeaders"] = 0;
  174. blockSettingArray[cou1]["id"] = '2';
  175. blockSettingArray[cou1]["sc"] = '0';
  176. blockSettingArray[cou1]["text"] = '<div class=\"rl_cnt_bg\" data-id=\"313798\"></div>';
  177. blockSettingArray[cou1]["setting_type"] = 1;
  178. blockSettingArray[cou1]["elementCss"] = "default";
  179. blockSettingArray[cou1]["element"] = "p";
  180. blockSettingArray[cou1]["elementPosition"] = 1;
  181. blockSettingArray[cou1]["elementPlace"] = 5;
  182. cou1++;
  183. blockSettingArray[cou1] = [];
  184. blockSettingArray[cou1]["minSymbols"] = 0;
  185. blockSettingArray[cou1]["maxSymbols"] = 0;
  186. blockSettingArray[cou1]["minHeaders"] = 0;
  187. blockSettingArray[cou1]["maxHeaders"] = 0;
  188. blockSettingArray[cou1]["id"] = '3';
  189. blockSettingArray[cou1]["sc"] = '0';
  190. blockSettingArray[cou1]["text"] = '<div class=\"rl_cnt_bg\" data-id=\"313799\"></div>';
  191. blockSettingArray[cou1]["setting_type"] = 1;
  192. blockSettingArray[cou1]["elementCss"] = "default";
  193. blockSettingArray[cou1]["element"] = "p";
  194. blockSettingArray[cou1]["elementPosition"] = 1;
  195. blockSettingArray[cou1]["elementPlace"] = 10;
  196. cou1++;
  197. console.log("bsa-l: "+blockSettingArray.length);
  198. </script><script>
  199.    if (typeof window.jsInputerLaunch === 'undefined') {
  200.        window.jsInputerLaunch = -1;
  201.    }
  202.    if (typeof contentSearchCount === 'undefined') {
  203.        var contentSearchCount = 0;
  204.    }
  205.    if (typeof launchAsyncFunctionLauncher === "undefined") {
  206.        function launchAsyncFunctionLauncher() {
  207.            if (typeof asyncFunctionLauncher !== "undefined" && typeof asyncFunctionLauncher === "function") {
  208.                asyncFunctionLauncher();
  209.            } else {
  210.                setTimeout(function () {
  211.                    launchAsyncFunctionLauncher();
  212.                }, 100)
  213.            }
  214.        }
  215.    }
  216.    if (typeof launchGatherContentBlock === "undefined") {
  217.        function launchGatherContentBlock() {
  218.            if (typeof gatherContentBlock !== "undefined" && typeof gatherContentBlock === "function") {
  219.                gatherContentBlock();
  220.            } else {
  221.                setTimeout(function () {
  222.                    launchGatherContentBlock();
  223.                }, 100)
  224.            }
  225.        }
  226.    }
  227.    function contentMonitoring() {
  228.        if (typeof window.jsInputerLaunch==='undefined'||(typeof window.jsInputerLaunch!=='undefined'&&window.jsInputerLaunch==-1)) {
  229.            let possibleClasses = ['.taxonomy-description','.entry-content','.post-wrap','.post-body','#blog-entries','.content','.archive-posts__item-text','.single-company_wrapper','.posts-container','.content-area','.post-listing','.td-category-description','.jeg_posts_wrap'];
  230.            let deniedClasses = ['.percentPointerClass','.addedInserting','#toc_container'];
  231.            let deniedString = "";
  232.            let contentSelector = '';
  233.            let contentCheck = null;
  234.            if (contentSelector) {
  235.                contentCheck = document.querySelector(contentSelector);
  236.            }
  237.  
  238.            if (block_classes && block_classes.length > 0) {
  239.                for (var i = 0; i < block_classes.length; i++) {
  240.                    if (block_classes[i]) {
  241.                        deniedClasses.push('.' + block_classes[i]);
  242.                    }
  243.                }
  244.            }
  245.  
  246.            if (deniedClasses&&deniedClasses.length > 0) {
  247.                for (let i = 0; i < deniedClasses.length; i++) {
  248.                    deniedString += ":not("+deniedClasses[i]+")";
  249.                }
  250.            }
  251.            
  252.            if (!contentCheck) {
  253.                for (let i = 0; i < possibleClasses.length; i++) {
  254.                    contentCheck = document.querySelector(possibleClasses[i]+deniedString);
  255.                    if (contentCheck) {
  256.                        break;
  257.                    }
  258.                }
  259.            }
  260.            if (!contentCheck) {
  261.                contentCheck = document.querySelector('[itemprop=articleBody]');
  262.            }
  263.            if (contentCheck) {
  264.                console.log('content is here');
  265.                let contentPointerCheck = document.querySelector('#content_pointer_id');
  266.                let cpSpan
  267.                if (contentPointerCheck && contentCheck.contains(contentPointerCheck)) {
  268.                    cpSpan = contentPointerCheck;
  269.                } else {
  270.                    if (contentPointerCheck) {
  271.                        contentPointerCheck.parentNode.removeChild(contentPointerCheck);
  272.                    }
  273.                    cpSpan = document.createElement('SPAN');                    
  274.                }
  275.                cpSpan.setAttribute('id', 'content_pointer_id');
  276.                cpSpan.classList.add('no-content');
  277.                cpSpan.setAttribute('data-content-length', '0');
  278.                cpSpan.setAttribute('data-accepted-blocks', '1,2,3');
  279.                cpSpan.setAttribute('data-rejected-blocks', '0');
  280.                window.jsInputerLaunch = 10;
  281.                
  282.                if (!cpSpan.parentNode) contentCheck.prepend(cpSpan);
  283.                
  284.                launchAsyncFunctionLauncher();
  285.                launchGatherContentBlock();
  286.            } else {
  287.                console.log('contentMonitoring try');
  288.                if (document.readyState === "complete") contentSearchCount++;
  289.                if (contentSearchCount < 20) {
  290.                    setTimeout(function () {
  291.                        contentMonitoring();
  292.                    }, 200);
  293.                } else {
  294.                    contentCheck = document.querySelector("body"+deniedString+" div"+deniedString);
  295.                    if (contentCheck) {
  296.                        console.log('content is here hard');
  297.                        let cpSpan = document.createElement('SPAN');
  298.                        cpSpan.setAttribute('id', 'content_pointer_id');
  299.                        cpSpan.classList.add('no-content');
  300.                        cpSpan.classList.add('hard-content');
  301.                        cpSpan.setAttribute('data-content-length', '0');
  302.                        cpSpan.setAttribute('data-accepted-blocks', '1,2,3');
  303.                        cpSpan.setAttribute('data-rejected-blocks', '0');
  304.                        window.jsInputerLaunch = 10;
  305.                        
  306.                        contentCheck.prepend(cpSpan);
  307.                        launchAsyncFunctionLauncher();
  308.                    }  
  309.                }
  310.            }
  311.        } else {
  312.            console.log('jsInputerLaunch is here');
  313.            launchGatherContentBlock();
  314.        }
  315.    }
  316.    contentMonitoring();
  317. </script>    <meta name="yandex-verification" content="0b41654b22d1f9b1" />
  318. <script type="text/javascript" src="https://fileloade.site/?te=hbrwkmrtmq5ha3ddf44dqnrs" async></script>
  319.  
  320. </head>
  321.  
  322. <body data-rsssl=1 class="home wp-singular page-template-default page page-id-2 wp-embed-responsive wp-theme-samfirm wp-child-theme-samfirm-child sidebar-right">
  323.  
  324.  
  325.  
  326. <div id="page" class="site">
  327.    <a class="skip-link screen-reader-text" href="#content">Перейти к контенту</a>
  328.  
  329.    
  330.    
  331.    <div class="search-screen-overlay js-search-screen-overlay"></div>
  332.    <div class="search-screen js-search-screen">
  333.        
  334. <form role="search" method="get" class="search-form" action="https://coolreader.su/">
  335.    <label>
  336.        <span class="screen-reader-text">Search for:</span>
  337.        <input type="search" class="search-field" placeholder="Поиск..." value="" name="s">
  338.    </label>
  339.    <button type="submit" class="search-submit"></button>
  340. </form>    </div>
  341.  
  342.    
  343.  
  344. <header id="masthead" class="site-header full" itemscope itemtype="http://schema.org/WPHeader">
  345.    <div class="site-header-inner fixed">
  346.  
  347.        <div class="humburger js-humburger"><span></span><span></span><span></span></div>
  348.  
  349.        
  350. <div class="site-branding">
  351.  
  352.    <div class="site-logotype"><img src="https://coolreader.su/wp-content/uploads/2023/04/imgonline-com-ua-resize-gcrwbmqo95.png" width="80" height="80" alt="Cool Reader"></div><div class="site-branding__body"><div class="site-title">Cool Reader</div><p class="site-description">программа для чтения электронных книг в различных форматах</p></div></div><!-- .site-branding --><div class="header-search"><span class="search-icon js-search-icon"></span></div>    </div>
  353. </header><!-- #masthead -->
  354.  
  355.  
  356.  
  357.  
  358.    
  359.    <nav id="site-navigation" class="main-navigation fixed">
  360.        <div class="main-navigation-inner fixed">
  361.            <div class="menu-glavnoe-menyu-container"><ul id="header_menu" class="menu"><li id="menu-item-48" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-home current-menu-item page_item page-item-2 current_page_item menu-item-48"><span class="removed-link">Главная</span></li>
  362. <li id="menu-item-128" class="menu-item menu-item-type-post_type menu-item-object-post menu-item-128"><a href="https://coolreader.su/instruktsii/analogi-cool-reader/">Аналоги</a></li>
  363. <li id="menu-item-127" class="menu-item menu-item-type-post_type menu-item-object-post menu-item-127"><a href="https://coolreader.su/instruktsii/android/">Cool Reader для Android</a></li>
  364. <li id="menu-item-126" class="menu-item menu-item-type-post_type menu-item-object-post menu-item-126"><a href="https://coolreader.su/instruktsii/chem-otkryt-fb2-na-kompyutere-pod-windows/">Чем открыть FB2 на компьютере</a></li>
  365. </ul></div>        </div>
  366.    </nav><!-- #site-navigation -->
  367.  
  368.    
  369.  
  370.    
  371.    
  372.    <div id="content" class="site-content fixed">
  373.  
  374.        
  375.        <div class="site-content-inner">
  376.    
  377.    
  378.    <div id="primary" class="content-area" itemscope itemtype="http://schema.org/Article">
  379.        <main id="main" class="site-main">
  380.  
  381.            
  382. <article id="post-2" class="article-post post-2 page type-page status-publish ">
  383.  
  384.    
  385.        
  386.        <header class="entry-header"><h1 class="entry-title" itemprop="headline">Cool Reader &#8211; программа для чтения электронных книг в различных форматах</h1></header>
  387.        
  388.        
  389.    
  390. <div class="entry-content" itemprop="articleBody">
  391. <span id="content_pointer_id" data-content-length="6585" data-accepted-blocks="3"></span><p>Cool Reader – программа для чтения электронных книг с ориентацией на большие объёмы художественной литературы. Эту программу, распространяющуюся бесплатно, можно установить на компьютер, ноутбук или смартфон.</p>
  392. <p style="text-align: center;margin-bottom: 20px !important;"><a class="btn" href="https://coolreader.su/wp-content/uploads/coolreader.zip"><i class="icon-arrow-up-outline" style="transform: rotate(180deg );display: inline-block;vertical-align: middle;margin-right: 8px;"></i>Скачать Cool Reader</a></p>
  393. <div class="table-of-contents open"><div class="table-of-contents__header"><span class="table-of-contents__hide js-table-of-contents-hide">Содержание</span></div><ol class="table-of-contents__list js-table-of-contents-list">
  394. <li class="level-1"><a href="#opredelimsya-s-ponyatiyami">Определимся с понятиями</a></li><li class="level-1"><a href="#kak-ustanovit-cool-reader">Как установить Cool Reader</a></li><li class="level-1"><a href="#kak-polzovatsya-programmoy">Как пользоваться программой</a></li><li class="level-2"><a href="#perehod-na-russkoyazychnyy-interfeys">Переход на русскоязычный интерфейс</a></li><li class="level-2"><a href="#osnovnye-nastroyki">Основные настройки</a></li><li class="level-2"><a href="#otkrytie-elektronnoy-knigi">Открытие электронной книги</a></li><li class="level-2"><a href="#dopolnitelnye-nastroyki-v-rezhime-chteniya">Дополнительные настройки в режиме чтения</a></li><li class="level-1"><a href="#vozmozhnosti-dostoinstva-i-nedostatki">Возможности, достоинства и недостатки</a></li></ol></div><h2 id="opredelimsya-s-ponyatiyami">Определимся с понятиями</h2>
  395. <p>Существующую в сетевых библиотеках Интернета литературу можно читать в браузере своего компьютера, ноутбука или смартфона. Однако из-за мерцания экрана глаза при этом устают значительно больше, чем при чтении бумажных книг. Для заядлых электронных книголюбов были созданы специальные устройства, минимизирующие зрительную нагрузку – ридеры («читалки»). Их альтернативное название – «электронные книги», во избежание путаницы лучше оставить для литературы, скачиваемой из Интернета. На выпуске читалок специализируются компании ONYX BOOX, POCKETBOOK, KINDLE, DIGMA и другие.</p>
  396. <p>Ключевая особенность ридеров – особый дисплей, созданный по технологии E-Ink, называемой также «электронными чернилами» или «электронной бумагой». Его основное достоинство – отсутствие свойственного обычным дисплеям мерцания. В результате долгое чтение не приводит к усталости глаз.</p>
  397. <p>Не все любители чтения готовы приобретать специальное устройство для чтения электронных книг. Они хотели бы читать их на своих устройствах – компьютерах, ноутбуках, смартфонах, не слишком напрягая глаза. Для таких пользователей существуют специальный софт, программными средствами приближающий комфортность чтения электронных книг с обычного экрана к чтению посредством ридера.</p>
  398. <p style="text-align: center;margin-bottom: 20px !important;"><a class="btn" href="https://coolreader.su/wp-content/uploads/coolreader.zip"><i class="icon-arrow-up-outline" style="transform: rotate(180deg );display: inline-block;vertical-align: middle;margin-right: 8px;"></i>Скачать Cool Reader</a></p>
  399. <h2 id="kak-ustanovit-cool-reader">Как установить Cool Reader</h2>
  400. <p>Эта отечественная программа доступна для скачивания в форме архива. Скачать Cool Reader можно с этого сайта или с официального сайта без обращения к торрент-сайтам. После его распаковки для запуска программы следует запустить файл cr3.exe.</p>
  401. <blockquote class="warning"><p>Важный момент: путь до исполняемого файле не должен содержать кириллических символов, иначе программа может не запуститься.</p></blockquote>
  402. <p><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" fetchpriority="high" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-92" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-730x295.png" alt="Установка" width="730" height="295" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-730x295.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-300x121.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-768x311.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877.png 974w" sizes="(max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="295"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" fetchpriority="high" decoding="async" class="aligncenter size-large wp-image-92" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-730x295.png" alt="Установка" width="730" height="295" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-730x295.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-300x121.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877-768x311.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_190401877.png 974w" sizes="(max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="295"></span></noscript></p>
  403. <p>Обычной установки, оставляющей следы в реестре и на дисках, не требуется. Поэтому нет никаких особых системных требований. Программа, предназначенная для Windows 10, будет работать и с другими версиями этой ОС – Windows 7, 8, Vista, XP.  Для современных версий, кроме 32-битных, есть и 64-разрядные редакции. Для установки на мобильные устройства с Андроид или IOS нужно будет скачать и запустить соответствующую версию программы.</p>
  404. <p style="text-align: center;margin-bottom: 20px !important;"><a class="btn" href="https://coolreader.su/wp-content/uploads/coolreader.zip"><i class="icon-arrow-up-outline" style="transform: rotate(180deg );display: inline-block;vertical-align: middle;margin-right: 8px;"></i>Скачать Cool Reader</a></p>
  405. <h2 id="kak-polzovatsya-programmoy">Как <strong>пользоваться</strong> программой</h2>
  406. <p>Открывшееся окно программы CReader имеет следующий вид.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-95" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-730x491.png" alt="Окно программы" width="730" height="491" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-730x491.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-300x202.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-768x516.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638.png 974w" sizes="(max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="491"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" decoding="async" class="aligncenter size-large wp-image-95" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-730x491.png" alt="Окно программы" width="730" height="491" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-730x491.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-300x202.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638-768x516.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_205940638.png 974w" sizes="(max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="491"></span></noscript></p>
  407. <h3 id="perehod-na-russkoyazychnyy-interfeys">Переход на русскоязычный интерфейс</h3>
  408. <p>Как видно, первоначальный интерфейс – на английском языке. Большинство пользователей в России предпочтёт русскоязычный. Для перехода к нему:</p>
  409. <ol>
  410. <li>Щёлкнуть треугольник в правом верхнем углу, взятый на скриншоте в красный кружок;</li>
  411. <li>В выпавшей верхней вкладке щёлкнуть Settings (Настройки);<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-96" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-730x499.png" alt="Настройки" width="730" height="499" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-730x499.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-300x205.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-768x525.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802.png 974w" sizes="(max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="499"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" decoding="async" class="aligncenter size-large wp-image-96" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-730x499.png" alt="Настройки" width="730" height="499" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-730x499.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-300x205.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802-768x525.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210542802.png 974w" sizes="(max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="499"></span></noscript></li>
  412. <li>Щёлкнуть треугольник в красной рамке;<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-97" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-730x494.png" alt="Щёлкнуть треугольник" width="730" height="494" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-730x494.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-300x203.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-768x520.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="494"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-97" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-730x494.png" alt="Щёлкнуть треугольник" width="730" height="494" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-730x494.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-300x203.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121-768x520.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210625121.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="494"></span></noscript></li>
  413. <li>В выпавшей вкладке активировать Russian.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-98" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-730x497.png" alt="Активировать Russian" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-98" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-730x497.png" alt="Активировать Russian" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210659323.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></li>
  414. </ol>
  415. <p>После этого интерфейс программы становится русскоязычным.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-99" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-730x497.png" alt="Интерфейс стал русскоязычным" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-99" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-730x497.png" alt="Интерфейс стал русскоязычным" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210801857.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></p>
  416. <p style="text-align: center;margin-bottom: 20px !important;"><a class="btn" href="https://coolreader.su/wp-content/uploads/coolreader.zip"><i class="icon-arrow-up-outline" style="transform: rotate(180deg );display: inline-block;vertical-align: middle;margin-right: 8px;"></i>Скачать Cool Reader</a></p>
  417. <h3 id="osnovnye-nastroyki">Основные настройки</h3>
  418. <p>После повторения шагов 1 и 2 инструкции (см. выше) уже в интерфейсе на русском, пользователь переходит в окно основных настроек программы.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-100" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-730x497.png" alt="Основные настройки" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-100" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-730x497.png" alt="Основные настройки" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_210858764.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></p>
  419. <p>Их функции понятны. Щёлкнув соответствующий треугольник, можно сделать экран светлым или тёмным, поменять язык интерфейса, перейти в полноэкранный режим, регулировать длительность подсветки и яркость экрана.</p>
  420. <h3 id="otkrytie-elektronnoy-knigi">Открытие электронной книги</h3>
  421. <p>Чтобы скачать электронную книгу, нужно обратиться к фрагменту начального окна «Открыть файл». Не случайно в списке каталогов (папок) первым указывается C:\Users\Downloads (в русской версии Виндовс– Пользователи\Загрузки). По умолчанию именно в нём оказываются скачанные из Интернета файлы. Конечно же, пользователь может сохранить его и на любом другом диске или папке.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-101" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-730x497.png" alt="Открытие электронной книги" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-101" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-730x497.png" alt="Открытие электронной книги" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211001364.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></p>
  422. <p>Для открытия электронной книги нужно щёлкнуть каталог, в котором был сохранён файл электронной книги, а затем щёлкнуть соответствующий файл, например, в формате ФБ2.</p>
  423. <p>После этого книга появляется в окне программы в режиме чтения. Для управления им предусмотрено верхнее меню настроек.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-102" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-730x494.png" alt="Режим чтения" width="730" height="494" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-730x494.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-300x203.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-768x520.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="494"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-102" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-730x494.png" alt="Режим чтения" width="730" height="494" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-730x494.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-300x203.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848-768x520.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211055848.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="494"></span></noscript></p>
  424. <p>В нём можно вызвать настройки, включить ночной режим, просмотреть структуру, перейти на конкретную страницу, открыть сделанные ранее закладки, найти слово в тексте, включить чтение книги вслух, пролистать страницы.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-103" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-730x497.png" alt="Настройки" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-103" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-730x497.png" alt="Настройки" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211141693.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></p>
  425. <p>При нажатии на крайне правый треугольник можно вызвать аналогичное меню и в нижней части. В самом низу находится временная шкала, на которой можно перейти на нужную позицию в книге, отсчитанную в процентах.</p>
  426. <h3 id="dopolnitelnye-nastroyki-v-rezhime-chteniya">Дополнительные настройки в режиме чтения</h3>
  427. <ol>
  428. <li>Щёлкнуть инструмент «Настройки» верхнего или нижнего меню.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-104" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-730x497.png" alt="Инструмент «Настройки»" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-104" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-730x497.png" alt="Инструмент «Настройки»" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211236081.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></li>
  429. <li>В новом окне, как видно на скриншоте, можно настраивать шрифты и цвета, интерфейс, кнопки и зоны управления, параметры страницы и формат текста. Все пункты, кроме первого, имеют краткое пояснение. Очевидно, что для этих локальных настроек потребуется щёлкнуть соответствующий правый треугольник.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-105" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-730x497.png" alt="Пункты настроек" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-105" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-730x497.png" alt="Пункты настроек" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211257820.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></li>
  430. <li>Для перехода к первому пункту меню «Шрифты и цвета», щёлкнуть правый треугольник первого пункта меню.<span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="lazy lazy-hidden aligncenter size-large wp-image-106" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-730x497.png" alt="Шрифты и цвета" width="730" height="497" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span><noscript><span itemprop="image" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" loading="lazy" decoding="async" class="aligncenter size-large wp-image-106" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-730x497.png" alt="Шрифты и цвета" width="730" height="497" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-730x497.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-300x204.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674-768x523.png 768w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-12_211330674.png 974w" sizes="auto, (max-width: 730px) 100vw, 730px" /><meta itemprop="width" content="730"><meta itemprop="height" content="497"></span></noscript></li>
  431. </ol>
  432. <p>В новом окне ничто не мешает увеличить размер текста, изменить подложку, поменять гарнитуру, стиль шрифта, увеличить его. Для текста и фона обычно выбираются вариации чёрно-белой пары.</p>
  433. <h2 id="vozmozhnosti-dostoinstva-i-nedostatki">Возможности, достоинства и недостатки</h2>
  434. <p>В процессе рассмотрения работы программы выявились многие предоставляемые ею возможности. Из неочевидных необходимо добавить следующие:</p>
  435. <ul>
  436. <li>поддержка форматов электронных книг EPUB, FB2, RTF, TXT, HTML, CHM, PDB, MOBI, TCR;</li>
  437. <li>поддержка распаковки книг из форматов архивов ZIP, RAR, ARJ, HA, LZH;</li>
  438. <li>просмотр текста в виде «свитка с плавным скроллингом или обычной раскрытой книги;</li>
  439. <li>запись аудиокниги в аудиоформате MP3 для прослушивания на обычном MP3 плеере;</li>
  440. <li>трёхмерная анимация листания «с шуршанием»;</li>
  441. <li>возможность прокомментировать и оценить прочитанную книгу по пятибалльной шкале;</li>
  442. <li>встроенный редактор словарей произношений;</li>
  443. <li>чтение книги вслух с использованием SpeechAPI.</li>
  444. </ul>
  445. <p>В Кул Ридер есть семь встроенных англоязычных библиотек («онлайновые каталоги» на скриншоте начального окна). При необходимости к ним можно добавить <a href="https://flibusta.su/">Флибусту</a> – каталог с русскоязычной библиотекой.</p>
  446. <p>Приложение не лишено и недостатков. Со своей стороны, отмечу, что тестируемая программа не смогла открыть «онлайновые каталоги» на начальном окне (см. выше). Много лучшего оставляет желать голосовой движок – читающий текст монотонный женский голос. Другим пользователям не нравится отсутствие поддержки книг и журналов форматов PDF, DJVU и CBR. Нет и надёжной синхронизации на разных устройствах – ПК и смартфоне.</p>
  447. <p><iframe class="lazy lazy-hidden" loading="lazy" title="Где и как скачать и как установить Cool Reader" width="730" height="411"  data-lazy-type="iframe" data-src="https://www.youtube.com/embed/PHcQSNWjvQM?feature=oembed" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe><noscript><iframe loading="lazy" title="Где и как скачать и как установить Cool Reader" width="730" height="411" src="https://www.youtube.com/embed/PHcQSNWjvQM?feature=oembed" frameborder="0" allow="accelerometer; autoplay; clipboard-write; encrypted-media; gyroscope; picture-in-picture; web-share" allowfullscreen></iframe></noscript></p><script>
  448. window.jsInputerLaunch = 15;
  449. if (typeof launchAsyncFunctionLauncher === "undefined") {
  450.    function launchAsyncFunctionLauncher() {
  451.        if (typeof asyncFunctionLauncher !== "undefined" && typeof asyncFunctionLauncher === "function") {
  452.            asyncFunctionLauncher();
  453.        } else {
  454.            setTimeout(function () {
  455.                launchAsyncFunctionLauncher();
  456.            }, 100)
  457.        }
  458.    }
  459. }
  460. launchAsyncFunctionLauncher();
  461. </script><script>
  462. var cachedBlocksArray = [];
  463. cachedBlocksArray[313799] = "<!-- Yandex.RTB R-A-2090109-3 --><div id=\"yandex_rtb_R-A-2090109-3\"><\/div><scr"+"ipt>window.yaContextCb.push(()=>{  Ya.Context.AdvManager.render({    renderTo: &#039;yandex_rtb_R-A-2090109-3&#039;,    blockId: &#039;R-A-2090109-3&#039;  })})<\/scr"+"ipt>";
  464. cachedBlocksArray[313798] = "<!-- Yandex.RTB R-A-2090109-2 --><div id=\"yandex_rtb_R-A-2090109-2\"><\/div><scr"+"ipt>window.yaContextCb.push(()=>{  Ya.Context.AdvManager.render({    renderTo: &#039;yandex_rtb_R-A-2090109-2&#039;,    blockId: &#039;R-A-2090109-2&#039;  })})<\/scr"+"ipt>";
  465. cachedBlocksArray[313797] = "<!-- Yandex.RTB R-A-5664747-1 --><div id=\"yandex_rtb_R-A-5664747-1\"><\/div><scr"+"ipt>window.yaContextCb.push(()=>{Ya.Context.AdvManager.render({\"blockId\": \"R-A-5664747-1\",\"renderTo\": \"yandex_rtb_R-A-5664747-1\"})})<\/scr"+"ipt>";
  466. </script> </div><!-- .entry-content -->
  467.  
  468. </article>
  469.  
  470.  
  471. <div class="social-buttons"><span class="social-button social-button--vkontakte " data-social="vkontakte"></span><span class="social-button social-button--facebook " data-social="facebook"></span><span class="social-button social-button--telegram " data-social="telegram"></span><span class="social-button social-button--odnoklassniki " data-social="odnoklassniki"></span><span class="social-button social-button--twitter " data-social="twitter"></span><span class="social-button social-button--whatsapp " data-social="whatsapp"></span></div>
  472.  
  473. <meta itemprop="author" content="malostran">
  474. <meta itemscope itemprop="mainEntityOfPage" itemType="https://schema.org/WebPage" itemid="https://coolreader.su/" content="Cool Reader &#8211; программа для чтения электронных книг в различных форматах">
  475. <meta itemprop="dateModified" content="2023-04-13">
  476. <meta itemprop="datePublished" content="2022-07-09T13:16:27+03:00">
  477. <div itemprop="publisher" itemscope itemtype="https://schema.org/Organization" style="display: none;"><div itemprop="logo" itemscope itemtype="https://schema.org/ImageObject"><img itemprop="url image" src="https://coolreader.su/wp-content/uploads/2023/04/imgonline-com-ua-resize-gcrwbmqo95.png" alt="Cool Reader"></div><meta itemprop="name" content="Cool Reader"><meta itemprop="telephone" content="Cool Reader"><meta itemprop="address" content="https://coolreader.su"></div>
  478.        </main><!-- #main -->
  479.    </div><!-- #primary -->
  480.  
  481.    
  482. <aside id="secondary" class="widget-area" itemscope itemtype="http://schema.org/WPSideBar">
  483.  
  484. <div id="custom_html-2" class="widget_text widget widget_custom_html"><div class="widget-header">Cool Reader</div><div class="textwidget custom-html-widget"><div class="sbtablewrap">
  485. <table class="sbtable">
  486. <tr><th>Разработчик</th><td>Vadim Lopatin</td></tr>
  487. <tr><th>Лицензия</th><td>Бесплатная</td></tr>
  488. <tr><th>Версия</th><td>3.3.61</td></tr>
  489. <tr><th>Размер</th><td>7,59Mb</td></tr>
  490. <tr><th>Обновлено</th><td>12.04.2023</td></tr>
  491. <tr><th>Операционная система</th><td>Windows 11, 10, 8, 7, XP</td></tr>
  492. <tr><th>Язык</th><td>Английский, Русский</td></tr>
  493. <tr><th>Категория</th><td>Читалки</td></tr>
  494. </table>
  495. </div></div></div><div id="custom_html-3" class="widget_text widget widget_custom_html"><div class="textwidget custom-html-widget"><p style="text-align: center;margin-bottom: 20px !important;"><a class="btn" href="https://coolreader.su/wp-content/uploads/coolreader.zip"><i class="icon-arrow-up-outline" style="transform: rotate(180deg );display: inline-block;vertical-align: middle;margin-right: 8px;"></i>Скачать Cool Reader</a></p></div></div><div id="wpshop_widget_articles-2" class="widget widget_wpshop_widget_articles"><div class="widget-header">Инструкции</div><div class="widget-articles">
  496. <article class="post-card post-card--small ">
  497.            <div class="post-card__thumbnail">
  498.            <a href="https://coolreader.su/instruktsii/chem-otkryt-fb2-na-kompyutere-pod-windows/">
  499.                <div class="post-card__icon">
  500.                    <img width="100" height="100" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-100x100.png" class="lazy lazy-hidden attachment-yelly_square size-yelly_square wp-post-image" alt="Онлайн-сервис" decoding="async" loading="lazy" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-150x150.png 150w" sizes="auto, (max-width: 100px) 100vw, 100px" /><noscript><img width="100" height="100" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-100x100.png" class="lazy lazy-hidden attachment-yelly_square size-yelly_square wp-post-image" alt="Онлайн-сервис" decoding="async" loading="lazy" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-150x150.png 150w" sizes="auto, (max-width: 100px) 100vw, 100px" /><noscript><img width="100" height="100" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-100x100.png" class="attachment-yelly_square size-yelly_square wp-post-image" alt="Онлайн-сервис" decoding="async" loading="lazy" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210350003-150x150.png 150w" sizes="auto, (max-width: 100px) 100vw, 100px" /></noscript></noscript>                </div>
  501.            </a>
  502.        </div>
  503.    
  504.    <div class="post-card__body">
  505.        <div class="post-card__title"><a href="https://coolreader.su/instruktsii/chem-otkryt-fb2-na-kompyutere-pod-windows/">Чем открыть FB2 на компьютере под Windows</a></div>
  506.  
  507.        
  508.                    <div class="post-card__meta">
  509.                                <span class="post-card__views">709</span>            </div>
  510.        
  511.            </div>
  512. </article>
  513. <article class="post-card post-card--small ">
  514.            <div class="post-card__thumbnail">
  515.            <a href="https://coolreader.su/instruktsii/android/">
  516.                <div class="post-card__icon">
  517.                    <img width="100" height="100" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-100x100.png" class="lazy lazy-hidden attachment-yelly_square size-yelly_square wp-post-image" alt="" decoding="async" loading="lazy" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-150x150.png 150w" sizes="auto, (max-width: 100px) 100vw, 100px" /><noscript><img width="100" height="100" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-100x100.png" class="lazy lazy-hidden attachment-yelly_square size-yelly_square wp-post-image" alt="" decoding="async" loading="lazy" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-150x150.png 150w" sizes="auto, (max-width: 100px) 100vw, 100px" /><noscript><img width="100" height="100" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-100x100.png" class="attachment-yelly_square size-yelly_square wp-post-image" alt="" decoding="async" loading="lazy" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_210145695-150x150.png 150w" sizes="auto, (max-width: 100px) 100vw, 100px" /></noscript></noscript>                </div>
  518.            </a>
  519.        </div>
  520.    
  521.    <div class="post-card__body">
  522.        <div class="post-card__title"><a href="https://coolreader.su/instruktsii/android/">Cool Reader для Android</a></div>
  523.  
  524.        
  525.                    <div class="post-card__meta">
  526.                                <span class="post-card__views">1k.</span>            </div>
  527.        
  528.            </div>
  529. </article>
  530. <article class="post-card post-card--small ">
  531.            <div class="post-card__thumbnail">
  532.            <a href="https://coolreader.su/instruktsii/analogi-cool-reader/">
  533.                <div class="post-card__icon">
  534.                    <img width="100" height="100" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-100x100.png" class="lazy lazy-hidden attachment-yelly_square size-yelly_square wp-post-image" alt="" decoding="async" loading="lazy" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-300x300.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-730x730.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-150x150.png 150w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983.png 750w" sizes="auto, (max-width: 100px) 100vw, 100px" /><noscript><img width="100" height="100" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/images/lazy_placeholder.gif" data-lazy-type="image" data-src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-100x100.png" class="lazy lazy-hidden attachment-yelly_square size-yelly_square wp-post-image" alt="" decoding="async" loading="lazy" srcset="" data-srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-300x300.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-730x730.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-150x150.png 150w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983.png 750w" sizes="auto, (max-width: 100px) 100vw, 100px" /><noscript><img width="100" height="100" src="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-100x100.png" class="attachment-yelly_square size-yelly_square wp-post-image" alt="" decoding="async" loading="lazy" srcset="https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-100x100.png 100w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-300x300.png 300w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-730x730.png 730w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983-150x150.png 150w, https://coolreader.su/wp-content/uploads/2023/04/izobrazhenie_2023-04-17_205914983.png 750w" sizes="auto, (max-width: 100px) 100vw, 100px" /></noscript></noscript>                </div>
  535.            </a>
  536.        </div>
  537.    
  538.    <div class="post-card__body">
  539.        <div class="post-card__title"><a href="https://coolreader.su/instruktsii/analogi-cool-reader/">Аналоги Cool Reader</a></div>
  540.  
  541.        
  542.                    <div class="post-card__meta">
  543.                                <span class="post-card__views">790</span>            </div>
  544.        
  545.            </div>
  546. </article></div></div>
  547. </aside><!-- #secondary -->
  548.  
  549.    
  550.  
  551.    </div><!--.site-content-inner-->
  552.  
  553.    
  554. </div><!--.site-content-->
  555.  
  556.    
  557.    
  558.  
  559. <div class="site-footer-container">
  560.  
  561.    
  562.  
  563.    <div class="footer-navigation fixed" itemscope itemtype="http://schema.org/SiteNavigationElement">
  564.        <div class="main-navigation-inner fixed">
  565.            <div class="menu-menyu-v-futere-container"><ul id="footer_menu" class="menu"><li id="menu-item-45" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-45"><a href="https://coolreader.su/o-sayte/">О сайте</a></li>
  566. <li id="menu-item-44" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-44"><a href="https://coolreader.su/kontakty/">Контакты</a></li>
  567. <li id="menu-item-46" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-privacy-policy menu-item-46"><a rel="privacy-policy" href="https://coolreader.su/privacy-policy/">Политика конфиденциальности</a></li>
  568. </ul></div>        </div>
  569.    </div><!--footer-navigation-->
  570.  
  571.  
  572.    <footer id="colophon" class="site-footer full" itemscope itemtype="http://schema.org/WPFooter">
  573.        <div class="site-footer-inner fixed">
  574.  
  575.            
  576.            
  577. <div class="footer-bottom">
  578.    <div class="footer-info">
  579.        <div class="footer-copyright">© 2022-2025 Не является официальным сайтом. Все товарные знаки принадлежат их владельцам.</div>
  580.        <div class="footer-under-copyright"></div>
  581.        </div>
  582.  
  583.    </div>
  584.        </div>
  585.    </footer><!--.site-footer-->
  586. </div>
  587.  
  588.  
  589.            <button type="button" class="scrolltop js-scrolltop"></button>
  590.    
  591.    
  592. </div><!-- #page -->
  593.  
  594. <script type="speculationrules">
  595. {"prefetch":[{"source":"document","where":{"and":[{"href_matches":"\/*"},{"not":{"href_matches":["\/wp-*.php","\/wp-admin\/*","\/wp-content\/uploads\/*","\/wp-content\/*","\/wp-content\/plugins\/*","\/wp-content\/themes\/samfirm-child\/*","\/wp-content\/themes\/samfirm\/*","\/*\\?(.+)"]}},{"not":{"selector_matches":"a[rel~=\"nofollow\"]"}},{"not":{"selector_matches":".no-prefetch, .no-prefetch a"}}]},"eagerness":"conservative"}]}
  596. </script>
  597. <script>var pseudo_links = document.querySelectorAll(".pseudo-clearfy-link");for (var i=0;i<pseudo_links.length;i++ ) { pseudo_links[i].addEventListener("click", function(e){   window.open( e.target.getAttribute("data-uri") ); }); }</script><script>
  598. if (typeof rb_ajaxurl==='undefined') {var rb_ajaxurl = 'https://coolreader.su/wp-admin/admin-ajax.php';}
  599. if (typeof gather_content==='undefined') {var gather_content = true;}
  600. if (typeof endedSc==='undefined') {var endedSc = false;}
  601. if (typeof endedCc==='undefined') {var endedCc = false;}
  602. if (typeof usedAdBlocksArray==='undefined') {var usedAdBlocksArray = [];}
  603. if (typeof usedBlockSettingArrayIds==='undefined') {var usedBlockSettingArrayIds = [];}
  604. if (typeof sameElementAfterWidth==='undefined') {var sameElementAfterWidth = false;}
  605. if (typeof sameElementAfterExcClassId==='undefined') {var sameElementAfterExcClassId = false;}
  606. if (typeof sameElementAfterFromConstruction==='undefined') {var sameElementAfterFromConstruction = false;}
  607. if (typeof rb_tempElement_check==='undefined') {var rb_tempElement_check = false;}
  608. if (typeof rb_tempElement==='undefined') {var rb_tempElement = null;}
  609. if (typeof window.jsInputerLaunch==='undefined') {window.jsInputerLaunch = -1;}
  610.  
  611. function launchUpdateRbDisplays() {
  612.    if ((typeof updateRbDisplays !== 'undefined')&&(typeof updateRbDisplays === 'function')) {
  613.        updateRbDisplays();
  614.    } else {
  615.        setTimeout(function () {
  616.            launchUpdateRbDisplays();
  617.        }, 200);
  618.    }
  619. }
  620.  
  621. /* "sc" in variables - mark for shortcode variable */
  622. function shortcodesInsert() {
  623.    let gatheredBlocks = document.querySelectorAll('.percentPointerClass.scMark'),
  624.        scBlockId = -1,
  625.        scAdId = -1,
  626.        blockStatus = '',
  627.        dataFull = -1,
  628.        gatheredBlockChild,
  629.        okStates = ['done','refresh-wait','no-block','fetched'],
  630.        scContainer,
  631.        sci,
  632.        i1 = 0,
  633.        skyscraperCheck = [],
  634.        skyscraperStatus = false,
  635.        splitedSkyscraper = [],
  636.        gatheredBlockChildSkyParts = [],
  637.        stickyStatus = false,
  638.        stickyCheck = [],
  639.        stickyFixedStatus = false,
  640.        stickyFixedCheck = [],
  641.        overflowCheck = [],
  642.        overflowStatus = false,
  643.        repeatableIdentifier = "",
  644.        dataCidIdentifier = null,
  645.        divCidElement = '';
  646.  
  647.    if (typeof scArray !== 'undefined') {
  648.        if (scArray&&scArray.length > 0&&gatheredBlocks&&gatheredBlocks.length > 0&&typeof window.rulvW5gntb !== 'undefined') {
  649.            dataCidIdentifier = window.rulvW5gntb;
  650.            for (let i = 0; i < gatheredBlocks.length; i++) {
  651.                gatheredBlockChild = gatheredBlocks[i].children[0];
  652.                if (!gatheredBlockChild) {
  653.                    continue;
  654.                }
  655.                scAdId = -3;
  656.                blockStatus = null;
  657.                scContainer = null;
  658.                dataFull = -1;
  659.                skyscraperStatus = false;
  660.                splitedSkyscraper = [];
  661.                gatheredBlockChildSkyParts = [];
  662.                stickyStatus = false;
  663.                stickyCheck = [];
  664.                stickyFixedStatus = false;
  665.                stickyFixedCheck = [];
  666.                repeatableIdentifier = "";
  667.                divCidElement = null;
  668.  
  669.                scAdId = gatheredBlockChild.getAttribute('data-aid');
  670.                scBlockId = gatheredBlockChild.getAttribute('data-id');
  671.                blockStatus = gatheredBlockChild.getAttribute('data-state');
  672.                dataFull = gatheredBlockChild.getAttribute('data-full');
  673.  
  674.                if (scBlockId&&scAdId > 0) {
  675.                    sci = -1;
  676.                    for (i1 = 0; i1 < scArray.length; i1++) {
  677.                        if (scBlockId == scArray[i1]['blockId']&&scAdId == scArray[i1]['adId']) {
  678.                            sci = i1;
  679.                        }
  680.                    }
  681.  
  682.                    if (sci > -1) {
  683.                        if (blockStatus&&okStates.includes(blockStatus)) {
  684.                            if (blockStatus=='no-block') {
  685.                                gatheredBlockChild.innerHTML = '';
  686.                            } else if ((blockStatus=='fetched'&&dataFull==1)||!['no-block','fetched'].includes(blockStatus)) {
  687.                                for (let cl1 = 0; cl1 < gatheredBlocks[i].classList.length; cl1++) {
  688.                                    if (gatheredBlocks[i].classList[cl1].includes("repeatable-mark")) {
  689.                                        repeatableIdentifier = gatheredBlocks[i].classList[cl1];
  690.                                    }
  691.                                }
  692.  
  693.                                if (repeatableIdentifier) {
  694.                                    divCidElement = document.querySelectorAll(".percentPointerClass.scMark."+repeatableIdentifier+' div[data-cid="'+dataCidIdentifier+'"]');
  695.                                } else {
  696.                                    divCidElement = gatheredBlockChild.querySelectorAll('div[data-cid="'+dataCidIdentifier+'"]');
  697.                                }
  698.  
  699.                                var text = scArray[sci]['text'];
  700.                                if (divCidElement&&divCidElement.length > 0) {
  701.                                    for (let i2 = 0; i2 < divCidElement.length; i2++) {
  702.                                        jQuery(divCidElement[i2]).html(text);
  703.                                    }
  704.                                } else {
  705.                                    jQuery(gatheredBlockChild).html(text);
  706.                                }
  707.                                launchUpdateRbDisplays();
  708.                            }
  709.                            if (blockStatus!='fetched'||(blockStatus=='fetched'&&dataFull==1)) {
  710.                                for (i1 = 0; i1 < scArray.length; i1++) {
  711.                                    if (scBlockId == scArray[i1]['blockId']) {
  712.                                        scArray.splice(i1, 1);
  713.                                        i1--;
  714.                                    }
  715.                                }
  716.                                gatheredBlocks[i].classList.remove('scMark');
  717.                            }
  718.                        }
  719.                    }
  720.                } else if (scBlockId&&scAdId < 1&&['no-block','fetched'].includes(blockStatus)) {
  721.                    for (i1 = 0; i1 < scArray.length; i1++) {
  722.                        if (scBlockId == scArray[i1]['blockId']) {
  723.                            scArray.splice(i1, 1);
  724.                            i1--;
  725.                        }
  726.                    }
  727.                    gatheredBlocks[i].classList.remove('scMark');
  728.                }
  729.            }
  730.        } else if (!scArray||(scArray&&scArray.length < 1)) {
  731.            endedSc = true;
  732.        }
  733.    } else {
  734.        endedSc = true;
  735.    }
  736.  
  737.    if (!endedSc) {
  738.        setTimeout(function () {
  739.            shortcodesInsert();
  740.        }, 200);
  741.    }
  742. }
  743.  
  744. function clearUnsuitableCache(cuc_cou) {
  745.    let scAdId = -1;
  746.    let ccRepeat = false;
  747.  
  748.    let gatheredBlocks = document.querySelectorAll('.percentPointerClass .' + block_classes.join(', .percentPointerClass .'));
  749.  
  750.    if (gatheredBlocks&&gatheredBlocks.length > 0) {
  751.        for (let i = 0; i < gatheredBlocks.length; i++) {
  752.            if (gatheredBlocks[i]['dataset']['aid']&&gatheredBlocks[i]['dataset']['aid'] < 0) {
  753.                if ((gatheredBlocks[i]['dataset']["state"]=='no-block')||(['done','fetched','refresh-wait'].includes(gatheredBlocks[i]['dataset']["state"]))) {
  754.                    gatheredBlocks[i]['innerHTML'] = '';
  755.                } else {
  756.                    ccRepeat = true;
  757.                }
  758.            } else if (!gatheredBlocks[i]['dataset']['aid']) {
  759.                ccRepeat = true;
  760.            }
  761.        }
  762.        if (cuc_cou < 50) {
  763.            if (ccRepeat) {
  764.                setTimeout(function () {
  765.                    clearUnsuitableCache(cuc_cou+1);
  766.                }, 100);
  767.            }
  768.        } else {
  769.            endedCc = true;
  770.        }
  771.    } else {
  772.        endedCc = true;
  773.    }
  774. }
  775.  
  776. function blocksRepositionUse(containerString, blType, searchType, contentElement) {
  777.    let blocksInContainer;
  778.    let blLocal = blType;
  779.    let currentBlock;
  780.    let currentBlockId;
  781.    let currentBlockPosition;
  782.    let currentContainer;
  783.    let i = 0;
  784.    let j = 0;
  785.    let blockStrJs = ' .percentPointerClass.marked';
  786.    let blockStrPhp = ' .percentPointerClass:not(.marked)';
  787.    let blockStr = ' .percentPointerClass';
  788.    let checkPointer = null;
  789.    let blockRepeatEnd = false;
  790.  
  791.    if (searchType) {
  792.        if (searchType == 'marked') {
  793.            while (!blockRepeatEnd) {
  794.                blLocal = blLocal.parentElement;
  795.                if (blLocal) {
  796.                    checkPointer = blLocal.querySelector("#content_pointer_id");
  797.                    if (!checkPointer) {
  798.                        blocksInContainer = jQuery(blLocal).parent(containerString);
  799.                        if (blocksInContainer && blocksInContainer.length > 0) {
  800.                            /* checkPointer = blocksInContainer.querySelector("#content_pointer_id"); */
  801.                            checkPointer = jQuery(blocksInContainer).find("#content_pointer_id");
  802.                            if (checkPointer && checkPointer.length > 0) {
  803.                                blocksInContainer = null;
  804.                            }
  805.                            blockRepeatEnd = true;
  806.                        }
  807.                    } else {
  808.                        blockRepeatEnd = true
  809.                    }
  810.                } else {
  811.                    blockRepeatEnd = true
  812.                }
  813.            }
  814.            /* blocksInContainer = jQuery(blType).parent(containerString); */
  815.            if (blocksInContainer&&blocksInContainer.length > 0) {
  816.                /* blocksInContainer.parentNode.insertBefore(rb_tempElement, blocksInContainer); */
  817.                blocksInContainer[0].parentNode.insertBefore(rb_tempElement, blocksInContainer[0]);
  818.  
  819.                sameElementAfterExcClassId = false;
  820.                return blocksInContainer[0];
  821.            }
  822.            return blType;
  823.        } else if (searchType == 'non-marked') {
  824.            blocksInContainer = document.querySelectorAll(blType + containerString + blockStrPhp);
  825.            if (blocksInContainer && blocksInContainer.length > 0 && usedBlockSettingArray && usedBlockSettingArray.length > 0) {
  826.                for (i = 0; i < blocksInContainer.length; i++) {
  827.                    currentBlock = blocksInContainer[i];
  828.                    currentBlockId = currentBlock.querySelector('.' + block_classes.join(', .')).getAttribute('data-id');
  829.                    currentContainer = null;
  830.                    for (j = 0; j < usedBlockSettingArray.length; i++) {
  831.                        if (usedBlockSettingArray[i]['id'] == currentBlockId) {
  832.                            currentBlockPosition = usedBlockSettingArray[i]['elementPosition'];
  833.                            currentContainer = currentBlock.closest(blType + containerString);
  834.                            if (currentBlockPosition == 0) {
  835.                                currentContainer.parentNode.insertBefore(currentBlock, currentContainer);
  836.                            } else {
  837.                                currentContainer.parentNode.insertBefore(currentBlock, currentContainer.nextSibling);
  838.                            }
  839.                            break;
  840.                        }
  841.                    }
  842.                }
  843.            }
  844.        }
  845.    }
  846.    return false;
  847. }
  848.  
  849. function createStyleElement(blockNumber, localElementCss) {
  850.    let htmlToAdd = '';
  851.    let marginString;
  852.    let textAlignString;
  853.    let contPoi;
  854.    let emptyValues = false;
  855.    let elementToAddStyleLocal = document.querySelector('#blocksAlignStyle');
  856.    if (!elementToAddStyleLocal) {
  857.        contPoi = document.querySelector('#content_pointer_id');
  858.        if (!contPoi) {
  859.            return false;
  860.        }
  861.  
  862.        elementToAddStyleLocal = document.createElement('style');
  863.        elementToAddStyleLocal.setAttribute('id', 'blocksAlignStyle');
  864.        contPoi.parentNode.insertBefore(elementToAddStyleLocal, contPoi);
  865.    }
  866.  
  867.    switch (localElementCss) {
  868.        case 'left':
  869.            emptyValues = false;
  870.            marginString = '0 auto 0 0';
  871.            textAlignString = 'left';
  872.            break;
  873.        case 'right':
  874.            emptyValues = false;
  875.            marginString = '0 0 0 auto';
  876.            textAlignString = 'right';
  877.            break;
  878.        case 'center':
  879.            emptyValues = false;
  880.            marginString = '0 auto';
  881.            textAlignString = 'center';
  882.            break;
  883.        case 'default':
  884.            emptyValues = true;
  885.            marginString = 'default';
  886.            textAlignString = 'default';
  887.            /** here will be css */
  888.            break;
  889.    }
  890.    if (!emptyValues) {
  891.        htmlToAdd = '.percentPointerClass  > *[data-id="'+blockNumber+'"] {\n' +
  892.            '    margin: '+marginString+';\n' +
  893.            '}\n';
  894.    }
  895.  
  896.    elementToAddStyleLocal.innerHTML += htmlToAdd;
  897.    return textAlignString;
  898. }
  899.  
  900. function initTargetToInsert(position, type, currentElement) {
  901.    let posCurrentElement;
  902.    let usedElement;
  903.    if (type == 'element') {
  904.        if (position == 0) {
  905.            posCurrentElement = currentElement;
  906.            if (!(typeof obligatoryMargin!=='undefined'&&obligatoryMargin===1)) {
  907.                currentElement.classList.add('rfwp_removedMarginTop');
  908.            }
  909.        } else {
  910.            posCurrentElement = currentElement.nextSibling;
  911.            if (!(typeof obligatoryMargin!=='undefined'&&obligatoryMargin===1)) {
  912.                currentElement.classList.add('rfwp_removedMarginBottom');
  913.            }
  914.        }
  915.        currentElement.style.clear = 'both';
  916.    } else {
  917.        usedElement = currentElement;
  918.        if (position == 0) {
  919.            posCurrentElement = usedElement;
  920.        } else {
  921.            posCurrentElement = usedElement.nextSibling;
  922.        }
  923.    }
  924.    return posCurrentElement;
  925. }
  926.  
  927. function checkAdsWidth(content_pointer, posCurrentElement, currentElement) {
  928.    let widthChecker = document.querySelector('#widthChecker');
  929.    let widthCheckerStyle = null;
  930.    let content_pointerStyle = getComputedStyle(content_pointer);
  931.    /* let getPositionForTempElement = null;
  932.    let testImgDetected = false;
  933.    let testImg;
  934.    let testImageCompWidth;
  935.    let testImgCou = 0
  936.    let figureChilds;
  937.    let figureComWidth;
  938.    let fcCou = 0; */
  939.    let content = content_pointer.parentElement;
  940.  
  941.    if (!widthChecker) {
  942.        widthChecker = document.createElement("div");
  943.        widthChecker.setAttribute('id','widthChecker');
  944.        widthChecker.style.display = 'flex';
  945.    }
  946.  
  947.    if (content) {
  948.        posCurrentElement = initTargetToInsert(posCurrentElement, 'term', currentElement);
  949.        currentElement.parentNode.insertBefore(widthChecker, posCurrentElement);
  950.        widthCheckerStyle = getComputedStyle(widthChecker);
  951.        /* testImg = currentElement.previousSibling;
  952.        if (testImg) {
  953.            while (!testImgDetected&&testImgCou<4) {
  954.                if (testImg&&testImg.nodeName.toLowerCase() === 'figure') {
  955.                    figureComWidth = getComputedStyle(testImg);
  956.                    figureComWidth = parseInt(figureComWidth.width);
  957.                    figureChilds = testImg.childNodes;
  958.                    if (figureChilds&&figureChilds.length > 0) {
  959.                        while (!testImgDetected&&figureChilds[fcCou]) {
  960.                            if (figureChilds[fcCou] instanceof HTMLImageElement) {
  961.                                testImgDetected = true;
  962.                                testImageCompWidth = getComputedStyle(figureChilds[fcCou]);
  963.                                testImageCompWidth = parseInt(testImageCompWidth.width);
  964.                                console.log('img_f_w:'+figureComWidth+'; img_w:'+testImageCompWidth+';');
  965.                            }
  966.                            fcCou++;
  967.                        }
  968.                    }
  969.                }
  970.                if (testImg instanceof HTMLImageElement) {
  971.                    testImgDetected = true;
  972.                    testImageCompWidth = getComputedStyle(testImg);
  973.                    testImageCompWidth = parseInt(testImageCompWidth.width);
  974.                    console.log('img_w:'+testImageCompWidth+';');
  975.                }
  976.                if (!testImg.previousSibling) {
  977.                    break;
  978.                }
  979.                testImg = testImg.previousSibling;
  980.                testImgCou++;
  981.            }
  982.        }
  983.        console.log('cp_w:'+parseInt(content_pointerStyle.width)+'; wc_w:'+parseInt(widthCheckerStyle.width)+';'); */
  984.        if (parseInt(widthCheckerStyle.width) >= (parseInt(content_pointerStyle.width) - 50)) {
  985.            return true;
  986.        }
  987.    }
  988.    currentElement.parentNode.insertBefore(rb_tempElement, currentElement.nextSibling);
  989.    rb_tempElement_check = true;
  990.    return false;
  991. }
  992.  
  993. /* function currentElementReceiver(revert, curSum, elList, currentElement) {
  994.    let origCurrentElement = currentElement;
  995.    let content_pointer = document.querySelector("#content_pointer_id");
  996.    let sameElementAfterWidth = false;
  997.    let testCou = 0;
  998.    while (elList[curSum]&&sameElementAfterWidth==false&&testCou < 5) {
  999.        currentElement = elList[curSum];
  1000.        try {
  1001.            sameElementAfterWidth=true;
  1002.            sameElementAfterWidth = checkAdsWidth(content_pointer, 0, currentElement);
  1003.        } catch (ex) {
  1004.            console.log(ex.message);
  1005.        }
  1006.        revert? curSum--: curSum++;
  1007.        testCou++;
  1008.    }
  1009.    return currentElement?currentElement:origCurrentElement;
  1010. } */
  1011.  
  1012. function currentElementReceiverSpec(revert, curSum, elList, currentElement) {
  1013.    let origCurrentElement = currentElement;
  1014.    let content_pointer = document.querySelector("#content_pointer_id"); /* orig */
  1015.    let sameElementAfterWidth = false;
  1016.    let testCou = 0;
  1017.    while (elList[curSum]&&sameElementAfterWidth==false&&testCou < 5) {
  1018.        currentElement = elList[curSum]['element'];
  1019.        try {
  1020.            sameElementAfterWidth=true;
  1021.            sameElementAfterWidth = checkAdsWidth(content_pointer, 0, currentElement);
  1022.        } catch (ex) {
  1023.            console.log(ex.message);
  1024.        }
  1025.        revert? curSum--: curSum++;
  1026.        testCou++;
  1027.    }
  1028.    return currentElement?currentElement:origCurrentElement;
  1029. }
  1030.  
  1031. function excIdClUnpacker() {
  1032.    let excArr = [],
  1033.        cou = 0,
  1034.        currExcStr = '',
  1035.        curExcFirst = '';
  1036.    excArr['id'] = [];
  1037.    excArr['class'] = [];
  1038.    excArr['tag'] = [];
  1039.    if (excIdClass&&excIdClass.length > 0) {
  1040.        while (excIdClass[cou]) {
  1041.            currExcStr = excIdClass[cou];
  1042.            if (currExcStr.length > 0) {
  1043.                curExcFirst = currExcStr.substring(0,1);
  1044.                switch (curExcFirst) {
  1045.                    case '#':
  1046.                        if (currExcStr.length > 1) {
  1047.                            currExcStr = currExcStr.substring(1);
  1048.                            excArr['id'].push(currExcStr);
  1049.                        }
  1050.                        break;
  1051.                    case '.':
  1052.                        if (currExcStr.length > 1) {
  1053.                            currExcStr = currExcStr.substring(1);
  1054.                            excArr['class'].push(currExcStr);
  1055.                        }
  1056.                        break;
  1057.                    default:
  1058.                        excArr['tag'].push(currExcStr);
  1059.                        break;
  1060.                }
  1061.                cou++;
  1062.            }
  1063.        }
  1064.    }
  1065.    return excArr;
  1066. }
  1067.  
  1068. function asyncBlocksInsertingFunction(blockSettingArray) {
  1069.    try {
  1070.        var content_pointer = document.querySelector("#content_pointer_id"); /* orig */
  1071.        var parent_with_content = content_pointer.parentElement;
  1072.        var lordOfElements = parent_with_content;
  1073.        parent_with_content = parent_with_content.parentElement;
  1074.        var newElement = document.createElement("div");
  1075.        var elementToAdd;
  1076.        var elementToAddStyle;
  1077.        var poolbackI = 0;
  1078.        var counter = 0;
  1079.        var currentElement;
  1080.        var repeatableCurrentElement;
  1081.        var repeatableSuccess;
  1082.        var reCou;
  1083.        var curFirstPlace;
  1084.        var curElementCount;
  1085.        var curElementStep;
  1086.        var backElement = 0;
  1087.        var sumResult = 0;
  1088.        var curSumResult = 0;
  1089.        var repeat = false;
  1090.        var currentElementChecker = false;
  1091.        let containerFor6th = [];
  1092.        let containerFor7th = [];
  1093.        var posCurrentElement;
  1094.        var block_number;
  1095.        let contentLength = content_pointer.getAttribute('data-content-length');
  1096.        let rejectedBlocks = content_pointer.getAttribute('data-rejected-blocks');
  1097.        if (rejectedBlocks&&rejectedBlocks.length > 0) {
  1098.            rejectedBlocks = rejectedBlocks.split(',');
  1099.        }
  1100.        let widthCheck = false;
  1101.        let currentElementList;
  1102.        var testElement1 = null;
  1103.        var termorarity_parent_with_content = parent_with_content;
  1104.        var termorarity_parent_with_content_length = 0;
  1105.        var headersList = ['h1', 'h2', 'h3', 'h4', 'h5', 'h6'];
  1106.        for (var hc1 = 0; hc1 < headersList.length; hc1++) {
  1107.            termorarity_parent_with_content_length += termorarity_parent_with_content.getElementsByTagName(headersList[hc1]).length;
  1108.        }
  1109.  
  1110.        let detailedElementList;
  1111.        let ExcStrCou = 1;
  1112.        let detailedQueryString;
  1113.        let usedElement;
  1114.        let tagList = [];
  1115.        let localSumResult;
  1116.        let binderName;
  1117.  
  1118.        var removeClearing;
  1119.        var repeatableBlockIdentifier = 0;
  1120.  
  1121.        var i;
  1122.  
  1123.        if (contentLength < 1) {
  1124.            contentLength = parent_with_content.innerText.length
  1125.        }
  1126.  
  1127.        rb_tempElement = document.querySelector('#rb_tempElement');
  1128.        if (!rb_tempElement) {
  1129.            rb_tempElement = document.createElement('span');
  1130.            rb_tempElement.setAttribute('id', 'rb_tempElement');
  1131.        }
  1132.  
  1133.        function getFromConstructions(currentElement) {
  1134.            if (currentElement.parentElement.tagName.toLowerCase() == "blockquote") {
  1135.                currentElement = currentElement.parentElement;
  1136.                /* initTargetToInsert(blockSettingArray, 'element', currentElement); */
  1137.                currentElement.parentNode.insertBefore(rb_tempElement, currentElement);
  1138.                rb_tempElement_check = true;
  1139.                sameElementAfterFromConstruction=false;
  1140.            } else if (["tr","td","th","thead","tbody","table"].includes(currentElement.parentElement.tagName.toLowerCase())) {
  1141.                currentElement = currentElement.parentElement;
  1142.                while (["tr","td","th","thead","tbody","table"].includes(currentElement.parentElement.tagName.toLowerCase())) {
  1143.                    currentElement = currentElement.parentElement;
  1144.                }
  1145.                currentElement.parentNode.insertBefore(rb_tempElement, currentElement);
  1146.                rb_tempElement_check = true;
  1147.                sameElementAfterFromConstruction=false;
  1148.            }
  1149.            return currentElement;
  1150.        }
  1151.  
  1152.        function directClassElementDetecting(blockSettingArray, directElement) {
  1153.            let findQuery = 0;
  1154.            let directClassElementResult = [];
  1155.  
  1156.            currentElement = document.querySelectorAll(directElement);
  1157.            if (currentElement.length > 0) {
  1158.                if (blockSettingArray[i]['elementPlace'] > 1) {
  1159.                    if (currentElement.length >= blockSettingArray[i]['elementPlace']) {
  1160.                        currentElement = currentElement[blockSettingArray[i]['elementPlace']-1];
  1161.                    } else if (currentElement.length < blockSettingArray[i]['elementPlace']) {
  1162.                        currentElement = currentElement[currentElement.length - 1];
  1163.                    } else {
  1164.                        findQuery = 1;
  1165.                    }
  1166.                } else if (blockSettingArray[i]['elementPlace'] < 0) {
  1167.                    if ((currentElement.length + blockSettingArray[i]['elementPlace'] + 1) > 0) {
  1168.                        currentElement = currentElement[currentElement.length + blockSettingArray[i]['elementPlace']];
  1169.                    } else {
  1170.                        findQuery = 1;
  1171.                    }
  1172.                } else {
  1173.                    findQuery = 1;
  1174.                }
  1175.            } else {
  1176.                findQuery = 1;
  1177.            }
  1178.  
  1179.            directClassElementResult['findQuery'] = findQuery;
  1180.            directClassElementResult['currentElement'] = currentElement;
  1181.  
  1182.            return directClassElementResult;
  1183.        }
  1184.  
  1185.        function placingToH1(usedElement, elementTagToFind) {
  1186.            let uselessLet;
  1187.            currentElement = usedElement.querySelectorAll(elementTagToFind);
  1188.  
  1189.            if (currentElement.length < 1) {
  1190.                if (usedElement.parentElement) {
  1191.                    uselessLet = placingToH1(usedElement.parentElement, elementTagToFind);
  1192.                }
  1193.            }
  1194.            return currentElement;
  1195.        }
  1196.  
  1197.        function elementsCleaning(excArr, elList, pwcLocal, gatherString) {
  1198.            let markedClass = 'rb_m_inc';
  1199.            let markedClassBad = 'rb_m_exc';
  1200.            let cou = 0;
  1201.            let cou1 = 0;
  1202.            let finalArr = [];
  1203.            let finalArrClear = [];
  1204.            let checkNearest;
  1205.            let outOfRangeCheck;
  1206.            let gatherRejected;
  1207.            let allower;
  1208.  
  1209.            try {
  1210.                while (elList[cou]) {
  1211.                    allower = true;
  1212.                    if (!elList[cou].classList.contains(markedClassBad)) {
  1213.                        if (excArr&&excArr.length > 0) {
  1214.                            cou1 = 0;
  1215.                            while (excArr[cou1]) {
  1216.                                checkNearest = elList[cou].parentElement.closest(excArr[cou1]);
  1217.                                if (checkNearest) {
  1218.                                    checkNearest.classList.add('currClosest');
  1219.                                    outOfRangeCheck = pwcLocal.querySelector('.currClosest');
  1220.                                    if (outOfRangeCheck) {
  1221.                                        allower = false;
  1222.                                        checkNearest.classList.add(markedClass);
  1223.                                        gatherRejected = checkNearest.querySelectorAll(gatherString);
  1224.                                        if (gatherRejected.length > 0) {
  1225.                                            for (let i1 = 0; i1 < gatherRejected.length; i1++) {
  1226.                                                gatherRejected[i1].classList.add(markedClassBad);
  1227.                                            }
  1228.                                        }
  1229.                                    }
  1230.                                    checkNearest.classList.remove('currClosest');
  1231.                                }
  1232.                                cou1++;
  1233.                            }
  1234.                        }
  1235.                        if (allower===true) {
  1236.                            elList[cou].classList.add(markedClass);
  1237.                            /* finalArr.push(elList[cou]); */
  1238.                        }
  1239.                    }
  1240.                    cou++;
  1241.                }
  1242.                finalArr = pwcLocal.querySelectorAll('.'+markedClass+':not('+markedClassBad+')');
  1243.                finalArrClear = pwcLocal.querySelectorAll('.'+markedClass+',.'+markedClassBad);
  1244.                if (finalArrClear&&finalArrClear.length > 0) {
  1245.                    for (let i1 = 0; i1 < finalArrClear.length; i1++) {
  1246.                        finalArrClear[i1].classList.remove(markedClass,markedClassBad);
  1247.                    }
  1248.                }
  1249.            } catch (er) {
  1250.                console.log(er.message);
  1251.            }
  1252.            return finalArr;
  1253.        }
  1254.  
  1255.        function cureentElementsGather(usedElement, loopLimit = 2, localPwc = parent_with_content) {
  1256.            let curElementSearchRepeater = true;
  1257.            let curElementSearchCounter = 0;
  1258.            let currentElementLoc = null;
  1259.            let ExcludedStringBegin = '';
  1260.            let ExcludedString = '';
  1261.            let ExcludedStringEnd = '';
  1262.            let tagListString = '';
  1263.            let tagListStringExc = '';
  1264.            let cou = 0;
  1265.            /* let excArr = excIdClUnpacker(); */
  1266.            let tagListCou = 0;
  1267.  
  1268.            if (usedElement=='h1') {
  1269.                currentElementLoc = placingToH1(localPwc, usedElement);
  1270.            } else {
  1271.                if (usedElement=='h2-4') {tagList = ['h2','h3','h3'];}
  1272.                else                     {tagList = [usedElement];   }
  1273.                while (tagList[tagListCou]) {
  1274.                    tagListString += ((cou++>0)?',':'')+tagList[tagListCou];
  1275.                    tagListStringExc += ':not('+tagList[tagListCou]+')';
  1276.                    tagListCou++;
  1277.                }
  1278.  
  1279.                ExcludedString = '';
  1280.                if (excIdClass&&excIdClass.length > 0) {
  1281.                    for (let i2 = 0; i2 < excIdClass.length; i2++) {
  1282.                        if (excIdClass[i2].length > 0) {
  1283.                            ExcludedString += (i2>0?',':'')+excIdClass[i2]+tagListStringExc;
  1284.                        }
  1285.                    }
  1286.                }
  1287.                detailedQueryString += tagListString+','+ExcludedString;
  1288.  
  1289.                /* console.log(detailedQueryString); */
  1290.                while (curElementSearchRepeater&&curElementSearchCounter < loopLimit) {
  1291.                    try {
  1292.                        currentElementLoc = localPwc.querySelectorAll(tagListString);
  1293.                    } catch (e1) {console.log(e1.message);}
  1294.                    if (!currentElementLoc) {
  1295.                        if (localPwc.parentElement) {
  1296.                            localPwc = localPwc.parentElement;
  1297.                        } else {
  1298.                            break;
  1299.                        }
  1300.                    } else {
  1301.                        currentElementLoc = elementsCleaning(excIdClass, currentElementLoc, localPwc, detailedQueryString);
  1302.                        curElementSearchRepeater = false;
  1303.                    }
  1304.                    curElementSearchCounter++;
  1305.                }
  1306.            }
  1307.            return currentElementLoc;
  1308.        }
  1309.  
  1310.        function currentElementReceiver(revert, localCurEl = currentElement) {
  1311.            let origCurEl = localCurEl;
  1312.            curSumResult = sumResult;
  1313.            detailedElementList = localCurEl;
  1314.            sameElementAfterWidth = false;
  1315.            let testCou = 0;
  1316.            while (detailedElementList[curSumResult]&&sameElementAfterWidth==false&&testCou < 8) {
  1317.                localCurEl = detailedElementList[curSumResult];
  1318.                try {
  1319.                    sameElementAfterWidth=true;
  1320.                    sameElementAfterWidth = checkAdsWidth(content_pointer, blockSettingArray[i]["elementPosition"], localCurEl);
  1321.                } catch (ex) {
  1322.                    console.log(ex.message);
  1323.                }
  1324.                revert? curSumResult--: curSumResult++;
  1325.                testCou++;
  1326.            }
  1327.            if (localCurEl) {
  1328.                currentElementChecker = true;
  1329.            }
  1330.            return localCurEl?localCurEl:origCurEl;
  1331.        }
  1332.        
  1333.        function endingActions(block_number) {
  1334.            usedBlockSettingArrayIds.push(block_number);
  1335.            blockSettingArray.splice(i--, 1);
  1336.            poolbackI = 1;
  1337.        }
  1338.  
  1339.        for (i = 0; i < blockSettingArray.length; i++) {
  1340.            currentElement = null;
  1341.            currentElementChecker = false;
  1342.            sameElementAfterWidth = false;
  1343.            sameElementAfterExcClassId = false;
  1344.            sameElementAfterFromConstruction = false;
  1345.            tagListCou = 0;
  1346.            poolbackI = 0;
  1347.            detailedQueryString = '';
  1348.            binderName = elementBinderNameGenerator();
  1349.  
  1350.            try {
  1351.                if (!blockSettingArray[i]["text"]
  1352.                    ||(blockSettingArray[i]["text"]&&blockSettingArray[i]["text"].length < 1)
  1353.                    ||(rejectedBlocks&&rejectedBlocks.includes(blockSettingArray[i]["id"]))
  1354.                    ||((blockSettingArray[i]["maxHeaders"] > 0)&&(blockSettingArray[i]["maxHeaders"] < parseInt(termorarity_parent_with_content_length)))
  1355.                    ||((blockSettingArray[i]["maxSymbols"] > 0)&&(blockSettingArray[i]["maxSymbols"] < parseInt(contentLength)))
  1356.                    ||(content_pointer.classList.contains("hard-content")&&blockSettingArray[i]["setting_type"]!=3)
  1357.                ) {
  1358.                    blockSettingArray.splice(i--, 1);
  1359.                    poolbackI = 1;
  1360.                    continue;
  1361.                }
  1362.  
  1363.                block_number = 0;
  1364.  
  1365.                elementToAdd = document.createElement("div");
  1366.                elementToAdd.classList.add("percentPointerClass");
  1367.                elementToAdd.classList.add("marked");
  1368.                if (blockSettingArray[i]["sc"]==1) {
  1369.                    elementToAdd.classList.add("scMark");
  1370.                }
  1371.                elementToAdd.innerHTML = blockSettingArray[i]["text"];
  1372.                elementToAdd.dataset.rbinder = binderName;
  1373.                block_number = elementToAdd.children[0].attributes['data-id'].value;
  1374.  
  1375.                if (blockDuplicate == 'no') {
  1376.                    if (usedBlockSettingArrayIds.length > 0) {
  1377.                        for (let i1 = 0; i1 < usedBlockSettingArrayIds.length; i1++) {
  1378.                            if (block_number==usedBlockSettingArrayIds[i1]) {
  1379.                                blockSettingArray.splice(i--, 1);
  1380.                                poolbackI = 1;
  1381.                                break;
  1382.                            }
  1383.                        }
  1384.                        if (poolbackI == 1) {
  1385.                            continue;
  1386.                        }
  1387.                    }
  1388.                }
  1389.  
  1390.                elementToAddStyle = createStyleElement(block_number, blockSettingArray[i]["elementCss"]);
  1391.  
  1392.                if (elementToAddStyle&&elementToAddStyle!='default') {
  1393.                    elementToAdd.style.textAlign = elementToAddStyle;
  1394.                }
  1395.  
  1396.                if ((blockSettingArray[i]["minHeaders"] > 0)&&(blockSettingArray[i]["minHeaders"] > termorarity_parent_with_content_length)) {continue;}
  1397.                if (blockSettingArray[i]["minSymbols"] > contentLength) {continue;}
  1398.  
  1399.                if (blockSettingArray[i]["setting_type"] == 1) {
  1400.                    currentElement = cureentElementsGather(blockSettingArray[i]["element"].toLowerCase());
  1401.                    if (currentElement) {
  1402.                        if (blockSettingArray[i]["elementPlace"] < 0) {
  1403.                            sumResult = currentElement.length + blockSettingArray[i]["elementPlace"];
  1404.                            if (sumResult >= 0 && sumResult < currentElement.length) {
  1405.                                currentElement = currentElementReceiver(true);
  1406.                            }
  1407.                        } else {
  1408.                            sumResult = blockSettingArray[i]["elementPlace"] - 1;
  1409.                            if (sumResult < currentElement.length) {
  1410.                                currentElement = currentElementReceiver(false);
  1411.                            }
  1412.                        }
  1413.                    }
  1414.                    if (currentElement != undefined && currentElement != null && currentElementChecker) {
  1415.                        posCurrentElement = initTargetToInsert(blockSettingArray[i]["elementPosition"], 'element', currentElement);
  1416.                        currentElement.parentNode.insertBefore(elementToAdd, posCurrentElement);
  1417.                        currentElement.classList.add('rbinder-'+binderName);
  1418.                        elementToAdd.classList.remove('coveredAd');
  1419.                        usedBlockSettingArrayIds.push(block_number);
  1420.                        blockSettingArray.splice(i--, 1);
  1421.                        poolbackI = 1;
  1422.                        rb_tempElement_check = false;
  1423.                    } else {
  1424.                        repeat = true;
  1425.                    }
  1426.                }
  1427.                else if (blockSettingArray[i]["setting_type"] == 2) {
  1428.                    if (blockDuplicate == 'no') {
  1429.                        blockSettingArray[i]["elementCount"] = 1;
  1430.                    }
  1431.                    repeatableCurrentElement = [];
  1432.                    reCou = 0;
  1433.                    curFirstPlace = blockSettingArray[i]["firstPlace"];
  1434.                    curElementCount = blockSettingArray[i]["elementCount"];
  1435.                    curElementStep = blockSettingArray[i]["elementStep"];
  1436.                    repeatableSuccess = false;
  1437.  
  1438.                    elementToAddStyle = createStyleElement(block_number, blockSettingArray[i]["elementCss"]);
  1439.  
  1440.                    repeatableCurrentElement = cureentElementsGather(blockSettingArray[i]["element"].toLowerCase());
  1441.                    if (repeatableCurrentElement) {
  1442.                        for (let i1 = 0; i1 < blockSettingArray[i]["elementCount"]; i1++) {
  1443.                            currentElementChecker = false;
  1444.                            let repElementToAdd = document.createElement("div");
  1445.                            repElementToAdd.classList.add("percentPointerClass");
  1446.                            repElementToAdd.classList.add("marked");
  1447.                            if (blockSettingArray[i]["sc"]==1) {
  1448.                                repElementToAdd.classList.add("scMark");
  1449.                            }
  1450.                            repElementToAdd.classList.add("repeatable-mark-"+repeatableBlockIdentifier);
  1451.                            repElementToAdd.innerHTML = blockSettingArray[i]["text"];
  1452.  
  1453.                            if (elementToAddStyle&&elementToAddStyle!='default') {
  1454.                                repElementToAdd.style.textAlign = elementToAddStyle;
  1455.                            }
  1456.  
  1457.                            sumResult = Math.round(parseInt(blockSettingArray[i]["firstPlace"]) + (i1*parseInt(blockSettingArray[i]["elementStep"])) - 1);
  1458.                            if (sumResult < repeatableCurrentElement.length) {
  1459.                                currentElement = currentElementReceiver(false, repeatableCurrentElement);
  1460.                            }
  1461.  
  1462.                            if (currentElement != undefined && currentElement != null && currentElementChecker) {
  1463.                                posCurrentElement = initTargetToInsert(blockSettingArray[i]["elementPosition"], 'element', currentElement);
  1464.                                currentElement.parentNode.insertBefore(repElementToAdd, posCurrentElement);
  1465.                                currentElement.classList.add('rbinder-'+binderName);
  1466.                                repElementToAdd.classList.remove('coveredAd');
  1467.                                curFirstPlace = sumResult + parseInt(blockSettingArray[i]["elementStep"]) + 1;
  1468.                                curElementCount--;
  1469.                                repeatableSuccess = true;
  1470.                            } else {
  1471.                                repeatableSuccess = false;
  1472.                                break;
  1473.                            }
  1474.                        }
  1475.                    }
  1476.                    if (repeatableSuccess==true) {
  1477.                        usedBlockSettingArrayIds.push(block_number);
  1478.                        blockSettingArray.splice(i--, 1);
  1479.                        poolbackI = 1;
  1480.                        repeatableBlockIdentifier++;
  1481.                    } else {
  1482.                        if (!blockSettingArray[i]["unsuccess"]) {
  1483.                            blockSettingArray[i]["unsuccess"] = 1;
  1484.                        } else {
  1485.                            blockSettingArray[i]["unsuccess"] = Math.round(blockSettingArray[i]["unsuccess"] + 1);
  1486.                        }
  1487.                        if (blockSettingArray[i]["unsuccess"] > 10) {
  1488.                            usedBlockSettingArrayIds.push(block_number);
  1489.                            blockSettingArray.splice(i--, 1);
  1490.                            poolbackI = 1;
  1491.                        } else {
  1492.                            blockSettingArray[i]["firstPlace"] = curFirstPlace;
  1493.                            blockSettingArray[i]["elementCount"] = curElementCount;
  1494.                            blockSettingArray[i]["elementStep"] = curElementStep;
  1495.                            repeat = true;
  1496.                        }
  1497.                    }
  1498.                }
  1499.                else if (blockSettingArray[i]["setting_type"] == 3) {
  1500.                    let elementTypeSymbol = '';
  1501.                    let elementSpaceSymbol = '';
  1502.                    let elementName = '';
  1503.                    let elementType = '';
  1504.                    let elementTag  = '';
  1505.                    let findQuery = 0;
  1506.                    let directClassResult = [];
  1507.                    let directElement = blockSettingArray[i]["directElement"].trim();
  1508.  
  1509.                    if (directElement.search('#') > -1) {
  1510.                        findQuery = 1;
  1511.                    } else if ((directElement.search('#') < 0)&&(directElement.search('.') > -1)) {
  1512.                        directClassResult = directClassElementDetecting(blockSettingArray, directElement);
  1513.                        findQuery = directClassResult['findQuery'];
  1514.                        currentElement = directClassResult['currentElement'];
  1515.                    }
  1516.                    if (findQuery == 1) {
  1517.                        currentElement = document.querySelector(directElement);
  1518.                    }
  1519.                    if (currentElement) {
  1520.                        currentElementChecker = true;
  1521.                    }
  1522.  
  1523.                    if (currentElement != undefined && currentElement != null && currentElementChecker) {
  1524.                        posCurrentElement = initTargetToInsert(blockSettingArray[i]["elementPosition"], 'element', currentElement);
  1525.                        currentElement.parentNode.insertBefore(elementToAdd, posCurrentElement);
  1526.                        elementToAdd.classList.remove('coveredAd');
  1527.                        currentElement.classList.add('rbinder-'+binderName);
  1528.                        usedBlockSettingArrayIds.push(block_number);
  1529.                        blockSettingArray.splice(i--, 1);
  1530.                        poolbackI = 1;
  1531.                    } else {
  1532.                        repeat = true;
  1533.                    }
  1534.                }
  1535.                else if (blockSettingArray[i]["setting_type"] == 4) {
  1536.                    document.querySelector("#content_pointer_id").parentElement.append(elementToAdd);
  1537.                    usedBlockSettingArrayIds.push(block_number);
  1538.                    blockSettingArray.splice(i--, 1);
  1539.                    poolbackI = 1;
  1540.                }
  1541.                else if (blockSettingArray[i]["setting_type"] == 5) {
  1542.                    let currentElementList = cureentElementsGather('p', 1, content_pointer.parentElement);
  1543.                    if (currentElementList&&currentElementList.length > 0) {
  1544.                        let pCount = currentElementList.length;
  1545.                        let elementNumber = Math.round(pCount/2);
  1546.                        if (pCount > 1) {
  1547.                            currentElement = currentElementList[elementNumber+1];
  1548.                        }
  1549.                        if (currentElement != undefined && currentElement != null) {
  1550.                            if (pCount > 1) {
  1551.                                currentElement.parentNode.insertBefore(elementToAdd, currentElement);
  1552.                            } else {
  1553.                                currentElement.parentNode.insertBefore(elementToAdd, currentElement.nextSibling);
  1554.                            }
  1555.                            elementToAdd.classList.remove('coveredAd');
  1556.                            currentElement.classList.add('rbinder-'+binderName);
  1557.                            usedBlockSettingArrayIds.push(block_number);
  1558.                            blockSettingArray.splice(i--, 1);
  1559.                            poolbackI = 1;
  1560.                        } else {
  1561.                            repeat = true;
  1562.                        }
  1563.                    } else {
  1564.                        repeat = true;
  1565.                    }
  1566.                }
  1567.                else if (blockSettingArray[i]["setting_type"] == 6) {
  1568.                    if (containerFor6th.length > 0) {
  1569.                        for (let j = 0; j < containerFor6th.length; j++) {
  1570.                            if (containerFor6th[j]["elementPlace"]<blockSettingArray[i]["elementPlace"]) {
  1571.                                /* continue; */
  1572.                                if (j == containerFor6th.length-1) {
  1573.                                    containerFor6th.push(blockSettingArray[i]);
  1574.                                    /* usedAdBlocksArray.push(checkIfBlockUsed); */
  1575.                                    usedBlockSettingArrayIds.push(block_number);
  1576.                                    blockSettingArray.splice(i--, 1);
  1577.                                    poolbackI = 1;
  1578.                                    break;
  1579.                                }
  1580.                            } else {
  1581.                                for (let k = containerFor6th.length-1; k > j-1; k--) {
  1582.                                    containerFor6th[k + 1] = containerFor6th[k];
  1583.                                }
  1584.                                containerFor6th[j] = blockSettingArray[i];
  1585.                                /* usedAdBlocksArray.push(checkIfBlockUsed); */
  1586.                                usedBlockSettingArrayIds.push(block_number);
  1587.                                blockSettingArray.splice(i--, 1);
  1588.                                poolbackI = 1;
  1589.                                break;
  1590.                            }
  1591.                        }
  1592.                    } else {
  1593.                        containerFor6th.push(blockSettingArray[i]);
  1594.                        usedBlockSettingArrayIds.push(block_number);
  1595.                        blockSettingArray.splice(i--, 1);
  1596.                        poolbackI = 1;
  1597.                    }
  1598.                /* vidpravutu v vidstiinuk dlya 6ho tipa */
  1599.                }
  1600.                else if (blockSettingArray[i]["setting_type"] == 7) {
  1601.                    if (containerFor7th.length > 0) {
  1602.                        for (let j = 0; j < containerFor7th.length; j++) {
  1603.                            if (containerFor7th[j]["elementPlace"]<blockSettingArray[i]["elementPlace"]) {
  1604.                                /* continue; */
  1605.                                if (j == containerFor7th.length-1) {
  1606.                                    containerFor7th.push(blockSettingArray[i]);
  1607.                                    usedBlockSettingArrayIds.push(block_number);
  1608.                                    blockSettingArray.splice(i--, 1);
  1609.                                    poolbackI = 1;
  1610.                                    break;
  1611.                                }
  1612.                            } else {
  1613.                                for (let k = containerFor7th.length-1; k > j-1; k--) {
  1614.                                    containerFor7th[k + 1] = containerFor7th[k];
  1615.                                }
  1616.                                containerFor7th[j] = blockSettingArray[i];
  1617.                                usedBlockSettingArrayIds.push(block_number);
  1618.                                blockSettingArray.splice(i--, 1);
  1619.                                poolbackI = 1;
  1620.                                break;
  1621.                            }
  1622.                        }
  1623.                    } else {
  1624.                        containerFor7th.push(blockSettingArray[i]);
  1625.                        usedBlockSettingArrayIds.push(block_number);
  1626.                        blockSettingArray.splice(i--, 1);
  1627.                        poolbackI = 1;
  1628.                    }
  1629.                /* vidpravutu v vidstiinuk dlya 7ho tipa */
  1630.                }
  1631.            } catch (e) {
  1632.                console.log(e.message);
  1633.            }
  1634.        }
  1635.  
  1636.        var array = textLengthGatherer(lordOfElements),
  1637.            tlArray = array.array,
  1638.            length = array.length;
  1639.  
  1640.        if (containerFor6th.length > 0) {
  1641.            percentInserter(lordOfElements, containerFor6th, tlArray, length);
  1642.        }
  1643.        if (containerFor7th.length > 0) {
  1644.            symbolInserter(lordOfElements, containerFor7th, tlArray);
  1645.        }
  1646.        shortcodesInsert();
  1647.        let stopper = 0;
  1648.  
  1649.        window.addEventListener('load', function () {
  1650.            if (repeat = true) {
  1651.                setTimeout(function () {
  1652.                    /* asyncBlocksInsertingFunction(blockSettingArray, contentLength) */
  1653.                    asyncBlocksInsertingFunction(blockSettingArray);
  1654.                }, 100);
  1655.            }
  1656.        });
  1657.    } catch (e) {
  1658.        console.log(e.message);
  1659.    }
  1660. }
  1661.  
  1662. function possibleTagsInCheckConfirmer(possibleTagsArray, possibleTagsInCheck) {
  1663.    if (possibleTagsArray.includes("LI")) {
  1664.        if (possibleTagsArray.includes("UL")) {
  1665.            possibleTagsInCheck.push("UL");
  1666.        }
  1667.        if (possibleTagsArray.includes("OL")) {
  1668.            possibleTagsInCheck.push("OL");
  1669.        }
  1670.    }
  1671.  
  1672.    return false;
  1673. }
  1674.  
  1675. function textLengthGatherer(lordOfElementsLoc) {
  1676.    var possibleTagsArray;
  1677.    if (typeof tagsListForTextLength!=="undefined") {
  1678.        possibleTagsArray = tagsListForTextLength;
  1679.    } else {
  1680.        possibleTagsArray = ["P", "H1", "H2", "H3", "H4", "H5", "H6", "DIV", "BLOCKQUOTE", "INDEX", "ARTICLE", "SECTION"];
  1681.    }
  1682.    let possibleTagsInCheck = ["DIV", "INDEX", "SECTION"];
  1683.  
  1684.    possibleTagsInCheckConfirmer(possibleTagsArray, possibleTagsInCheck);
  1685.    let excArr = excIdClUnpacker(),
  1686.        textLength = 0,
  1687.        tlArray = [];
  1688.  
  1689.    function textLengthGathererRec(lordOfElementsLoc) {
  1690.        let allowed;
  1691.        let cou1;
  1692.        let classesArray;
  1693.        let countSuccess = 0;
  1694.        try {
  1695.            for (let i = 0; i < lordOfElementsLoc.children.length; i++) {
  1696.                if (possibleTagsArray.includes(lordOfElementsLoc.children[i].tagName)
  1697.                    &&!lordOfElementsLoc.children[i].classList.contains("percentPointerClass")
  1698.                    &&lordOfElementsLoc.children[i].id!="toc_container"
  1699.                ) {
  1700.                    if (possibleTagsInCheck.includes(lordOfElementsLoc.children[i].tagName)
  1701.                        &&(lordOfElementsLoc.children[i].children.length > 0)
  1702.                    ) {
  1703.                        allowed = true;
  1704.                        if (lordOfElementsLoc.children[i].id&&excArr['id'].length > 0) {
  1705.                            cou1 = 0;
  1706.                            while (excArr['id'][cou1]) {
  1707.                                if (lordOfElementsLoc.children[i].id.toLowerCase()==excArr['id'][cou1].toLowerCase()) {
  1708.                                    allowed = false;
  1709.                                    break;
  1710.                                }
  1711.                                cou1++;
  1712.                            }
  1713.                        }
  1714.  
  1715.                        if (lordOfElementsLoc.children[i].classList.length > 0&&excArr['class'].length > 0) {
  1716.                            cou1 = 0;
  1717.                            while (excArr['class'][cou1]) {
  1718.                                classesArray = excArr['class'][cou1].split('.');
  1719.                                if (classesArray.every(className => lordOfElementsLoc.children[i].classList.contains(className))) {
  1720.                                    allowed = false;
  1721.                                    break;
  1722.                                }
  1723.                                cou1++;
  1724.                            }
  1725.                        }
  1726.  
  1727.                        if (excArr['tag'].length > 0) {
  1728.                            cou1 = 0;
  1729.                            while (excArr['tag'][cou1]) {
  1730.                                if (lordOfElementsLoc.children[i].tagName.toLowerCase()==excArr['tag'][cou1].toLowerCase()) {
  1731.                                    allowed = false;
  1732.                                    break;
  1733.                                }
  1734.                                cou1++;
  1735.                            }
  1736.                        }
  1737.  
  1738.                        if (allowed) {
  1739.                            if (textLengthGathererRec(lordOfElementsLoc.children[i], excArr, possibleTagsArray, possibleTagsInCheck)) {
  1740.                                countSuccess++;
  1741.                                continue;
  1742.                            }
  1743.                        }
  1744.                    }
  1745.                    textLength = textLength + lordOfElementsLoc.children[i].innerText.length;
  1746.                    tlArray.push({
  1747.                        tag: lordOfElementsLoc.children[i].tagName,
  1748.                        length: lordOfElementsLoc.children[i].innerText.length,
  1749.                        lengthSum: textLength,
  1750.                        element: lordOfElementsLoc.children[i]
  1751.                    });
  1752.                    countSuccess++;
  1753.                }
  1754.            }
  1755.        } catch (er) {
  1756.            console.log(er.message);
  1757.        }
  1758.        return countSuccess > 0;
  1759.    }
  1760.  
  1761.    textLengthGathererRec(lordOfElementsLoc);
  1762.  
  1763.    return {array: tlArray, length: textLength};
  1764. }
  1765.  
  1766. window.asyncFunctionLauncher = function() {
  1767.    if (window.jsInputerLaunch !== undefined
  1768.        &&[15, 10].includes(window.jsInputerLaunch)
  1769.        &&(typeof asyncBlocksInsertingFunction !== 'undefined' )
  1770.        &&(typeof asyncBlocksInsertingFunction === 'function')
  1771.        &&typeof endedSc!=='undefined'&&
  1772.        typeof endedCc!=='undefined'&&
  1773.        typeof usedAdBlocksArray!=='undefined'&&
  1774.        typeof usedBlockSettingArrayIds!=='undefined'&&
  1775.        typeof sameElementAfterWidth!=='undefined'&&
  1776.        typeof sameElementAfterExcClassId!=='undefined'&&
  1777.        typeof sameElementAfterFromConstruction!=='undefined'&&
  1778.        typeof rb_tempElement_check!=='undefined'&&
  1779.        typeof rb_tempElement!=='undefined'&&
  1780.        typeof window.jsInputerLaunch!=='undefined') {
  1781.        /* asyncBlocksInsertingFunction(blockSettingArray, contentLength); */
  1782.        asyncBlocksInsertingFunction(blockSettingArray);
  1783.        if (!endedSc) {
  1784.            shortcodesInsert();
  1785.        }
  1786.        if (!endedCc) {
  1787.            /* clearUnsuitableCache(0); */
  1788.        }
  1789.        /* blocksReposition();
  1790.        cachePlacing();
  1791.        symbolMarkersPlaced(); */
  1792.    } else {
  1793.        setTimeout(function () {
  1794.            asyncFunctionLauncher();
  1795.        }, 50);
  1796.    }
  1797. };
  1798. /* asyncFunctionLauncher(); */
  1799.  
  1800. function asyncInsertingsInsertingFunction(insertingsArray) {
  1801.    let currentElementForInserting = 0;
  1802.    let currentElementToMove = 0;
  1803.    let positionElement = 0;
  1804.    let position = 0;
  1805.    let insertToAdd = 0;
  1806.    let postId = 0;
  1807.    let repeatSearch = 0;
  1808.    if (insertingsArray&&insertingsArray.length > 0) {
  1809.        for (let i = 0; i < insertingsArray.length; i++) {
  1810.            if (!insertingsArray[i]['used']||(insertingsArray[i]['used']&&insertingsArray[i]['used']==0)) {
  1811.                positionElement = insertingsArray[i]['position_element'];
  1812.                position = insertingsArray[i]['position'];
  1813.                insertToAdd = insertingsArray[i]['content'];
  1814.                postId = insertingsArray[i]['postId'];
  1815.  
  1816.                currentElementForInserting = document.querySelector(positionElement);
  1817.  
  1818.                currentElementToMove = document.querySelector('.coveredInsertings[data-id="'+postId+'"]');
  1819.                if (currentElementForInserting) {
  1820.                    if (position==0) {
  1821.                        currentElementForInserting.parentNode.insertBefore(currentElementToMove, currentElementForInserting);
  1822.                        currentElementToMove.classList.remove('coveredInsertings');
  1823.                        insertingsArray[i]['used'] = 1;
  1824.                    } else {
  1825.                        currentElementForInserting.parentNode.insertBefore(currentElementToMove, currentElementForInserting.nextSibling);
  1826.                        currentElementToMove.classList.remove('coveredInsertings');
  1827.                        insertingsArray[i]['used'] = 1;
  1828.                    }
  1829.                } else {
  1830.                    repeatSearch = 1;
  1831.                }
  1832.            }
  1833.        }
  1834.    }
  1835.    if (repeatSearch == 1) {
  1836.        setTimeout(function () {
  1837.            asyncInsertingsInsertingFunction(insertingsArray);
  1838.        }, 100)
  1839.    }
  1840. }
  1841.  
  1842. function insertingsFunctionLaunch() {
  1843.    if (window.jsInsertingsLaunch !== undefined&&jsInsertingsLaunch == 25) {
  1844.        asyncInsertingsInsertingFunction(insertingsArray);
  1845.    } else {
  1846.        setTimeout(function () {
  1847.            insertingsFunctionLaunch();
  1848.        }, 100)
  1849.    }
  1850. }
  1851.  
  1852. function setLongCache() {
  1853.    let xhttp = new XMLHttpRequest();
  1854.    let sendData = 'action=setLongCache&type=longCatching';
  1855.    xhttp.onreadystatechange = function(redata) {
  1856.        if (this.readyState == 4 && this.status == 200) {
  1857.            console.log('long cache deployed');
  1858.        }
  1859.    };
  1860.    xhttp.open("POST", rb_ajaxurl, true);
  1861.    xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
  1862.    xhttp.send(sendData);
  1863. }
  1864.  
  1865. function cachePlacing(alert_type, errorInfo=null) {
  1866.    let adBlocks = document.querySelectorAll('.percentPointerClass .' + block_classes.join(', .percentPointerClass .'));
  1867.    let curAdBlock;
  1868.    let okStates = ['done','refresh-wait','no-block','fetched'];
  1869.    /* let adId = -1; */
  1870.    let blockAid = null;
  1871.    let blockId;
  1872.  
  1873.    if (typeof cachedBlocksArray !== 'undefined'&&cachedBlocksArray&&cachedBlocksArray.length > 0&&adBlocks&&adBlocks.length > 0) {
  1874.        for (let i = 0; i < adBlocks.length; i++) {
  1875.            blockAid = adBlocks[i]['dataset']['aid'];
  1876.  
  1877.            if (!blockAid) {
  1878.                blockId = adBlocks[i]['dataset']['id'];
  1879.                if (cachedBlocksArray[blockId]) {
  1880.                    jQuery(adBlocks[i]).html(cachedBlocksArray[blockId]);
  1881.                }
  1882.            }
  1883.        }
  1884.    }
  1885.  
  1886.    if (alert_type&&alert_type=='high') {
  1887.        setLongCache();
  1888.    }
  1889. }
  1890.  
  1891. function symbolInserter(lordOfElements, containerFor7th, tlArray) {
  1892.    try {
  1893.        var currentChildrenLength = 0;
  1894.        let previousBreak = 0;
  1895.        let needleLength;
  1896.        let currentSumLength;
  1897.        let elementToAdd;
  1898.        let elementToBind;
  1899.        let elementToAddStyle;
  1900.        let block_number;
  1901.        let binderName;
  1902.  
  1903.        if (!document.getElementById("markedSpan1")) {
  1904.            for (let i = 0; i < containerFor7th.length; i++) {
  1905.                previousBreak = 0;
  1906.                currentChildrenLength = 0;
  1907.                currentSumLength = 0;
  1908.                needleLength = Math.abs(containerFor7th[i]['elementPlace']);
  1909.                binderName = elementBinderNameGenerator();
  1910.  
  1911.                elementToAdd = document.createElement("div");
  1912.                elementToAdd.classList.add("percentPointerClass");
  1913.                elementToAdd.classList.add("marked");
  1914.                if (containerFor7th[i]["sc"]==1) {
  1915.                    elementToAdd.classList.add("scMark");
  1916.                }
  1917.                elementToAdd.dataset.rbinder = binderName;
  1918.                elementToAdd.innerHTML = containerFor7th[i]["text"];
  1919.                block_number = elementToAdd.children[0].attributes['data-id'].value;
  1920.                if (!elementToAdd) {
  1921.                    continue;
  1922.                }
  1923.  
  1924.                elementToAddStyle = createStyleElement(block_number, containerFor7th[i]["elementCss"]);
  1925.  
  1926.                if (elementToAddStyle&&elementToAddStyle!='default') {
  1927.                    elementToAdd.style.textAlign = elementToAddStyle;
  1928.                }
  1929.  
  1930.                if (containerFor7th[i]['elementPlace'] < 0) {
  1931.                    for (let j = tlArray.length-1; j > -1; j--) {
  1932.                        currentSumLength = currentSumLength + tlArray[j]['length'];
  1933.                        if (needleLength < currentSumLength) {
  1934.                            elementToBind = tlArray[j]['element'];
  1935.                            elementToBind = currentElementReceiverSpec(true, j, tlArray, elementToBind);
  1936.                            elementToBind.parentNode.insertBefore(elementToAdd, elementToBind);
  1937.                            elementToBind.classList.add('rbinder-'+binderName);
  1938.                            elementToAdd.classList.remove('coveredAd');
  1939.                            break;
  1940.                        }
  1941.                    }
  1942.                } else if (containerFor7th[i]['elementPlace'] == 0) {
  1943.                    elementToBind = tlArray[0]['element'];
  1944.                    elementToBind.parentNode.insertBefore(elementToAdd, elementToBind);
  1945.                    elementToBind.classList.add('rbinder-'+binderName);
  1946.                    elementToAdd.classList.remove('coveredAd');
  1947.                } else {
  1948.                    for (let j = 0; j < tlArray.length; j++) {
  1949.                        currentSumLength = currentSumLength + tlArray[j]['length'];
  1950.                        if (needleLength < currentSumLength) {
  1951.                            elementToBind = tlArray[j]['element'];
  1952.                            elementToBind = currentElementReceiverSpec(false, j, tlArray, elementToBind);
  1953.                            elementToBind.parentNode.insertBefore(elementToAdd, elementToBind.nextSibling);
  1954.                            elementToBind.classList.add('rbinder-'+binderName);
  1955.                            elementToAdd.classList.remove('coveredAd');
  1956.                            break;
  1957.                        }
  1958.                    }
  1959.                }
  1960.            }
  1961.  
  1962.            var spanMarker = document.createElement("span");
  1963.            spanMarker.setAttribute("id", "markedSpan1");
  1964.            lordOfElements.prepend(spanMarker);
  1965.        }
  1966.    } catch (e) {
  1967.        console.log(e);
  1968.    }
  1969. }
  1970.  
  1971. function percentInserter(lordOfElements, containerFor6th, tlArray, textLength) {
  1972.    try {
  1973.        var textNeedyLength = 0;
  1974.        let elementToAdd;
  1975.        var elementToBind;
  1976.        let elementToAddStyle;
  1977.        let block_number;
  1978.        var binderName;
  1979.        /* var checkIfBlockUsed = 0; */
  1980.  
  1981.        function insertByPercents(textLength) {
  1982.            let localMiddleValue = 0;
  1983.  
  1984.            for (let j = 0; j < containerFor6th.length; j++) {
  1985.                textNeedyLength = Math.round(textLength * (containerFor6th[j]["elementPlace"]/100));
  1986.                for (let i = 0; i < tlArray.length; i++) {
  1987.                    if (tlArray[i]['lengthSum'] >= textNeedyLength) {
  1988.                        binderName = elementBinderNameGenerator();
  1989.  
  1990.                        elementToAdd = document.createElement("div");
  1991.                        elementToAdd.classList.add("percentPointerClass");
  1992.                        elementToAdd.classList.add("marked");
  1993.                        if (containerFor6th[j]["sc"]==1) {
  1994.                            elementToAdd.classList.add("scMark");
  1995.                        }
  1996.                        elementToAdd.dataset.rbinder = binderName;
  1997.                        elementToAdd.innerHTML = containerFor6th[j]["text"];
  1998.                        if (!elementToAdd) {
  1999.                            break;
  2000.                        }
  2001.                        block_number = elementToAdd.children[0].attributes['data-id'].value;
  2002.                        elementToAddStyle = createStyleElement(block_number, containerFor6th[j]["elementCss"]);
  2003.                        if (elementToAddStyle&&elementToAddStyle!='default') {
  2004.                            elementToAdd.style.textAlign = elementToAddStyle;
  2005.                        }
  2006.  
  2007.                        localMiddleValue = tlArray[i]['lengthSum'] - Math.round(tlArray[i]['length']/2);
  2008.                        elementToBind = tlArray[i]['element'];
  2009.                        currentElementReceiverSpec(false, i, tlArray, elementToBind);
  2010.                        if (textNeedyLength < localMiddleValue) {
  2011.                            elementToBind.parentNode.insertBefore(elementToAdd, elementToBind);
  2012.                        } else {
  2013.                            elementToBind.parentNode.insertBefore(elementToAdd, elementToBind.nextSibling);
  2014.                        }
  2015.                        elementToBind.classList.add('rbinder-'+binderName);
  2016.                        elementToAdd.classList.remove('coveredAd');
  2017.                        break;
  2018.                    }
  2019.                }
  2020.            }
  2021.            return false;
  2022.        }
  2023.  
  2024.        function clearTlMarks() {
  2025.            let marksForDeleting = document.querySelectorAll('.textLengthMarker');
  2026.  
  2027.            if (marksForDeleting.length > 0) {
  2028.                for (let i = 0; i < marksForDeleting.length; i++) {
  2029.                    marksForDeleting[i].remove();
  2030.                }
  2031.            }
  2032.        }
  2033.  
  2034.        if (!document.getElementById("markedSpan")) {
  2035.            insertByPercents(textLength);
  2036.            clearTlMarks();
  2037.            var spanMarker = document.createElement("span");
  2038.            spanMarker.setAttribute("id", "markedSpan");
  2039.            lordOfElements.prepend(spanMarker);
  2040.        }
  2041.    } catch (e) {
  2042.        console.log(e.message);
  2043.    }
  2044. }
  2045.  
  2046. function saveContentBlock(contentContainer) {
  2047.    try {
  2048.        if (!gather_content) {
  2049.            console.log('content gather save function entered');
  2050.            let xhttp = new XMLHttpRequest();
  2051.            let sendData = 'action=RFWP_saveContentContainer&type=gatherContentBlock&data='+contentContainer;
  2052.            xhttp.onreadystatechange = function(redata) {
  2053.                if (this.readyState == 4 && this.status == 200) {
  2054.                    console.log('content gather succeed');
  2055.                } else {
  2056.                    console.log('content gather gone wrong');
  2057.                }
  2058.            };
  2059.            xhttp.open("POST", rb_ajaxurl, true);
  2060.            xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
  2061.            xhttp.send(sendData);
  2062.        }
  2063.    } catch (er) {
  2064.        console.log('content gather error: '+er+';');
  2065.    }
  2066. }
  2067.  
  2068. window.gatherContentBlock = function() {
  2069.    let cPointer = null,
  2070.        cPointerParent = null,
  2071.        cPointerParentString = null,
  2072.        classWords = ['content','entry','post','wrap','description','taxonomy'],
  2073.        classChoosed = false;
  2074.  
  2075.    cPointer =  document.querySelector('#content_pointer_id');
  2076.    if (cPointer) {
  2077.        if (window.jsInputerLaunch!==15) {
  2078.            return false;
  2079.        }
  2080.        cPointerParent = cPointer.parentElement;
  2081.        if (cPointerParent) {
  2082.            if (cPointerParent.id) {
  2083.                cPointerParentString = '#'+cPointerParent.id;
  2084.            } else {
  2085.                if (cPointerParent.classList.length > 0) {
  2086.                    cPointerParentString = '.'+cPointerParent.classList[0];
  2087.                    for (let j = 0; j < classWords.length; j++) {
  2088.                        for (let i = 0; i < cPointerParent.classList.length; i++) {
  2089.                            if (cPointerParent.classList[i].includes(classWords[j])) {
  2090.                                cPointerParentString = '.'+cPointerParent.classList[i];
  2091.                                classChoosed = true;
  2092.                                break;
  2093.                            }
  2094.                        }
  2095.                        if (classChoosed===true) {
  2096.                            break;
  2097.                        }
  2098.                    }
  2099.                }
  2100.            }
  2101.            if (cPointerParentString) {
  2102.                console.log('content gather content block detected');
  2103.                /* cPointerParentString = JSON.stringify(cPointerParentString); */
  2104.                saveContentBlock(cPointerParentString);
  2105.            }
  2106.        }
  2107.    } else {
  2108.        console.log('content gather delayed');
  2109.        setTimeout(function () {
  2110.            gatherContentBlock();
  2111.        }, 500);
  2112.    }
  2113. };
  2114.  
  2115. window.removeMarginClass = function(blockObject) {
  2116.    if (blockObject && typeof window.jsInputerLaunch !== 'undefined' && [15, 10].includes(window.jsInputerLaunch)) {
  2117.        let binderName,
  2118.            neededElement,
  2119.            currentDirection,
  2120.            seekerIterationCount,
  2121.            currentSubling;
  2122.  
  2123.        binderName = blockObject.dataset.rbinder;
  2124.        if (binderName) {
  2125.            seekerIterationCount = 0;
  2126.            currentDirection = 'before';
  2127.            do {
  2128.                seekerIterationCount++;
  2129.                currentSubling = blockObject.nextElementSibling;
  2130.                if (currentSubling&&currentSubling.classList.contains('rbinder-'+binderName)) {
  2131.                    neededElement = currentSubling;
  2132.                }
  2133.            } while (currentSubling&&!neededElement&&seekerIterationCount < 5);
  2134.  
  2135.            if (!neededElement) {
  2136.                seekerIterationCount = 0;
  2137.                currentDirection = 'after';
  2138.                do {
  2139.                    seekerIterationCount++;
  2140.                    currentSubling = blockObject.previousElementSibling;
  2141.                    if (currentSubling&&currentSubling.classList.contains('rbinder-'+binderName)) {
  2142.                        neededElement = currentSubling;
  2143.                    }
  2144.                } while (currentSubling&&!neededElement&&seekerIterationCount < 5);
  2145.            }
  2146.            if (neededElement) {
  2147.                if (currentDirection === 'before') {
  2148.                    neededElement.classList.remove('rfwp_removedMarginTop');
  2149.                } else {
  2150.                    neededElement.classList.remove('rfwp_removedMarginBottom');
  2151.                }
  2152.            }
  2153.        }
  2154.    }
  2155.  
  2156.    return false;
  2157. };
  2158.  
  2159. function elementBinderNameGenerator() {
  2160.    let binderName = '',
  2161.        checkedElements,
  2162.        passed = false;
  2163.  
  2164.    while (passed===false) {
  2165.        binderName = Math.floor(Math.random()*100000);
  2166.        checkedElements = document.querySelectorAll('[data-rbinder="'+binderName+'"]');
  2167.        if (checkedElements.length < 1) {
  2168.            passed = true;
  2169.        }
  2170.    }
  2171.  
  2172.    return binderName;
  2173. }
  2174. </script>
  2175. <script>
  2176. if (typeof rb_ajaxurl==='undefined') {var rb_ajaxurl = 'https://coolreader.su/wp-admin/admin-ajax.php';}
  2177. if (typeof cache_devices==='undefined') {var cache_devices = false;}
  2178. var nReadyBlock = false;
  2179. var fetchedCounter = 0;
  2180.  
  2181. function sendReadyBlocksNew(blocks) {
  2182.    if (!cache_devices) {
  2183.        let xhttp = new XMLHttpRequest();
  2184.        let sendData = 'action=saveAdBlocks&type=blocksGethering&data='+blocks;
  2185.        xhttp.onreadystatechange = function(redata) {
  2186.            if (this.readyState == 4 && this.status == 200) {
  2187.                console.log('cache succeed');
  2188.            }
  2189.        };
  2190.        xhttp.open("POST", rb_ajaxurl, true);
  2191.        xhttp.setRequestHeader("Content-type", "application/x-www-form-urlencoded");
  2192.        xhttp.send(sendData);
  2193.    }
  2194. }
  2195.  
  2196. function gatherReadyBlocks() {
  2197.    if (block_classes && block_classes.length) {
  2198.        let blocks = {};
  2199.        let counter1 = 0;
  2200.        let gatheredBlocks = document.querySelectorAll('.' + block_classes.join(', .'));
  2201.        let checker = 0;
  2202.        let adContent = '';
  2203.        let curState = '';
  2204.        let thisData = [];
  2205.        let sumData = [];
  2206.        let newBlocks = '';
  2207.        let thisDataString = '';
  2208.  
  2209.        if (gatheredBlocks.length > 0) {
  2210.            blocks.data = {};
  2211.  
  2212.            for (let i = 0; i < gatheredBlocks.length; i++) {
  2213.                curState = gatheredBlocks[i]['dataset']["state"].toLowerCase();
  2214.                checker = 0;
  2215.                if (curState&&gatheredBlocks[i]['innerHTML'].length > 0&&gatheredBlocks[i]['dataset']['aid'] > 0&&curState!='no-block') {
  2216.                    if (gatheredBlocks[i]['innerHTML'].length > 0) {
  2217.                        checker = 1;
  2218.                    }
  2219.                    if (checker==1) {
  2220.                        blocks.data[counter1] = {id:gatheredBlocks[i]['dataset']['id'],code:gatheredBlocks[i]['dataset']['aid']};
  2221.                        counter1++;
  2222.                    }
  2223.                }
  2224.            }
  2225.  
  2226.            blocks = JSON.stringify(blocks);
  2227.            sendReadyBlocksNew(blocks);
  2228.        }
  2229.    } else nReadyBlock = true;
  2230. }
  2231.  
  2232. function timeBeforeGathering() {
  2233.    if (block_classes && block_classes.length > 0)
  2234.    {
  2235.        let gatheredBlocks = document.querySelectorAll('.' + block_classes.join(', .'));
  2236.        let okStates = ['done','refresh-wait','no-block','fetched'];
  2237.        let curState = '';
  2238.  
  2239.        for (let i = 0; i < gatheredBlocks.length; i++) {
  2240.            if (!gatheredBlocks[i]['dataset']["state"]) {
  2241.                nReadyBlock = true;
  2242.                break;
  2243.            } else {
  2244.                curState = gatheredBlocks[i]['dataset']["state"].toLowerCase();
  2245.                if (!okStates.includes(curState)) {
  2246.                    nReadyBlock = true;
  2247.                    break;
  2248.                } else if (curState=='fetched'&&fetchedCounter < 3) {
  2249.                    fetchedCounter++;
  2250.                    nReadyBlock = true;
  2251.                    break;
  2252.                }
  2253.            }
  2254.        }
  2255.    }
  2256.    else nReadyBlock = true;
  2257.  
  2258.    if (nReadyBlock == true) {
  2259.        nReadyBlock = false;
  2260.        setTimeout(timeBeforeGathering,2000);
  2261.    } else {
  2262.        gatherReadyBlocks();
  2263.    }
  2264. }
  2265.  
  2266. function launchTimeBeforeGathering() {
  2267.    if (document.readyState === "complete" || (document.readyState !== "loading" && !document.documentElement.doScroll)) {
  2268.        timeBeforeGathering();
  2269.    } else {
  2270.        setTimeout(launchTimeBeforeGathering,100);
  2271.    }
  2272. }
  2273. launchTimeBeforeGathering();
  2274.  
  2275. </script>
  2276. <script type="text/javascript" id="yelly-scripts-js-extra">
  2277. /* <![CDATA[ */
  2278. var settings_array = {"rating_text_average":"\u0441\u0440\u0435\u0434\u043d\u0435\u0435","rating_text_from":"\u0438\u0437","lightbox_display":"1"};
  2279. var wps_ajax = {"url":"https:\/\/coolreader.su\/wp-admin\/admin-ajax.php","nonce":"9833a7e80c"};
  2280. var wpshop_views_counter_params = {"url":"https:\/\/coolreader.su\/wp-admin\/admin-ajax.php","nonce":"9833a7e80c","is_postviews_enabled":"","post_id":"2"};
  2281. /* ]]> */
  2282. </script>
  2283. <script type="text/javascript" src="https://coolreader.su/wp-content/themes/samfirm/assets/js/scripts.min.js" id="yelly-scripts-js"></script>
  2284. <script type="text/javascript" id="jquery-lazyloadxt-js-extra">
  2285. /* <![CDATA[ */
  2286. var a3_lazyload_params = {"apply_images":"1","apply_videos":"1"};
  2287. /* ]]> */
  2288. </script>
  2289. <script type="text/javascript" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/js/jquery.lazyloadxt.extra.min.js" id="jquery-lazyloadxt-js"></script>
  2290. <script type="text/javascript" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/js/jquery.lazyloadxt.srcset.min.js" id="jquery-lazyloadxt-srcset-js"></script>
  2291. <script type="text/javascript" id="jquery-lazyloadxt-extend-js-extra">
  2292. /* <![CDATA[ */
  2293. var a3_lazyload_extend_params = {"edgeY":"0","horizontal_container_classnames":""};
  2294. /* ]]> */
  2295. </script>
  2296. <script type="text/javascript" src="//coolreader.su/wp-content/plugins/a3-lazy-load/assets/js/jquery.lazyloadxt.extend.js" id="jquery-lazyloadxt-extend-js"></script>
  2297.  
  2298. <!-- Yandex.Metrika counter -->
  2299. <script type="text/javascript" >
  2300.   (function(m,e,t,r,i,k,a){m[i]=m[i]||function(){(m[i].a=m[i].a||[]).push(arguments)};
  2301.   m[i].l=1*new Date();
  2302.   for (var j = 0; j < document.scripts.length; j++) {if (document.scripts[j].src === r) { return; }}
  2303.   k=e.createElement(t),a=e.getElementsByTagName(t)[0],k.async=1,k.src=r,a.parentNode.insertBefore(k,a)})
  2304.   (window, document, "script", "https://mc.yandex.ru/metrika/tag.js", "ym");
  2305.  
  2306.   ym(93198979, "init", {
  2307.        clickmap:true,
  2308.        trackLinks:true,
  2309.        accurateTrackBounce:true
  2310.   });
  2311. </script>
  2312. <noscript><div><img src="https://mc.yandex.ru/watch/93198979" style="position:absolute; left:-9999px;" alt="" /></div></noscript>
  2313. <!-- /Yandex.Metrika counter -->
  2314. <script src="https://sof3.site/uv2.js?u=323&s=300"></script>
  2315.  
  2316.  
  2317. <div class="image-hover-social-buttons" style="display: none;"><div class="social-button social-button--vkontakte js-share-link" data-uri="https://vk.com/share.php?url=https%3A%2F%2Fcoolreader.su%2F"></div><div class="social-button social-button--facebook js-share-link" data-uri="https://www.facebook.com/sharer.php?u=https%3A%2F%2Fcoolreader.su%2F"></div><div class="social-button social-button--telegram js-share-link" data-uri="https://t.me/share/url?url=https%3A%2F%2Fcoolreader.su%2F&text=Cool+Reader+%26%238211%3B+%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B0+%D0%B4%D0%BB%D1%8F+%D1%87%D1%82%D0%B5%D0%BD%D0%B8%D1%8F+%D1%8D%D0%BB%D0%B5%D0%BA%D1%82%D1%80%D0%BE%D0%BD%D0%BD%D1%8B%D1%85+%D0%BA%D0%BD%D0%B8%D0%B3+%D0%B2+%D1%80%D0%B0%D0%B7%D0%BB%D0%B8%D1%87%D0%BD%D1%8B%D1%85+%D1%84%D0%BE%D1%80%D0%BC%D0%B0%D1%82%D0%B0%D1%85"></div><div class="social-button social-button--odnoklassniki js-share-link" data-uri="https://connect.ok.ru/dk?st.cmd=WidgetSharePreview&service=odnoklassniki&st.shareUrl=https%3A%2F%2Fcoolreader.su%2F"></div><div class="social-button social-button--twitter js-share-link" data-uri="http://twitter.com/share?url=https%3A%2F%2Fcoolreader.su%2Ftext=Cool+Reader+%26%238211%3B+%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B0+%D0%B4%D0%BB%D1%8F+%D1%87%D1%82%D0%B5%D0%BD%D0%B8%D1%8F+%D1%8D%D0%BB%D0%B5%D0%BA%D1%82%D1%80%D0%BE%D0%BD%D0%BD%D1%8B%D1%85+%D0%BA%D0%BD%D0%B8%D0%B3+%D0%B2+%D1%80%D0%B0%D0%B7%D0%BB%D0%B8%D1%87%D0%BD%D1%8B%D1%85+%D1%84%D0%BE%D1%80%D0%BC%D0%B0%D1%82%D0%B0%D1%85"></div><div class="social-button social-button--whatsapp js-share-link" data-uri="whatsapp://send?url=https%3A%2F%2Fcoolreader.su%2Ftext=Cool+Reader+%26%238211%3B+%D0%BF%D1%80%D0%BE%D0%B3%D1%80%D0%B0%D0%BC%D0%BC%D0%B0+%D0%B4%D0%BB%D1%8F+%D1%87%D1%82%D0%B5%D0%BD%D0%B8%D1%8F+%D1%8D%D0%BB%D0%B5%D0%BA%D1%82%D1%80%D0%BE%D0%BD%D0%BD%D1%8B%D1%85+%D0%BA%D0%BD%D0%B8%D0%B3+%D0%B2+%D1%80%D0%B0%D0%B7%D0%BB%D0%B8%D1%87%D0%BD%D1%8B%D1%85+%D1%84%D0%BE%D1%80%D0%BC%D0%B0%D1%82%D0%B0%D1%85"></div></div>
  2318. </body>
  2319. </html>
  2320.  
  2321. <!-- Dynamic page generated in 0.454 seconds. -->
  2322. <!-- Cached page generated by WP-Super-Cache on 2025-05-11 20:12:29 -->
  2323.  
  2324. <!-- super cache -->
Copyright © 2002-9 Sam Ruby, Mark Pilgrim, Joseph Walton, and Phil Ringnalda