├── LICENCE ├── readme.md └── source └── 2.2.0 ├── dynamicColorPage-2.2.0.min.js └── dynamicColorPage-2.2.0.js /LICENCE: -------------------------------------------------------------------------------- 1 | First of all the code uses 2 | http://stackoverflow.com/a/13542669 3 | to generate the color shades. 4 | 5 | DynamicColorPage is published under "Attribution-NonCommercial-ShareAlike 4.0 International (CC BY-NC-SA 4.0)". 6 | See https://creativecommons.org/licenses/by-nc-sa/4.0/ for detailed information. 7 | 8 | If you want to use this plugin for commercial projects, please contact me per Mail under "robinul [at] gmail . com". A tiny 9 | donation will be enough :) 10 | 11 | Please feel free to contact me, for other annotations, too :) 12 | -------------------------------------------------------------------------------- /readme.md: -------------------------------------------------------------------------------- 1 | # dynamicColorPage v2.2.0 2 | dynamicColorPage was previously a tiny jQuery plugin to easily adopt the page's color styling. 3 | Due to a rewrite, it is now a pure javascript "plugin" with some awesome new features! 4 | 5 | ## Demo: 6 | Please visit 7 | https://drohnen-videograf.de/dynamicColorPage/ 8 | to view an example page. The important button is the small blue one in the right bottom corner of the website. 9 | 10 | ## What is it for? 11 | dynamicColorPage was made to give the visitors of a website the possibility to choose their favourite style colors. 12 | All you have to do, is to add the class "dcl" (for dynamic text color), "dclHover" (for dynamic text color on hovering the element) or "dbg" (for dynamic background-color) to all elements, that should apply the given color scheme. 13 | 14 | The extended functionality applies some additional classes, in combination with an appended number 15 | (-100, -90, -80, -70, -60, -50, -40, -30, -20, -10, 0, 10, 20, 30, 40, 50, 60, 70, 80, 90, 100) at the end of the class (e.g. "dbg-70"). 16 | These colors are darked or lighted color versions of the basic color for the selected color. 17 | 18 | ## Changelog 19 | 20 | ### What's new in v2.2? 21 | Function and variable names prefixed with dynamicColorPage_ to avoid collisions with existing functions. The release now includes a minified version again. Added config variable to change when cookie will expire. 22 | ### What's new in v2.1? 23 | Now the script doesn't crash the browser when the already active color is clicked again. 24 | 25 | ### What's new in v2.0? 26 | Now the selected color is automatically stored in a cookie on the webpage, so a reload, or navigating to another page on the same server won't reset the selected color! 27 | 28 | ## Dependences: 29 | The script is written without the usage of any dependences! There is no jQuery or anything else needed for all releases since dynamicColorPage@2.0.0. 30 | 31 | ## Installation: 32 | The script only has to be included anywhere in the page. Then it automatically adds all the necessary DOM elements and stylesheets, 33 | that are automatically generated out of the given "colors" object. 34 | 35 | ## Options / Customization: 36 | The script was made to be easy to use. As a result, you can only customize four options. 37 | 38 | ### JS - "dynamicColorPage_colors" - Data type: object 39 | This object defines the choosable colors. These colors are automatically applied to the page and will get listed in the color- 40 | changer are by default. The "default" property (don't remove it!) sets the standard style, when the page is loaded. 41 | ### JS - "dynamicColorPage_useCookiesFeature" - Data type: Boolean 42 | With this variable you can define, whether the script should store the currently selected color in a cookie and automatically re-use this stored color, when the page is reloaded or the user navigates to another page with this script included. 43 | ### JS - "dynamicColorPage_cookieExpiresAfterDays" - Data type: int 44 | With this variable you can define, after how many days the cookie will expire and the user has to do the color selection again. 45 | ### JS - "dynamicColorPage_colorTilesPerRow" - Data type: int 46 | This variable defines, how many color tiles should be in one row of the color-changer element. 47 | ### JS - "dynamicColorPage_activeColor" - Data type: String 48 | With this variable you can define another standard color class, the script should look for, if the color is changed. 49 | For exaple if this variable is "grey", then you have to add "dclgrey" or "dbggrey" as classes to your elements to active the script 50 | and the color-change-functionality for these elements. For default the value is "", so you can just use "dcl" and "dbg" as classes. 51 | 52 | 53 | ### CSS - Styling 54 | The only possibility to directly change the css code of the color-changer, is, to adapt the css code that is written at the end of the javascript code and that is stored in the variable "css_string". 55 | 56 | ## How it works: 57 | When the user picks a new color, the script just replaces the previous "dcl", "dclHover" or "dbg" class of all elements and replaces this with the new color name. 58 | For example (colorChangerOldColor="", new_color="red"): 59 | "dcl" gets replaced with "dclred", 60 | "dclHover-50" gets replaced with "dclHoverred-50", 61 | ... 62 | 63 | ## Questions, suggestions, problems, etc.? 64 | Please create a new issue on Github :) 65 | -------------------------------------------------------------------------------- /source/2.2.0/dynamicColorPage-2.2.0.min.js: -------------------------------------------------------------------------------- 1 | /* Please visit https://github.com/ulrichrobin/dynamicColorPage/ for detailed documentation and license information */ 2 | /* Live demo available at https://drohnen-videograf.de/dynamicColorPage/ */ 3 | /* dynamicColorPage@2.2.0 */ 4 | 5 | var dynamicColorPage_colors = { 6 | standard: '#f34e36', 7 | red: '#f34e36', 8 | green: '#b5d947', 9 | purple: '#9d6fc8', 10 | blue: '#4abcdd', 11 | turquoise: '#1abc9c', 12 | pink: '#c61c72', 13 | orange: '#f4a622', 14 | emerald: '#2ecc71' 15 | }; 16 | var dynamicColorPage_useCookiesFeature = true; // Default value: true 17 | var dynamicColorPage_cookieExpiresAfterDays = 365; // Default value: 365 18 | var dynamicColorPage_colorTilesPerRow = 2; // Default value: 2 19 | var dynamicColorPage_activeColor = ''; // Default value: '' 20 | 21 | /* Don't change any code below! */ 22 | /* Don't change any code below! */ 23 | /* Don't change any code below! */ 24 | 25 | function dynamicColorPage_pageLoad(){var e=document.createElement("div");e.className="color_changer",document.body.appendChild(e);var o=document.createElement("button");o.className="color_changer-toggle",document.body.appendChild(o),document.body.addEventListener("click",function(e){dynamicColorPage_hasClass(document.getElementsByClassName("color_changer")[0],"expanded")&&!dynamicColorPage_hasClass(e.target,"color_changer-toggle")&&dynamicColorPage_removeClass(document.getElementsByClassName("color_changer")[0],"expanded")}),document.getElementsByClassName("color_changer-toggle")[0].addEventListener("click",function(e){(dynamicColorPage_hasClass(document.getElementsByClassName("color_changer")[0],"expanded")?dynamicColorPage_removeClass:dynamicColorPage_addClass)(document.getElementsByClassName("color_changer")[0],"expanded")});var a='
',r=0;for(var l in dynamicColorPage_colors)if(dynamicColorPage_colors.hasOwnProperty(l)){var n=dynamicColorPage_colors[l];"standard"==l?l="":r
'):(a=a+'
',a+='
',r=0);for(var c=!1,t=-100;t<101;t+=10)c||(css_string=(css_string=(css_string=css_string+".dcl"+l+"{color:"+n+"}")+".dclHover"+l+":hover{color:"+n+"}")+".dbg"+l+"{background-color:"+n+"}",c=!0),css_string=(css_string=(css_string=css_string+".dcl"+l+t+"{color:"+colorLuminance(n,t/100)+"}")+".dclHover"+l+t+":hover{color:"+colorLuminance(n,t/100)+"}")+".dbg"+l+t+"{background-color:"+colorLuminance(n,t/100)+"}"}a+="
",document.getElementsByClassName("color_changer")[0].innerHTML=a;for(var s=0;s'; 65 | } 66 | else { 67 | domElementContent = domElementContent + '
'; 68 | domElementContent = domElementContent + '
'; 69 | color_tiles_counter = 0; 70 | } 71 | } 72 | var plainKeyStyling_printed = false; 73 | for(var h = -100; h < 101; h += 10) { 74 | if(!plainKeyStyling_printed) { 75 | css_string = css_string + '.dcl' + key + '{color:' + property_value + '}'; 76 | css_string = css_string + '.dclHover' + key + ':hover{color:' + property_value + '}'; 77 | css_string = css_string + '.dbg' + key + '{background-color:' + property_value + '}'; 78 | plainKeyStyling_printed = true; 79 | } 80 | css_string = css_string + '.dcl' + key + h + '{color:' + colorLuminance(property_value, (h / 100)) + '}'; 81 | css_string = css_string + '.dclHover' + key + h + ':hover{color:' + colorLuminance(property_value, (h / 100)) + '}'; 82 | css_string = css_string + '.dbg' + key + h + '{background-color:' + colorLuminance(property_value, (h / 100)) + '}'; 83 | } 84 | } 85 | } 86 | domElementContent = domElementContent + '
'; 87 | document.getElementsByClassName('color_changer')[0].innerHTML = domElementContent; 88 | 89 | var this_element; 90 | 91 | // Events for clicking one of the color tiles 92 | for(var i = 0; i < document.getElementsByClassName('color_tile').length; i++) { 93 | document.getElementsByClassName('color_tile')[i].addEventListener('click', function(e) { 94 | dynamicColorChange_changeColor(e.target.getAttribute('data-color')); 95 | }); 96 | } 97 | 98 | // Include generated css string into document 99 | var cssStringStyle = document.createElement('style'); 100 | cssStringStyle.type = 'text/css'; 101 | cssStringStyleInner = document.createTextNode(css_string); 102 | cssStringStyle.appendChild(cssStringStyleInner); 103 | document.head.appendChild(cssStringStyle); 104 | 105 | // Auto get/set cookies to use the last selected color in the page automatically again 106 | if(dynamicColorPage_useCookiesFeature && dynamicColorPage_getCookie('dynamicColorPage_activeColor') != '') { 107 | if(dynamicColorPage_colors.hasOwnProperty(dynamicColorPage_getCookie('dynamicColorPage_activeColor'))) dynamicColorChange_changeColor(dynamicColorPage_getCookie('dynamicColorPage_activeColor')); 108 | } 109 | } 110 | function dynamicColorChange_changeColor(dynamicColorPage_newColor) { 111 | if(dynamicColorPage_activeColor == dynamicColorPage_newColor) return; 112 | // Change old dcl class to new one 113 | while(document.getElementsByClassName('dcl' + dynamicColorPage_activeColor).length != 0) { 114 | this_element = document.getElementsByClassName('dcl' + dynamicColorPage_activeColor)[0]; 115 | dynamicColorPage_removeClass(this_element, 'dcl' + dynamicColorPage_activeColor); 116 | dynamicColorPage_addClass(this_element, 'dcl' + dynamicColorPage_newColor); 117 | } 118 | // Change old dclHover class to new one 119 | while(document.getElementsByClassName('dclHover' + dynamicColorPage_activeColor).length != 0) { 120 | this_element = document.getElementsByClassName('dclHover' + dynamicColorPage_activeColor)[0]; 121 | dynamicColorPage_removeClass(this_element, 'dclHover' + dynamicColorPage_activeColor); 122 | dynamicColorPage_addClass(this_element, 'dclHover' + dynamicColorPage_newColor); 123 | } 124 | // Change old dbg class to new one 125 | while(document.getElementsByClassName('dbg' + dynamicColorPage_activeColor).length != 0) { 126 | this_element = document.getElementsByClassName('dbg' + dynamicColorPage_activeColor)[0]; 127 | dynamicColorPage_removeClass(this_element, 'dbg' + dynamicColorPage_activeColor); 128 | dynamicColorPage_addClass(this_element, 'dbg' + dynamicColorPage_newColor); 129 | } 130 | // Change old luminanceStep-classes to new ones 131 | for(var j = -100; j < 101; j += 10) { 132 | // Change old luminanceStep-dcl class to new one 133 | while(document.getElementsByClassName('dcl' + dynamicColorPage_activeColor + j).length != 0) { 134 | this_element = document.getElementsByClassName('dcl' + dynamicColorPage_activeColor + j)[0]; 135 | dynamicColorPage_removeClass(this_element, 'dcl' + dynamicColorPage_activeColor + j); 136 | dynamicColorPage_addClass(this_element, 'dcl' + dynamicColorPage_newColor + j); 137 | } 138 | // Change old luminanceStep-dclHover class to new one 139 | while(document.getElementsByClassName('dclHover' + dynamicColorPage_activeColor + j).length != 0) { 140 | this_element = document.getElementsByClassName('dclHover' + dynamicColorPage_activeColor + j)[0]; 141 | dynamicColorPage_removeClass(this_element, 'dclHover' + dynamicColorPage_activeColor + j); 142 | dynamicColorPage_addClass(this_element, 'dclHover' + dynamicColorPage_newColor + j); 143 | } 144 | // Change old luminanceStep-dbg class to new one 145 | while(document.getElementsByClassName('dbg' + dynamicColorPage_activeColor + j).length != 0) { 146 | this_element = document.getElementsByClassName('dbg' + dynamicColorPage_activeColor + j)[0]; 147 | dynamicColorPage_removeClass(this_element, 'dbg' + dynamicColorPage_activeColor + j); 148 | dynamicColorPage_addClass(this_element, 'dbg' + dynamicColorPage_newColor + j); 149 | } 150 | } 151 | dynamicColorPage_activeColor = dynamicColorPage_newColor; 152 | if(dynamicColorPage_useCookiesFeature) dynamicColorPage_setCookie('dynamicColorPage_activeColor', dynamicColorPage_newColor); 153 | } 154 | 155 | 156 | /* Helper functions */ 157 | function dynamicColorPage_removeClass(element, classToRemove) { 158 | var reg = new RegExp('(\\s|^)' + classToRemove + '(\\s|$)'); 159 | element.className = (element.className.replace(reg, ' ')).trim(); 160 | } 161 | function dynamicColorPage_addClass(element, classToAdd) { 162 | element.className = (element.className + " " + classToAdd).trim(); 163 | } 164 | function dynamicColorPage_hasClass(element, classToCheckFor) { 165 | return (element.className.indexOf(classToCheckFor) >= 0); 166 | } 167 | function colorLuminance(color_hex, factor) { 168 | color_hex = String(color_hex).replace(/[^0-9a-f]/gi, ''); 169 | if(color_hex.length < 6) color_hex = color_hex[0] + color_hex[0] + color_hex[1] + color_hex[1] + color_hex[2] + color_hex[2]; 170 | factor = factor || 0; 171 | var rgb='#', c, i; 172 | for(var i = 0; i < 3; i++) { 173 | c = parseInt(color_hex.substr(i * 2, 2), 16); 174 | c = Math.round(Math.min(Math.max(0, c + (c * factor)), 255)).toString(16); 175 | rgb += ('00' + c).substr(c.length); 176 | } 177 | return rgb; 178 | } 179 | function dynamicColorPage_setCookie(cookieName, cookieValue) { 180 | var date = new Date(); 181 | date.setTime(date.getTime() + (dynamicColorPage_cookieExpiresAfterDays*1000*60*60*24)); 182 | document.cookie = cookieName + '=' + cookieValue + '; expires=' + date.toUTCString(); 183 | } 184 | function dynamicColorPage_getCookie(cookieName) { 185 | cookieName = cookieName + '='; 186 | var cookiesArray = document.cookie.split(';'); 187 | for(var i = 0; i < cookiesArray.length; i++) { 188 | var currentIndex = cookiesArray[i]; 189 | while(currentIndex.charAt(0) == ' ') currentIndex = currentIndex.substring(1); 190 | if(currentIndex.indexOf(cookieName) == 0) return currentIndex.substring(cookieName.length, currentIndex.length); 191 | } 192 | return ''; 193 | } 194 | 195 | /* Write css strings here, to have a better order in the code */ 196 | var css_string = '.color_changer-toggle{border:0px solid transparent;background-color:transparent;position:fixed;right:10px;bottom:10px;z-index:10000;width:38px;height:38px;background-repeat:no-repeat;background-size:contain;}.color_changer{position:fixed;right:10px;bottom:55px;z-index:10000;max-height:0vh;overflow:hidden;transition:all 1s ease-out, background-color linear 1ms 1s;border:1px solid transparent;padding:5px;margin-bottom:0px;border-radius:4px;}.color_changer.expanded{transition:all 1s ease-in, background-color linear 1ms;max-height:100vh;border:1px solid gray;background-color:white;}.color_changer_row .color_tile{width:25px;height:25px;border-radius:4px;float:left;margin:5px;cursor:pointer}'; 197 | css_string = css_string + '.color_changer-toggle{background-image:url("");}'; 198 | --------------------------------------------------------------------------------