Генератор скрипта 60 секунд

Сервис генерации JS кода под ваш ID счетчика Яндекс Метрики. Скрипт работает по системе постоянной отправки целей каждые 30 секунд в Яндекс Метрику с уникальным идентификатором и при этом вся активность на сайте запоминается в КУКАХ браузера пользователя. Это значит, что все посещения сохраняются и при следующем посещении сайта пользователем его активность продолжит идти в плюс без разрыва и повторно отправленных целей 60 секунд от одного пользователя.

Как пользоваться сервисом?

Как создать цели в Яндекс Метрике?

Как установить скрипт?

Разработчики

  • В поле ID Яндекс Метрики впишите ID своего счетчика;
  • Нажмите кнопку "Установить ID счетчика";
  • Произойдет замена в тексте CodeCode на ID вашей Яндекс Метрики;
  • Далее вы можете нажать "Копировать код" и вставить сгенерированный код в HEAD своего на сайта.

Дополнительное пояснение: В скрипте ничего более менять не надо :) Вписываем, кликаем, генерируем и вставляем на сайт >_<

А для повторной генерации кода требуется обновить страницу.

Заходите в настройки Яндекс Метрики

Переходите во вкладку "Цели".

Здесь вы можете создать как раздельные JavaScript-события по отслеживания активности на сайте на 30sec, 60sec,90sec и т.д. Либо создать единую составную цель с этапами отслеживания активности пользователей:

Раздельные цели

Составная цель

Далее созданные цели вы можете применять уже в Яндекс Директе и задавать их в Мастер Кампании или в РСЯ с оптимизацией по конверсии.

PDF инструкция от Прайс Дмитрия по установке кода на сайт созданный в Tilda и LPMotor: Перейти

Если сайт на Creatium

Заходите в панель своего сайта, далее "Плагины" и нажимаете "Новый плагин"

В блоке "Выберите плагин" находите "Свой код"

Вставляете сгенерированный код в </HEAD> и нажимаете сохранить. Вуаля. Код работает как часы :)

Доработал скрипт с запоминанием активности пользователя
Вечкасов Кирилл: https://t.me/pomogay_marketing

Основной разработчик скрипта и идеи оптимизации МК по активности пользователей на сайте
Вячеслав Федоров: https://t.me/yandex_fedorov

<script>
var settings = {
    /* Настройки которые надо менять */
    need: 30, // Сюда вписываем через какое количество секунд повторно отправлять цель, по умолчанию стоит 60, но можно указать и 30
    checkTime: 10, // секунды. период проверки. 
    //желательно, чтобы need было кратно checkTime
	IDmetrika: CodeCode, // Сюда вписываем ИД Счетчика Яндекс Метрики
	/* Настройки которые надо менять */
}
 
/* 
## Инструкция по добавлению целей в Яндекс.Метрику ##
Если вы указываете в функции NEED шаг в 30 секунд, то в Метрике вы можете отслеживать цели с шагом в 30 секунд и цели событий добавляйте такие:
30sec
60sec
90sec
120sec
150sec и т.д.
 
Если вы указываете в функции NEED шаг в 60 секунд, то в Метрике вы можете отслеживать цели с шагом в 30 секунд и цели событий добавляйте такие:
60sec
120sec
180sec
240sec и т.д.
*/

/* БОЛЬШЕ В КОДЕ НИЧЕГО НЕ ТРОГАЕМ, ЦЕЛИ ТОЖЕ НЕ ПРАВИМ */

var metricsFn = function () {
    console.log(ActiveScore.timer);
    console.log(ActiveScore.need);
    var c1 = this.getCookie(this.cookieName);
    console.log(c1);
    if (ActiveScore.timer >= ActiveScore.need) {
        console.log("событие отправилось");
        /* Тут перечислять все что нужно будет вызвать по достижению цели */
        ym(settings.IDmetrika, "reachGoal", this.cookieName.slice(0, -3));
		
        /* Тут перечислять все что нужно будет вызвать по достижению цели */
    }
};

var ActiveScore = {
    need: settings.need,
    checkTime: settings.checkTime,
    loop: true,
    counter: 0,
    cookieName: "60sec_ap",
    sendFn: null,
    parts: 0,
    active_parts: 0,
    timer: 0,
    events: [
        "touchmove",
        "blur",
        "focus",
        "focusin",
        "focusout",
        "load",
        "resize",
        "scroll",
        "unload",
        "click",
        "dblclick",
        "mousedown",
        "mouseup",
        "mousemove",
        "mouseover",
        "mouseout",
        "mouseenter",
        "mouseleave",
        "change",
        "select",
        "submit",
        "keydown",
        "keypress",
        "keyup",
        "error",
    ],

    setEvents: function () {
        for (var index = 0; index < this.events.length; index++) {
            var eName = this.events[index];
            window.addEventListener(eName, function (e) {
                if (e.isTrusted && ActiveScore.period.events == false) {
                    ActiveScore.period.events = true;
                }
            });
        }
    },

    period: {
        start: 0,
        end: 0,
        events: false,
    },

    init: function (fn) {
        this.calcParts();
        this.setEvents();
        this.setStartCounter();
        if (this.checkCookie()) {
            this.sendFn = fn;
            this.start();
        }
    },

    readLastCookie: function () {
        var absurdlyLarge = 100000;
        for (var i = 1; i < absurdlyLarge; i++) {
            var cookie = this.getCookie(i * this.need + 'sec_ap');
            if (cookie != this.parts * this.parts) return { i: i, cookie: cookie };
        }
        return { i: 1, cookie: 0 };
    },

    setStartCounter: function () {
        var lastCookie = this.readLastCookie();
        this.counter = lastCookie.i - 1;
        this.active_parts = Number(lastCookie.cookie);
        this.cookieName = (this.counter + 1) * this.need + "sec_ap";
    },

    calcParts: function () {
        this.parts = Math.ceil(this.need / this.checkTime);
    },

    setPeriod: function () {
        this.period.start = this.microtime();
        this.period.end = this.period.start + this.checkTime;
        this.period.events = false;
    },

    microtime: function () {
        var now = new Date().getTime() / 1000;
        var s = parseInt(now);
        return s;
    },

    start: function () {
        this.setPeriod();
        this.runPeriod();
    },

    timeoutId: null,

    checkPeriod: function () {
        if (this.period.events == true) {
            this.active_parts = this.active_parts + 1;
            // console.log('В этой секции были действия');
        } else {
            // console.log('В этой секции НЕБЫЛО действия');
        }
        this.timer = this.active_parts * this.checkTime;
        console.log(
            this.active_parts + " / " + this.parts + " [" + this.timer + "]"
        );

        if (this.checkSecs()) {
        } else {
            this.start();
        }
        this.setCookie(this.cookieName, this.active_parts);
    },

    checkSecs: function () {
        if (this.timer >= this.need) {
            this.send();
            if (this.loop == true) {
                this.counter++;
                this.timer = 0;
                this.active_parts = 0;
                this.cookieName = (this.counter + 1) * this.need + "sec_ap";
                return false;
            } else {
                // console.log('Завершили проверку активности');
                return true;
            }
        }
        return false;
    },

    timeoutFn: function () {
        ActiveScore.checkPeriod();
    },

    runPeriod: function () {
        this.timeoutId = setTimeout(this.timeoutFn, this.checkTime * 1000);
    },

    send: function () {
        if (this.getCookie(this.cookieName) == this.parts * this.parts) {
            this.setStartCounter();
        } else {
            this.setCookie(this.cookieName, this.active_parts * this.active_parts);
        }
        this.sendFn();
    },

    checkCookie: function () {
        var c = this.getCookie(this.cookieName);
        if (c == null) {
            return true;
        } else {
            if (c == '') return true;
            c = parseInt(c);
            if (c >= this.parts) {
                // console.log('Скрипт даже не запустился...');
                if (this.loop == true) {
                    return true;
                }
                return false;
            } else {
                this.active_parts = c;
                return true;
            }
        }
    },

    setCookie: function (name, value, days) {
        var expires = "";
        if (days) {
            var date = new Date();
            date.setTime(date.getTime() + days * 24 * 60 * 60 * 1000);
            expires = "; expires=" + date.toUTCString();
        }
        document.cookie = name + "=" + (value || "") + expires + "; path=/";
    },
    getCookie: function (name) {
        var nameEQ = name + "=";
        var ca = document.cookie.split(";");
        for (var i = 0; i < ca.length; i++) {
            var c = ca[i];
            while (c.charAt(0) == " ") c = c.substring(1, c.length);
            if (c.indexOf(nameEQ) == 0) return c.substring(nameEQ.length, c.length);
        }
        return null;
    },
    eraseCookie: function (name) {
        document.cookie =
            name + "=; Path=/; Expires=Thu, 01 Jan 1970 00:00:01 GMT;";
    },
};

ActiveScore.init(metricsFn);
</script>

ТЕЛЕГРАМ-КАНАЛ
ПОМОГАЮЩИЙ МАРКЕТОЛОГ

ПОДПИСАТЬСЯ!

Делюсь фишками маркетинга, о которых не прочитаешь в интернетах. 

Показываю на примерах,
как привожу клиентов
себе и своим клиентам!

Нас уже

ПОМОГАЮЩИЙ МАРКЕТОЛОГ

1910