Greasy Fork is available in English.

Onlinetrade Product Search

Onlinetrade - Product search on other sites

// ==UserScript==
// @name         Onlinetrade Product Search
// @name:ru      Onlinetrade Поиск товаров
// @namespace    https://github.com/AlekPet/Onlinetrade-Product-Search
// @version      0.3.3
// @description  Onlinetrade - Product search on other sites
// @description:ru Onlinetrade - Поиск товара на других сайтах
// @copyright    2021, AlekPet
// @author       AlekPet
// @license      MIT; https://raw.githubusercontent.com/AlekPet/Onlinetrade-Product-Search/master/LICENSE
// @icon       
// @match        *://www.onlinetrade.ru/*
// @connect www.onlinetrade.ru
// @run-at document-end
// @grant GM_getValue
// @grant GM_setValue
// @grant GM_addStyle
// @require https://ajax.googleapis.com/ajax/libs/jquery/1.11.1/jquery.min.js
// ==/UserScript==

(function() {
    'use strict';

    GM_addStyle(`
.services_search_item_name {
    border: 1px solid silver;
    padding: 5px;
    background: #ffffffd1;
    box-shadow: 2px 2px 8px #77d2d299;
    transform: translate(-50%,0);
    transition: all .5s;
    font-size: 0.7em;
    width: 200px;
    color:#2b52e2;
    font-weight: bold;
}
.menu_cat{
    overflow-y: auto;
    max-height: 350px;
}
.menu_cat > li {
    list-style: none;
    margin-bottom: 2px;
    background: linear-gradient(45deg, #77d2d299, transparent);
    border-radius: 0 8px 8px 0;
    padding: 5px;
    word-break: break-all;
}
.menu_cat > li:hover {
    transition: all .5s;
    background: linear-gradient(45deg, #9bffff99, transparent);
    font-size: 1.1em;
}
.menu_cat > li:first-child a{
    color:#f76f6f;
}
.menu_cat_list{
   margin-left: 0;
   display: inline-block;
   margin-top: 0.8%;
}
ul.services_list li {
    display: inline-block;
    padding: 2px;
    margin-bottom: 4px;
    font-size: 8px;
    cursor: pointer;
    user-select:none;
}
li.service_active{
    background: #c2fb8fbf;
    border-left: 5px solid #09ff00;
}
.search_goods_button {
    margin-right: 8px;
}
.search_goods_button:before {
    background-position: -96px 0px;
}
.box_items {
    top: 20px;
    position: absolute;
    z-index: 14;
}
.menu_cat::-webkit-scrollbar {
    width: 10px;
}
.menu_cat::-webkit-scrollbar-button {
}
.menu_cat::-webkit-scrollbar-thumb {
    background: #ff8100;
    border-radius: 10px;
    box-shadow: 0 0 6px rgba(0,0,0,0.3);
}

.menu_cat::-webkit-scrollbar-track-piece {
    background: #d7d7d7;
    border-radius: 10px;
    box-shadow: inset 0 0 6px rgba(0,0,0,0.3);
}
`)

    const $ = window.jQuery,
          debug = true

    var services = {
        'E-Katalog':{
            s:'https://www.e-katalog.ru/ek-list.php?search_='
        },
        'YAMarket':{
            s:'https://market.yandex.ru/search?text='
        },
        'OZON':{
            s:'https://www.ozon.ru/search/?from_global=true&text='
        },
        'Citilink':{
            s:'https://www.citilink.ru/search/?text='
        },
        'Onlinetrade':{
            s:'https://www.onlinetrade.ru/sitesearch.html?query='
        },
        'Dns-shop':{
            s:'https://www.dns-shop.ru/search/?q='
        }
    }

    // Functions
    function log(text, ...other){
        if(debug){
            let tip = other[0] in Object.keys(console)? other[0]: 'log'
            console[tip](text, ...other)
        }
    }
    // end - Functions

    function getListGoods(){
        let self = this,
            list = $(".indexGoods__item"),//.not(".swiper-slide")
            past = $(".catalog__displayedItem__marksLine > .floatLeft")

        this.currentService = Object.keys(services)[0]

        if (past.length && /\.html.*$/i.test(location.href)){
            log("Модуль поиска, активирован для отдного товара...")
            let name = $(".productPage__card > .name").text() || $(".productPage__card").children().eq(0).text(),
                button = $("<a class='ic__hasSet search_goods_button'><span class='box_items'></span></a>").css({'margin-left': '8px', height: '24px', 'margin-right': 0}), //$("<div>Goods Find</div>").css({"font": "bold 1em monospace","margin-left": "50px",'color': '#0053b9','float': 'right','cursor':'pointer'})
                pastEl = button.find('.box_items')

            button.mouseenter(function(e){
                self.make_menu(pastEl, name)
            })

            button.mouseleave(function(e){
                self.del_menu(pastEl)
            })
            past.append(button)

        }

        if(list.length){
            log("Модуль поиска, активирован для товаров...")
            list.each(function(indx, el){
                if ($(el).find(".search_goods_button").length>0) return

                const name = $(el).find(".indexGoods__item__name").text(),
                      button = $("<a class='ic__hasSet search_goods_button'><span class='box_items'></span></a>"),
                      pastEl = button.find('.box_items'),
                      managerTop = $(el).find(".indexGoods__item__manageTop")

                button.mouseenter(function(e){
                    self.make_menu(pastEl, name)
                })

                button.mouseleave(function(e){
                    self.del_menu(pastEl)
                })

                if(managerTop.length){
                    managerTop.children().first().before(button)

                } else {
                    button.css({left: '50%', top: '-5%', display: 'block', 'z-index': '15','text-align':'left'})
                    $(el).append(button)
                }

            })


            // Reviews
            let sort = $('<div>').css('float', 'right').html(`<select id='sorted_reviews'>
            <option value="none">Без сортировки</option>
            <option value="dup">Дата по возр.</option>
            <option value="dud">Дата по убыв.</option>
            <option value="sup">Рейтинг по возр.</option>
            <option value="sd">Рейтинг по убыв.</option>
            </select>`), select = null

            $('#tabs_feedbacks h3:eq(0)').append(sort)
            select = $('#sorted_reviews')

            sort.change(()=>{
                const select_val = select.val()
                if(select_val == 'none') return

                let ritems = $('.reviewlist__item[itemprop]'),
                    arr_feed = [],
                    parent = ritems.parent().eq(0)

                ritems.each((idx,item)=>{
                    const $item = $(item)

                    if($item.hasClass('noDisplay')) $item.removeClass('noDisplay')

                    let feedback = $item.find('.feedbacksHeader_info')

                    if(feedback.length){
                        let stars, opit, date
                        if(feedback.length === 3) [stars, opit, date] = [...feedback.get()]
                        if(feedback.length === 2) [stars, date] = [...feedback.get()]

                        stars = stars.children[0].title.includes('Оценка') ? +stars.children[0].title.match(/(\d+)/g) : 0

                        let [_date, _time] = [...date.children[1].textContent.split(' ')]
                        _date = _date.slice(0,10).split('.').reverse().join('-')

                        _date = new Date(_date+' '+_time+':00')

                        arr_feed.push({el:$item, stars: stars, date: _date})

                    }
                })

                if(select_val == 'dup' || select_val == 'dud'){
                    arr_feed.sort(function(a,b) {
                        var an = a.date,
                            bn = b.date
                        return an - bn;
                    });

                    if(select_val == 'dud') arr_feed.reverse()

                }


                if(select_val == 'sup' || select_val == 'sd'){
                    arr_feed.sort(function(a,b) {
                        var an = a.stars,
                            bn = b.stars
                        return an - bn;
                    });

                    if(select_val == 'sd') arr_feed.reverse()

                }

                for(let i of arr_feed){
                    let el = i.el
                    el.detach().appendTo(parent)
                }
            })

        }
    }

    getListGoods.prototype.del_menu = function(el_past){
        $(el_past).find(".services_search_item_name").remove()
        //let c = $(el_past).find('.menu_cat').get(0)
        //if(c) el_past.removeChild(c)
    }

    getListGoods.prototype.selectService = function(el, menu, params){
        this.prevService.removeClass('service_active')
        this.prevService = el

        el.addClass('service_active')

        this.menu_update(menu, this.split_links(params.name))
    }

    getListGoods.prototype.menu_update = function(menu, params){
        menu.empty()

        $(params.items).each(function(indx,el){
            let li = $("<li></li>"),
                a = $("<a></a>").attr({"href":el.href,"target":"_blank", "title":el.title}).text(el.name)

            li.append(a)
            menu.append(li)
        })
    }

    getListGoods.prototype.make_menu = function(el_past, name){
        const self = this

        this.prevService = null

        let services_search_item_name = $("<div class='services_search_item_name'></div>"),
            div_items = $("<div class='services_search'></div>"),
            ul = $("<ul class='services_list'></ul>"),
            menu = $("<ul class='menu_cat'></ul>"),
            params = self.split_links(name)

        if (el_past.parentNode && el_past.parentNode.className.indexOf('floatLeft')!=-1) services_search_item_name.addClass("menu_cat_list")

        for(let s in services){
            const service = services[s]

            let li=$(`<li></li>`).attr('title', s).text(s).click(function(){
                self.currentService = s
                self.selectService(li, menu, params)
            })

            if(s == this.currentService && !li.hasClass('service_active')){
                this.prevService = li
                li.addClass('service_active')
            }

            ul.append(li)
        }
        div_items.append(ul)

        self.menu_update(menu, params)

        services_search_item_name.append(div_items,menu)

        $(el_past).append(services_search_item_name)
    }

    getListGoods.prototype.srez = function(text, s=0, e=30){
        return text.length>e?text.slice(s,e)+"...":text
    }

    getListGoods.prototype.split_links = function(name){

        let alllinksOrig = name.split(" "),
            alllinks = [...alllinksOrig],
            params = {name:name, items:[]}

        while(alllinks.length){
            let curPop = alllinks.join(' ')
            if(/(^\d{1}$)|\.{3}/i.test(curPop)) continue
            curPop = curPop.trim().replace(/,$/ig,'')
            params.items.push({'href':services[this.currentService].s+encodeURI(curPop),'name':this.srez(curPop,0, 200), 'title':curPop})
            curPop = alllinks.pop()
        }

        let advVariants = alllinksOrig.map((item)=>({'href':services[this.currentService].s+encodeURI(item),'name':this.srez(item,0, 200), 'title':item})).filter((cv)=>{
            for(let x of params.items) if(x.name == cv.name) return false
            return true
        })
        params.items = [...params.items,...advVariants]

        return params
    }

    new getListGoods()
})();