2023年政策修订增补工作正在进行中,欢迎参与!
  • Moegirl.ICU:萌娘百科流亡社群 581077156(QQ),欢迎对萌娘百科运营感到失望的编辑者加入
  • Moegirl.ICU:账号认领正在试运行,有意者请参照账号认领流程

User:W3jc/js/ColorPicker.js

萌娘百科,万物皆可萌的百科全书!转载请标注来源页面的网页链接,并声明引自萌娘百科。内容不可商用。
< User:W3jc‎ | js
跳转到导航 跳转到搜索

注意:在保存之后,您可能需要清除浏览器缓存才能看到所作出的变更的影响。

  • Firefox/Safari:按住“Shift”的同时单击“刷新”,或按“Ctrl-F5”或“Ctrl-R”(Mac为“⌘-R”)
  • Google Chrome:按“Ctrl-Shift-R”(Mac为“⌘-Shift-R”)
  • Internet Explorer:按住“Ctrl”的同时单击“刷新”,或按“Ctrl-F5”
  • Opera:在“工具→首选项”中清除缓存
如果您已登录但该页面出现未登录状态,请尝试在地址栏的地址最后添加代码?_=1来访问最新页面。
添加代码后的本页地址如下:-{R|https://moegirl.icu/User:W3jc/js/ColorPicker.js?_=1}-
//可视化颜色选择器
var favColor = localStorage.getItem("favColor");
if(favColor === null) {
	favColor = "#A5E4A5";
	localStorage.setItem("favColor", favColor);
}
$.getScript("/index.php?title=User:W3jc/js/w3color.js&action=raw&ctype=text/javascript", () => {
	if(mw.config.get("wgNamespaceNumber") === -1) {
		return;
	}
	$colorPicker = $("<div class='portal' id='p-cp' style='position:sticky;top:0;bottom:0;background-color:rgba(246, 246, 246, 0.9);'></div>");
	if($("#p-sl").length) {
		$colorPicker.css("top", $("#p-sl").outerHeight());
	} else {
		$("body").css("height", "auto");
		$("#mw-panel").height($("body").height());
	}
	$colorPicker.append("<h3 lang='zh-CN' dir='ltr' id='p-cp-label'>颜色选择器</h3>");
	$colorPicker.append("<div class='body'><ul id='p-cp-list'></ul></div>");
	$("#mw-panel>div:last").after($colorPicker);
	$("#p-cp-list").append("<li><input id='cp-color' type='color' style='height:2em;width:80px;'/></li>");
	$("#p-cp-list").append("<li><select id='cp-select' style='height:2em;width:80px;'><option value='FavColor' selected></option></select></li>");
	$("#p-cp-list").append("<li><input id='cp-insert' type='button' value='插入颜色' style='height:2em;width:80px;' disabled=true/></li>");
	$("#cp-color").on("change", colorChange);
	$("#cp-select").on("change", selectChange);
	$("#cp-color").on("click", updateColor);
	$("#cp-insert").on("click", insertColor);
	if((mw.config.get('wgIsProbablyEditable') === true) && (mw.config.get("wgAction") == "edit" || mw.config.get("wgAction") == "submit")) {
		$("#cp-insert").attr("disabled", false);
	}
	updateColor();
	if (typeof customColors != "undefined") {
		addColors(customColors);
	}
	addColors(defaultColors);
});
function addColors(colors) {
	for(let i=0;i<colors.length;i++) {
		let $tempOptgroup = $("<optgroup></optgroup>");
		$tempOptgroup.attr("label",colors[i].name);
		for(let j=0;j<colors[i].value.length;j++) {
			let $tempOption = $("<option></option>");
			$tempOptgroup.append($tempOption);
			$tempOption.val(colors[i].value[j].value);
			$tempOption.text(colors[i].value[j].name);
			$tempOption.css("background-color", colors[i].value[j].value);
			if(w3color(colors[i].value[j].value).isDark()) {
				$tempOption.css("color", "white");
			} else {
				$tempOption.css("color", "black");
			}
		}
		$("#cp-select").append($tempOptgroup);
	}
}
function updateColor() {
	favColor = localStorage.getItem("favColor");
	$("#cp-color").val(favColor);
	$('#cp-select').val("FavColor");
	$("#cp-select>option:first").text(favColor);
	if(w3color(favColor).isDark()) {
		$("#cp-select>option:first").css("color", "white");
	} else {
		$("#cp-select>option:first").css("color", "black");
	}
	$("#cp-select>option:first").css("background-color", favColor);
}
function selectChange(event) {
	if(event.target.value == "FavColor") {
		$("#cp-color").val(favColor);
	} else {
		$("#cp-color").val(w3color(event.target.value).toHexString());
	}
}
function colorChange(event) {
	favColor = event.target.value;
	$('#cp-select').val("FavColor");
	$("#cp-select>option:first").text(favColor);
	if(w3color(favColor).isDark()) {
		$("#cp-select>option:first").css("color", "white");
	} else {
		$("#cp-select>option:first").css("color", "black");
	}
	$('#cp-select>option:first').css("background-color", favColor);
	localStorage.setItem("favColor", favColor);
}
function insertColor() {
	var targetColor = $('#cp-select').val();
	if(targetColor == "FavColor") {
		targetColor = favColor;
	}
	let $currentFocused = $('#wpTextbox1');
	if ($currentFocused.length) {
		$currentFocused.textSelection('encapsulateSelection', {peri: targetColor, replace: true});
	}
}
var defaultColors = [{
	"name":"粉色",
	"value":[
		{"name":"Pink","value":"Pink"},
		{"name":"LightPink","value":"LightPink"},
		{"name":"HotPink","value":"HotPink"},
		{"name":"DeepPink","value":"DeepPink"},
		{"name":"PaleVioletRed","value":"PaleVioletRed"},
		{"name":"MediumVioletRed","value":"MediumVioletRed"}]
	},{
	"name":"紫色",
	"value":[
		{"name":"Lavender","value":"Lavender"},
		{"name":"Thistle","value":"Thistle"},
		{"name":"Plum","value":"Plum"},
		{"name":"Orchid","value":"Orchid"},
		{"name":"Violet","value":"Violet"},
		{"name":"Fuchsia","value":"Fuchsia"},
		{"name":"Magenta","value":"Magenta"},
		{"name":"MediumOrchid","value":"MediumOrchid"},
		{"name":"DarkOrchid","value":"DarkOrchid"},
		{"name":"DarkViolet","value":"DarkViolet"},
		{"name":"BlueViolet","value":"BlueViolet"},
		{"name":"DarkMagenta","value":"DarkMagenta"},
		{"name":"Purple","value":"Purple"},
		{"name":"MediumPurple","value":"MediumPurple"},
		{"name":"MediumSlateBlue","value":"MediumSlateBlue"},
		{"name":"SlateBlue","value":"SlateBlue"},
		{"name":"DarkSlateBlue","value":"DarkSlateBlue"},
		{"name":"RebeccaPurple","value":"RebeccaPurple"},
		{"name":"Indigo","value":"Indigo"}]
	},{
	"name":"红色",
	"value":[
		{"name":"LightSalmon","value":"LightSalmon"},
		{"name":"Salmon","value":"Salmon"},
		{"name":"DarkSalmon","value":"DarkSalmon"},
		{"name":"LightCoral","value":"LightCoral"},
		{"name":"IndianRed","value":"IndianRed"},
		{"name":"Crimson","value":"Crimson"},
		{"name":"Red","value":"Red"},
		{"name":"FireBrick","value":"FireBrick"},
		{"name":"DarkRed","value":"DarkRed"}]
	},{
	"name":"橙色",
	"value":[
		{"name":"Orange","value":"Orange"},
		{"name":"DarkOrange","value":"DarkOrange"},
		{"name":"Coral","value":"Coral"},
		{"name":"Tomato","value":"Tomato"},
		{"name":"OrangeRed","value":"OrangeRed"}]
	},{
	"name":"黄色",
	"value":[
		{"name":"Gold","value":"Gold"},
		{"name":"Yellow","value":"Yellow"},
		{"name":"LightYellow","value":"LightYellow"},
		{"name":"LemonChiffon","value":"LemonChiffon"},
		{"name":"LightGoldenrodYellow","value":"LightGoldenrodYellow"},
		{"name":"PapayaWhip","value":"PapayaWhip"},
		{"name":"Moccasin","value":"Moccasin"},
		{"name":"PeachPuff","value":"PeachPuff"},
		{"name":"PaleGoldenrod","value":"PaleGoldenrod"},
		{"name":"Khaki","value":"Khaki"},
		{"name":"DarkKhaki","value":"DarkKhaki"}]
	},{
	"name":"绿色",
	"value":[
		{"name":"GreenYellow","value":"GreenYellow"},
		{"name":"Chartreuse","value":"Chartreuse"},
		{"name":"LawnGreen","value":"LawnGreen"},
		{"name":"Lime","value":"Lime"},
		{"name":"LimeGreen","value":"LimeGreen"},
		{"name":"PaleGreen","value":"PaleGreen"},
		{"name":"LightGreen","value":"LightGreen"},
		{"name":"MediumSpringGreen","value":"MediumSpringGreen"},
		{"name":"SpringGreen","value":"SpringGreen"},
		{"name":"MediumSeaGreen","value":"MediumSeaGreen"},
		{"name":"SeaGreen","value":"SeaGreen"},
		{"name":"ForestGreen","value":"ForestGreen"},
		{"name":"Green","value":"Green"},
		{"name":"DarkGreen","value":"DarkGreen"},
		{"name":"YellowGreen","value":"YellowGreen"},
		{"name":"OliveDrab","value":"OliveDrab"},
		{"name":"DarkOliveGreen","value":"DarkOliveGreen"},
		{"name":"MediumAquamarine","value":"MediumAquamarine"},
		{"name":"DarkSeaGreen","value":"DarkSeaGreen"},
		{"name":"LightSeaGreen","value":"LightSeaGreen"},
		{"name":"DarkCyan","value":"DarkCyan"},
		{"name":"Teal","value":"Teal"}]
	},{
	"name":"青色",
	"value":[
		{"name":"Aqua","value":"Aqua"},
		{"name":"Cyan","value":"Cyan"},
		{"name":"LightCyan","value":"LightCyan"},
		{"name":"PaleTurquoise","value":"PaleTurquoise"},
		{"name":"Aquamarine","value":"Aquamarine"},
		{"name":"Turquoise","value":"Turquoise"},
		{"name":"MediumTurquoise","value":"MediumTurquoise"},
		{"name":"DarkTurquoise","value":"DarkTurquoise"}]
	},{
	"name":"蓝色",
	"value":[
		{"name":"CadetBlue","value":"CadetBlue"},
		{"name":"SteelBlue","value":"SteelBlue"},
		{"name":"LightSteelBlue","value":"LightSteelBlue"},
		{"name":"LightBlue","value":"LightBlue"},
		{"name":"PowderBlue","value":"PowderBlue"},
		{"name":"LightSkyBlue","value":"LightSkyBlue"},
		{"name":"SkyBlue","value":"SkyBlue"},
		{"name":"CornflowerBlue","value":"CornflowerBlue"},
		{"name":"DeepSkyBlue","value":"DeepSkyBlue"},
		{"name":"DodgerBlue","value":"DodgerBlue"},
		{"name":"RoyalBlue","value":"RoyalBlue"},
		{"name":"Blue","value":"Blue"},
		{"name":"MediumBlue","value":"MediumBlue"},
		{"name":"DarkBlue","value":"DarkBlue"},		
		{"name":"Navy","value":"Navy"},
		{"name":"MidnightBlue","value":"MidnightBlue"}]
	},{
	"name":"棕色",
	"value":[
		{"name":"Cornsilk","value":"Cornsilk"},
		{"name":"BlanchedAlmond","value":"BlanchedAlmond"},
		{"name":"Bisque","value":"Bisque"},
		{"name":"NavajoWhite","value":"NavajoWhite"},
		{"name":"Wheat","value":"Wheat"},
		{"name":"BurlyWood","value":"BurlyWood"},
		{"name":"Tan","value":"Tan"},
		{"name":"RosyBrown","value":"RosyBrown"},
		{"name":"SandyBrown","value":"SandyBrown"},
		{"name":"GoldenRod","value":"GoldenRod"},
		{"name":"DarkGoldenRod","value":"DarkGoldenRod"},
		{"name":"Peru","value":"Peru"},
		{"name":"Chocolate","value":"Chocolate"},
		{"name":"Olive","value":"Olive"},
		{"name":"SaddleBrown","value":"SaddleBrown"},
		{"name":"Sienna","value":"Sienna"},
		{"name":"Brown","value":"Brown"},
		{"name":"Maroon","value":"Maroon"}]
	},{
	"name":"白色",
	"value":[
		{"name":"White","value":"White"},
		{"name":"Snow","value":"Snow"},
		{"name":"HoneyDew","value":"HoneyDew"},
		{"name":"MintCream","value":"MintCream"},
		{"name":"Azure","value":"Azure"},
		{"name":"AliceBlue","value":"AliceBlue"},
		{"name":"GhostWhite","value":"GhostWhite"},
		{"name":"WhiteSmoke","value":"WhiteSmoke"},
		{"name":"SeaShell","value":"SeaShell"},
		{"name":"Beige","value":"Beige"},
		{"name":"OldLace","value":"OldLace"},
		{"name":"FloralWhite","value":"FloralWhite"},
		{"name":"Ivory","value":"Ivory"},
		{"name":"AntiqueWhite","value":"AntiqueWhite"},
		{"name":"Linen","value":"Linen"},
		{"name":"LavenderBlush","value":"LavenderBlush"},
		{"name":"MistyRose","value":"MistyRose"}]
	},{
	"name":"灰色",
	"value":[
		{"name":"Gainsboro","value":"Gainsboro"},
		{"name":"LightGray","value":"LightGray"},
		{"name":"Silver","value":"Silver"},
		{"name":"DarkGray","value":"DarkGray"},
		{"name":"DimGray","value":"DimGray"},
		{"name":"Gray","value":"Gray"},
		{"name":"LightSlateGray","value":"LightSlateGray"},
		{"name":"SlateGray","value":"SlateGray"},
		{"name":"DarkSlateGray","value":"DarkSlateGray"},
		{"name":"Black","value":"Black"}]
	}
];