From 5caec5573b551349f8844be18e7530aa49de0ad0 Mon Sep 17 00:00:00 2001 From: Thomas Grainger Date: Wed, 30 Nov 2016 10:57:53 +0000 Subject: [PATCH] use bootstrap-colorpicker css from yarn --- package.json | 1 + src/css/index.js | 2 +- src/css/lib/bootstrap-colorpicker.css | 222 -------------------------- src/js/index.js | 1 + src/js/operations/HTML.js | 18 +-- src/js/views/html/OutputWaiter.js | 24 ++- webpack-babel.js | 1 + yarn.lock | 8 +- 8 files changed, 37 insertions(+), 240 deletions(-) delete mode 100755 src/css/lib/bootstrap-colorpicker.css diff --git a/package.json b/package.json index e2bdb5d4..4047ba55 100755 --- a/package.json +++ b/package.json @@ -72,6 +72,7 @@ }, "dependencies": { "bootstrap": "^3.3.7", + "bootstrap-colorpicker": "^2.3.6", "bootstrap-switch": "^3.3.2", "core-js": "^2.4.1", "crypto-js": "^3.1.8", diff --git a/src/css/index.js b/src/css/index.js index 4e38b9a7..85e9c2a9 100644 --- a/src/css/index.js +++ b/src/css/index.js @@ -1,4 +1,4 @@ -import './lib/bootstrap-colorpicker.css'; +import 'bootstrap-colorpicker/dist/css/bootstrap-colorpicker.css'; import 'google-code-prettify/src/prettify.css'; import 'bootstrap/less/bootstrap.less'; import 'bootstrap-switch/src/less/bootstrap3/build.less'; diff --git a/src/css/lib/bootstrap-colorpicker.css b/src/css/lib/bootstrap-colorpicker.css deleted file mode 100755 index 91b02e8a..00000000 --- a/src/css/lib/bootstrap-colorpicker.css +++ /dev/null @@ -1,222 +0,0 @@ -/** @license -======================================================================== - Bootstrap Colorpicker v2.3.6 - https://itsjavi.com/bootstrap-colorpicker/ - - Originally written by (c) 2012 Stefan Petre - Licensed under the Apache License v2.0 - http://www.apache.org/licenses/LICENSE-2.0.txt -*/ - -.colorpicker-saturation { - width: 100px; - height: 100px; - background-image: url(''); - cursor: crosshair; - float: left; -} -.colorpicker-saturation i { - display: block; - height: 5px; - width: 5px; - border: 1px solid #000; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - position: absolute; - top: 0; - left: 0; - margin: -4px 0 0 -4px; -} -.colorpicker-saturation i b { - display: block; - height: 5px; - width: 5px; - border: 1px solid #fff; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; -} -.colorpicker-hue, -.colorpicker-alpha { - width: 15px; - height: 100px; - float: left; - cursor: row-resize; - margin-left: 4px; - margin-bottom: 4px; -} -.colorpicker-hue i, -.colorpicker-alpha i { - display: block; - height: 1px; - background: #000; - border-top: 1px solid #fff; - position: absolute; - top: 0; - left: 0; - width: 100%; - margin-top: -1px; -} -.colorpicker-hue { - background-image: url(''); -} -.colorpicker-alpha { - background-image: url(''); - display: none; -} -.colorpicker-saturation, -.colorpicker-hue, -.colorpicker-alpha { - background-size: contain; -} -.colorpicker { - padding: 4px; - min-width: 130px; - margin-top: 1px; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - z-index: 2500; -} -.colorpicker:before, -.colorpicker:after { - display: table; - content: ""; - line-height: 0; -} -.colorpicker:after { - clear: both; -} -.colorpicker:before { - content: ''; - display: inline-block; - border-left: 7px solid transparent; - border-right: 7px solid transparent; - border-bottom: 7px solid #ccc; - border-bottom-color: rgba(0, 0, 0, 0.2); - position: absolute; - top: -7px; - left: 6px; -} -.colorpicker:after { - content: ''; - display: inline-block; - border-left: 6px solid transparent; - border-right: 6px solid transparent; - border-bottom: 6px solid #ffffff; - position: absolute; - top: -6px; - left: 7px; -} -.colorpicker div { - position: relative; -} -.colorpicker.colorpicker-with-alpha { - min-width: 140px; -} -.colorpicker.colorpicker-with-alpha .colorpicker-alpha { - display: block; -} -.colorpicker-color { - height: 10px; - margin-top: 5px; - clear: both; - background-image: url(''); - background-position: 0 100%; -} -.colorpicker-color div { - height: 10px; -} -.colorpicker-selectors { - display: none; - height: 10px; - margin-top: 5px; - clear: both; -} -.colorpicker-selectors i { - cursor: pointer; - float: left; - height: 10px; - width: 10px; -} -.colorpicker-selectors i + i { - margin-left: 3px; -} -.colorpicker-element .input-group-addon i, -.colorpicker-element .add-on i { - display: inline-block; - cursor: pointer; - height: 16px; - vertical-align: text-top; - width: 16px; -} -.colorpicker.colorpicker-inline { - position: relative; - display: inline-block; - float: none; - z-index: auto; -} -.colorpicker.colorpicker-horizontal { - width: 110px; - min-width: 110px; - height: auto; -} -.colorpicker.colorpicker-horizontal .colorpicker-saturation { - margin-bottom: 4px; -} -.colorpicker.colorpicker-horizontal .colorpicker-color { - width: 100px; -} -.colorpicker.colorpicker-horizontal .colorpicker-hue, -.colorpicker.colorpicker-horizontal .colorpicker-alpha { - width: 100px; - height: 15px; - float: left; - cursor: col-resize; - margin-left: 0px; - margin-bottom: 4px; -} -.colorpicker.colorpicker-horizontal .colorpicker-hue i, -.colorpicker.colorpicker-horizontal .colorpicker-alpha i { - display: block; - height: 15px; - background: #ffffff; - position: absolute; - top: 0; - left: 0; - width: 1px; - border: none; - margin-top: 0px; -} -.colorpicker.colorpicker-horizontal .colorpicker-hue { - background-image: url(''); -} -.colorpicker.colorpicker-horizontal .colorpicker-alpha { - background-image: url(''); -} -.colorpicker.colorpicker-hidden { - display: none; -} -.colorpicker.colorpicker-visible { - display: block; -} -.colorpicker-inline.colorpicker-visible { - display: inline-block; -} -.colorpicker-right:before { - left: auto; - right: 6px; -} -.colorpicker-right:after { - left: auto; - right: 7px; -} -.colorpicker-no-arrow:before { - border-right: 0; - border-left: 0; -} -.colorpicker-no-arrow:after { - border-right: 0; - border-left: 0; -} diff --git a/src/js/index.js b/src/js/index.js index a1758ce6..07bcf641 100644 --- a/src/js/index.js +++ b/src/js/index.js @@ -5,4 +5,5 @@ import 'bootstrap/js/collapse'; import 'bootstrap/js/modal'; import 'bootstrap/js/tooltip'; import 'bootstrap/js/popover'; +import 'bootstrap-colorpicker'; import './views/html/main.js'; diff --git a/src/js/operations/HTML.js b/src/js/operations/HTML.js index 25389b10..2a543161 100755 --- a/src/js/operations/HTML.js +++ b/src/js/operations/HTML.js @@ -226,26 +226,14 @@ const HTML = { cmyk = `cmyk(${c}, ${m}, ${y}, ${k})`; // Generate output - return `${"
" + + return `${"
" + 'Hex: '}${hex}\n` + `RGB: ${rgb}\n` + `RGBA: ${rgba}\n` + `HSL: ${hsl}\n` + `HSLA: ${hsla}\n` + `CMYK: ${cmyk - }`; + }`; }, @@ -858,3 +846,5 @@ const HTML = { }, }; + +export default HTML; diff --git a/src/js/views/html/OutputWaiter.js b/src/js/views/html/OutputWaiter.js index 73ba94d2..b8ccac02 100755 --- a/src/js/views/html/OutputWaiter.js +++ b/src/js/views/html/OutputWaiter.js @@ -1,5 +1,22 @@ +import $ from 'jquery'; import Utils from '../../core/Utils'; +const inlineFuncs = { + colorpicker({ rgba }) { + $('#colorpicker').colorpicker({ + format: 'rgba', + color: rgba, + container: true, + inline: true, + }).on('changeColor', function(e) { + const { r, g, b, a} = e.color.toRGB(); + const css = `rgba(${r}, ${g}, ${b}, ${a})`; + document.getElementById('input-text').value = css; + window.app.auto_bake(); + }); + } +} + /** * Waiter to handle events related to the output. * @@ -50,10 +67,13 @@ OutputWaiter.prototype.set = function (data_str, type, duration) { output_html.innerHTML = data_str; // Execute script sections - const script_elements = output_html.querySelectorAll('script'); + const script_elements = output_html.querySelectorAll('[data-cyber-chef-func]'); for (let i = 0; i < script_elements.length; i++) { + const el = script_elements[i]; + const data = el.dataset; + const func = inlineFuncs[data.cyberChefFunc]; try { - eval(script_elements[i].innerHTML); // jshint ignore:line + func(data); } catch (err) { console.error(err); } diff --git a/webpack-babel.js b/webpack-babel.js index a8ab553e..538eaaaf 100644 --- a/webpack-babel.js +++ b/webpack-babel.js @@ -34,6 +34,7 @@ function css(target) { return extractCSS.extract({ fallbackLoader: 'style-loader', loader: `${cssOptions}${loader}`, + publicPath: '../', }); } diff --git a/yarn.lock b/yarn.lock index ef328169..bdc9cfe0 100644 --- a/yarn.lock +++ b/yarn.lock @@ -747,6 +747,12 @@ boom@2.x.x: dependencies: hoek "2.x.x" +bootstrap-colorpicker@^2.3.6: + version "2.3.6" + resolved "https://registry.yarnpkg.com/bootstrap-colorpicker/-/bootstrap-colorpicker-2.3.6.tgz#816095c35dd7919dcb4de3f0c807f13b121e8f17" + dependencies: + jquery ">=1.10" + bootstrap-switch@^3.3.2: version "3.3.2" resolved "https://registry.yarnpkg.com/bootstrap-switch/-/bootstrap-switch-3.3.2.tgz#79ddb49fadc308fb731e257f95957af48996eea7" @@ -2893,7 +2899,7 @@ jodid25519@^1.0.0: dependencies: jsbn "~0.1.0" -jquery@>=1.9.0, jquery@^3.1.1: +jquery@>=1.10, jquery@>=1.9.0, jquery@^3.1.1: version "3.1.1" resolved "https://registry.yarnpkg.com/jquery/-/jquery-3.1.1.tgz#347c1c21c7e004115e0a4da32cece041fad3c8a3"