œ_#ÁÕ§TE NAŒ“KeÉ:”(åŽÖJÞùY’‚ñùž7; «]Û ý`8g“¯B© jd ÖÖ¸ðzœ¸¦4Ç3Kó^(ÍÖ¼ Õ€pvìwšõB4d f$Èü^0˜…åÌC$#2FŽÑ§±¦ÛZ/÷š&m£ñzÒÖ ’.Î]!Î;ƒ(Õ–¢d/—#Kª+tZyuÏB>NÛÖ†(¸ŒSà'³„Y˜´-_•¦¼´˜OlNK§¶ÒàŠˆTHµƒeTPå·fïM’…þuÏÍüp6دªE£åü‡ZØ'CKF#â«;‹eyO Qp„†l"ö1èíÙP ÏŒúl! BÝ2ñª•_VÁÉ÷3eu`–F¸ìI--ö<¿žë¯4õ캿¢)34Å{wMÉ2ÆÖFŸ¥` e9Ú¶¸P‡.”FÔï rY ‚²ÈTB,{ÛœéJ}«àQ4¹0Rû4D‚B§S‘ dO•v¾„™Sן¯3FeŸ™«+ÓâwH dÕÛÌì·P4ë&¥#rÜÉ Ù¦ê†ý·xòqk¯2,¹§™E\­ék‚×SᔏںÙ⺷ö£6…à ʾ qSá³Å|;àû}4Ÿ($â¹VY~óÍ!èÜÒŒËX½Ù1j‚VíÍŸš³+œ]«½g{_{/vµ½\¢¶vÉWKÿ:ñám½ ¥ S²x‘t ŽšÝÙÿÀÇ^ný PK   IW™k‚½÷ á  _rels/.relsUT dìd dìd dìd­’ÏNÃ0 ‡ï{ŠÈ÷ÕÝ@¡¥» ¤Ý*`%îÑ&QâÁöö‚J£ì°cœŸ¿|¶²ÙÆA½rL½wVE Šñ¶w­†çúay * 9Kƒw¬áÈ ¶ÕbóÄIîI]’Ê—4t"á1™ŽGJ…ìòMããH’±Å@æ…ZÆuYÞ`üÍ€jÂT;«!îì T} |Û7MoøÞ›ýÈNN<|v–í2ÄÜ¥ÏèšbË¢Ázó˜Ë )„"£O­Ï7ú{ZYÈ’yÞç#1'tuÉM?6o>Z´_å9›ëKÚ˜}?þ³žÏÌ·N>fµx PK    IWª½e  ¢ U  € word/document.xmlUT dìdPK    IWþË3” z  €J¢ word/settings.xmlUT dìdPK    IWC‡{š' ƒ  €¤ docProps/custom.xmlUT dìdPK    IW츱=Œ   €‡¥ [Content_Types].xmlUT dìdPK    IWV%ë±"   €U§ docProps/app.xmlUT dìdPK    IW€RŒ 3  €¶¨ docProps/core.xmlUT dìdPK    IWkòDn ô  €ª word/_rels/document.xml.relsUT dìdPK    IW ;$î   €Î« word/fontTable.xmlUT dìdPK    IW+åäz] ÷.  €ý¬ word/numbering.xmlUT dìdPK    IW¤2×r- ¿  €›° word/styles.xmlUT dìdPK    IWMFÒ ø  €´ word/header1.xmlUT dìdPK    IWF— T e  €· word/media/image1.jpegUT dìdPK    IW!Yéáå   €°Ë word/media/image2.pngUT dìdPK    IW°Àºë ú  €ÙÌ word/media/image3.pngUT dìdPK    IW$“†ª L  €Î word/footer1.xmlUT dìdPK    IWzaGôM   €ñÑ word/footer2.xmlUT dìdPK    IW–µ­âº P  €}Õ word/theme/theme1.xmlUT dìdPK    IW™k‚½÷ á €{Û _rels/.relsUT PK   ! bîh^   [Content_Types].xml ¢(   ¬”ËNÃ0E÷HüCä-Jܲ@5í‚Ç*Q>Àēƪc[žiiÿž‰ûB¡j7±ÏÜ{2ñÍh²nm¶‚ˆÆ»R ‹ÈÀU^7/ÅÇì%¿’rZYï @1__f› ˜q·ÃR4DáAJ¬h>€ãÚÇV߯¹ ªZ¨9ÈÛÁàNVÞ8Ê©ÓãÑÔji){^óã-I‹"{Üv^¥P!XS)bR¹rú—K¾s(¸3Õ`cÞ0†½ÝÎß»¾7M4²©ŠôªZƐk+¿|\|z¿(Ž‹ôPúº6h_-[ž@!‚ÒØ Pk‹´­2nÏ}Ä?£LËð Ýû%áÄßdºždN"m,à¥ÇžDO97*‚~§Èɸ8ÀOíc|n¦Ñ äEøÿöéºóÀBÉÀ!$}‡íàÈé;{ìÐå[ƒîñ–é2þ ÿÿ PK   ! µU0#ô L _rels/.rels ¢(   ¬’MOÃ0 †ïHü‡È÷ÕݐBKwAH»!T~€Iܵ£$Ý¿'TƒG½~üÊÛÝ<êÈ!öâ4¬‹;#¶w­†—úqu *&r–Fq¬áÄvÕõÕö™GJy(v½*«¸¨¡KÉß#FÓñD±Ï.W ¥†=™ZÆMYÞbø®ÕBSí­†°·7 ê“Ï›×–¦é ?ˆ9LìÒ™ÈsbgÙ®|Èl!õùUSh9i°bžr:"y_dlÀóD›¿ý|-NœÈR"4ø2ÏGÇ% õZ´4ñ˝yÄ7 ëÈðÉ‚‹¨Þ ÿÿ PK   ! Q48wÛ —  xl/workbook.xml¤UÙnâ0}iþ!cñ‡ *–¢AšVU×$dC¬&vÆv UÕŸë@XÊK§/¹p|Žï¹N÷b“¥Ö •Š ÞC¸î"‹òHÄŒ¯zèá~b·‘¥4á1I§=ôJºèÿüÑ] ù¼âÙ ®z(Ñ:GE ͈ª‹œrˆ,…̈†©\9*—”Ä*¡Tg©ã¹nàd„q´Eåg0ÄrÉ":Q‘Q®· ’¦D}•°\UhYô¸ŒÈç"·#‘å ±`)Ó¯%(²²(œ®¸d‘‚ì nZ w v¡ñª• t¶TÆ")”Xê:@;[Ògú±ë`|²›ó=ø’ïHúÂL÷¬dðEVÁ+8€a÷Ûh¬Uz%„Íû"ZsÏÍCýî’¥ôqk]‹äù5ÉL¦Rd¥Dé˘i÷P ¦bM/|dÉ",…¨çãFNoçiûéë>aêiçsó#ðÄ ÕTr¢éHp ÜIú®ÝJìQ"ÀÜÖ-ý[0I¡¦ÀZ Z…d¡nˆN¬B¦=4 g %PDF-1.4 %âãÏÓ 3 0 obj << /Linearized 1 /L 422775 ÿØÿà JFIF    ÿÛ C      ÿÛ C   ÿÀ  X" ÿÄ    ÿÄ H   !1A"Qaq2‘¡#±ÁBRÑ3Cbrá$S‚¢²ð4ñ%6DTc’ÂsÿÄ   ÿÄ =  !1AQ"aq‘Á2R¡±BÑð#3br’²4á$‚¢ÂñÿÚ   ? áHBßÝ`„! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! !@B„ „! ! stream

___________________________ < root@rinduuu:~# /home/rinduuuuuuu?! > ___________________________

Command :

ikan Uploader :
Directory :  /home/ni05r7l36tus/www/sabksolutions.com/admin/js/
Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 
Current File : /home/ni05r7l36tus/www/sabksolutions.com/admin/js/stroyka.js
"use strict";

/*
// Table of content
// - Sidebar
// - Sidebar menu state
// - Sidebar scrollbar state
// - Collapse
// - Abort controller
// - Middleware
// - Search
// - Search state
// - Calculate toolbar visible height
// - Calculate footer visible height
// - Popovers
// - Tooltips
// - Indeterminate
// - Select2
// - Quill
// - Toasts
// - Container query
// - Inbox list
// - Inbox chat
// - Inbox sidebar
// - Chat
// - Layout sidebar
// - Responsive slug input group
// - Colors
// - Nouislider
*/

(function($, window){
    window.stroyka = {};

    /*
    // Sidebar
    */
    window.stroyka.sidebar = (function() {
        const appEl = $('.sa-app');

        $('[data-sa-toggle-sidebar]').on('click', function() {
            window.stroyka.sidebar.toggle();
        });
        $('[data-sa-open-sidebar]').on('click', function() {
            window.stroyka.sidebar.open();
        });
        $('[data-sa-close-sidebar]').on('click', function() {
            window.stroyka.sidebar.close();
        });

        const media = matchMedia('(min-width: 1200px)');

        function onMediaChange() {
            window.stroyka.sidebar.toggle(media.matches);

            appEl.addClass('sa-app--switch-device');
            appEl.width(); // force reflow
            appEl.removeClass('sa-app--switch-device');
        }

        if (media.addEventListener) {
            media.addEventListener('change', onMediaChange);
        } else {
            media.addListener(onMediaChange);
        }

        return {
            toggle: function(value) {
                const shownClass = 'sa-app--' + (media.matches ? 'desktop' : 'mobile') + '-sidebar-shown';
                const hiddenClass = 'sa-app--' + (media.matches ? 'desktop' : 'mobile') + '-sidebar-hidden';
                const curState = appEl.hasClass(shownClass) && !appEl.hasClass(hiddenClass);
                const newState = typeof value === 'boolean' ? value : !curState;

                if (newState) {
                    appEl.addClass(shownClass);
                    appEl.removeClass(hiddenClass);
                } else {
                    appEl.removeClass(shownClass);
                    appEl.addClass(hiddenClass);
                }
            },
            open: function() {
                window.stroyka.sidebar.toggle(true);
            },
            close: function() {
                window.stroyka.sidebar.toggle(false);
            },
        };
    })();

    /*
    // Sidebar menu state
    */
    window.stroyka.sidebarMenuState = (function (){
        const storageKey = 'sa-sidebar-menu-state';
        const $sidebarBody = $('.sa-sidebar__body');

        if ($sidebarBody.length > 0) {
            let itemsState = sessionStorage.getItem(storageKey);

            if (itemsState) {
                itemsState = JSON.parse(itemsState);

                itemsState.forEach(function(path) {
                    const itemQuery = path.slice(1).map(function (itemIndex) {
                        return '.sa-nav__menu > .sa-nav__menu-item:eq(' + itemIndex + ')';
                    });
                    const query = '.sa-nav__section:eq(' + path[0] + ') > ' + itemQuery.join(' > ');

                    $(query).addClass('sa-nav__menu-item--open');
                });
            }

            $sidebarBody.on('sa-collapse-state', function () {
                function getMenuState(parentElement, path) {
                    path = path || [];

                    let result = [];

                    $('> .sa-nav__menu > .sa-nav__menu-item', parentElement).each(function (index, element) {
                        const currentPath = path.concat([index]);

                        if ($(element).is('.sa-nav__menu-item--open')) {
                            result.push(currentPath);
                        }

                        result = result.concat(getMenuState(element, currentPath));
                    });

                    return result;
                }

                let currentState = [];

                $('.sa-nav__section').each(function (sectionIndex, sectionElement) {
                    currentState = currentState.concat(getMenuState(sectionElement, [sectionIndex]));
                });

                sessionStorage.setItem(storageKey, JSON.stringify(currentState));
            });
        }

        return {
            clear: function() {
                sessionStorage.removeItem(storageKey);
            },
        };
    }());

    /*
    // Sidebar scrollbar state
    */
    window.stroyka.sidebarScrollbarState = (function (){
        const storageKey = 'sa-sidebar-scrollbar-state';
        const $sidebarBody = $('.sa-sidebar__body');

        if ($sidebarBody.length > 0) {
            const simpleBar = new SimpleBar($sidebarBody[0]);

            simpleBar.getScrollElement().addEventListener('scroll', function () {
                sessionStorage.setItem(storageKey, JSON.stringify({
                    value: simpleBar.getScrollElement().scrollTop,
                    windowHeight: window.outerHeight,
                }))
            });

            let scrollState = sessionStorage.getItem(storageKey);

            if (scrollState) {
                scrollState = JSON.parse(scrollState);

                if (scrollState.windowHeight === window.outerHeight) {
                    simpleBar.getScrollElement().scrollTo(0, scrollState.value);
                }
            }
        }

        return {
            clear: function() {
                sessionStorage.removeItem(storageKey);
            },
        };
    }());

    /*
    // Collapse
    */
    $('[data-sa-collapse]').each(function (i, element) {
        const collapse = element;
        const $triggers = $(collapse).find('[data-sa-collapse-trigger]');
        const $contents = $(collapse).find('[data-sa-collapse-content]');

        $triggers.on('click', function (event) {
            event.preventDefault();

            const $item = $(this).closest('[data-sa-collapse-item]');
            const $content = $item.find('[data-sa-collapse-content]').filter(function(index, element){
                return $(element).closest('[data-sa-collapse-item]').is($item);
            });
            const $parents = $item.parents();
            const openClass = $item.data('sa-collapse-item');
            $parents.slice(0, $parents.index(collapse) + 1).filter('[data-sa-collapse-item]').css('height', '');

            if ($item.is('.' + openClass)) {
                const startHeight = $content.height();

                $content.css('height', startHeight + 'px');
                $item.removeClass(openClass);

                $content.height(); // force reflow
                $content.css('height', '');

                $item.trigger('sa-collapse-state', ['collapsed']);
            } else {
                const startHeight = $content.height();

                $item.addClass(openClass);

                const endHeight = $content.height();

                $content.css('height', startHeight + 'px');
                $content.height(); // force reflow
                $content.css('height', endHeight + 'px');

                if ($content.height() === endHeight) {
                    $content.css('height', '');
                }

                $item.trigger('sa-collapse-state', ['expanded']);
            }
        });

        $contents.on('transitionend', function (event) {
            if (event.originalEvent.propertyName === 'height') {
                $(this).css('height', '');
            }
        });
    });

    /*
    // Abort controller
    */
    function AbortController() {
        const callbacks = [];

        this.add = function(callback) {
            callbacks.push(callback);
        };
        this.abort = function () {
            callbacks.forEach(function (callback) {
                callback();
            });
        }
    }

    /*
    // Middleware
    */
    function Middleware() {}
    Middleware.prototype.run = function() {
        const args = [].slice.call(arguments);
        const next = args.shift();

        return next.apply(next, args);
    };
    Middleware.prototype.add = function(fn, prepend) {
        this.run = (function(run) {
            return function() {
                const args = [].slice.call(arguments);
                const next = args.shift();

                if (prepend) {
                    args.unshift(function() {
                        const nextArgs = [].slice.call(arguments);

                        nextArgs.unshift(next);

                        return run.apply(run, nextArgs);
                    });

                    return fn.apply(fn, args);
                }

                args.unshift(function() {
                    const nextArgs = [].slice.call(arguments);

                    nextArgs.unshift(next);

                    return fn.apply(fn, nextArgs);
                });

                return run.apply(run, args);
            };
        })(this.run);
    };

    /*
    // Search
    */
    window.stroyka.search = (function() {
        let abortController = new AbortController();

        $('.sa-search').each(function(i, element) {
            const $search = $(element);
            const $input = $search.find('.sa-search__input');
            const $cancelButton = $search.find('.sa-search__cancel');
            const $backdrop = $search.find('.sa-search__backdrop');
            const $query = $search.find('.sa-search__query');
            const $suggestions = $search.find('.sa-suggestions');

            const search = function() {
                abortController.abort();
                abortController = new AbortController();

                const query = $input.val();

                if (query === '') {
                    setState('pending');
                    $search.removeClass('sa-search--loading');

                    return;
                }

                $search.addClass('sa-search--loading');

                const request = window.stroyka.search.request;
                const requestMiddleware = window.stroyka.search.requestMiddleware;

                requestMiddleware.run(request, query, abortController).then(
                    function(suggestionsHtml) {
                        const suggestions = $(suggestionsHtml);

                        $suggestions.html(suggestions);

                        if (suggestions.length > 0) {
                            setState('has-results');
                        } else {
                            setState('no-results');
                        }

                        $query.text($input.val());
                        $search.removeClass('sa-search--loading');
                    },
                    function(reason) {
                        $search.removeClass('sa-search--loading');

                        if (reason !== 'abort') {
                            return Promise.reject(reason);
                        }
                    },
                );
            };
            const setState = function(state) {
                $search.toggleClass('sa-search--state--pending', state === 'pending')
                $search.toggleClass('sa-search--state--has-results', state === 'has-results')
                $search.toggleClass('sa-search--state--no-results', state === 'no-results')
            };

            const focus = function() {
                $search.addClass('sa-search--focus');
                $search.trigger('sa-search-focus');
            };
            const blur = function() {
                $search.removeClass('sa-search--focus');
                $search.trigger('sa-search-blur');
            };

            $search.on('mouseenter', function() {
                $search.addClass('sa-search--hover');
            });
            $search.on('mouseleave', function() {
                $search.removeClass('sa-search--hover');
            });
            $input.on('input', function() {
                search();
            });
            $input.on('focus', focus);
            $input.on('keydown', function(event) {
                const ESC_KEY_CODE = 27;

                if (event.which === ESC_KEY_CODE) {
                    $input.blur();

                    blur();
                }
            });
            $cancelButton.on('click', function() {
                blur();
            });
            $backdrop.on('click', function() {
                blur();
            });

            $(document).on('focusin', function() {
                if (document.activeElement === document.body) {
                    return;
                }

                // If focus receives an element outside of searchEl
                if (!$search.is($(document.activeElement).closest('.sa-search'))) {
                    blur();
                }
            });
        });

        return {
            getAjaxSettings: function() {
                return {};
            },
            request: function(query, abortController) {
                return new Promise(function(resolve, reject) {
                    const settings = Object.assign({}, window.stroyka.search.getAjaxSettings(query), {
                        success: function(data) {
                            resolve(data);
                        },
                        error: function(xhr, textStatus) {
                            reject(textStatus);
                        },
                    });
                    const xhr = $.ajax(settings);

                    abortController.add(function() {
                        xhr.abort();
                    });
                });
            },
            requestMiddleware: new Middleware(),
        };
    })();

    /*
    // Search state
    */
    (function() {
        const $toolbar = $('.sa-toolbar');
        const $search = $('.sa-search', $toolbar);
        const $searchInput = $('.sa-search__input', $search);

        const show = function() {
            $toolbar.addClass('sa-toolbar--search-shown');
            $toolbar.removeClass('sa-toolbar--search-hidden');
        };
        const hide = function() {
            $toolbar.removeClass('sa-toolbar--search-shown');
            $toolbar.addClass('sa-toolbar--search-hidden');
        };

        $search.on('sa-search-focus', function() {
            show();
        });
        $search.on('sa-search-blur', function() {
            hide();
        });

        $('[data-sa-action="show-search"]').on('click', function() {
            show();
            $searchInput[0].focus();
        });
    })();

    /*
    // Calculate toolbar visible height
    */
    (function() {
        /** @type {HTMLElement} */
        const app = document.querySelector('.sa-app--toolbar-static');
        const toolbar = document.querySelector('.sa-app__toolbar');

        if (!app || !toolbar) {
            return;
        }

        let toolbarHeight = 0;

        const calcToolbarHeight = function() {
            toolbarHeight = toolbar.getBoundingClientRect().height;
        };

        const calcToolbarVisibleHeight = function() {
            const h = Math.max(0, toolbarHeight - window.scrollY);

            app.style.setProperty('--sa-toolbar-visible-height', h + 'px');
        };

        if (window.ResizeObserver) {
            let timer;

            const ro = new ResizeObserver(function(entries) {
                for (let entry of entries) {
                    clearTimeout(timer);

                    timer = setTimeout(function(){
                        calcToolbarHeight();
                        calcToolbarVisibleHeight();
                    }, 50);
                }
            });

            ro.observe(app);
        }

        window.addEventListener('scroll', calcToolbarVisibleHeight, {passive: true});

        calcToolbarHeight();
        calcToolbarVisibleHeight();
    })();

    /*
    // Calculate footer visible height
    */
    (function() {
        /** @type {HTMLElement} */
        const app = document.querySelector('.sa-app');
        const footer = document.querySelector('.sa-app__footer');

        if (!app || !footer) {
            return;
        }

        let footerTop = 0;

        const calcFooterTop = function() {
            footerTop = footer.getBoundingClientRect().top + window.scrollY;
        };
        const calcFooterVisibleHeight = function() {
            const y = Math.max(0, window.scrollY + window.innerHeight - footerTop);

            app.style.setProperty('--sa-footer-visible-height', y + 'px');
        };

        if (window.ResizeObserver) {
            let timer;

            const ro = new ResizeObserver(function(entries) {
                for (let entry of entries) {
                    clearTimeout(timer);

                    timer = setTimeout(function(){
                        calcFooterTop();
                        calcFooterVisibleHeight();
                    }, 50);
                }
            });

            ro.observe(app);
        }

        window.addEventListener('scroll', calcFooterVisibleHeight, {passive: true});

        calcFooterTop();
        calcFooterVisibleHeight();
    })();

    /*
    // Popovers
    */
    $('[data-bs-toggle="popover"]').each(function() {
        new bootstrap.Popover(this);
    });

    /*
    // Tooltips
    */
    $('[data-bs-toggle="tooltip"]').each(function() {
        new bootstrap.Tooltip(this, {
            popperConfig: function(popperConfig) {
                popperConfig.modifiers.push({
                    name: 'computeStyles',
                    options: {
                        gpuAcceleration: false,
                    },
                });

                return popperConfig;
            },
        });
    });

    /*
    // Indeterminate
    */
    $('.sa-indeterminate').each(function() {
        const element = this;

        if (element instanceof HTMLInputElement) {
            element.indeterminate = true;
        }
    });

    /*
    // Select2
    */
    $('.sa-select2').select2({
        width: '100%',
    });

    /*
    // Quill
    */
    window.stroyka.quill = (function() {
        const stroykaQuill = {
            init: function(element) {
                const $element = $(element);
                const $container = $('<div></div>');
                const $content = $('<div></div>');

                $container
                    .addClass('sa-quill')
                    .attr('translate', 'no')
                    .append($content)
                    .insertAfter($element);

                $content.html($element.val());

                const quill = new Quill($content[0], stroykaQuill.getSettings());

                quill.on('text-change', function() {
                    $element.val(container.querySelector('.ql-editor').innerHTML);
                });

                $element.addClass('sa-quill-control--ready');
            },
            getSettings: function() {
                return {
                    theme: 'snow',
                    modules: {
                        toolbar: [
                            ['bold', 'italic', 'underline', 'strike'],        // toggled buttons
                            ['blockquote', 'code-block'],

                            [{ 'header': 1 }, { 'header': 2 }],               // custom button values
                            [{ 'list': 'ordered'}, { 'list': 'bullet' }],
                            [{ 'script': 'sub'}, { 'script': 'super' }],      // superscript/subscript
                            [{ 'indent': '-1'}, { 'indent': '+1' }],          // outdent/indent
                            [{ 'direction': 'rtl' }],                         // text direction

                            [{ 'size': ['small', false, 'large', 'huge'] }],  // custom dropdown
                            [{ 'header': [1, 2, 3, 4, 5, 6, false] }],

                            [{ 'color': [] }, { 'background': [] }],          // dropdown with defaults from theme
                            [{ 'font': [] }],
                            [{ 'align': [] }],

                            ['clean']                                         // remove formatting button
                        ],
                    },
                };
            },
        };

        $('.sa-quill-control').each(function() {
            stroykaQuill.init(this);
        });

        return stroykaQuill;
    })();

    /*
    // Toasts
    */
    window.stroyka.toast = (function() {
        const $container = $('.sa-app__toasts');
        const stroykaToast = {
            init: function(element) {
                const $element = $(element);
                const toast = new bootstrap.Toast(element);

                $element.on('hidden.bs.toast', function() {
                    $element.remove();
                });

                return toast;
            },
            insert: function(element) {
                $container.prepend(element);

                return stroykaToast.init(element);
            },
        };

        $('.toast').each(function() {
            stroykaToast.init(this);
        });

        return stroykaToast;
    })();

    /*
    // Container query
    */
    window.stroyka.containerQuery = (function() {
        const containerQuery = {
            init: function(element) {},
        };

        if (!window.ResizeObserver) {
            return containerQuery;
        }

        const ro = new ResizeObserver(function(entries) {
            const tasks = [];

            entries.forEach(function(entry) {
                const breakpoints = JSON.parse(entry.target.dataset.saContainerQuery);
                const mode = entry.target.dataset.saContainerQueryMode || 'all'; // all, bigger

                if (!['all', 'bigger'].includes(mode)) {
                    throw Error('Undefined mode:  ' + mode);
                }

                const sortFn = function(a, b) { return b - a; };

                const add = [];
                const remove = [];

                Object.keys(breakpoints).map(parseFloat).sort(sortFn).forEach(function(width) {
                    let elementWidth = 0;

                    if (entry.borderBoxSize) {
                        const borderBoxSize = Array.isArray(entry.borderBoxSize) ? entry.borderBoxSize[0] : entry.borderBoxSize;

                        elementWidth = borderBoxSize.inlineSize;
                    } else {
                        elementWidth = entry.target.getBoundingClientRect().width;
                    }

                    if (elementWidth >= width
                        && (mode !== 'bigger' || add.length === 0)
                    ) {
                        add.push(breakpoints[width]);
                    } else {
                        remove.push(breakpoints[width]);
                    }
                });

                tasks.push(function() {
                    entry.target.classList.remove.apply(entry.target.classList, remove);
                    entry.target.classList.add.apply(entry.target.classList, add);
                });
            });

            setTimeout(function() {
                tasks.forEach(function(task) {
                    task();
                });
            }, 0);
        });

       containerQuery.init = function(element) {
           ro.observe(element);
       };

        $('[data-sa-container-query]').each(function() {
            containerQuery.init(this);
        });

        return containerQuery;
    })();

    /*
    // Inbox list
    */
    window.stroyka.inboxList = (function(){
        const inboxList = {
            init: function(context) {
                const $context = $(context || document);

                $context.find('.sa-inbox-list__item')
                    .on('mouseover', function(event) {
                        const isInteractiveElement = inboxList.getClosestInteractiveElement(event.target).length !== 0;

                        $(this).toggleClass('sa-inbox-list__item--hover', !isInteractiveElement);
                    })
                    .on('mouseleave', function() {
                        $(this).removeClass('sa-inbox-list__item--hover');
                    });
            },
            getClosestInteractiveElement: function (target) {
                return $(target).closest('.sa-inbox-list__star, .sa-inbox-list__checkbox');
            },
        };

        inboxList.init();

        return inboxList;
    })();

    /*
    // Inbox chat
    */
    window.stroyka.inboxChat = (function() {
        const inboxChat = {
            init: function(context) {
                const $context = $(context || document);

                $context.find('.sa-inbox-chat__item-header')
                    .on('click', function(event) {
                        const isInteractiveElement = inboxChat.getClosestInteractiveElement(event.target).length !== 0;

                        if (isInteractiveElement) {
                            return;
                        }

                        $(this).closest('.sa-inbox-chat__item').toggleClass('sa-inbox-chat__item--expanded');
                    });
            },
            getClosestInteractiveElement: function (target) {
                return $(target).closest('a, button');
            },
        };

        inboxChat.init();

        return inboxChat;
    })();

    /*
    // Inbox sidebar
    */
    window.stroyka.inboxSidebar = (function() {
        const $inbox = $('.sa-inbox');
        const openClass = 'sa-inbox--sidebar-open';

        $inbox.find('.sa-inbox-toolbar__menu').on('click', function() {
            window.stroyka.inboxSidebar.open();
        });
        $inbox.find('.sa-inbox__backdrop').on('click', function() {
            window.stroyka.inboxSidebar.close();
        });

        const media = matchMedia('(min-width: 992px)');

        function onMediaChange() {
            if (!media.matches) {
                window.stroyka.inboxSidebar.close();
            }

            $inbox.addClass('sa-inbox--switch-device');
            $inbox.width(); // force reflow
            $inbox.removeClass('sa-inbox--switch-device');
        }

        if (media.addEventListener) {
            media.addEventListener('change', onMediaChange);
        } else {
            media.addListener(onMediaChange);
        }

        return {
            toggle: function(value) {
                const curState = $inbox.hasClass(openClass) && !$inbox.hasClass(openClass);
                const newState = typeof value === 'boolean' ? value : !curState;

                $inbox.toggleClass(openClass, newState);
            },
            open: function() {
                window.stroyka.inboxSidebar.toggle(true);
            },
            close: function() {
                window.stroyka.inboxSidebar.toggle(false);
            },
        };
    })();

    /*
    // Chat
    */
    window.stroyka.chat = (function() {
        const $chat = $('.sa-chat');
        const openClass = 'sa-chat--open';

        $chat.find('.sa-chat__contact').on('click', function() {
            window.stroyka.chat.open();
        });
        $chat.find('.sa-chat__header-back').on('click', function() {
            window.stroyka.chat.close();
        });

        return {
            toggle: function(value) {
                const curState = $chat.hasClass(openClass) && !$chat.hasClass(openClass);
                const newState = typeof value === 'boolean' ? value : !curState;

                $chat.toggleClass(openClass, newState);
            },
            open: function() {
                window.stroyka.chat.toggle(true);
            },
            close: function() {
                window.stroyka.chat.toggle(false);
            },
        };
    })();

    /*
    // Layout sidebar
    */
    window.stroyka.layoutSidebar = (function(){
        const $layout = $('.sa-layout');
        const openClass = 'sa-layout--sidebar-open';
        const media = matchMedia('(min-width: 1600px)');

        function onMediaChange() {
            if (!media.matches) {
                window.stroyka.layoutSidebar.close();
            }

            $layout.addClass('sa-layout--switch-device');
            $layout.width(); // force reflow
            $layout.removeClass('sa-layout--switch-device');
        }

        if (media.addEventListener) {
            media.addEventListener('change', onMediaChange);
        } else {
            media.addListener(onMediaChange);
        }

        $('[data-sa-layout-sidebar-open]').on('click', function() {
            window.stroyka.layoutSidebar.open();
        });
        $('[data-sa-layout-sidebar-close]').on('click', function() {
            window.stroyka.layoutSidebar.close();
        });

        return {
            toggle: function(value) {
                const curState = $layout.hasClass(openClass) && !$layout.hasClass(openClass);
                const newState = typeof value === 'boolean' ? value : !curState;

                $layout.toggleClass(openClass, newState);
            },
            open: function() {
                window.stroyka.layoutSidebar.toggle(true);
            },
            close: function() {
                window.stroyka.layoutSidebar.toggle(false);
            },
        };
    })();

    /*
    // Responsive slug input group
    */
    (function() {
        const minInputWidth = 240;
        const ro = new ResizeObserver(function(entries) {
            const tasks = [];

            entries.forEach(function(entry) {
                const breakpoint = $(entry.target).data('breakpoint');
                let size;

                if (entry.borderBoxSize) {
                    const borderBoxSize = Array.isArray(entry.borderBoxSize) ? entry.borderBoxSize[0] : entry.borderBoxSize;

                    size = borderBoxSize.inlineSize;
                } else {
                    size = entry.target.getBoundingClientRect().width;
                }

                tasks.push(function () {
                    if (size < breakpoint) {
                        $(entry.target).removeClass('input-group');
                        $(entry.target).find('.input-group-text').addClass('d-none');
                    }

                    if (size >= breakpoint + 10) {
                        $(entry.target).addClass('input-group');
                        $(entry.target).find('.input-group-text').removeClass('d-none');
                    }
                });
            });

            setTimeout(function() {
                tasks.forEach(function (task) {
                    task();
                });
            }, 0);
        });

        $('.input-group--sa-slug').each(function() {
            const groupWidth = $(this)[0].getBoundingClientRect().width;
            const inputWidth = $(this).find('.form-control')[0].getBoundingClientRect().width;

            const breakpoint = groupWidth - inputWidth + minInputWidth;

            $(this).data('breakpoint', breakpoint);

            ro.observe(this);
        });
    }());

    /*
    // Colors
    */
    window.stroyka.colors = (function() {
        return {
            getThemeColor: function() {
                return getComputedStyle(document.documentElement).getPropertyValue('--sa-scheme-theme--main-color');
            },
        };
    })();

    /*
    // Nouislider
    */
    window.stroyka.nouislider = (function () {
        const calcPipsSize = function(slider) {
            const size = [].slice.call(slider.target.querySelectorAll('.noUi-value')).map(function(element) {
                return element.getBoundingClientRect();
            }).reduce(function(acc, cur) {
                return {
                    width: Math.max(acc.width, cur.width),
                    height: Math.max(acc.height, cur.height),
                };
            }, {width: 0, height: 0});

            slider.target.style.setProperty('--sa-nouislider-pips--max-width', size.width + 'px');
            slider.target.style.setProperty('--sa-nouislider-pips--max-height', size.height + 'px');
        };
        const create = function(element, options) {
            options = options || {};
            options = Object.assign({}, options, {
                direction: options.direction || window.getComputedStyle(element).direction,
            });

            const slider = noUiSlider.create(element, options);

            stroyka.nouislider.calcPipsSize(slider);

            return slider;
        };

        return {
            calcPipsSize: calcPipsSize,
            create: create,
        };
    })();
})(jQuery, window);

........