// ==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()
})();