From 3f97a4c798c8b830aa70e6839f7526a2ce5cf6b9 Mon Sep 17 00:00:00 2001 From: Phil Buchanan Date: Sat, 23 Feb 2013 12:51:23 -0500 Subject: [PATCH] Code cleanup and optimizations - preview will now only display when there is valid input - fixed issue where saved colors title was displayed when no colors had been saved - added color value check function --- css/style.less | 2 +- index.html | 6 +-- js/script.js | 123 +++++++++++++++++++++++++++++++++++-------------- 3 files changed, 93 insertions(+), 38 deletions(-) diff --git a/css/style.less b/css/style.less index 7d057d6..84b3419 100644 --- a/css/style.less +++ b/css/style.less @@ -135,7 +135,7 @@ input { text-shadow: 0px 1px 1px white; margin: 10px 0 0; } -#preview, .recent-preview { +.preview, .recent-preview { position: absolute; right: 34px; top: 38px; diff --git a/index.html b/index.html index 87615b3..168df1e 100644 --- a/index.html +++ b/index.html @@ -13,10 +13,10 @@

RGBtone

Convert hex to rgb and vise versa

-
+
-

PreviewSave

+

PreviewSave

#fff

@@ -38,7 +38,7 @@

Convert hex to rgb and vise versa

-

Your saved colours

+

Your saved colours

diff --git a/js/script.js b/js/script.js index e5e6a70..6325667 100644 --- a/js/script.js +++ b/js/script.js @@ -16,6 +16,7 @@ var preview = document.getElementById('preview'); var pcolor = document.getElementById('previewcolor'); var ptitle = document.getElementById('previewtitle'); var saveBtn = document.getElementById('save'); +var savedTitle = document.getElementById('savedtitle'); var savedColors = document.getElementById('savedcolors'); var maxSave = 6; @@ -31,7 +32,7 @@ window.onload = init(); * Initialization * * Creates event listeners and displays recent - * saved colors + * saved colors. */ function init() { @@ -56,30 +57,48 @@ function init() { * * Gets the RGB string for a given HEX value and * prints it to the RGB input. - * - * @param value the hex value to convert */ function getRgbValue() { var value = hexInput.value; - if (value.length === 3) var fullvalue = value.substr(0, 1) + value.substr(0, 1) + value.substr(1, 1) + value.substr(1, 1) + value.substr(2, 1) + value.substr(2, 1); - else var fullvalue = value; + if (value.length === 3) { + var r = value.substr(0, 1); + var g = value.substr(1, 1); + var b = value.substr(2, 1); + var hexValue = r + r + g + g + b + b; + } + else if (value.length === 6) { + var hexValue = value; + } - if (hexToRgb(fullvalue)) { + if (hexValue) { - var rgbValues = hexToRgb(fullvalue); - rgbInput.value = rgbValues['r'] + ', ' + rgbValues['g'] + ', ' + rgbValues['b']; - pcolor.style.background = '#' + fullvalue; - ptitle.innerHTML = '#' + value; - preview.className = ''; - saveBtn.className = ''; + var rgbValues = hexToRgb(hexValue); + if (rgbValues) { + rgbInput.value = rgbValues['r'] + ', ' + rgbValues['g'] + ', ' + rgbValues['b']; + pcolor.style.background = '#' + hexValue; + ptitle.innerHTML = '#' + value; + preview.classList.remove('hide'); + } } + else { + preview.classList.add('hide'); + } } + + +/** + * HEX to RGB Converter + * + * @param hex the HEX code to convert + * return array of RGB values + */ + function hexToRgb(hex) { var result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex); @@ -98,43 +117,67 @@ function hexToRgb(hex) { * * Gets the HEX value for a given RGB string and * prints it to the HEX input. - * - * @param value the rgb value string to convert */ function getHexValue() { var value = rgbInput.value; - value.replace(/\s+/g, ' '); - var rgbArray = value.split(","); - - if (rgbArray[0] > 255) rgbArray[0] = 255; - if (rgbArray[1] > 255) rgbArray[1] = 255; - if (rgbArray[2] > 255) rgbArray[2] = 255; + value.replace(' ', ''); + var rgb = value.split(",", 3); - if (rgbArray[0] < 0) rgbArray[0] = 0; - if (rgbArray[1] < 0) rgbArray[1] = 0; - if (rgbArray[2] < 0) rgbArray[2] = 0; + var r = checkColorValue(rgb[0]); + var g = checkColorValue(rgb[1]); + var b = checkColorValue(rgb[2]); - if (rgbToHex(parseInt(rgbArray[0]), parseInt(rgbArray[1]), parseInt(rgbArray[2]))) { + if (r !== false && g !== false && b !== false) { - var hexValue = rgbToHex(parseInt(rgbArray[0]), parseInt(rgbArray[1]), parseInt(rgbArray[2])); + var hexValue = rgbToHex(r, g, b); hexInput.value = hexValue; pcolor.style.background = '#' + hexValue; ptitle.innerHTML = '#' + hexValue; - preview.className = ''; - saveBtn.className = ''; + preview.classList.remove('hide'); + + } + else { + + preview.classList.add('hide'); } } -function rgbToHex(r, g, b) { - if (isNaN(r)) r = 255; - if (isNaN(g)) g = 255; - if (isNaN(b)) b = 255; + +/** + * Check Color Value + * + * @param n the number to check + * return returns the fixed number, or false if NaN + */ + +function checkColorValue(n) { + + n = parseInt(Math.round(n), 10); + if (isNaN(n)) return false; + else if (n > 255) return 255; + else if (n < 0) return 0; + else return n; + +} + + + +/** + * RGB to HEX Converter + * + * @param r the red value + * @param g the green value + * @param b the blue value + * return the HEX string + */ + +function rgbToHex(r, g, b) { var hr = componentToHex(r); var hg = componentToHex(g); @@ -143,9 +186,9 @@ function rgbToHex(r, g, b) { if (hr.substr(0, 1) == hr.substr(1, 1)) { if (hg.substr(0, 1) == hg.substr(1, 1)) { if (hb.substr(0, 1) == hb.substr(1, 1)) { - var hr = componentToHex(r).substr(0, 1); - var hg = componentToHex(g).substr(0, 1); - var hb = componentToHex(b).substr(0, 1); + hr = componentToHex(r).substr(0, 1); + hg = componentToHex(g).substr(0, 1); + hb = componentToHex(b).substr(0, 1); } } } @@ -153,6 +196,17 @@ function rgbToHex(r, g, b) { return hr + hg + hb; } + + + +/** + * Color Value to HEX + * + * Converts an color value to its HEX version. + * + * @param c the color value to convert + * return the hex value + */ function componentToHex(c) { @@ -234,6 +288,7 @@ function displayRecents() { } + if (i > 0) savedTitle.classList.remove('hide'); savedColors.innerHTML = string; }