Уважаемые пользователи!
C 7 ноября 2020 года phpBB Group прекратила выпуск обновлений и завершила дальнейшее развитие phpBB версии 3.2.
С 1 августа 2024 года phpBB Group прекращает поддержку phpBB 3.2 на официальном сайте.
Сайт официальной русской поддержки phpBB Guru продолжит поддержку phpBB 3.2 до 31 декабря 2024 года.
С учетом этого, настоятельно рекомендуется обновить конференции до версии 3.3.

Индикатор загрузки форума на jQuery

Есть любые вопросы, связанные со стилями/темами для phpBB 3.2.x или 3.3.x? Задайте их здесь!
Правила форума
Местная Конституция | Шаблон запроса | Документация (phpBB3) | Мини [FAQ] по phpBB 3.1.x/3.2.x | FAQ | Как задавать вопросы | Как устанавливать расширения

Ваш вопрос может быть удален без объяснения причин, если на него есть ответы по приведённым ссылкам (а вы рискуете получить предупреждение ;) ).
al36rus
phpBB 1.4.2
Сообщения: 68
Стаж: 4 года 3 месяца
Благодарил (а): 25 раз
Поблагодарили: 3 раза
Забанен: Бессрочно

Индикатор загрузки форума на jQuery

Сообщение al36rus »

Прикрутил себе, понравилось

С использованием плагина NProgress.js
loader.jpg
Демо


  1. Внутрь <head></head>

    nprogress.css

    Код: Выделить всё

    /* Make clicks pass-through */
    #nprogress {
      pointer-events: none;
    }
    
    #nprogress .bar {
      background: #29d;
    
      position: fixed;
      z-index: 1031;
      top: 0;
      left: 0;
    
      width: 100%;
      height: 2px;
    }
    
    /* Fancy blur effect */
    #nprogress .peg {
      display: block;
      position: absolute;
      right: 0px;
      width: 100px;
      height: 100%;
      box-shadow: 0 0 10px #29d, 0 0 5px #29d;
      opacity: 1.0;
    
      -webkit-transform: rotate(3deg) translate(0px, -4px);
          -ms-transform: rotate(3deg) translate(0px, -4px);
              transform: rotate(3deg) translate(0px, -4px);
    }
    
    /* Remove these to get rid of the spinner */
    #nprogress .spinner {
      display: block;
      position: fixed;
      z-index: 1031;
      top: 15px;
      right: 15px;
    }
    
    #nprogress .spinner-icon {
      width: 18px;
      height: 18px;
      box-sizing: border-box;
    
      border: solid 2px transparent;
      border-top-color: #29d;
      border-left-color: #29d;
      border-radius: 50%;
    
      -webkit-animation: nprogress-spinner 400ms linear infinite;
              animation: nprogress-spinner 400ms linear infinite;
    }
    
    .nprogress-custom-parent {
      overflow: hidden;
      position: relative;
    }
    
    .nprogress-custom-parent #nprogress .spinner,
    .nprogress-custom-parent #nprogress .bar {
      position: absolute;
    }
    
    @-webkit-keyframes nprogress-spinner {
      0%   { -webkit-transform: rotate(0deg); }
      100% { -webkit-transform: rotate(360deg); }
    }
    @keyframes nprogress-spinner {
      0%   { transform: rotate(0deg); }
      100% { transform: rotate(360deg); }
    }

    nprogress.js

    Код: Выделить всё

    /* NProgress, (c) 2013, 2014 Rico Sta. Cruz - http://ricostacruz.com/nprogress
     * @license MIT */
    
    ;(function(root, factory) {
    
      if (typeof define === 'function' && define.amd) {
        define(factory);
      } else if (typeof exports === 'object') {
        module.exports = factory();
      } else {
        root.NProgress = factory();
      }
    
    })(this, function() {
      var NProgress = {};
    
      NProgress.version = '0.2.0';
    
      var Settings = NProgress.settings = {
        minimum: 0.08,
        easing: 'linear',
        positionUsing: '',
        speed: 200,
        trickle: true,
        trickleSpeed: 200,
        showSpinner: true,
        barSelector: '[role="bar"]',
        spinnerSelector: '[role="spinner"]',
        parent: 'body',
        template: '<div class="bar" role="bar"><div class="peg"></div></div><div class="spinner" role="spinner"><div class="spinner-icon"></div></div>'
      };
    
      /**
       * Updates configuration.
       *
       *     NProgress.configure({
       *       minimum: 0.1
       *     });
       */
      NProgress.configure = function(options) {
        var key, value;
        for (key in options) {
          value = options[key];
          if (value !== undefined && options.hasOwnProperty(key)) Settings[key] = value;
        }
    
        return this;
      };
    
      /**
       * Last number.
       */
    
      NProgress.status = null;
    
      /**
       * Sets the progress bar status, where `n` is a number from `0.0` to `1.0`.
       *
       *     NProgress.set(0.4);
       *     NProgress.set(1.0);
       */
    
      NProgress.set = function(n) {
        var started = NProgress.isStarted();
    
        n = clamp(n, Settings.minimum, 1);
        NProgress.status = (n === 1 ? null : n);
    
        var progress = NProgress.render(!started),
            bar      = progress.querySelector(Settings.barSelector),
            speed    = Settings.speed,
            ease     = Settings.easing;
    
        progress.offsetWidth; /* Repaint */
    
        queue(function(next) {
          // Set positionUsing if it hasn't already been set
          if (Settings.positionUsing === '') Settings.positionUsing = NProgress.getPositioningCSS();
    
          // Add transition
          css(bar, barPositionCSS(n, speed, ease));
    
          if (n === 1) {
            // Fade out
            css(progress, {
              transition: 'none',
              opacity: 1
            });
            progress.offsetWidth; /* Repaint */
    
            setTimeout(function() {
              css(progress, {
                transition: 'all ' + speed + 'ms linear',
                opacity: 0
              });
              setTimeout(function() {
                NProgress.remove();
                next();
              }, speed);
            }, speed);
          } else {
            setTimeout(next, speed);
          }
        });
    
        return this;
      };
    
      NProgress.isStarted = function() {
        return typeof NProgress.status === 'number';
      };
    
      /**
       * Shows the progress bar.
       * This is the same as setting the status to 0%, except that it doesn't go backwards.
       *
       *     NProgress.start();
       *
       */
      NProgress.start = function() {
        if (!NProgress.status) NProgress.set(0);
    
        var work = function() {
          setTimeout(function() {
            if (!NProgress.status) return;
            NProgress.trickle();
            work();
          }, Settings.trickleSpeed);
        };
    
        if (Settings.trickle) work();
    
        return this;
      };
    
      /**
       * Hides the progress bar.
       * This is the *sort of* the same as setting the status to 100%, with the
       * difference being `done()` makes some placebo effect of some realistic motion.
       *
       *     NProgress.done();
       *
       * If `true` is passed, it will show the progress bar even if its hidden.
       *
       *     NProgress.done(true);
       */
    
      NProgress.done = function(force) {
        if (!force && !NProgress.status) return this;
    
        return NProgress.inc(0.3 + 0.5 * Math.random()).set(1);
      };
    
      /**
       * Increments by a random amount.
       */
    
      NProgress.inc = function(amount) {
        var n = NProgress.status;
    
        if (!n) {
          return NProgress.start();
        } else if(n > 1) {
          return;
        } else {
          if (typeof amount !== 'number') {
            if (n >= 0 && n < 0.2) { amount = 0.1; }
            else if (n >= 0.2 && n < 0.5) { amount = 0.04; }
            else if (n >= 0.5 && n < 0.8) { amount = 0.02; }
            else if (n >= 0.8 && n < 0.99) { amount = 0.005; }
            else { amount = 0; }
          }
    
          n = clamp(n + amount, 0, 0.994);
          return NProgress.set(n);
        }
      };
    
      NProgress.trickle = function() {
        return NProgress.inc();
      };
    
      /**
       * Waits for all supplied jQuery promises and
       * increases the progress as the promises resolve.
       *
       * @param $promise jQUery Promise
       */
      (function() {
        var initial = 0, current = 0;
    
        NProgress.promise = function($promise) {
          if (!$promise || $promise.state() === "resolved") {
            return this;
          }
    
          if (current === 0) {
            NProgress.start();
          }
    
          initial++;
          current++;
    
          $promise.always(function() {
            current--;
            if (current === 0) {
                initial = 0;
                NProgress.done();
            } else {
                NProgress.set((initial - current) / initial);
            }
          });
    
          return this;
        };
    
      })();
    
      /**
       * (Internal) renders the progress bar markup based on the `template`
       * setting.
       */
    
      NProgress.render = function(fromStart) {
        if (NProgress.isRendered()) return document.getElementById('nprogress');
    
        addClass(document.documentElement, 'nprogress-busy');
    
        var progress = document.createElement('div');
        progress.id = 'nprogress';
        progress.innerHTML = Settings.template;
    
    
    
        var bar = progress.querySelector(Settings.barSelector),
            perc = fromStart ? '-100' : toBarPerc(NProgress.status || 0),
            parent = isDOM(Settings.parent)
              ? Settings.parent
              : document.querySelector(Settings.parent),
            spinner
    
        css(bar, {
          transition: 'all 0 linear',
          transform: 'translate3d(' + perc + '%,0,0)'
        });
    
        if (!Settings.showSpinner) {
          spinner = progress.querySelector(Settings.spinnerSelector);
          spinner && removeElement(spinner);
        }
    
        if (parent != document.body) {
          addClass(parent, 'nprogress-custom-parent');
        }
    
        parent.appendChild(progress);
        return progress;
      };
    
      /**
       * Removes the element. Opposite of render().
       */
    
      NProgress.remove = function() {
        removeClass(document.documentElement, 'nprogress-busy');
        var parent = isDOM(Settings.parent)
          ? Settings.parent
          : document.querySelector(Settings.parent)
        removeClass(parent, 'nprogress-custom-parent')
        var progress = document.getElementById('nprogress');
        progress && removeElement(progress);
      };
    
      /**
       * Checks if the progress bar is rendered.
       */
    
      NProgress.isRendered = function() {
        return !!document.getElementById('nprogress');
      };
    
      /**
       * Determine which positioning CSS rule to use.
       */
    
      NProgress.getPositioningCSS = function() {
        // Sniff on document.body.style
        var bodyStyle = document.body.style;
    
        // Sniff prefixes
        var vendorPrefix = ('WebkitTransform' in bodyStyle) ? 'Webkit' :
                           ('MozTransform' in bodyStyle) ? 'Moz' :
                           ('msTransform' in bodyStyle) ? 'ms' :
                           ('OTransform' in bodyStyle) ? 'O' : '';
    
        if (vendorPrefix + 'Perspective' in bodyStyle) {
          // Modern browsers with 3D support, e.g. Webkit, IE10
          return 'translate3d';
        } else if (vendorPrefix + 'Transform' in bodyStyle) {
          // Browsers without 3D support, e.g. IE9
          return 'translate';
        } else {
          // Browsers without translate() support, e.g. IE7-8
          return 'margin';
        }
      };
    
      /**
       * Helpers
       */
    
      function isDOM (obj) {
        if (typeof HTMLElement === 'object') {
          return obj instanceof HTMLElement
        }
        return (
          obj &&
          typeof obj === 'object' &&
          obj.nodeType === 1 &&
          typeof obj.nodeName === 'string'
        )
      }
    
      function clamp(n, min, max) {
        if (n < min) return min;
        if (n > max) return max;
        return n;
      }
    
      /**
       * (Internal) converts a percentage (`0..1`) to a bar translateX
       * percentage (`-100%..0%`).
       */
    
      function toBarPerc(n) {
        return (-1 + n) * 100;
      }
    
    
      /**
       * (Internal) returns the correct CSS for changing the bar's
       * position given an n percentage, and speed and ease from Settings
       */
    
      function barPositionCSS(n, speed, ease) {
        var barCSS;
    
        if (Settings.positionUsing === 'translate3d') {
          barCSS = { transform: 'translate3d('+toBarPerc(n)+'%,0,0)' };
        } else if (Settings.positionUsing === 'translate') {
          barCSS = { transform: 'translate('+toBarPerc(n)+'%,0)' };
        } else {
          barCSS = { 'margin-left': toBarPerc(n)+'%' };
        }
    
        barCSS.transition = 'all '+speed+'ms '+ease;
    
        return barCSS;
      }
    
      /**
       * (Internal) Queues a function to be executed.
       */
    
      var queue = (function() {
        var pending = [];
    
        function next() {
          var fn = pending.shift();
          if (fn) {
            fn(next);
          }
        }
    
        return function(fn) {
          pending.push(fn);
          if (pending.length == 1) next();
        };
      })();
    
      /**
       * (Internal) Applies css properties to an element, similar to the jQuery
       * css method.
       *
       * While this helper does assist with vendor prefixed property names, it
       * does not perform any manipulation of values prior to setting styles.
       */
    
      var css = (function() {
        var cssPrefixes = [ 'Webkit', 'O', 'Moz', 'ms' ],
            cssProps    = {};
    
        function camelCase(string) {
          return string.replace(/^-ms-/, 'ms-').replace(/-([\da-z])/gi, function(match, letter) {
            return letter.toUpperCase();
          });
        }
    
        function getVendorProp(name) {
          var style = document.body.style;
          if (name in style) return name;
    
          var i = cssPrefixes.length,
              capName = name.charAt(0).toUpperCase() + name.slice(1),
              vendorName;
          while (i--) {
            vendorName = cssPrefixes[i] + capName;
            if (vendorName in style) return vendorName;
          }
    
          return name;
        }
    
        function getStyleProp(name) {
          name = camelCase(name);
          return cssProps[name] || (cssProps[name] = getVendorProp(name));
        }
    
        function applyCss(element, prop, value) {
          prop = getStyleProp(prop);
          element.style[prop] = value;
        }
    
        return function(element, properties) {
          var args = arguments,
              prop,
              value;
    
          if (args.length == 2) {
            for (prop in properties) {
              value = properties[prop];
              if (value !== undefined && properties.hasOwnProperty(prop)) applyCss(element, prop, value);
            }
          } else {
            applyCss(element, args[1], args[2]);
          }
        }
      })();
    
      /**
       * (Internal) Determines if an element or space separated list of class names contains a class name.
       */
    
      function hasClass(element, name) {
        var list = typeof element == 'string' ? element : classList(element);
        return list.indexOf(' ' + name + ' ') >= 0;
      }
    
      /**
       * (Internal) Adds a class to an element.
       */
    
      function addClass(element, name) {
        var oldList = classList(element),
            newList = oldList + name;
    
        if (hasClass(oldList, name)) return;
    
        // Trim the opening space.
        element.className = newList.substring(1);
      }
    
      /**
       * (Internal) Removes a class from an element.
       */
    
      function removeClass(element, name) {
        var oldList = classList(element),
            newList;
    
        if (!hasClass(element, name)) return;
    
        // Replace the class name.
        newList = oldList.replace(' ' + name + ' ', ' ');
    
        // Trim the opening and closing spaces.
        element.className = newList.substring(1, newList.length - 1);
      }
    
      /**
       * (Internal) Gets a space separated list of the class names on the element.
       * The list is wrapped with a single space on each end to facilitate finding
       * matches within the list.
       */
    
      function classList(element) {
        return (' ' + (element && element.className || '') + ' ').replace(/\s+/gi, ' ');
      }
    
      /**
       * (Internal) Removes an element from the DOM.
       */
    
      function removeElement(element) {
        element && element.parentNode && element.parentNode.removeChild(element);
      }
    
      return NProgress;
    });
  2. Перед </body>

    Код: Выделить всё

    <script>
        NProgress.start();
    
        var interval = setInterval(function() { NProgress.inc(); }, 1000);        
    
        jQuery(window).load(function () {
            clearInterval(interval);
            NProgress.done();
        });
    
        jQuery(window).unload(function () {
            NProgress.start();
        });
    </script>
У вас нет необходимых прав для просмотра вложений в этом сообщении.
Последний раз редактировалось Татьяна5 12.05.2020 12:48, всего редактировалось 1 раз.
Причина: Убрала подключение jQuery по просьбе автора
Аватара пользователя
southklad
phpBB 3.1.0 RC2
Сообщения: 3232
Стаж: 12 лет 3 месяца
Благодарил (а): 704 раза
Поблагодарили: 152 раза

Re: Индикатор загрузки форума на jQuery

Сообщение southklad »

Накой тем более в таком виде?
Изображение
al36rus
phpBB 1.4.2
Сообщения: 68
Стаж: 4 года 3 месяца
Благодарил (а): 25 раз
Поблагодарили: 3 раза
Забанен: Бессрочно

Re: Индикатор загрузки форума на jQuery

Сообщение al36rus »

какой-то глупый вопрос.
не нужен - не используй, очевидно же
Аватара пользователя
Татьяна5
Поддержка
Поддержка
Сообщения: 12425
Стаж: 12 лет 8 месяцев
Благодарил (а): 166 раз
Поблагодарили: 2477 раз

Re: Индикатор загрузки форума на jQuery

Сообщение Татьяна5 »

На 3.1 и выше ставить в таком виде не рекомендуется, будет очень много конфликтов с расширениями

Отправлено спустя 4 минуты 3 секунды:
al36rus, советую: Подключение своего css через расширение [Для новичков]
Другие файлы с html подключаются так же, как там описано, только названия файлов в папке event будут разные (названия можно посмотреть в файлах шаблонов стиля, в нужных для вставки кода местах)
Подключение jQuery не нужно вообще
Аватара пользователя
KEMnEP
phpBB 2.0.17
Сообщения: 1117
Стаж: 9 лет 1 месяц
Благодарил (а): 42 раза
Поблагодарили: 278 раз

Re: Индикатор загрузки форума на jQuery

Сообщение KEMnEP »

al36rus, глючит, зашёл на демо, первый раз страница загрузилась быстро и если бы не знал куда смотреть, вообще бы не увидел разницы, что что то крутилось :D Но! обновив тут же страницу получил глюк, страница явно загрузилась уже, а кругляк всё крутился довольно долго. И ещё, у Вас 2 раза подключен скрипт

Код: Выделить всё

<script src="//ajax.googleapis.com/ajax/libs/jquery/3.1.0/jquery.min.js"></script>
и

Код: Выделить всё

<script src="./assets/javascript/jquery.min.js?assets_version=607"></script>
Это нехорошо, первый лишний.
al36rus
phpBB 1.4.2
Сообщения: 68
Стаж: 4 года 3 месяца
Благодарил (а): 25 раз
Поблагодарили: 3 раза
Забанен: Бессрочно

Re: Индикатор загрузки форума на jQuery

Сообщение al36rus »

никаких конфликтов с расширениями быть не может.
редактируется только шаблон (даже не материнский просильвер), стили так же можно не отдельным файлом, а докинуть классы в css шаблона. про jquery не в курсе.

Отправлено спустя 4 минуты 26 секунд:
он не глючит, это у меня проблема с периодическим подвисанием (возможно, из-за кеширования - не разбирался). короче, долгая загрузка у меня отношения к нему не имеет, так было и до него и до phpbb.
про библиотеку уже понял, благодарю

Отправлено спустя 2 минуты 18 секунд:
кругляк вообще убрать надо, суть не в нем :lol:
Аватара пользователя
Татьяна5
Поддержка
Поддержка
Сообщения: 12425
Стаж: 12 лет 8 месяцев
Благодарил (а): 166 раз
Поблагодарили: 2477 раз

Re: Индикатор загрузки форума на jQuery

Сообщение Татьяна5 »

al36rus писал(а): 12.05.2020 4:09 про jquery не в курсе
Вот. При дубле этой библиотеки конфликтов как раз будет очень много

Отправлено спустя 2 минуты 6 секунд:
al36rus, в расширение оформите? (На уровне шаблонов это сделать вообще несложно)
Аватара пользователя
Siava
Поддержка
Поддержка
Сообщения: 5283
Стаж: 19 лет 3 месяца
Откуда: Питер
Благодарил (а): 186 раз
Поблагодарили: 793 раза

Re: Индикатор загрузки форума на jQuery

Сообщение Siava »

al36rus писал(а): 12.05.2020 4:09 это у меня проблема с периодическим подвисанием
У вас похоже cron.feedpost запускается при каждом открытии страницы, занимая при этом до 10 секунд времени.
Еще одно нарушение правил и будете забанены. © Mr. Anderson
Ты очистил кеш? © Sheer
https://siava.ru (phpbb 2.0.x 3.5.x)
al36rus
phpBB 1.4.2
Сообщения: 68
Стаж: 4 года 3 месяца
Благодарил (а): 25 раз
Поблагодарили: 3 раза
Забанен: Бессрочно

Re: Индикатор загрузки форума на jQuery

Сообщение al36rus »

Не могу редактировать свой пост и удалить подключение библиотеки - извиняюсь, был невнимателен.
По поводу расширения: если не заморочено, попробую оформить, конечно, позже :dontknow
С кроном есть момент - ноги растут отсюда, но подобный тормоз был и до phpBB. короче, нужен настрой, чтобы разобраться.

п.с. кругляк отключается в nprogress.js

Код: Выделить всё

showSpinner: true,

Вернуться в «Стили для phpBB 3.2.x / 3.3.x»