add original colorpicker plugin
This commit is contained in:
		
							parent
							
								
									10ce4eeefa
								
							
						
					
					
						commit
						c50b251ae4
					
				
							
								
								
									
										21
									
								
								vendor-overwrites/colorpicker/LICENSE
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										21
									
								
								vendor-overwrites/colorpicker/LICENSE
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,21 @@ | ||||||
|  | MIT License | ||||||
|  | 
 | ||||||
|  | Copyright (c) 2017 jinho park (cyberuls@gmail.com, easylogic) | ||||||
|  | 
 | ||||||
|  | Permission is hereby granted, free of charge, to any person obtaining a copy | ||||||
|  | of this software and associated documentation files (the "Software"), to deal | ||||||
|  | in the Software without restriction, including without limitation the rights | ||||||
|  | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell | ||||||
|  | copies of the Software, and to permit persons to whom the Software is | ||||||
|  | furnished to do so, subject to the following conditions: | ||||||
|  | 
 | ||||||
|  | The above copyright notice and this permission notice shall be included in all | ||||||
|  | copies or substantial portions of the Software. | ||||||
|  | 
 | ||||||
|  | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR | ||||||
|  | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, | ||||||
|  | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE | ||||||
|  | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER | ||||||
|  | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, | ||||||
|  | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE | ||||||
|  | SOFTWARE. | ||||||
							
								
								
									
										310
									
								
								vendor-overwrites/colorpicker/colorpicker.css
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										310
									
								
								vendor-overwrites/colorpicker/colorpicker.css
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,310 @@ | ||||||
|  | 
 | ||||||
|  | /* codemirror colorview */ | ||||||
|  | 
 | ||||||
|  | .codemirror-colorview { | ||||||
|  | 	border : 1px solid #8e8e8e; | ||||||
|  |     position: relative; | ||||||
|  | 	display : inline-block; | ||||||
|  | 	box-sizing : border-box; | ||||||
|  | 	margin : 0px 2px; | ||||||
|  | 	width : 10px; | ||||||
|  | 	height : 10px; | ||||||
|  | 	cursor: pointer; | ||||||
|  |     background-image : url(""); | ||||||
|  |     background-repeat: repeat; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorview .codemirror-colorview-background { | ||||||
|  |   content: ""; | ||||||
|  |   position: absolute; | ||||||
|  |   left:0px; | ||||||
|  |   right:0px; | ||||||
|  |   bottom:0px; | ||||||
|  |   top:0px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorview:hover { | ||||||
|  | 	border-color: #494949; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | /* codemirror-colorpicker */ | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker { | ||||||
|  |   position: relative; | ||||||
|  |   width: 226px; | ||||||
|  |   z-index: 1000; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .color { | ||||||
|  |   position: relative; | ||||||
|  |   height: 120px; | ||||||
|  |   overflow: hidden; | ||||||
|  |   cursor: pointer; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .color > .saturation { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .color > .saturation > .value { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 100%; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .color > .saturation > .value > .drag-pointer { | ||||||
|  |   position: absolute; | ||||||
|  |   width: 10px; | ||||||
|  |   height: 10px; | ||||||
|  |   -webkit-border-radius: 50%; | ||||||
|  |   -moz-border-radius: 50%; | ||||||
|  |   border-radius: 50%; | ||||||
|  |   left: -5px; | ||||||
|  |   top: -5px; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control { | ||||||
|  |   position: relative; | ||||||
|  |   padding: 18px 0px 14px 0px; | ||||||
|  |   -webkit-user-select: none; | ||||||
|  |   -moz-user-select: none; | ||||||
|  |   -ms-user-select: none; | ||||||
|  |   -o-user-select: none; | ||||||
|  |   user-select: none; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .color, | ||||||
|  | .codemirror-colorpicker > .control > .empty { | ||||||
|  |   position: absolute; | ||||||
|  |   left: 11px; | ||||||
|  |   top: 24px; | ||||||
|  |   width: 30px; | ||||||
|  |   height: 30px; | ||||||
|  |   -webkit-border-radius: 50%; | ||||||
|  |   -moz-border-radius: 50%; | ||||||
|  |   border-radius: 50%; | ||||||
|  |   -webkit-box-sizing: border-box; | ||||||
|  |   -moz-box-sizing: border-box; | ||||||
|  |   box-sizing: border-box; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .hue { | ||||||
|  |   position: relative; | ||||||
|  |   padding: 6px 12px; | ||||||
|  |   margin: 0px 0px 0px 45px; | ||||||
|  |   -webkit-box-sizing: border-box; | ||||||
|  |   -moz-box-sizing: border-box; | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   cursor: pointer; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .hue > .hue-container { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 10px; | ||||||
|  |   -webkit-border-radius: 3px; | ||||||
|  |   -moz-border-radius: 3px; | ||||||
|  |   border-radius: 3px; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .opacity { | ||||||
|  |   position: relative; | ||||||
|  |   padding: 3px 12px; | ||||||
|  |   margin: 0px 0px 0px 45px; | ||||||
|  |   -webkit-box-sizing: border-box; | ||||||
|  |   -moz-box-sizing: border-box; | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   cursor: pointer; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .opacity > .opacity-container { | ||||||
|  |   position: relative; | ||||||
|  |   width: 100%; | ||||||
|  |   height: 10px; | ||||||
|  |   z-index: 2; | ||||||
|  |   -webkit-border-radius: 3px; | ||||||
|  |   -moz-border-radius: 3px; | ||||||
|  |   border-radius: 3px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .control .drag-bar, | ||||||
|  | .codemirror-colorpicker > .control .drag-bar2 { | ||||||
|  |   position: absolute; | ||||||
|  |   cursor: pointer; | ||||||
|  |   top: 50% !important; | ||||||
|  |   margin-top: -7px !important; | ||||||
|  |   left: -3px; | ||||||
|  |   width: 12px; | ||||||
|  |   height: 12px; | ||||||
|  |   -webkit-border-radius: 50px; | ||||||
|  |   -moz-border-radius: 50px; | ||||||
|  |   border-radius: 50px; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .information { | ||||||
|  |   position: relative; | ||||||
|  |   -webkit-box-sizing: padding-box; | ||||||
|  |   -moz-box-sizing: padding-box; | ||||||
|  |   box-sizing: padding-box; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information.hex > .information-item.hex { | ||||||
|  |   display: flex; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information.rgb > .information-item.rgb { | ||||||
|  |   display: flex; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information.hsl > .information-item.hsl { | ||||||
|  |   display: flex; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information > .information-item { | ||||||
|  |   display:none; | ||||||
|  |   position: relative; | ||||||
|  |   padding: 0px 5px; | ||||||
|  |   -webkit-box-sizing: border-box; | ||||||
|  |   -moz-box-sizing: border-box; | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   margin-right:40px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information > .information-change { | ||||||
|  |   position:absolute; | ||||||
|  |   display:block; | ||||||
|  |   width:40px; | ||||||
|  |   top:0px; | ||||||
|  |   right:0px; | ||||||
|  |   bottom:0px; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information > .information-change > .format-change-button { | ||||||
|  |   width:100%; | ||||||
|  |   height:100%; | ||||||
|  |   background:transparent; | ||||||
|  |   border:0px; | ||||||
|  |   cursor:pointer; | ||||||
|  |   outline:none; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information > .information-item > .input-field { | ||||||
|  |   display:block; | ||||||
|  |   flex:1; | ||||||
|  |   padding: 5px; | ||||||
|  |   -webkit-box-sizing: border-box; | ||||||
|  |   -moz-box-sizing: border-box; | ||||||
|  |   box-sizing: border-box; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information > .information-item > .input-field > input { | ||||||
|  |   text-align: center; | ||||||
|  |   width:100%; | ||||||
|  |   padding:3px 5px; | ||||||
|  |   font-size:11px; | ||||||
|  |   color: #333; | ||||||
|  |   -webkit-box-sizing: border-box; | ||||||
|  |   -moz-box-sizing: border-box; | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   -webkit-user-select: text; | ||||||
|  |   -moz-user-select: text; | ||||||
|  |   -ms-user-select: text; | ||||||
|  |   -o-user-select: text; | ||||||
|  |   user-select: text; | ||||||
|  |   border: 1px solid #cbcbcb; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information > .information-item > .input-field > .title { | ||||||
|  |   text-align:center; | ||||||
|  |   font-size:12px; | ||||||
|  |   color:#a9a9a9; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .information > input { | ||||||
|  |   position: absolute; | ||||||
|  |   font-size: 10px; | ||||||
|  |   height: 20px; | ||||||
|  |   bottom: 20px; | ||||||
|  |   padding: 0 0 0 2px; | ||||||
|  |   -webkit-box-sizing: border-box; | ||||||
|  |   -moz-box-sizing: border-box; | ||||||
|  |   box-sizing: border-box; | ||||||
|  |   -webkit-user-select: text; | ||||||
|  |   -moz-user-select: text; | ||||||
|  |   -ms-user-select: text; | ||||||
|  |   -o-user-select: text; | ||||||
|  |   user-select: text; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker { | ||||||
|  |   border: 1px solid #ececec; | ||||||
|  |   background-color: #fff; | ||||||
|  |   -webkit-box-shadow: 0 0px 10px 0px rgba(0, 0, 0, 0.12); | ||||||
|  |   -moz-box-shadow: 0 0px 10px 0px rgba(0, 0, 0, 0.12); | ||||||
|  |   box-shadow: 0 0px 10px 0px rgba(0, 0, 0, 0.12); | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .color > .saturation { | ||||||
|  |   background-color: rgba(204, 154, 129, 0); | ||||||
|  |   background-image: -moz-linear-gradient(left, #FFF, rgba(204, 154, 129, 0)); | ||||||
|  |   background-image: -webkit-gradient(linear, 0 0, 100% 0, from(#FFF), to(rgba(204, 154, 129, 0))); | ||||||
|  |   background-image: -webkit-linear-gradient(left, #FFF, rgba(204, 154, 129, 0)); | ||||||
|  |   background-image: -o-linear-gradient(left, #FFF, rgba(204, 154, 129, 0)); | ||||||
|  |   background-image: linear-gradient(to right, #FFF, rgba(204, 154, 129, 0)); | ||||||
|  |   background-repeat: repeat-x; | ||||||
|  |   filter: progid:DXImageTransform.Microsoft.gradient(startColorstr='#ffffffff', endColorstr='#00cc9a81', GradientType=1); | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .color > .saturation > .value { | ||||||
|  |   background-image: -webkit-gradient(linear, 0 100%, 0 0, from(#000000), to(rgba(204, 154, 129, 0))); | ||||||
|  |   background-image: -webkit-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0)); | ||||||
|  |   background-image: -moz-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0)); | ||||||
|  |   background-image: -o-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0)); | ||||||
|  |   background-image: -ms-linear-gradient(bottom, #000000, rgba(204, 154, 129, 0)); | ||||||
|  |   background-image: linear-gradient(to top, #000000, rgba(204, 154, 129, 0)); | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .color > .saturation > .value > .drag-pointer { | ||||||
|  |   border: 1px solid #fff; | ||||||
|  |   -webkit-box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.05); | ||||||
|  |   -moz-box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.05); | ||||||
|  |   box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.05); | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .hue > .hue-container { | ||||||
|  |   background: -moz-linear-gradient(left, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); | ||||||
|  |   background: -ms-linear-gradient(left, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); | ||||||
|  |   background: -o-linear-gradient(left, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); | ||||||
|  |   background: -webkit-gradient(linear, left top, right top, from(#ff0000), color-stop(0.17, #ffff00), color-stop(0.33, #00ff00), color-stop(0.5, #00ffff), color-stop(0.67, #0000ff), color-stop(0.83, #ff00ff), to(#ff0000)); | ||||||
|  |   background: -webkit-linear-gradient(left, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); | ||||||
|  |   background: linear-gradient(to right, #ff0000 0%, #ffff00 17%, #00ff00 33%, #00ffff 50%, #0000ff 67%, #ff00ff 83%, #ff0000 100%); | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .opacity > .opacity-container > .color-bar { | ||||||
|  |   position:absolute; | ||||||
|  |   display:block; | ||||||
|  |   content:""; | ||||||
|  |   left:0px; | ||||||
|  |   right:0px; | ||||||
|  |   bottom:0px; | ||||||
|  |   top:0px; | ||||||
|  |   background: -moz-linear-gradient(left, rgba(232, 232, 232, 0), rgba(232, 232, 232, 1)); | ||||||
|  |   background: -ms-linear-gradient(left, rgba(232, 232, 232, 0), rgba(232, 232, 232, 1)); | ||||||
|  |   background: -o-linear-gradient(left, rgba(232, 232, 232, 0), rgba(232, 232, 232, 1)); | ||||||
|  |   background: -webkit-gradient(linear, left top, right top, from(rgba(232, 232, 232, 0)), to(rgba(232, 232, 232, 1))); | ||||||
|  |   background: -webkit-linear-gradient(left, rgba(232, 232, 232, 0), rgba(232, 232, 232, 1)); | ||||||
|  |   background: linear-gradient(to right, rgba(232, 232, 232, 0) , rgba(232, 232, 232, 1) ); | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control > .opacity > .opacity-container { | ||||||
|  |   background-image : url(""); | ||||||
|  |   background-repeat: repeat; | ||||||
|  | } | ||||||
|  | 
 | ||||||
|  | .codemirror-colorpicker > .control > .empty { | ||||||
|  |   background: url("") repeat; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .control .drag-bar, | ||||||
|  | .codemirror-colorpicker > .control .drag-bar2 { | ||||||
|  |   border: 1px solid rgba(0, 0, 0, 0.5); | ||||||
|  |   -webkit-box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.1); | ||||||
|  |   -moz-box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.1); | ||||||
|  |   box-shadow: 0 0 2px 0 rgba(0, 0, 0, 0.1); | ||||||
|  |   background-color: #FFFFFF; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .information { | ||||||
|  |   /*border-top: 1px solid #e8e8e8;*/ | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .information > .title { | ||||||
|  |   color: #a3a3a3; | ||||||
|  | } | ||||||
|  | .codemirror-colorpicker > .information > .input { | ||||||
|  |   color: #333; | ||||||
|  | } | ||||||
							
								
								
									
										1369
									
								
								vendor-overwrites/colorpicker/colorpicker.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										1369
									
								
								vendor-overwrites/colorpicker/colorpicker.js
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										434
									
								
								vendor-overwrites/colorpicker/colorview.js
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										434
									
								
								vendor-overwrites/colorpicker/colorview.js
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,434 @@ | ||||||
|  | (function(mod) { | ||||||
|  |     if (typeof exports == "object" && typeof module == "object") // CommonJS
 | ||||||
|  |         mod(require("codemirror")); | ||||||
|  |     else if (typeof define == "function" && define.amd) // AMD
 | ||||||
|  |         define(["codemirror"], mod); | ||||||
|  |     else // Plain browser env
 | ||||||
|  |         mod(CodeMirror); | ||||||
|  | })(function(CodeMirror) { | ||||||
|  |     "use strict"; | ||||||
|  | 
 | ||||||
|  |     // color names
 | ||||||
|  |     var color_names={aliceblue:"rgb(240, 248, 255)",antiquewhite:"rgb(250, 235, 215)",aqua:"rgb(0, 255, 255)",aquamarine:"rgb(127, 255, 212)",azure:"rgb(240, 255, 255)",beige:"rgb(245, 245, 220)",bisque:"rgb(255, 228, 196)",black:"rgb(0, 0, 0)",blanchedalmond:"rgb(255, 235, 205)",blue:"rgb(0, 0, 255)",blueviolet:"rgb(138, 43, 226)",brown:"rgb(165, 42, 42)",burlywood:"rgb(222, 184, 135)",cadetblue:"rgb(95, 158, 160)",chartreuse:"rgb(127, 255, 0)",chocolate:"rgb(210, 105, 30)",coral:"rgb(255, 127, 80)",cornflowerblue:"rgb(100, 149, 237)",cornsilk:"rgb(255, 248, 220)",crimson:"rgb(237, 20, 61)",cyan:"rgb(0, 255, 255)",darkblue:"rgb(0, 0, 139)",darkcyan:"rgb(0, 139, 139)",darkgoldenrod:"rgb(184, 134, 11)",darkgray:"rgb(169, 169, 169)",darkgrey:"rgb(169, 169, 169)",darkgreen:"rgb(0, 100, 0)",darkkhaki:"rgb(189, 183, 107)",darkmagenta:"rgb(139, 0, 139)",darkolivegreen:"rgb(85, 107, 47)",darkorange:"rgb(255, 140, 0)",darkorchid:"rgb(153, 50, 204)",darkred:"rgb(139, 0, 0)",darksalmon:"rgb(233, 150, 122)",darkseagreen:"rgb(143, 188, 143)",darkslateblue:"rgb(72, 61, 139)",darkslategray:"rgb(47, 79, 79)",darkslategrey:"rgb(47, 79, 79)",darkturquoise:"rgb(0, 206, 209)",darkviolet:"rgb(148, 0, 211)",deeppink:"rgb(255, 20, 147)",deepskyblue:"rgb(0, 191, 255)",dimgray:"rgb(105, 105, 105)",dimgrey:"rgb(105, 105, 105)",dodgerblue:"rgb(30, 144, 255)",firebrick:"rgb(178, 34, 34)",floralwhite:"rgb(255, 250, 240)",forestgreen:"rgb(34, 139, 34)",fuchsia:"rgb(255, 0, 255)",gainsboro:"rgb(220, 220, 220)",ghostwhite:"rgb(248, 248, 255)",gold:"rgb(255, 215, 0)",goldenrod:"rgb(218, 165, 32)",gray:"rgb(128, 128, 128)",grey:"rgb(128, 128, 128)",green:"rgb(0, 128, 0)",greenyellow:"rgb(173, 255, 47)",honeydew:"rgb(240, 255, 240)",hotpink:"rgb(255, 105, 180)",indianred:"rgb(205, 92, 92)",indigo:"rgb(75, 0, 130)",ivory:"rgb(255, 255, 240)",khaki:"rgb(240, 230, 140)",lavender:"rgb(230, 230, 250)",lavenderblush:"rgb(255, 240, 245)",lawngreen:"rgb(124, 252, 0)",lemonchiffon:"rgb(255, 250, 205)",lightblue:"rgb(173, 216, 230)",lightcoral:"rgb(240, 128, 128)",lightcyan:"rgb(224, 255, 255)",lightgoldenrodyellow:"rgb(250, 250, 210)",lightgreen:"rgb(144, 238, 144)",lightgray:"rgb(211, 211, 211)",lightgrey:"rgb(211, 211, 211)",lightpink:"rgb(255, 182, 193)",lightsalmon:"rgb(255, 160, 122)",lightseagreen:"rgb(32, 178, 170)",lightskyblue:"rgb(135, 206, 250)",lightslategray:"rgb(119, 136, 153)",lightslategrey:"rgb(119, 136, 153)",lightsteelblue:"rgb(176, 196, 222)",lightyellow:"rgb(255, 255, 224)",lime:"rgb(0, 255, 0)",limegreen:"rgb(50, 205, 50)",linen:"rgb(250, 240, 230)",magenta:"rgb(255, 0, 255)",maroon:"rgb(128, 0, 0)",mediumaquamarine:"rgb(102, 205, 170)",mediumblue:"rgb(0, 0, 205)",mediumorchid:"rgb(186, 85, 211)",mediumpurple:"rgb(147, 112, 219)",mediumseagreen:"rgb(60, 179, 113)",mediumslateblue:"rgb(123, 104, 238)",mediumspringgreen:"rgb(0, 250, 154)",mediumturquoise:"rgb(72, 209, 204)",mediumvioletred:"rgb(199, 21, 133)",midnightblue:"rgb(25, 25, 112)",mintcream:"rgb(245, 255, 250)",mistyrose:"rgb(255, 228, 225)",moccasin:"rgb(255, 228, 181)",navajowhite:"rgb(255, 222, 173)",navy:"rgb(0, 0, 128)",oldlace:"rgb(253, 245, 230)",olive:"rgb(128, 128, 0)",olivedrab:"rgb(107, 142, 35)",orange:"rgb(255, 165, 0)",orangered:"rgb(255, 69, 0)",orchid:"rgb(218, 112, 214)",palegoldenrod:"rgb(238, 232, 170)",palegreen:"rgb(152, 251, 152)",paleturquoise:"rgb(175, 238, 238)",palevioletred:"rgb(219, 112, 147)",papayawhip:"rgb(255, 239, 213)",peachpuff:"rgb(255, 218, 185)",peru:"rgb(205, 133, 63)",pink:"rgb(255, 192, 203)",plum:"rgb(221, 160, 221)",powderblue:"rgb(176, 224, 230)",purple:"rgb(128, 0, 128)",rebeccapurple:"rgb(102, 51, 153)",red:"rgb(255, 0, 0)",rosybrown:"rgb(188, 143, 143)",royalblue:"rgb(65, 105, 225)",saddlebrown:"rgb(139, 69, 19)",salmon:"rgb(250, 128, 114)",sandybrown:"rgb(244, 164, 96)",seagreen:"rgb(46, 139, 87)",seashell:"rgb(255, 245, 238)",sienna:"rgb(160, 82, 45)",silver:"rgb(192, 192, 192)",skyblue:"rgb(135, 206, 235)",slateblue:"rgb(106, 90, 205)",slategray:"rgb(112, 128, 144)",slategrey:"rgb(112, 128, 144)",snow:"rgb(255, 250, 250)",springgreen:"rgb(0, 255, 127)",steelblue:"rgb(70, 130, 180)",tan:"rgb(210, 180, 140)",teal:"rgb(0, 128, 128)",thistle:"rgb(216, 191, 216)",tomato:"rgb(255, 99, 71)",turquoise:"rgb(64, 224, 208)",violet:"rgb(238, 130, 238)",wheat:"rgb(245, 222, 179)",white:"rgb(255, 255, 255)",whitesmoke:"rgb(245, 245, 245)",yellow:"rgb(255, 255, 0)",yellowgreen:"rgb(154, 205, 50)",transparent:"rgba(0, 0, 0, 0)"}; | ||||||
|  | 
 | ||||||
|  |     var colorpicker_class = 'codemirror-colorview'; | ||||||
|  |     var colorpicker_background_class = 'codemirror-colorview-background'; | ||||||
|  | 
 | ||||||
|  |     // Excluded tokens do not show color views..
 | ||||||
|  |     var excluded_token = ['comment']; | ||||||
|  | 
 | ||||||
|  |     CodeMirror.defineOption("colorpicker", false, function (cm, val, old) { | ||||||
|  | 
 | ||||||
|  |         if (old && old != CodeMirror.Init) { | ||||||
|  | 
 | ||||||
|  |             if (cm.state.colorpicker) | ||||||
|  |             { | ||||||
|  |                 cm.state.colorpicker.destroy(); | ||||||
|  |                 cm.state.colorpicker = null; | ||||||
|  | 
 | ||||||
|  |             } | ||||||
|  |             // remove event listener
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         if (val) | ||||||
|  |         { | ||||||
|  |             cm.state.colorpicker = new codemirror_colorpicker(cm, val); | ||||||
|  |         } | ||||||
|  |     }); | ||||||
|  | 
 | ||||||
|  |     function onChange(cm, evt) { | ||||||
|  |         if (evt.origin == 'setValue') {  // if content is changed by setValue method, it initialize markers
 | ||||||
|  |             cm.state.colorpicker.close_color_picker(); | ||||||
|  |             cm.state.colorpicker.init_color_update(); | ||||||
|  |             cm.state.colorpicker.style_color_update(); | ||||||
|  |         } else { | ||||||
|  |             cm.state.colorpicker.style_color_update(cm.getCursor().line); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function onUpdate(cm, evt) { | ||||||
|  |         if (!cm.state.colorpicker.isUpdate) { | ||||||
|  |             cm.state.colorpicker.isUpdate = true; | ||||||
|  |             cm.state.colorpicker.close_color_picker(); | ||||||
|  |             cm.state.colorpicker.init_color_update(); | ||||||
|  |             cm.state.colorpicker.style_color_update(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function onRefresh(cm, evt) { | ||||||
|  |         onChange(cm, { origin : 'setValue'}); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function onKeyup(cm, evt) { | ||||||
|  |         cm.state.colorpicker.keyup(evt); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function onMousedown(cm, evt) { | ||||||
|  |         if (cm.state.colorpicker.is_edit_mode()) | ||||||
|  |         { | ||||||
|  |             cm.state.colorpicker.check_mousedown(evt); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function onPaste (cm, evt) { | ||||||
|  |         onChange(cm, { origin : 'setValue'}); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function onScroll (cm) { | ||||||
|  |         cm.state.colorpicker.close_color_picker(); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function debounce (callback, delay) { | ||||||
|  | 
 | ||||||
|  |         var t = undefined; | ||||||
|  | 
 | ||||||
|  |         return function (cm, e) { | ||||||
|  |             if (t) { | ||||||
|  |                 clearTimeout(t); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |             t = setTimeout(function () { | ||||||
|  |                 callback(cm, e); | ||||||
|  |             }, delay || 300); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function has_class(el, cls) { | ||||||
|  |         if (!el || !el.className) { | ||||||
|  |             return false; | ||||||
|  |         } else { | ||||||
|  |             var newClass = ' ' + el.className + ' '; | ||||||
|  |             return newClass.indexOf(' ' + cls + ' ') > -1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     function codemirror_colorpicker (cm, opt) { | ||||||
|  |         var self = this; | ||||||
|  | 
 | ||||||
|  |         if (typeof opt == 'boolean') | ||||||
|  |         { | ||||||
|  |             opt = { mode : 'view' }; | ||||||
|  |         } else { | ||||||
|  |             opt = Object.assign({ mode: 'view' }, opt || {}); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         this.opt = opt; | ||||||
|  |         this.cm = cm; | ||||||
|  |         this.markers = {}; | ||||||
|  | 
 | ||||||
|  |         // set excluded token
 | ||||||
|  |         excluded_token = this.opt.excluded_token || excluded_token; | ||||||
|  | 
 | ||||||
|  |         if (this.cm.colorpicker) { | ||||||
|  |             this.colorpicker = this.cm.colorpicker(); | ||||||
|  |         } else if (this.opt.colorpicker) { | ||||||
|  |             this.colorpicker = this.opt.colorpicker; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         this.init_event(); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.init_event = function () { | ||||||
|  | 
 | ||||||
|  |         this.cm.on('mousedown', onMousedown); | ||||||
|  |         this.cm.on('keyup', onKeyup); | ||||||
|  |         this.cm.on('change', onChange); | ||||||
|  |         this.cm.on('update', onUpdate); | ||||||
|  |         this.cm.on('refresh', onRefresh); | ||||||
|  | 
 | ||||||
|  |         // create paste callback
 | ||||||
|  |         this.onPasteCallback = (function (cm, callback) { | ||||||
|  |             return  function (evt) { | ||||||
|  |                 callback.call(this, cm, evt); | ||||||
|  |             } | ||||||
|  |         })(this.cm, onPaste); | ||||||
|  | 
 | ||||||
|  |         this.cm.getWrapperElement().addEventListener('paste', this.onPasteCallback); | ||||||
|  | 
 | ||||||
|  |         if (this.is_edit_mode()) | ||||||
|  |         { | ||||||
|  |             this.cm.on('scroll', debounce(onScroll, 50)); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.is_edit_mode = function () { | ||||||
|  |         return this.opt.mode == 'edit'; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.is_view_mode = function () { | ||||||
|  |         return this.opt.mode == 'view'; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.destroy = function () { | ||||||
|  |         this.cm.off('mousedown', onMousedown); | ||||||
|  |         this.cm.off('keyup', onKeyup); | ||||||
|  |         this.cm.off('change', onChange) | ||||||
|  |         this.cm.getWrapperElement().removeEventListener('paste', this.onPasteCallback); | ||||||
|  | 
 | ||||||
|  |         if (this.is_edit_mode()) | ||||||
|  |         { | ||||||
|  |             this.cm.off('scroll'); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.hasClass = function (el, className) { | ||||||
|  |         if (!el.className) | ||||||
|  |         { | ||||||
|  |             return false; | ||||||
|  |         } else { | ||||||
|  |             var newClass = ' ' + el.className + ' '; | ||||||
|  |             return newClass.indexOf(' ' + className + ' ') > -1; | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.check_mousedown = function (evt) { | ||||||
|  |         if (this.hasClass(evt.target, colorpicker_background_class) ) | ||||||
|  |         { | ||||||
|  |             this.open_color_picker(evt.target.parentNode); | ||||||
|  |         } else { | ||||||
|  |             this.close_color_picker(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.popup_color_picker = function (defalutColor) { | ||||||
|  |         var cursor = this.cm.getCursor(); | ||||||
|  |         var self = this; | ||||||
|  |         var colorMarker = { | ||||||
|  |             lineNo : cursor.line, | ||||||
|  |             ch : cursor.ch, | ||||||
|  |             color: defalutColor || '#FFFFFF', | ||||||
|  |             isShortCut : true | ||||||
|  |         }; | ||||||
|  | 
 | ||||||
|  |         Object.keys(this.markers).forEach(function(key) { | ||||||
|  |             var searchKey = "#" + key; | ||||||
|  |             if (searchKey.indexOf( "#" + colorMarker.lineNo + ":") > -1) { | ||||||
|  |                 var marker = self.markers[key]; | ||||||
|  | 
 | ||||||
|  |                 if (marker.ch <= colorMarker.ch && colorMarker.ch <= marker.ch + marker.color.length) { | ||||||
|  |                     // when cursor has marker
 | ||||||
|  |                     colorMarker.ch = marker.ch; | ||||||
|  |                     colorMarker.color = marker.color; | ||||||
|  |                     colorMarker.nameColor = marker.nameColor; | ||||||
|  |                 } | ||||||
|  | 
 | ||||||
|  |             } | ||||||
|  |         }); | ||||||
|  | 
 | ||||||
|  |         this.open_color_picker(colorMarker); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.open_color_picker = function (el) { | ||||||
|  |         var lineNo = el.lineNo; | ||||||
|  |         var ch = el.ch; | ||||||
|  |         var nameColor = el.nameColor; | ||||||
|  |         var color = el.color; | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         if (this.colorpicker) { | ||||||
|  |             var self = this; | ||||||
|  |             var prevColor = color; | ||||||
|  |             var pos = this.cm.charCoords({line : lineNo, ch : ch }); | ||||||
|  |             this.colorpicker.show({ | ||||||
|  |                 left : pos.left, | ||||||
|  |                 top : pos.bottom, | ||||||
|  |                 isShortCut : el.isShortCut || false, | ||||||
|  |                 hideDelay : self.opt.hideDelay || 2000 | ||||||
|  |             }, nameColor || color, function (newColor) { | ||||||
|  |                 self.cm.replaceRange(newColor, { line : lineNo, ch : ch } , { line : lineNo, ch : ch + prevColor.length }, '*colorpicker'); | ||||||
|  |                 prevColor = newColor; | ||||||
|  |             }); | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.close_color_picker = function (el) { | ||||||
|  |         if (this.colorpicker) | ||||||
|  |         { | ||||||
|  |             this.colorpicker.hide(); | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.key = function (lineNo, ch) { | ||||||
|  |         return [lineNo, ch].join(":"); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.keyup = function (evt) { | ||||||
|  | 
 | ||||||
|  |         if (this.colorpicker ) { | ||||||
|  |             if (evt.key == 'Escape') { | ||||||
|  |                 this.colorpicker.hide(); | ||||||
|  |             } else if (this.colorpicker.isShortCut() == false) { | ||||||
|  |                 this.colorpicker.hide(); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.init_color_update = function () { | ||||||
|  |         this.markers = {};  // initialize marker list
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.style_color_update = function (lineHandle) { | ||||||
|  | 
 | ||||||
|  |         if (lineHandle) { | ||||||
|  |             this.match(lineHandle); | ||||||
|  |         } else { | ||||||
|  |             var max = this.cm.lineCount(); | ||||||
|  | 
 | ||||||
|  |             for(var lineNo = 0; lineNo < max; lineNo++) { | ||||||
|  |                 this.match(lineNo); | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.empty_marker = function (lineNo, lineHandle) { | ||||||
|  |         var list = lineHandle.markedSpans || []; | ||||||
|  | 
 | ||||||
|  |         for(var i = 0, len = list.length; i < len; i++) { | ||||||
|  |             var key = this.key(lineNo, list[i].from); | ||||||
|  | 
 | ||||||
|  |             if (key && has_class(list[i].marker.replacedWith, colorpicker_class)) { | ||||||
|  |                 delete this.markers[key]; | ||||||
|  |                 list[i].marker.clear(); | ||||||
|  |             } | ||||||
|  | 
 | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.color_regexp = /(#(?:[\da-f]{3}){1,2}|rgb\((?:\s*\d{1,3},\s*){2}\d{1,3}\s*\)|rgba\((?:\s*\d{1,3},\s*){3}\d*\.?\d+\s*\)|hsl\(\s*\d{1,3}(?:,\s*\d{1,3}%){2}\s*\)|hsla\(\s*\d{1,3}(?:,\s*\d{1,3}%){2},\s*\d*\.?\d+\s*\)|([\w_\-]+))/gi; | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.match_result = function (lineHandle) { | ||||||
|  |         return lineHandle.text.match(this.color_regexp); | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.match = function (lineNo) { | ||||||
|  |         var lineHandle = this.cm.getLineHandle(lineNo); | ||||||
|  | 
 | ||||||
|  |         this.empty_marker(lineNo, lineHandle); | ||||||
|  | 
 | ||||||
|  |         var result = this.match_result(lineHandle); | ||||||
|  |         if (result) | ||||||
|  |         { | ||||||
|  |             var obj = { next : 0 }; | ||||||
|  |             for(var i = 0, len = result.length; i < len; i++) { | ||||||
|  | 
 | ||||||
|  |                 if (result[i].indexOf('#') > -1 || result[i].indexOf('rgb') > -1 || result[i].indexOf('hsl') > -1) { | ||||||
|  |                     this.render(obj, lineNo, lineHandle, result[i]); | ||||||
|  |                 } else { | ||||||
|  |                     var nameColor = color_names[result[i]]; | ||||||
|  |                     if (nameColor) { | ||||||
|  |                         this.render(obj, lineNo, lineHandle, result[i], nameColor); | ||||||
|  |                     } | ||||||
|  |                 } | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.make_element = function () { | ||||||
|  |         var el = document.createElement('div'); | ||||||
|  | 
 | ||||||
|  |         el.className = colorpicker_class; | ||||||
|  | 
 | ||||||
|  |         if (this.is_edit_mode()) | ||||||
|  |         { | ||||||
|  |             el.title ="open color picker"; | ||||||
|  |         } else { | ||||||
|  |             el.title =""; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         el.back_element = this.make_background_element(); | ||||||
|  |         el.appendChild(el.back_element); | ||||||
|  | 
 | ||||||
|  |         return el; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.make_background_element = function () { | ||||||
|  |         var el = document.createElement('div'); | ||||||
|  | 
 | ||||||
|  |         el.className = colorpicker_background_class; | ||||||
|  | 
 | ||||||
|  |         return el; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.set_state = function (lineNo, start, color, nameColor) { | ||||||
|  |         var marker = this.create_marker(lineNo, start); | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         marker.lineNo = lineNo; | ||||||
|  |         marker.ch = start; | ||||||
|  |         marker.color = color; | ||||||
|  |         marker.nameColor = nameColor; | ||||||
|  | 
 | ||||||
|  |         return marker; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.create_marker = function (lineNo, start) { | ||||||
|  | 
 | ||||||
|  |         var key = this.key(lineNo,start); | ||||||
|  | 
 | ||||||
|  |         if (!this.markers[key]) { | ||||||
|  |             this.markers[key] = this.make_element(); | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  |         return this.markers[key]; | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.has_marker = function (lineNo, start) { | ||||||
|  |         var key = this.key(lineNo,start); | ||||||
|  |         return !!(this.markers[key]) | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.update_element = function (el, color) { | ||||||
|  |         el.back_element.style.backgroundColor = color; | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.set_mark = function (line, ch, el) { | ||||||
|  |         this.cm.setBookmark({ line : line, ch : ch}, { widget : el, handleMouseEvents : true} ); | ||||||
|  | 
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.is_excluded_token = function (line, ch) { | ||||||
|  |         var token = this.cm.getTokenAt({line : line, ch : ch}); | ||||||
|  |         var count = 0; | ||||||
|  |         for(var i = 0, len = excluded_token.length; i < len; i++) { | ||||||
|  |             if (token.type === excluded_token[i]) { | ||||||
|  |                 count++; | ||||||
|  |                 break; | ||||||
|  |             } | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         return count > 0;   // true is that it has a excluded token
 | ||||||
|  |     } | ||||||
|  | 
 | ||||||
|  |     codemirror_colorpicker.prototype.render = function (cursor, lineNo, lineHandle, color, nameColor) { | ||||||
|  |         var start = lineHandle.text.indexOf(color, cursor.next); | ||||||
|  | 
 | ||||||
|  |         if (this.is_excluded_token(lineNo, start) === true) { | ||||||
|  |             // excluded token do not show.
 | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         cursor.next = start + color.length; | ||||||
|  | 
 | ||||||
|  |         if (this.has_marker(lineNo, start)) | ||||||
|  |         { | ||||||
|  |             this.update_element(this.create_marker(lineNo, start), nameColor || color); | ||||||
|  |             this.set_state(lineNo, start, color, nameColor); | ||||||
|  |             return; | ||||||
|  |         } | ||||||
|  | 
 | ||||||
|  |         var el  = this.create_marker(lineNo, start); | ||||||
|  | 
 | ||||||
|  |         this.update_element(el, nameColor || color); | ||||||
|  |         this.set_state(lineNo, start, color, nameColor || color); | ||||||
|  |         this.set_mark(lineNo, start, el); | ||||||
|  |     } | ||||||
|  | }); | ||||||
		Loading…
	
		Reference in New Issue
	
	Block a user