diff --git a/assets/icons/128.png b/assets/icons/128.png index 7fb9c23..3952f77 100644 Binary files a/assets/icons/128.png and b/assets/icons/128.png differ diff --git a/assets/icons/16.png b/assets/icons/16.png index 5b3becb..2360bce 100644 Binary files a/assets/icons/16.png and b/assets/icons/16.png differ diff --git a/assets/icons/32.png b/assets/icons/32.png index be0d414..5f3e215 100644 Binary files a/assets/icons/32.png and b/assets/icons/32.png differ diff --git a/assets/icons/48.png b/assets/icons/48.png index 5ebe87c..101fe62 100644 Binary files a/assets/icons/48.png and b/assets/icons/48.png differ diff --git a/assets/rating.svg b/assets/rating.svg deleted file mode 100644 index 3bc1986..0000000 --- a/assets/rating.svg +++ /dev/null @@ -1 +0,0 @@ - ratingrating★★★★★★★★★★ \ No newline at end of file diff --git a/assets/size.svg b/assets/size.svg deleted file mode 100644 index 9d5c83b..0000000 --- a/assets/size.svg +++ /dev/null @@ -1 +0,0 @@ - code sizecode size884 kB884 kB \ No newline at end of file diff --git a/manifest.json b/manifest.json index 54f1c87..31e8b25 100644 --- a/manifest.json +++ b/manifest.json @@ -1,7 +1,7 @@ { "manifest_version": 2, "name": "Dark Mode", - "version": "1.45", + "version": "1.50", "description": "Dark Mode, read at night. Blue Light Filter for Every Website. Relax your eyes at night and day.", "default_locale": "en", diff --git a/popup.css b/popup.css index b26bd08..eab5a9b 100644 --- a/popup.css +++ b/popup.css @@ -453,20 +453,6 @@ body[data-website-text-editor="true"] .websites-textfield } -/*--------------------------------------------------------------- -4.0 FOLDER ----------------------------------------------------------------*/ - -.satus-main .satus-folder svg -{ - width: 20px; - height: 20px; - margin: 0 14px 0 0; - - stroke: none; -} - - /*--------------------------------------------------------------- 5.0 SWITCH ---------------------------------------------------------------*/ @@ -543,27 +529,6 @@ body[data-website-text-editor="true"] .websites-textfield } -/*--------------------------------------------------------------- -8.0 LANGUAGE ----------------------------------------------------------------*/ - -.satus-select[data-storage-key=language] -{ - padding-left: 50px; -} - -.satus-select[data-storage-key=language] svg -{ - position: absolute; - left: 16px; - - width: 20px; - height: 20px; - - stroke: none; -} - - /*--------------------------------------------------------------- 9.0 ABOUT ---------------------------------------------------------------*/ diff --git a/popup.js b/popup.js index bc53271..5ac760b 100644 --- a/popup.js +++ b/popup.js @@ -103,8 +103,8 @@ var Menu = { button_vert: { type: 'button', class: 'satus-dialog--vertical-menu-button', - icon: '', - onClickRender: { + before: '', + onclick: { type: 'dialog', class: 'satus-dialog--vertical-menu', diff --git a/satus.css b/satus.css index bf6648b..9b2d200 100644 --- a/satus.css +++ b/satus.css @@ -1,7 +1,7 @@ -/*----------------------------------------------------------------------------- +/*--------------------------------------------------------------- >>> ANIMATIONS ------------------------------------------------------------------------------*/ +---------------------------------------------------------------*/ .satus-animation--fade-in { @@ -33,6 +33,16 @@ animation: fadeOutRight 250ms; } +.satus-animation--zoom-in +{ + animation: zoomIn 250ms; +} + +.satus-animation--zoom-out +{ + animation: zoomOut 250ms; +} + @keyframes fadeIn { from @@ -41,8 +51,6 @@ } to { - transform: translateX(0%); - opacity: 1; } } @@ -55,8 +63,6 @@ } to { - transform: translateX(0%); - opacity: 0; } } @@ -124,18 +130,52 @@ opacity: 0; } } + +@keyframes zoomIn +{ + from + { + transform: scale(.8); + + opacity: 0; + } + to + { + transform: scale(1); + + opacity: 1; + } +} + +@keyframes zoomOut +{ + from + { + transform: scale(1); + + opacity: 1; + } + to + { + transform: scale(.8); + + opacity: 0; + } +} -/*----------------------------------------------------------------------------- +/*--------------------------------------------------------------- >>> THEMES -------------------------------------------------------------------------------- +----------------------------------------------------------------- 1.0 Default ------------------------------------------------------------------------------*/ +---------------------------------------------------------------*/ html { --satus-theme-primary: #f6b465; --satus-theme-dialog: #f7f7f6; + --satus-theme-dialog-backdrop: rgba(25,25,25,.2); + --satus-theme-dialog-shadow: inset 0 -1px 1px 1px rgba(0,0,0,.1), 0 2px 6px rgba(0, 0, 0, .15); --satus-theme-dialog-text: #777; --satus-theme-header: #fff; @@ -394,11 +434,7 @@ html width: 36px; height: 36px; padding: 6px; -} - -.satus-header .satus-button::before -{ - border-radius: 50%; + border-radius: 50%; } @@ -463,23 +499,26 @@ body[data-appearance='home'] .satus-text--title text-align: left; } -.satus-dialog--vertical-menu .satus-folder svg, .satus-dialog--vertical-menu .satus-button svg { width: 20px; - height: 18px; - margin: 0 14px 0 0; + height: 20px; opacity: .75; } -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> SELECT ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ -.satus-select +.satus-select > svg { - justify-content: space-between; + width: 20px +} + +.satus-select > svg + .satus-select__label +{ + margin: 0 0 0 8px; } .satus-select__value @@ -489,6 +528,8 @@ body[data-appearance='home'] .satus-text--title text-align: right; opacity: .7; + + flex: 1; } @@ -766,18 +807,18 @@ body[data-appearance='home'] .satus-text--title z-index: 1 } -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> FOLDER ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ -.satus-folder +.satus-button.satus-folder { - text-align: left + text-transform: unset } -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> TEXT ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ .satus-text-field { @@ -795,15 +836,16 @@ body[data-appearance='home'] .satus-text--title background: unset; } -/*----------------------------------------------------------------------------- +/*--------------------------------------------------------------- >>> MAIN -------------------------------------------------------------------------------- +----------------------------------------------------------------- 1.0 General ------------------------------------------------------------------------------*/ +2.0 Other +---------------------------------------------------------------*/ -/*----------------------------------------------------------------------------- -1.0 General ------------------------------------------------------------------------------*/ +/*--------------------------------------------------------------- +1.0 GENERAL +---------------------------------------------------------------*/ .satus-main { @@ -817,7 +859,7 @@ body[data-appearance='home'] .satus-text--title color: var(--satus-theme-main-text); background-color: var(--satus-theme-main); - fill: var(--satus-theme-main-text); + flex: 1; } .satus-main__container @@ -835,8 +877,24 @@ body[data-appearance='home'] .satus-text--title transition: 250ms; background-color: var(--satus-theme-main); +} - will-change: transform; + +/*--------------------------------------------------------------- +2.0 OTHER +---------------------------------------------------------------*/ + +.satus-main .satus-button +{ + width: 100%; + height: 48px; + padding: 0 16px; + + text-align: left; + + border-radius: 0; + + justify-content: flex-start; } /*-------------------------------------------------------------- @@ -1053,6 +1111,8 @@ body[data-appearance='home'] .satus-text--title .satus-scrollbar__content { + display: inline-block; + min-height: 100%; } @@ -1109,9 +1169,16 @@ body[data-appearance='home'] .satus-text--title list-style: none; } -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> DIALOG ---------------------------------------------------------------*/ +----------------------------------------------------------------- +1.0 General +2.0 Other +---------------------------------------------------------------*/ + +/*--------------------------------------------------------------- +1.0 GENERAL +---------------------------------------------------------------*/ .satus-dialog { @@ -1122,7 +1189,7 @@ body[data-appearance='home'] .satus-text--title display: flex; - width: 100%; + width: 100vw; height: 100vh; justify-content: center; @@ -1141,9 +1208,8 @@ body[data-appearance='home'] .satus-text--title animation: fadeIn 150ms linear forwards; opacity: 0; - background: rgba(25,25,25,.2); + background: var(--satus-theme-dialog-backdrop); - fill: var(--satus-theme-dialog-text); backdrop-filter: blur(8px); } @@ -1168,7 +1234,7 @@ body[data-appearance='home'] .satus-text--title color: var(--satus-theme-dialog-text); border-radius: 6px; background-color: var(--satus-theme-dialog); - box-shadow: inset 0 -1px 1px 1px rgba(0,0,0,.1), 0 2px 6px rgba(0, 0, 0, .15); + box-shadow: var(--satus-theme-dialog-shadow); } .satus-dialog--closing .satus-dialog__scrim @@ -1181,126 +1247,58 @@ body[data-appearance='home'] .satus-text--title animation: zoomOut 70ms linear forwards; } -@keyframes fadeIn -{ - from - { - opacity: 0; - } - to - { - opacity: 1; - } -} -@keyframes fadeOut -{ - from - { - opacity: 1; - } - to - { - opacity: 0; - } -} - -@keyframes zoomIn -{ - from - { - transform: scale(.8); - - opacity: 0; - } - to - { - transform: scale(1); - - opacity: 1; - } -} +/*--------------------------------------------------------------- +2.0 OTHER +---------------------------------------------------------------*/ -@keyframes zoomOut +.satus-dialog .satus-button { - from - { - transform: scale(1); - - opacity: 1; - } - to - { - transform: scale(.8); - - opacity: 0; - } + justify-content: flex-start } -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> BUTTON ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ .satus-button { - font-size: inherit; - font-family: inherit; - - position: relative; + font: inherit; - display: flex; + display: inline-flex; + height: 36px; margin: 0; + padding: 0 8px; cursor: pointer; color: inherit; border: none; + border-radius: 4px; outline: none; - background-color: var(--satus-theme-button); + background-color: transparent; - -webkit-tap-highlight-color: transparent; align-items: center; + justify-content: center; + -webkit-tap-highlight-color: transparent; -webkit-appearance: none; } -.satus-button::before +.satus-button:hover { - position: absolute; - top: 0; - left: 0; - - width: 100%; - height: 100%; - - content: ''; - - opacity: 0; background-color: var(--satus-theme-ripple); } -.satus-button:focus::before, -.satus-button:hover::before +.satus-button > svg { - opacity: 1; + width: 22px; + height: 22px } -.satus-button__icon +.satus-button > svg + .satus-button__label { - width: 24px; - height: 24px; -} - -.satus-button svg -{ - width: 100%; - - color: inherit; -} - -.satus-button__icon + .satus-button__label -{ - margin-left: 8px; + margin: 0 0 0 8px } /*-------------------------------------------------------------- @@ -1344,82 +1342,53 @@ body[data-appearance='home'] .satus-text--title margin: 16px auto 8px; } -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> COLOR PICKER ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ .satus-color-picker { - font-size: inherit; - - position: relative; - display: flex; + flex-direction: column; - box-sizing: border-box; - margin: 0; - - cursor: pointer; - - color: inherit; - border: none; - outline: none; - background-color: var(--satus-theme-button); - - justify-content: space-between; - -webkit-tap-highlight-color: transparent; + justify-content: center; align-items: center; - -webkit-appearance: none; } -.satus-color-picker__value +.satus-color-picker__container { - width: 24px; - height: 24px; - - border-radius: 50%; + position: relative; } -.satus-dialog--color-picker .satus-scrollbar__content +.satus-color-picker canvas { - display: flex; - flex-direction: column; - - align-items: center; + border-radius: 50%; } -.satus-dialog--color-picker .satus-button +.satus-color-picker__cursor { - box-sizing: unset; - width: 24px; - height: 24px; - margin: 0 0 8px; - padding: 8px; + position: absolute; + top: 128px; + left: 128px; - border-radius: 50%; -} + width: 12px; + height: 12px; -.satus-dialog--color-picker .satus-button:hover -{ - background-color: var(--satus-theme-ripple); -} + transform: translate(-50%, -50%); + pointer-events: none; -.satus-dialog--color-picker .satus-button::before -{ - content: unset; + border: 2px solid rgba(0,0,0,.4); + border-radius: 50%; } -.satus-dialog--color-picker .satus-button svg +.satus-color-picker__value { - fill: transparent; - stroke: var(--satus-theme-primary); -} + width: 28px; + height: 28px; + margin: 0 8px 0 0; -.satus-dialog--color-picker canvas -{ - width: 200px; - height: 200px; - margin: 0 0 16px; + border: 2px solid #dcdcdc; + border-radius: 4px; } /*--------------------------------------------------------------- diff --git a/satus.js b/satus.js index 8237012..06226a6 100644 --- a/satus.js +++ b/satus.js @@ -77,7 +77,7 @@ Satus.getAnimationDuration = function(element) { # LOCALE --------------------------------------------------------------*/ -Satus.locale = { +satus.locale = { messages: {} }; @@ -86,7 +86,7 @@ Satus.locale = { # GET MESSAGE --------------------------------------------------------------*/ -Satus.locale.getMessage = function(string) { +satus.locale.getMessage = function(string) { return this.messages[string] || string; }; @@ -94,18 +94,26 @@ Satus.locale.getMessage = function(string) { # IMPORT LOCALE --------------------------------------------------------------*/ -Satus.locale.import = function(src, callback) { +satus.locale.import = function(language, callback) { var xhr = new XMLHttpRequest(); + + if (typeof language === 'function') { + var callback = language; + } + + if (typeof language !== 'string') { + var language = chrome.i18n.getUILanguage(); + } xhr.onload = function() { try { var object = JSON.parse(this.responseText); for (var key in object) { - Satus.locale.messages[key] = object[key].message; + satus.locale.messages[key] = object[key].message; } - callback(); + callback(language); } catch (err) { function listener(request) { if (request !== null && typeof request === 'object') { @@ -115,10 +123,10 @@ Satus.locale.import = function(src, callback) { chrome.runtime.onMessage.removeListener(listener); for (var key in object) { - Satus.locale.messages[key] = object[key].message; + satus.locale.messages[key] = object[key].message; } - callback(); + callback(language); } } } @@ -127,14 +135,23 @@ Satus.locale.import = function(src, callback) { chrome.runtime.sendMessage({ name: 'translation_request', - path: src + path: '_locales/' + language + '/messages.json' }); } }; + + xhr.onerror = function() { + if (language === 'en') { + callback(); + } else { + satus.locale.import('en', callback); + } + }; - xhr.open('GET', src, true); + xhr.open('GET', '_locales/' + language + '/messages.json', true); xhr.send(); -}; +}; + /*-------------------------------------------------------------- # CLONE NODE STYLES --------------------------------------------------------------*/ @@ -146,25 +163,6 @@ Satus.cloneNodeStyles = function(origin, target) { Satus.cloneNodeStyles(origin.children[i], target.children[i]); } }; -Satus.on('render', function(component, data) { - if (data.perspective === true) { - component.style.willChange = 'transform'; - component.style.transformStyle = 'preserve-3d'; - component.style.transition = '.4s'; - - component.addEventListener('mousemove', function(event) { - var bounding = component.getBoundingClientRect(), - dx = event.clientX - bounding.left - bounding.width / 2, - dy = event.clientY - bounding.top - bounding.height / 2; - - this.style.transform = 'perspective(440px) rotateX(' + dy * -1 + 'deg) rotateY(' + dx + 'deg) translateZ(0)'; - }); - - component.addEventListener('mouseout', function(event) { - this.style.transform = 'perspective(440px) rotateX(0deg) rotateY(0deg) translateZ(0)'; - }); - } -}); /*----------------------------------------------------------------------------- >>> «USER» MODULE ------------------------------------------------------------------------------- @@ -525,6 +523,23 @@ Satus.modules.user = function() { return data; }; +/*--------------------------------------------------------------- +>>> MATH +----------------------------------------------------------------- +1.0 Converts degrees to radians +---------------------------------------------------------------*/ + +satus.math = {}; + + +/*--------------------------------------------------------------- +1.0 CONVERTS DEGREES TO RADIANS +---------------------------------------------------------------*/ + +satus.math.degToRad = function(degrees) { + return degrees * (Math.PI / 180); +}; + /*--------------------------------------------------------------- >>> CHROMIUM STORAGE ----------------------------------------------------------------- @@ -684,7 +699,7 @@ Satus.render = function(element, container, callback) { if (object && object.type) { var type = Satus.camelize(object.type), component = Satus.components[type](object), - excluded_properties = ['type', 'label', 'class', 'title', 'storage']; + excluded_properties = ['type', 'label', 'class', 'title', 'storage', 'onclick']; function applyProperties(object, target) { for (var key in object) { @@ -736,10 +751,12 @@ Satus.render = function(element, container, callback) { (container || document.body).appendChild(component); - if (typeof component.onClickRender === 'object') { + if (typeof object.onclick === 'object') { component.addEventListener('click', function() { - Satus.render(component.onClickRender); + Satus.render(this.skelet.onclick); }); + } else if (typeof object.onclick === 'function') { + component.onclick = object.onclick; } if (Satus.isset(Satus.events.render)) { @@ -1331,51 +1348,55 @@ Satus.components.tabs = function(object) { return component; }; -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> FOLDER ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ -Satus.components.folder = function(object) { +Satus.components.folder = function(element) { var component = document.createElement('button'); - component.object = object; - component.classList.add('satus-button'); + + if (satus.isset(element.label)) { + var label = document.createElement('span'); + + label.className = 'satus-button__label'; + label.innerText = satus.locale.getMessage(element.label); + + component.appendChild(label); + } component.addEventListener('click', function() { - var parent = document.querySelector(component.object.parent) || document.querySelector('.satus-main'); + var parent = document.querySelector(component.skelet.parent) || document.querySelector('.satus-main'); - if (!component.object.parent || !parent.classList.contains('satus-main')) { + if (!component.skelet.parent || !parent.classList.contains('satus-main')) { while (!parent.classList.contains('satus-main')) { parent = parent.parentNode; } } - parent.open(this.object, object.onopen); + parent.open(this.skelet, this.skelet.onopen); }); - if (Satus.isset(object.label)) { - var component_label = document.createElement('span'); - - component_label.className = 'satus-folder__label'; - component_label.innerText = Satus.locale.getMessage(object.label); - - component.appendChild(component_label); - } - return component; -}; -/*-------------------------------------------------------------- +}; + +/*--------------------------------------------------------------- >>> TEXT FIELD ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ Satus.components.textField = function(element) { - var component = element.rows > 1 ? document.createElement('textarea') : document.createElement('input'); - - component.type = 'text'; + if (element.rows > 1) { + var component = document.createElement('textarea'); + } else { + var component = document.createElement('input'); + + component.type = 'text'; + } return component; -}; +}; + /*-------------------------------------------------------------- >>> MAIN --------------------------------------------------------------*/ @@ -1815,9 +1836,9 @@ Satus.components.list = function(object) { return ul; }; -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> DIALOG ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ Satus.components.dialog = function(element) { var component = document.createElement('div'), @@ -1850,10 +1871,9 @@ Satus.components.dialog = function(element) { function keydown(event) { if (event.keyCode === 27) { event.preventDefault(); + close(); - } - - if (event.keyCode === 9) { + } else if (event.keyCode === 9) { var elements = component_surface.querySelectorAll('button, input'), focused = false; @@ -1902,34 +1922,27 @@ Satus.components.dialog = function(element) { // END OPTIONS return component; -}; -/*-------------------------------------------------------------- +}; + +/*--------------------------------------------------------------- >>> BUTTON ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ -Satus.components.button = function(element) { +satus.components.button = function(element) { var component = document.createElement('button'); - if (Satus.isset(element.icon)) { - var component_icon = document.createElement('span'); - - component_icon.className = 'satus-button__icon'; - component_icon.innerHTML = element.icon; - - component.appendChild(component_icon); - } + if (satus.isset(element.label)) { + var label = document.createElement('span'); - if (Satus.isset(element.label)) { - var component_label = document.createElement('span'); + label.className = 'satus-button__label'; + label.innerText = satus.locale.getMessage(element.label); - component_label.className = 'satus-button__label'; - component_label.innerText = Satus.locale.getMessage(element.label); - - component.appendChild(component_label); + component.appendChild(label); } return component; -}; +}; + /*-------------------------------------------------------------- >>> TEXT --------------------------------------------------------------*/ @@ -1971,86 +1984,130 @@ Satus.components.section = function(element) { return component; }; -/*-------------------------------------------------------------- +/*--------------------------------------------------------------- >>> COLOR PICKER ---------------------------------------------------------------*/ +---------------------------------------------------------------*/ Satus.components.colorPicker = function(element) { var component = document.createElement('div'), - component_value = document.createElement('div'); + container = document.createElement('div'), + cursor = document.createElement('div'), + cvs = document.createElement('canvas'), + ctx = cvs.getContext('2d'), + value = satus.storage.set(element.storage_key) || { + color: [255, 255, 255, 255], + x: 128, + y: 128 + }, + pivot_pointer = 0, + rgb = [255, 0, 0]; - element.class = 'satus-button'; - component_value.className = 'satus-color-picker__value'; - component_value.style.backgroundColor = Satus.storage.get(element.storage_key) || element.value || ''; + cvs.width = 256; + cvs.height = 256; - if (Satus.isset(element.label)) { - var component_label = document.createElement('span'); + container.className = 'satus-color-picker__container'; + cursor.className = 'satus-color-picker__cursor'; - component_label.className = 'satus-button__label'; - component_label.innerText = Satus.locale.getMessage(element.label); + for (var i = 0; i < 360; i++) { + var b = (pivot_pointer + 3 - 1) % 3; - component.appendChild(component_label); - } + if (rgb[pivot_pointer] < 255) { + rgb[pivot_pointer] = Math.min(rgb[pivot_pointer] + 4.322, 255); + } else if (rgb[b] > 0) { + rgb[b] = rgb[b] > 4.322 ? rgb[b] - 4.322 : 0; + } else if (rgb[pivot_pointer] >= 255) { + rgb[pivot_pointer] = 255; - component.addEventListener('click', function() { - var component = document.createElement('div'), - component_canvas = document.createElement('canvas'), - close = document.createElement('button'), - ctx = component_canvas.getContext('2d'), - image = new Image(), - dialog = Satus.components.dialog({}); - - close.className = 'satus-button'; - close.innerHTML = ''; - close.onclick = function() { - dialog.querySelector('.satus-dialog__scrim').click(); - }; + pivot_pointer = (pivot_pointer + 1) % 3; + } - dialog.className = 'satus-dialog satus-dialog--color-picker'; + var radial_gradient = ctx.createRadialGradient(128, 128, 0, 128, 128, 128); - component_canvas.width = 200; - component_canvas.height = 200; + radial_gradient.addColorStop(0, '#fff'); + radial_gradient.addColorStop(1, 'rgb(' + rgb.map(function(rgb) { + return Math.floor(rgb); + }).join(',') + ')'); - function select(event) { - var coordinates = component_canvas.getBoundingClientRect(), - x = event.clientX - coordinates.left, - y = event.clientY - coordinates.top, - color = ctx.getImageData(x, y, 1, 1).data; + ctx.fillStyle = radial_gradient; + ctx.globalCompositeOperation = 'source-over'; + ctx.beginPath(); + ctx.moveTo(128, 128); + ctx.arc(128, 128, 128, satus.math.degToRad(i), satus.math.degToRad(360)); + ctx.closePath(); + ctx.fill(); + } - component_value.style.backgroundColor = 'rgb(' + color[0] + ',' + color[1] + ',' + color[2] + ')'; + function select(event) { + var coordinates = cvs.getBoundingClientRect(), + x = event.clientX - coordinates.left, + y = event.clientY - coordinates.top, + color = ctx.getImageData(x, y, 1, 1).data, + rgb = ''; - Satus.storage.set(element.storage_key, component_value.style.backgroundColor); - } + cursor.style.left = x + 'px'; + cursor.style.top = y + 'px'; - function mouseup(event) { - component_canvas.removeEventListener('mousemove', select); - window.removeEventListener('mouseup', mouseup); - } + value.x = x; + value.y = y; + value.color = color; - component_canvas.addEventListener('mousedown', function() { - select(event); - this.addEventListener('mousemove', select); - window.addEventListener('mouseup', mouseup); - }); + component.querySelector('.satus-color-picker__value').style.background = 'rgba(' + value.color[0] + ', ' + value.color[1] + ', ' + value.color[2] + ', ' + value.color[3] / 255 + ')'; + } - image.onload = function() { - ctx.drawImage(image, 0, 0); + function mouseup(event) { + cvs.removeEventListener('mousemove', select); + window.removeEventListener('mouseup', mouseup); + } - image.remove(); - }; + cvs.addEventListener('mousedown', function(event) { + select(event); + + this.addEventListener('mousemove', select); + window.addEventListener('mouseup', mouseup); + }); - image.src = 'data:image/svg+xml;base64,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 270 270"><defs><radialGradient id="a"><stop offset="0%" stop-color="#fff"/><stop offset="100%" stop-color="#fff" stop-opacity="0"/></radialGradient></defs><g fill="none" stroke-width="133" class="IroWheelHue"><path stroke="hsl(240, 100%, 50%)" d="M201.477 136.74a66.5 66.5 0 00.023-1.74"/><path stroke="hsl(241, 100%, 50%)" d="M201.437 137.9a66.5 66.5 0 00.053-1.74"/><path stroke="hsl(242, 100%, 50%)" d="M201.376 139.06a66.5 66.5 0 00.083-1.74"/><path stroke="hsl(243, 100%, 50%)" d="M201.295 140.218a66.5 66.5 0 00.114-1.738"/><path stroke="hsl(244, 100%, 50%)" d="M201.194 141.374a66.5 66.5 0 00.144-1.735"/><path stroke="hsl(245, 100%, 50%)" d="M201.073 142.528a66.5 66.5 0 00.174-1.732"/><path stroke="hsl(246, 100%, 50%)" d="M200.931 143.68a66.5 66.5 0 00.205-1.729"/><path stroke="hsl(247, 100%, 50%)" d="M200.77 144.83a66.5 66.5 0 00.234-1.726"/><path stroke="hsl(248, 100%, 50%)" d="M200.588 145.976a66.5 66.5 0 00.265-1.721"/><path stroke="hsl(249, 100%, 50%)" d="M200.386 147.119a66.5 66.5 0 00.295-1.716"/><path stroke="hsl(250, 100%, 50%)" d="M200.165 148.258a66.5 66.5 0 00.325-1.71"/><path stroke="hsl(251, 100%, 50%)" d="M199.924 149.393a66.5 66.5 0 00.354-1.704"/><path stroke="hsl(252, 100%, 50%)" d="M199.663 150.524a66.5 66.5 0 00.384-1.698"/><path stroke="hsl(253, 100%, 50%)" d="M199.382 151.65a66.5 66.5 0 00.414-1.69"/><path stroke="hsl(254, 100%, 50%)" d="M199.081 152.771a66.5 66.5 0 00.444-1.683"/><path stroke="hsl(255, 100%, 50%)" d="M198.762 153.887a66.5 66.5 0 00.472-1.676"/><path stroke="hsl(256, 100%, 50%)" d="M198.422 154.997a66.5 66.5 0 00.502-1.667"/><path stroke="hsl(257, 100%, 50%)" d="M198.064 156.1a66.5 66.5 0 00.53-1.657"/><path stroke="hsl(258, 100%, 50%)" d="M197.686 157.198a66.5 66.5 0 00.56-1.648"/><path stroke="hsl(259, 100%, 50%)" d="M197.289 158.289a66.5 66.5 0 00.588-1.639"/><path stroke="hsl(260, 100%, 50%)" d="M196.873 159.372a66.5 66.5 0 00.617-1.628"/><path stroke="hsl(261, 100%, 50%)" d="M196.438 160.448a66.5 66.5 0 00.645-1.617"/><path stroke="hsl(262, 100%, 50%)" d="M195.984 161.517a66.5 66.5 0 00.674-1.606"/><path stroke="hsl(263, 100%, 50%)" d="M195.512 162.577a66.5 66.5 0 00.702-1.593"/><path stroke="hsl(264, 100%, 50%)" d="M195.022 163.629a66.5 66.5 0 00.729-1.581"/><path stroke="hsl(265, 100%, 50%)" d="M194.513 164.672a66.5 66.5 0 00.756-1.568"/><path stroke="hsl(266, 100%, 50%)" d="M193.986 165.706a66.5 66.5 0 00.784-1.554"/><path stroke="hsl(267, 100%, 50%)" d="M193.441 166.731a66.5 66.5 0 00.81-1.54"/><path stroke="hsl(268, 100%, 50%)" d="M192.879 167.746a66.5 66.5 0 00.837-1.526"/><path stroke="hsl(269, 100%, 50%)" d="M192.298 168.751a66.5 66.5 0 00.864-1.511"/><path stroke="hsl(270, 100%, 50%)" d="M191.7 169.746a66.5 66.5 0 00.89-1.496"/><path stroke="hsl(271, 100%, 50%)" d="M191.086 170.73a66.5 66.5 0 00.916-1.48"/><path stroke="hsl(272, 100%, 50%)" d="M190.453 171.704a66.5 66.5 0 00.942-1.464"/><path stroke="hsl(273, 100%, 50%)" d="M189.804 172.666a66.5 66.5 0 00.968-1.448"/><path stroke="hsl(274, 100%, 50%)" d="M189.139 173.617a66.5 66.5 0 00.992-1.43"/><path stroke="hsl(275, 100%, 50%)" d="M188.456 174.556a66.5 66.5 0 001.018-1.413"/><path stroke="hsl(276, 100%, 50%)" d="M187.758 175.483a66.5 66.5 0 001.042-1.395"/><path stroke="hsl(277, 100%, 50%)" d="M187.043 176.397a66.5 66.5 0 001.066-1.376"/><path stroke="hsl(278, 100%, 50%)" d="M186.313 177.3a66.5 66.5 0 001.09-1.359"/><path stroke="hsl(279, 100%, 50%)" d="M185.567 178.188a66.5 66.5 0 001.113-1.338"/><path stroke="hsl(280, 100%, 50%)" d="M184.806 179.064a66.5 66.5 0 001.136-1.319"/><path stroke="hsl(281, 100%, 50%)" d="M184.029 179.927a66.5 66.5 0 001.16-1.3"/><path stroke="hsl(282, 100%, 50%)" d="M183.237 180.776a66.5 66.5 0 001.182-1.279"/><path stroke="hsl(283, 100%, 50%)" d="M182.431 181.61a66.5 66.5 0 001.204-1.257"/><path stroke="hsl(284, 100%, 50%)" d="M181.61 182.431a66.5 66.5 0 001.226-1.236"/><path stroke="hsl(285, 100%, 50%)" d="M180.776 183.237a66.5 66.5 0 001.247-1.214"/><path stroke="hsl(286, 100%, 50%)" d="M179.927 184.029a66.5 66.5 0 001.268-1.193"/><path stroke="hsl(287, 100%, 50%)" d="M179.064 184.806a66.5 66.5 0 001.289-1.171"/><path stroke="hsl(288, 100%, 50%)" d="M178.188 185.567a66.5 66.5 0 001.31-1.148"/><path stroke="hsl(289, 100%, 50%)" d="M177.3 186.313a66.5 66.5 0 001.328-1.125"/><path stroke="hsl(290, 100%, 50%)" d="M176.397 187.043a66.5 66.5 0 001.348-1.101"/><path stroke="hsl(291, 100%, 50%)" d="M175.483 187.758a66.5 66.5 0 001.367-1.078"/><path stroke="hsl(292, 100%, 50%)" d="M174.556 188.456a66.5 66.5 0 001.385-1.053"/><path stroke="hsl(293, 100%, 50%)" d="M173.617 189.139a66.5 66.5 0 001.404-1.03"/><path stroke="hsl(294, 100%, 50%)" d="M172.666 189.804a66.5 66.5 0 001.422-1.004"/><path stroke="hsl(295, 100%, 50%)" d="M171.704 190.453a66.5 66.5 0 001.439-.98"/><path stroke="hsl(296, 100%, 50%)" d="M170.73 191.086a66.5 66.5 0 001.456-.955"/><path stroke="hsl(297, 100%, 50%)" d="M169.746 191.7a66.5 66.5 0 001.472-.928"/><path stroke="hsl(298, 100%, 50%)" d="M168.751 192.298a66.5 66.5 0 001.489-.903"/><path stroke="hsl(299, 100%, 50%)" d="M167.746 192.879a66.5 66.5 0 001.504-.877"/><path stroke="hsl(300, 100%, 50%)" d="M166.731 193.441a66.5 66.5 0 001.519-.85"/><path stroke="hsl(301, 100%, 50%)" d="M165.706 193.986a66.5 66.5 0 001.534-.824"/><path stroke="hsl(302, 100%, 50%)" d="M164.672 194.513a66.5 66.5 0 001.548-.797"/><path stroke="hsl(303, 100%, 50%)" d="M163.629 195.022a66.5 66.5 0 001.561-.77"/><path stroke="hsl(304, 100%, 50%)" d="M162.577 195.512a66.5 66.5 0 001.575-.742"/><path stroke="hsl(305, 100%, 50%)" d="M161.517 195.984a66.5 66.5 0 001.587-.715"/><path stroke="hsl(306, 100%, 50%)" d="M160.448 196.438a66.5 66.5 0 001.6-.687"/><path stroke="hsl(307, 100%, 50%)" d="M159.372 196.873a66.5 66.5 0 001.612-.66"/><path stroke="hsl(308, 100%, 50%)" d="M158.289 197.289a66.5 66.5 0 001.622-.631"/><path stroke="hsl(309, 100%, 50%)" d="M157.198 197.686a66.5 66.5 0 001.633-.603"/><path stroke="hsl(310, 100%, 50%)" d="M156.1 198.064a66.5 66.5 0 001.644-.574"/><path stroke="hsl(311, 100%, 50%)" d="M154.997 198.422a66.5 66.5 0 001.653-.545"/><path stroke="hsl(312, 100%, 50%)" d="M153.887 198.762a66.5 66.5 0 001.663-.517"/><path stroke="hsl(313, 100%, 50%)" d="M152.771 199.081a66.5 66.5 0 001.672-.487"/><path stroke="hsl(314, 100%, 50%)" d="M151.65 199.382a66.5 66.5 0 001.68-.458"/><path stroke="hsl(315, 100%, 50%)" d="M150.524 199.663a66.5 66.5 0 001.687-.429"/><path stroke="hsl(316, 100%, 50%)" d="M149.393 199.924a66.5 66.5 0 001.695-.4"/><path stroke="hsl(317, 100%, 50%)" d="M148.258 200.165a66.5 66.5 0 001.701-.37"/><path stroke="hsl(318, 100%, 50%)" d="M147.119 200.386a66.5 66.5 0 001.707-.34"/><path stroke="hsl(319, 100%, 50%)" d="M145.976 200.588a66.5 66.5 0 001.713-.31"/><path stroke="hsl(320, 100%, 50%)" d="M144.83 200.77a66.5 66.5 0 001.718-.28"/><path stroke="hsl(321, 100%, 50%)" d="M143.68 200.931a66.5 66.5 0 001.723-.25"/><path stroke="hsl(322, 100%, 50%)" d="M142.528 201.073a66.5 66.5 0 001.727-.22"/><path stroke="hsl(323, 100%, 50%)" d="M141.374 201.194a66.5 66.5 0 001.73-.19"/><path stroke="hsl(324, 100%, 50%)" d="M140.218 201.295a66.5 66.5 0 001.733-.16"/><path stroke="hsl(325, 100%, 50%)" d="M139.06 201.376a66.5 66.5 0 001.736-.13"/><path stroke="hsl(326, 100%, 50%)" d="M137.9 201.437a66.5 66.5 0 001.739-.099"/><path stroke="hsl(327, 100%, 50%)" d="M136.74 201.477a66.5 66.5 0 001.74-.068"/><path stroke="hsl(328, 100%, 50%)" d="M135.58 201.497a66.5 66.5 0 001.74-.038"/><path stroke="hsl(329, 100%, 50%)" d="M134.42 201.497a66.5 66.5 0 001.74-.007"/><path stroke="hsl(330, 100%, 50%)" d="M133.26 201.477a66.5 66.5 0 001.74.023"/><path stroke="hsl(331, 100%, 50%)" d="M132.1 201.437a66.5 66.5 0 001.74.053"/><path stroke="hsl(332, 100%, 50%)" d="M130.94 201.376a66.5 66.5 0 001.74.083"/><path stroke="hsl(333, 100%, 50%)" d="M129.782 201.295a66.5 66.5 0 001.738.114"/><path stroke="hsl(334, 100%, 50%)" d="M128.626 201.194a66.5 66.5 0 001.735.144"/><path stroke="hsl(335, 100%, 50%)" d="M127.472 201.073a66.5 66.5 0 001.732.174"/><path stroke="hsl(336, 100%, 50%)" d="M126.32 200.931a66.5 66.5 0 001.729.205"/><path stroke="hsl(337, 100%, 50%)" d="M125.17 200.77a66.5 66.5 0 001.726.234"/><path stroke="hsl(338, 100%, 50%)" d="M124.024 200.588a66.5 66.5 0 001.721.265"/><path stroke="hsl(339, 100%, 50%)" d="M122.881 200.386a66.5 66.5 0 001.716.295"/><path stroke="hsl(340, 100%, 50%)" d="M121.742 200.165a66.5 66.5 0 001.71.325"/><path stroke="hsl(341, 100%, 50%)" d="M120.607 199.924a66.5 66.5 0 001.704.354"/><path stroke="hsl(342, 100%, 50%)" d="M119.476 199.663a66.5 66.5 0 001.698.384"/><path stroke="hsl(343, 100%, 50%)" d="M118.35 199.382a66.5 66.5 0 001.69.414"/><path stroke="hsl(344, 100%, 50%)" d="M117.229 199.081a66.5 66.5 0 001.683.444"/><path stroke="hsl(345, 100%, 50%)" d="M116.113 198.762a66.5 66.5 0 001.676.472"/><path stroke="hsl(346, 100%, 50%)" d="M115.003 198.422a66.5 66.5 0 001.667.502"/><path stroke="hsl(347, 100%, 50%)" d="M113.9 198.064a66.5 66.5 0 001.657.53"/><path stroke="hsl(348, 100%, 50%)" d="M112.802 197.686a66.5 66.5 0 001.648.56"/><path stroke="hsl(349, 100%, 50%)" d="M111.711 197.289a66.5 66.5 0 001.639.588"/><path stroke="hsl(350, 100%, 50%)" d="M110.628 196.873a66.5 66.5 0 001.628.617"/><path stroke="hsl(351, 100%, 50%)" d="M109.552 196.438a66.5 66.5 0 001.617.645"/><path stroke="hsl(352, 100%, 50%)" d="M108.483 195.984a66.5 66.5 0 001.606.674"/><path stroke="hsl(353, 100%, 50%)" d="M107.423 195.512a66.5 66.5 0 001.593.702"/><path stroke="hsl(354, 100%, 50%)" d="M106.371 195.022a66.5 66.5 0 001.581.729"/><path stroke="hsl(355, 100%, 50%)" d="M105.328 194.513a66.5 66.5 0 001.568.756"/><path stroke="hsl(356, 100%, 50%)" d="M104.294 193.986a66.5 66.5 0 001.554.784"/><path stroke="hsl(357, 100%, 50%)" d="M103.269 193.441a66.5 66.5 0 001.54.81"/><path stroke="hsl(358, 100%, 50%)" d="M102.254 192.879a66.5 66.5 0 001.526.837"/><path stroke="hsl(359, 100%, 50%)" d="M101.249 192.298a66.5 66.5 0 001.511.864"/><path stroke="hsl(0, 100%, 50%)" d="M100.254 191.7a66.5 66.5 0 001.496.89"/><path stroke="hsl(1, 100%, 50%)" d="M99.27 191.086a66.5 66.5 0 001.48.916"/><path stroke="hsl(2, 100%, 50%)" d="M98.296 190.453a66.5 66.5 0 001.464.942"/><path stroke="hsl(3, 100%, 50%)" d="M97.334 189.804a66.5 66.5 0 001.448.968"/><path stroke="hsl(4, 100%, 50%)" d="M96.383 189.139a66.5 66.5 0 001.43.992"/><path stroke="hsl(5, 100%, 50%)" d="M95.444 188.456a66.5 66.5 0 001.413 1.018"/><path stroke="hsl(6, 100%, 50%)" d="M94.517 187.758a66.5 66.5 0 001.395 1.042"/><path stroke="hsl(7, 100%, 50%)" d="M93.603 187.043a66.5 66.5 0 001.376 1.066"/><path stroke="hsl(8, 100%, 50%)" d="M92.7 186.313a66.5 66.5 0 001.359 1.09"/><path stroke="hsl(9, 100%, 50%)" d="M91.812 185.567a66.5 66.5 0 001.338 1.113"/><path stroke="hsl(10, 100%, 50%)" d="M90.936 184.806a66.5 66.5 0 001.319 1.136"/><path stroke="hsl(11, 100%, 50%)" d="M90.073 184.029a66.5 66.5 0 001.3 1.16"/><path stroke="hsl(12, 100%, 50%)" d="M89.224 183.237a66.5 66.5 0 001.279 1.182"/><path stroke="hsl(13, 100%, 50%)" d="M88.39 182.431a66.5 66.5 0 001.257 1.204"/><path stroke="hsl(14, 100%, 50%)" d="M87.569 181.61a66.5 66.5 0 001.236 1.226"/><path stroke="hsl(15, 100%, 50%)" d="M86.763 180.776a66.5 66.5 0 001.214 1.247"/><path stroke="hsl(16, 100%, 50%)" d="M85.971 179.927a66.5 66.5 0 001.193 1.268"/><path stroke="hsl(17, 100%, 50%)" d="M85.194 179.064a66.5 66.5 0 001.171 1.289"/><path stroke="hsl(18, 100%, 50%)" d="M84.433 178.188a66.5 66.5 0 001.148 1.31"/><path stroke="hsl(19, 100%, 50%)" d="M83.687 177.3a66.5 66.5 0 001.125 1.328"/><path stroke="hsl(20, 100%, 50%)" d="M82.957 176.397a66.5 66.5 0 001.101 1.348"/><path stroke="hsl(21, 100%, 50%)" d="M82.242 175.483a66.5 66.5 0 001.078 1.367"/><path stroke="hsl(22, 100%, 50%)" d="M81.544 174.556a66.5 66.5 0 001.053 1.385"/><path stroke="hsl(23, 100%, 50%)" d="M80.861 173.617a66.5 66.5 0 001.03 1.404"/><path stroke="hsl(24, 100%, 50%)" d="M80.196 172.666a66.5 66.5 0 001.004 1.422"/><path stroke="hsl(25, 100%, 50%)" d="M79.547 171.704a66.5 66.5 0 00.98 1.439"/><path stroke="hsl(26, 100%, 50%)" d="M78.914 170.73a66.5 66.5 0 00.955 1.456"/><path stroke="hsl(27, 100%, 50%)" d="M78.3 169.746a66.5 66.5 0 00.928 1.472"/><path stroke="hsl(28, 100%, 50%)" d="M77.702 168.751a66.5 66.5 0 00.903 1.489"/><path stroke="hsl(29, 100%, 50%)" d="M77.121 167.746a66.5 66.5 0 00.877 1.504"/><path stroke="hsl(30, 100%, 50%)" d="M76.559 166.731a66.5 66.5 0 00.85 1.519"/><path stroke="hsl(31, 100%, 50%)" d="M76.014 165.706a66.5 66.5 0 00.824 1.534"/><path stroke="hsl(32, 100%, 50%)" d="M75.487 164.672a66.5 66.5 0 00.797 1.548"/><path stroke="hsl(33, 100%, 50%)" d="M74.978 163.629a66.5 66.5 0 00.77 1.561"/><path stroke="hsl(34, 100%, 50%)" d="M74.488 162.577a66.5 66.5 0 00.742 1.575"/><path stroke="hsl(35, 100%, 50%)" d="M74.016 161.517a66.5 66.5 0 00.715 1.587"/><path stroke="hsl(36, 100%, 50%)" d="M73.562 160.448a66.5 66.5 0 00.687 1.6"/><path stroke="hsl(37, 100%, 50%)" d="M73.127 159.372a66.5 66.5 0 00.66 1.612"/><path stroke="hsl(38, 100%, 50%)" d="M72.711 158.289a66.5 66.5 0 00.631 1.622"/><path stroke="hsl(39, 100%, 50%)" d="M72.314 157.198a66.5 66.5 0 00.603 1.633"/><path stroke="hsl(40, 100%, 50%)" d="M71.936 156.1a66.5 66.5 0 00.574 1.644"/><path stroke="hsl(41, 100%, 50%)" d="M71.578 154.997a66.5 66.5 0 00.545 1.653"/><path stroke="hsl(42, 100%, 50%)" d="M71.238 153.887a66.5 66.5 0 00.517 1.663"/><path stroke="hsl(43, 100%, 50%)" d="M70.919 152.771a66.5 66.5 0 00.487 1.672"/><path stroke="hsl(44, 100%, 50%)" d="M70.618 151.65a66.5 66.5 0 00.458 1.68"/><path stroke="hsl(45, 100%, 50%)" d="M70.337 150.524a66.5 66.5 0 00.429 1.687"/><path stroke="hsl(46, 100%, 50%)" d="M70.076 149.393a66.5 66.5 0 00.4 1.695"/><path stroke="hsl(47, 100%, 50%)" d="M69.835 148.258a66.5 66.5 0 00.37 1.701"/><path stroke="hsl(48, 100%, 50%)" d="M69.614 147.119a66.5 66.5 0 00.34 1.707"/><path stroke="hsl(49, 100%, 50%)" d="M69.412 145.976a66.5 66.5 0 00.31 1.713"/><path stroke="hsl(50, 100%, 50%)" d="M69.23 144.83a66.5 66.5 0 00.28 1.718"/><path stroke="hsl(51, 100%, 50%)" d="M69.069 143.68a66.5 66.5 0 00.25 1.723"/><path stroke="hsl(52, 100%, 50%)" d="M68.927 142.528a66.5 66.5 0 00.22 1.727"/><path stroke="hsl(53, 100%, 50%)" d="M68.806 141.374a66.5 66.5 0 00.19 1.73"/><path stroke="hsl(54, 100%, 50%)" d="M68.705 140.218a66.5 66.5 0 00.16 1.733"/><path stroke="hsl(55, 100%, 50%)" d="M68.624 139.06a66.5 66.5 0 00.13 1.736"/><path stroke="hsl(56, 100%, 50%)" d="M68.563 137.9a66.5 66.5 0 00.099 1.739"/><path stroke="hsl(57, 100%, 50%)" d="M68.523 136.74a66.5 66.5 0 00.068 1.74"/><path stroke="hsl(58, 100%, 50%)" d="M68.503 135.58a66.5 66.5 0 00.038 1.74"/><path stroke="hsl(59, 100%, 50%)" d="M68.503 134.42a66.5 66.5 0 00.007 1.74"/><path stroke="hsl(60, 100%, 50%)" d="M68.523 133.26A66.5 66.5 0 0068.5 135"/><path stroke="hsl(61, 100%, 50%)" d="M68.563 132.1a66.5 66.5 0 00-.053 1.74"/><path stroke="hsl(62, 100%, 50%)" d="M68.624 130.94a66.5 66.5 0 00-.083 1.74"/><path stroke="hsl(63, 100%, 50%)" d="M68.705 129.782a66.5 66.5 0 00-.114 1.738"/><path stroke="hsl(64, 100%, 50%)" d="M68.806 128.626a66.5 66.5 0 00-.144 1.735"/><path stroke="hsl(65, 100%, 50%)" d="M68.927 127.472a66.5 66.5 0 00-.174 1.732"/><path stroke="hsl(66, 100%, 50%)" d="M69.069 126.32a66.5 66.5 0 00-.205 1.729"/><path stroke="hsl(67, 100%, 50%)" d="M69.23 125.17a66.5 66.5 0 00-.234 1.726"/><path stroke="hsl(68, 100%, 50%)" d="M69.412 124.024a66.5 66.5 0 00-.265 1.721"/><path stroke="hsl(69, 100%, 50%)" d="M69.614 122.881a66.5 66.5 0 00-.295 1.716"/><path stroke="hsl(70, 100%, 50%)" d="M69.835 121.742a66.5 66.5 0 00-.325 1.71"/><path stroke="hsl(71, 100%, 50%)" d="M70.076 120.607a66.5 66.5 0 00-.354 1.704"/><path stroke="hsl(72, 100%, 50%)" d="M70.337 119.476a66.5 66.5 0 00-.384 1.698"/><path stroke="hsl(73, 100%, 50%)" d="M70.618 118.35a66.5 66.5 0 00-.414 1.69"/><path stroke="hsl(74, 100%, 50%)" d="M70.919 117.229a66.5 66.5 0 00-.444 1.683"/><path stroke="hsl(75, 100%, 50%)" d="M71.238 116.113a66.5 66.5 0 00-.472 1.676"/><path stroke="hsl(76, 100%, 50%)" d="M71.578 115.003a66.5 66.5 0 00-.502 1.667"/><path stroke="hsl(77, 100%, 50%)" d="M71.936 113.9a66.5 66.5 0 00-.53 1.657"/><path stroke="hsl(78, 100%, 50%)" d="M72.314 112.802a66.5 66.5 0 00-.56 1.648"/><path stroke="hsl(79, 100%, 50%)" d="M72.711 111.711a66.5 66.5 0 00-.588 1.639"/><path stroke="hsl(80, 100%, 50%)" d="M73.127 110.628a66.5 66.5 0 00-.617 1.628"/><path stroke="hsl(81, 100%, 50%)" d="M73.562 109.552a66.5 66.5 0 00-.645 1.617"/><path stroke="hsl(82, 100%, 50%)" d="M74.016 108.483a66.5 66.5 0 00-.674 1.606"/><path stroke="hsl(83, 100%, 50%)" d="M74.488 107.423a66.5 66.5 0 00-.702 1.593"/><path stroke="hsl(84, 100%, 50%)" d="M74.978 106.371a66.5 66.5 0 00-.729 1.581"/><path stroke="hsl(85, 100%, 50%)" d="M75.487 105.328a66.5 66.5 0 00-.756 1.568"/><path stroke="hsl(86, 100%, 50%)" d="M76.014 104.294a66.5 66.5 0 00-.784 1.554"/><path stroke="hsl(87, 100%, 50%)" d="M76.559 103.269a66.5 66.5 0 00-.81 1.54"/><path stroke="hsl(88, 100%, 50%)" d="M77.121 102.254a66.5 66.5 0 00-.837 1.526"/><path stroke="hsl(89, 100%, 50%)" d="M77.702 101.249a66.5 66.5 0 00-.864 1.511"/><path stroke="hsl(90, 100%, 50%)" d="M78.3 100.254a66.5 66.5 0 00-.89 1.496"/><path stroke="hsl(91, 100%, 50%)" d="M78.914 99.27a66.5 66.5 0 00-.916 1.48"/><path stroke="hsl(92, 100%, 50%)" d="M79.547 98.296a66.5 66.5 0 00-.942 1.464"/><path stroke="hsl(93, 100%, 50%)" d="M80.196 97.334a66.5 66.5 0 00-.968 1.448"/><path stroke="hsl(94, 100%, 50%)" d="M80.861 96.383a66.5 66.5 0 00-.992 1.43"/><path stroke="hsl(95, 100%, 50%)" d="M81.544 95.444a66.5 66.5 0 00-1.018 1.413"/><path stroke="hsl(96, 100%, 50%)" d="M82.242 94.517a66.5 66.5 0 00-1.042 1.395"/><path stroke="hsl(97, 100%, 50%)" d="M82.957 93.603a66.5 66.5 0 00-1.066 1.376"/><path stroke="hsl(98, 100%, 50%)" d="M83.687 92.7a66.5 66.5 0 00-1.09 1.359"/><path stroke="hsl(99, 100%, 50%)" d="M84.433 91.812a66.5 66.5 0 00-1.113 1.338"/><path stroke="hsl(100, 100%, 50%)" d="M85.194 90.936a66.5 66.5 0 00-1.136 1.319"/><path stroke="hsl(101, 100%, 50%)" d="M85.971 90.073a66.5 66.5 0 00-1.16 1.3"/><path stroke="hsl(102, 100%, 50%)" d="M86.763 89.224a66.5 66.5 0 00-1.182 1.279"/><path stroke="hsl(103, 100%, 50%)" d="M87.569 88.39a66.5 66.5 0 00-1.204 1.257"/><path stroke="hsl(104, 100%, 50%)" d="M88.39 87.569a66.5 66.5 0 00-1.226 1.236"/><path stroke="hsl(105, 100%, 50%)" d="M89.224 86.763a66.5 66.5 0 00-1.247 1.214"/><path stroke="hsl(106, 100%, 50%)" d="M90.073 85.971a66.5 66.5 0 00-1.268 1.193"/><path stroke="hsl(107, 100%, 50%)" d="M90.936 85.194a66.5 66.5 0 00-1.289 1.171"/><path stroke="hsl(108, 100%, 50%)" d="M91.812 84.433a66.5 66.5 0 00-1.31 1.148"/><path stroke="hsl(109, 100%, 50%)" d="M92.7 83.687a66.5 66.5 0 00-1.328 1.125"/><path stroke="hsl(110, 100%, 50%)" d="M93.603 82.957a66.5 66.5 0 00-1.348 1.101"/><path stroke="hsl(111, 100%, 50%)" d="M94.517 82.242a66.5 66.5 0 00-1.367 1.078"/><path stroke="hsl(112, 100%, 50%)" d="M95.444 81.544a66.5 66.5 0 00-1.385 1.053"/><path stroke="hsl(113, 100%, 50%)" d="M96.383 80.861a66.5 66.5 0 00-1.404 1.03"/><path stroke="hsl(114, 100%, 50%)" d="M97.334 80.196a66.5 66.5 0 00-1.422 1.004"/><path stroke="hsl(115, 100%, 50%)" d="M98.296 79.547a66.5 66.5 0 00-1.439.98"/><path stroke="hsl(116, 100%, 50%)" d="M99.27 78.914a66.5 66.5 0 00-1.456.955"/><path stroke="hsl(117, 100%, 50%)" d="M100.254 78.3a66.5 66.5 0 00-1.472.928"/><path stroke="hsl(118, 100%, 50%)" d="M101.249 77.702a66.5 66.5 0 00-1.489.903"/><path stroke="hsl(119, 100%, 50%)" d="M102.254 77.121a66.5 66.5 0 00-1.504.877"/><path stroke="hsl(120, 100%, 50%)" d="M103.269 76.559a66.5 66.5 0 00-1.519.85"/><path stroke="hsl(121, 100%, 50%)" d="M104.294 76.014a66.5 66.5 0 00-1.534.824"/><path stroke="hsl(122, 100%, 50%)" d="M105.328 75.487a66.5 66.5 0 00-1.548.797"/><path stroke="hsl(123, 100%, 50%)" d="M106.371 74.978a66.5 66.5 0 00-1.561.77"/><path stroke="hsl(124, 100%, 50%)" d="M107.423 74.488a66.5 66.5 0 00-1.575.742"/><path stroke="hsl(125, 100%, 50%)" d="M108.483 74.016a66.5 66.5 0 00-1.587.715"/><path stroke="hsl(126, 100%, 50%)" d="M109.552 73.562a66.5 66.5 0 00-1.6.687"/><path stroke="hsl(127, 100%, 50%)" d="M110.628 73.127a66.5 66.5 0 00-1.612.66"/><path stroke="hsl(128, 100%, 50%)" d="M111.711 72.711a66.5 66.5 0 00-1.622.631"/><path stroke="hsl(129, 100%, 50%)" d="M112.802 72.314a66.5 66.5 0 00-1.633.603"/><path stroke="hsl(130, 100%, 50%)" d="M113.9 71.936a66.5 66.5 0 00-1.644.574"/><path stroke="hsl(131, 100%, 50%)" d="M115.003 71.578a66.5 66.5 0 00-1.653.545"/><path stroke="hsl(132, 100%, 50%)" d="M116.113 71.238a66.5 66.5 0 00-1.663.517"/><path stroke="hsl(133, 100%, 50%)" d="M117.229 70.919a66.5 66.5 0 00-1.672.487"/><path stroke="hsl(134, 100%, 50%)" d="M118.35 70.618a66.5 66.5 0 00-1.68.458"/><path stroke="hsl(135, 100%, 50%)" d="M119.476 70.337a66.5 66.5 0 00-1.687.429"/><path stroke="hsl(136, 100%, 50%)" d="M120.607 70.076a66.5 66.5 0 00-1.695.4"/><path stroke="hsl(137, 100%, 50%)" d="M121.742 69.835a66.5 66.5 0 00-1.701.37"/><path stroke="hsl(138, 100%, 50%)" d="M122.881 69.614a66.5 66.5 0 00-1.707.34"/><path stroke="hsl(139, 100%, 50%)" d="M124.024 69.412a66.5 66.5 0 00-1.713.31"/><path stroke="hsl(140, 100%, 50%)" d="M125.17 69.23a66.5 66.5 0 00-1.718.28"/><path stroke="hsl(141, 100%, 50%)" d="M126.32 69.069a66.5 66.5 0 00-1.723.25"/><path stroke="hsl(142, 100%, 50%)" d="M127.472 68.927a66.5 66.5 0 00-1.727.22"/><path stroke="hsl(143, 100%, 50%)" d="M128.626 68.806a66.5 66.5 0 00-1.73.19"/><path stroke="hsl(144, 100%, 50%)" d="M129.782 68.705a66.5 66.5 0 00-1.733.16"/><path stroke="hsl(145, 100%, 50%)" d="M130.94 68.624a66.5 66.5 0 00-1.736.13"/><path stroke="hsl(146, 100%, 50%)" d="M132.1 68.563a66.5 66.5 0 00-1.739.099"/><path stroke="hsl(147, 100%, 50%)" d="M133.26 68.523a66.5 66.5 0 00-1.74.068"/><path stroke="hsl(148, 100%, 50%)" d="M134.42 68.503a66.5 66.5 0 00-1.74.038"/><path stroke="hsl(149, 100%, 50%)" d="M135.58 68.503a66.5 66.5 0 00-1.74.007"/><path stroke="hsl(150, 100%, 50%)" d="M136.74 68.523A66.5 66.5 0 00135 68.5"/><path stroke="hsl(151, 100%, 50%)" d="M137.9 68.563a66.5 66.5 0 00-1.74-.053"/><path stroke="hsl(152, 100%, 50%)" d="M139.06 68.624a66.5 66.5 0 00-1.74-.083"/><path stroke="hsl(153, 100%, 50%)" d="M140.218 68.705a66.5 66.5 0 00-1.738-.114"/><path stroke="hsl(154, 100%, 50%)" d="M141.374 68.806a66.5 66.5 0 00-1.735-.144"/><path stroke="hsl(155, 100%, 50%)" d="M142.528 68.927a66.5 66.5 0 00-1.732-.174"/><path stroke="hsl(156, 100%, 50%)" d="M143.68 69.069a66.5 66.5 0 00-1.729-.205"/><path stroke="hsl(157, 100%, 50%)" d="M144.83 69.23a66.5 66.5 0 00-1.726-.234"/><path stroke="hsl(158, 100%, 50%)" d="M145.976 69.412a66.5 66.5 0 00-1.721-.265"/><path stroke="hsl(159, 100%, 50%)" d="M147.119 69.614a66.5 66.5 0 00-1.716-.295"/><path stroke="hsl(160, 100%, 50%)" d="M148.258 69.835a66.5 66.5 0 00-1.71-.325"/><path stroke="hsl(161, 100%, 50%)" d="M149.393 70.076a66.5 66.5 0 00-1.704-.354"/><path stroke="hsl(162, 100%, 50%)" d="M150.524 70.337a66.5 66.5 0 00-1.698-.384"/><path stroke="hsl(163, 100%, 50%)" d="M151.65 70.618a66.5 66.5 0 00-1.69-.414"/><path stroke="hsl(164, 100%, 50%)" d="M152.771 70.919a66.5 66.5 0 00-1.683-.444"/><path stroke="hsl(165, 100%, 50%)" d="M153.887 71.238a66.5 66.5 0 00-1.676-.472"/><path stroke="hsl(166, 100%, 50%)" d="M154.997 71.578a66.5 66.5 0 00-1.667-.502"/><path stroke="hsl(167, 100%, 50%)" d="M156.1 71.936a66.5 66.5 0 00-1.657-.53"/><path stroke="hsl(168, 100%, 50%)" d="M157.198 72.314a66.5 66.5 0 00-1.648-.56"/><path stroke="hsl(169, 100%, 50%)" d="M158.289 72.711a66.5 66.5 0 00-1.639-.588"/><path stroke="hsl(170, 100%, 50%)" d="M159.372 73.127a66.5 66.5 0 00-1.628-.617"/><path stroke="hsl(171, 100%, 50%)" d="M160.448 73.562a66.5 66.5 0 00-1.617-.645"/><path stroke="hsl(172, 100%, 50%)" d="M161.517 74.016a66.5 66.5 0 00-1.606-.674"/><path stroke="hsl(173, 100%, 50%)" d="M162.577 74.488a66.5 66.5 0 00-1.593-.702"/><path stroke="hsl(174, 100%, 50%)" d="M163.629 74.978a66.5 66.5 0 00-1.581-.729"/><path stroke="hsl(175, 100%, 50%)" d="M164.672 75.487a66.5 66.5 0 00-1.568-.756"/><path stroke="hsl(176, 100%, 50%)" d="M165.706 76.014a66.5 66.5 0 00-1.554-.784"/><path stroke="hsl(177, 100%, 50%)" d="M166.731 76.559a66.5 66.5 0 00-1.54-.81"/><path stroke="hsl(178, 100%, 50%)" d="M167.746 77.121a66.5 66.5 0 00-1.526-.837"/><path stroke="hsl(179, 100%, 50%)" d="M168.751 77.702a66.5 66.5 0 00-1.511-.864"/><path stroke="hsl(180, 100%, 50%)" d="M169.746 78.3a66.5 66.5 0 00-1.496-.89"/><path stroke="hsl(181, 100%, 50%)" d="M170.73 78.914a66.5 66.5 0 00-1.48-.916"/><path stroke="hsl(182, 100%, 50%)" d="M171.704 79.547a66.5 66.5 0 00-1.464-.942"/><path stroke="hsl(183, 100%, 50%)" d="M172.666 80.196a66.5 66.5 0 00-1.448-.968"/><path stroke="hsl(184, 100%, 50%)" d="M173.617 80.861a66.5 66.5 0 00-1.43-.992"/><path stroke="hsl(185, 100%, 50%)" d="M174.556 81.544a66.5 66.5 0 00-1.413-1.018"/><path stroke="hsl(186, 100%, 50%)" d="M175.483 82.242a66.5 66.5 0 00-1.395-1.042"/><path stroke="hsl(187, 100%, 50%)" d="M176.397 82.957a66.5 66.5 0 00-1.376-1.066"/><path stroke="hsl(188, 100%, 50%)" d="M177.3 83.687a66.5 66.5 0 00-1.359-1.09"/><path stroke="hsl(189, 100%, 50%)" d="M178.188 84.433a66.5 66.5 0 00-1.338-1.113"/><path stroke="hsl(190, 100%, 50%)" d="M179.064 85.194a66.5 66.5 0 00-1.319-1.136"/><path stroke="hsl(191, 100%, 50%)" d="M179.927 85.971a66.5 66.5 0 00-1.3-1.16"/><path stroke="hsl(192, 100%, 50%)" d="M180.776 86.763a66.5 66.5 0 00-1.279-1.182"/><path stroke="hsl(193, 100%, 50%)" d="M181.61 87.569a66.5 66.5 0 00-1.257-1.204"/><path stroke="hsl(194, 100%, 50%)" d="M182.431 88.39a66.5 66.5 0 00-1.236-1.226"/><path stroke="hsl(195, 100%, 50%)" d="M183.237 89.224a66.5 66.5 0 00-1.214-1.247"/><path stroke="hsl(196, 100%, 50%)" d="M184.029 90.073a66.5 66.5 0 00-1.193-1.268"/><path stroke="hsl(197, 100%, 50%)" d="M184.806 90.936a66.5 66.5 0 00-1.171-1.289"/><path stroke="hsl(198, 100%, 50%)" d="M185.567 91.812a66.5 66.5 0 00-1.148-1.31"/><path stroke="hsl(199, 100%, 50%)" d="M186.313 92.7a66.5 66.5 0 00-1.125-1.328"/><path stroke="hsl(200, 100%, 50%)" d="M187.043 93.603a66.5 66.5 0 00-1.101-1.348"/><path stroke="hsl(201, 100%, 50%)" d="M187.758 94.517a66.5 66.5 0 00-1.078-1.367"/><path stroke="hsl(202, 100%, 50%)" d="M188.456 95.444a66.5 66.5 0 00-1.053-1.385"/><path stroke="hsl(203, 100%, 50%)" d="M189.139 96.383a66.5 66.5 0 00-1.03-1.404"/><path stroke="hsl(204, 100%, 50%)" d="M189.804 97.334a66.5 66.5 0 00-1.004-1.422"/><path stroke="hsl(205, 100%, 50%)" d="M190.453 98.296a66.5 66.5 0 00-.98-1.439"/><path stroke="hsl(206, 100%, 50%)" d="M191.086 99.27a66.5 66.5 0 00-.955-1.456"/><path stroke="hsl(207, 100%, 50%)" d="M191.7 100.254a66.5 66.5 0 00-.928-1.472"/><path stroke="hsl(208, 100%, 50%)" d="M192.298 101.249a66.5 66.5 0 00-.903-1.489"/><path stroke="hsl(209, 100%, 50%)" d="M192.879 102.254a66.5 66.5 0 00-.877-1.504"/><path stroke="hsl(210, 100%, 50%)" d="M193.441 103.269a66.5 66.5 0 00-.85-1.519"/><path stroke="hsl(211, 100%, 50%)" d="M193.986 104.294a66.5 66.5 0 00-.824-1.534"/><path stroke="hsl(212, 100%, 50%)" d="M194.513 105.328a66.5 66.5 0 00-.797-1.548"/><path stroke="hsl(213, 100%, 50%)" d="M195.022 106.371a66.5 66.5 0 00-.77-1.561"/><path stroke="hsl(214, 100%, 50%)" d="M195.512 107.423a66.5 66.5 0 00-.742-1.575"/><path stroke="hsl(215, 100%, 50%)" d="M195.984 108.483a66.5 66.5 0 00-.715-1.587"/><path stroke="hsl(216, 100%, 50%)" d="M196.438 109.552a66.5 66.5 0 00-.687-1.6"/><path stroke="hsl(217, 100%, 50%)" d="M196.873 110.628a66.5 66.5 0 00-.66-1.612"/><path stroke="hsl(218, 100%, 50%)" d="M197.289 111.711a66.5 66.5 0 00-.631-1.622"/><path stroke="hsl(219, 100%, 50%)" d="M197.686 112.802a66.5 66.5 0 00-.603-1.633"/><path stroke="hsl(220, 100%, 50%)" d="M198.064 113.9a66.5 66.5 0 00-.574-1.644"/><path stroke="hsl(221, 100%, 50%)" d="M198.422 115.003a66.5 66.5 0 00-.545-1.653"/><path stroke="hsl(222, 100%, 50%)" d="M198.762 116.113a66.5 66.5 0 00-.517-1.663"/><path stroke="hsl(223, 100%, 50%)" d="M199.081 117.229a66.5 66.5 0 00-.487-1.672"/><path stroke="hsl(224, 100%, 50%)" d="M199.382 118.35a66.5 66.5 0 00-.458-1.68"/><path stroke="hsl(225, 100%, 50%)" d="M199.663 119.476a66.5 66.5 0 00-.429-1.687"/><path stroke="hsl(226, 100%, 50%)" d="M199.924 120.607a66.5 66.5 0 00-.4-1.695"/><path stroke="hsl(227, 100%, 50%)" d="M200.165 121.742a66.5 66.5 0 00-.37-1.701"/><path stroke="hsl(228, 100%, 50%)" d="M200.386 122.881a66.5 66.5 0 00-.34-1.707"/><path stroke="hsl(229, 100%, 50%)" d="M200.588 124.024a66.5 66.5 0 00-.31-1.713"/><path stroke="hsl(230, 100%, 50%)" d="M200.77 125.17a66.5 66.5 0 00-.28-1.718"/><path stroke="hsl(231, 100%, 50%)" d="M200.931 126.32a66.5 66.5 0 00-.25-1.723"/><path stroke="hsl(232, 100%, 50%)" d="M201.073 127.472a66.5 66.5 0 00-.22-1.727"/><path stroke="hsl(233, 100%, 50%)" d="M201.194 128.626a66.5 66.5 0 00-.19-1.73"/><path stroke="hsl(234, 100%, 50%)" d="M201.295 129.782a66.5 66.5 0 00-.16-1.733"/><path stroke="hsl(235, 100%, 50%)" d="M201.376 130.94a66.5 66.5 0 00-.13-1.736"/><path stroke="hsl(236, 100%, 50%)" d="M201.437 132.1a66.5 66.5 0 00-.099-1.739"/><path stroke="hsl(237, 100%, 50%)" d="M201.477 133.26a66.5 66.5 0 00-.068-1.74"/><path stroke="hsl(238, 100%, 50%)" d="M201.497 134.42a66.5 66.5 0 00-.038-1.74"/><path stroke="hsl(239, 100%, 50%)" d="M201.497 135.58a66.5 66.5 0 00-.007-1.74"/></g><circle cx="135" cy="135" r="133" fill="url(#a)" class="IroWheelSaturation"/><circle cx="135" cy="135" r="133" fill="none" stroke="#fff" stroke-width="2" class="IroWheelBorder"/></svg>'; + component.appendChild(container); + container.appendChild(cvs); + container.appendChild(cursor); - dialog.querySelector('.satus-scrollbar__content').appendChild(close); - dialog.querySelector('.satus-scrollbar__content').appendChild(component_canvas); + satus.render({ + type: 'section', + style: { + margin: '16px 0 8px' + }, - document.body.appendChild(dialog); - }); + value: { + type: 'div', + class: 'satus-color-picker__value', + style: { + background: 'rgba(' + value.color[0] + ', ' + value.color[1] + ', ' + value.color[2] + ', ' + value.color[3] / 255 + ')' + } + }, + cancel: { + type: 'button', + label: 'cancel', + onclick: function() { + document.querySelector('.satus-dialog__scrim').click(); + } + }, + save: { + type: 'button', + label: 'save', + onclick: function() { + satus.storage.set(element.storage_key, { + color: value.color, + x: value.x, + y: value.y + }); - component.appendChild(component_value); + document.querySelector('.satus-dialog__scrim').click(); + } + } + }, component); return component; -}; +}; + /*--------------------------------------------------------------- >>> SHORTCUT ---------------------------------------------------------------*/ diff --git a/src/css/basic.css b/src/css/basic.css index 6f59c73..dcdcdda 100644 --- a/src/css/basic.css +++ b/src/css/basic.css @@ -1,9 +1,8 @@ /*--------------------------------------------------------------- ->>> TABLE OF CONTENTS: +>>> BASIC ----------------------------------------------------------------- 1.0 Fonts 2.0 Body -3.0 Button ---------------------------------------------------------------*/ /*--------------------------------------------------------------- @@ -75,9 +74,6 @@ body transition: .5s linear; } - - - .satus.loading { top: 14px; @@ -98,13 +94,3 @@ body transition: 0s linear; } - - -/*--------------------------------------------------------------- -3.0 BUTTON ----------------------------------------------------------------*/ - -button -{ - font-family: 'Open Sans', sans-serif; -} diff --git a/src/css/main.css b/src/css/main.css index d01e47a..226eba0 100644 --- a/src/css/main.css +++ b/src/css/main.css @@ -143,20 +143,6 @@ body[data-website-text-editor="true"] .websites-textfield } -/*--------------------------------------------------------------- -4.0 FOLDER ----------------------------------------------------------------*/ - -.satus-main .satus-folder svg -{ - width: 20px; - height: 20px; - margin: 0 14px 0 0; - - stroke: none; -} - - /*--------------------------------------------------------------- 5.0 SWITCH ---------------------------------------------------------------*/ @@ -233,27 +219,6 @@ body[data-website-text-editor="true"] .websites-textfield } -/*--------------------------------------------------------------- -8.0 LANGUAGE ----------------------------------------------------------------*/ - -.satus-select[data-storage-key=language] -{ - padding-left: 50px; -} - -.satus-select[data-storage-key=language] svg -{ - position: absolute; - left: 16px; - - width: 20px; - height: 20px; - - stroke: none; -} - - /*--------------------------------------------------------------- 9.0 ABOUT ---------------------------------------------------------------*/ diff --git a/src/js/header.js b/src/js/header.js index 856ee0a..eca3e26 100644 --- a/src/js/header.js +++ b/src/js/header.js @@ -87,8 +87,8 @@ var Menu = { button_vert: { type: 'button', class: 'satus-dialog--vertical-menu-button', - icon: '', - onClickRender: { + before: '', + onclick: { type: 'dialog', class: 'satus-dialog--vertical-menu',