NOTICE: By continued use of this site you understand and agree to the binding Terms of Service and Privacy Policy.
// ==UserScript== // @name Comexpo - kuzzle udpate // @version 0.1 // @description Add human date + color indexes // @author Yann Roseau // @copyright 2019, Yann Roseau (https://github.com/yroseau) // @license MIT // @match http://console.kuzzle.io/ // @grant none // ==/UserScript== (function () { // C'est ultra sale.. fait à la va-vite pour mon usage perso function updateDataView() { if ($('[data-customcss]').length !== 0) { return; } $('.index-branch .tree-item:contains("catalog")') .attr('data-customcss', 'catalog') .closest('li').attr('data-order', '1000'); $('.index-branch .tree-item:contains("backoffice"), \ .index-branch .tree-item:contains("global")') .attr('data-customcss', 'global') .closest('li').attr('data-order', '0'); $('.index-branch .tree-item:contains("logs"), \ .index-branch .tree-item:contains("import")') .attr('data-customcss', 'unused') .attr('title', 'This index is unused') .closest('li').attr('data-order', '9999'); $('.index-branch .tree-item:contains("mails"), \ .index-branch .tree-item:contains("selections")') .attr('data-customcss', 'other') .closest('li').attr('data-order', '5'); var order = 20; $('.index-branch .tree-item:not([data-customcss])') .each(function () { var salon = $(this).text().trim(); salon = salon.substring(0, salon.indexOf(' ')); var numSession = $('.index-branch .tree-item:contains("' + salon + '_")').length; if (numSession !== 0) { $(this).attr('data-customcss', 'salon') .closest('li').attr('data-order', ++order); } else { $(this).attr('data-customcss', 'session') .closest('li').attr('data-order', ++order); } }); // sort $(function () { $("Treeview-root>li").sort(sort_li).appendTo('.Treeview-root'); function sort_li(a, b) { return ($(b).data('order')) < ($(a).data('order')) ? 1 : -1; } }); // Add splitter handle var $sideNav = $('.side-nav'); $('<div class="splitter-handle"></div>').insertAfter($sideNav.closest('aside')); var $splitterHandle = $('.splitter-handle'); $splitterHandle.css('left', $sideNav.width()); var $section = $splitterHandle.next(); $section.attr('data-init-left', $sideNav.width()); $splitterHandle.mousedown(function (e) { $('body').attr('style', 'cursor: col-resize !important;' + $('body').attr('style')); $(document).mousemove(function (e) { var width = Math.max(150, e.pageX); width = Math.min(width, $(document).width() / 2); $sideNav.css('width', width); $splitterHandle.css('left', $sideNav.width()); $section.css('margin-left', $sideNav.width() - $section.attr('data-init-left')); e.preventDefault(); }) .mouseup(function (e) { $(document).unbind('mousemove'); $('body').css('cursor', ''); e.preventDefault(); }); e.preventDefault(); }); } function addHumanDate() { var dateKeys = ['updateUserValidityToken:', 'creationDate:', 'lastUpdate:', 'createdAt:', 'updatedAt:', 'activationDate:', 'date:'] var all = document.querySelectorAll('.json-formatter-key:not(.human-date-treated)') for (let e of all) { e.classList.add("human-date-treated") if (dateKeys.includes(e.innerText)) { let val = parseInt(e.nextSibling.innerText) if (val < 10000000000) { val = val * 1000 } let d = new Date(val); e.nextSibling.innerHTML = e.nextSibling.innerHTML + ' <span class="human-date">' + d.toString() + '</span>' } } } $(document).ready(function () { $('body').append('<style>\ .human-date { \ opacity: 0.6; \ font-size: 0.9em; \ margin-left: 0.5em; \ font-weight: initial; \ } \ </style>'); $('body').append('<style>\ z[data-customcss="catalog"], [data-customcss="catalog"] .fa { \ color: #8e9633 !important; \ } \ z[data-customcss="salon"], [data-customcss="salon"] .fa { \ color: #92568b !important; \ } \ z[data-customcss="session"], [data-customcss="session"] .fa { \ color: #226c92 !important; \ } \ z[data-customcss="unused"], [data-customcss="unused"] .fa { \ color: #cc5c5c !important; \ } \ z[data-customcss="global"], [data-customcss="global"] .fa { \ color: #bf9c3f !important; \ /*font-weight: bold !important;*/ \ } \ .splitter-handle { \ top: 0; \ bottom: 0; \ width: 10px; \ background-image: url(); \ background-position: right center; \ background-repeat: no-repeat; \ position: fixed; \ cursor: col-resize; \ } \ </style>'); var currentHash = window.location.hash; setTimeout(addHumanDate, 500) //if (window.location.hash == "#/data") { setTimeout(updateDataView, 500); //} setInterval(function () { setTimeout(addHumanDate, 500); if (currentHash == window.location.hash) { return; } currentHash = window.location.hash; //if (window.location.hash == "#/data") { setTimeout(updateDataView, 500); //} }, 1000); }); })();