Variable button count (up to 32)
- adds ability to configure variable number of buttons during runtime - fixes #4692
This commit is contained in:
		| @@ -6,7 +6,7 @@ | ||||
| 	<title>LED Settings</title> | ||||
| 	<script src="common.js" async type="text/javascript"></script> | ||||
| 	<script> | ||||
| 		var maxB=1,maxD=1,maxA=1,maxV=0,maxM=4000,maxPB=2048,maxL=1664,maxCO=5; //maximum bytes for LED allocation: 4kB for 8266, 32kB for 32 | ||||
| 		var maxB=1,maxD=1,maxA=1,maxV=0,maxM=4000,maxPB=2048,maxL=1664,maxCO=5,maxBT=10; //maximum bytes for LED allocation: 4kB for 8266, 32kB for 32 | ||||
| 		var oMaxB=1; | ||||
| 		var customStarts=false,startsDirty=[]; | ||||
| 		function off(n)    { gN(n).value = -1;} | ||||
| @@ -42,7 +42,7 @@ | ||||
| 			});	// If we set async false, file is loaded and executed, then next statement is processed | ||||
| 			if (loc) d.Sf.action = getURL('/settings/leds'); | ||||
| 		} | ||||
| 		function bLimits(b,v,p,m,l,o=5,d=2,a=6) { | ||||
| 		function bLimits(b,v,p,m,l,o=5,d=2,a=6,n=10) { | ||||
| 			oMaxB = maxB = b; // maxB - max buses (can be changed if using ESP32 parallel I2S): 20 - ESP32, 14 - S3/S2, 6 - C3, 4 - 8266 | ||||
| 			maxD  = d; // maxD - max digital channels (can be changed if using ESP32 parallel I2S): 17 - ESP32, 12 - S3/S2, 2 - C3, 3 - 8266 | ||||
| 			maxA  = a; // maxA - max analog channels: 16 - ESP32, 8 - S3/S2, 6 - C3, 5 - 8266 | ||||
| @@ -51,6 +51,7 @@ | ||||
| 			maxM  = m; // maxM - max LED memory | ||||
| 			maxL  = l; // maxL - max LEDs (will serve to determine ESP >1664 == ESP32) | ||||
| 			maxCO = o; // maxCO - max Color Order mappings | ||||
| 			maxBT = n; // maxBT - max buttons | ||||
| 		} | ||||
| 		function pinsOK() { | ||||
| 			var ok = true; | ||||
| @@ -560,9 +561,10 @@ Swap: <select id="xw${s}" name="XW${s}"> | ||||
| 		} | ||||
|  | ||||
| 		function addBtn(i,p,t) { | ||||
| 			var c = gId("btns").innerHTML; | ||||
| 			var b = gId("btns"); | ||||
| 			var c = b.innerHTML; | ||||
| 			var s = chrID(i); | ||||
| 			c += `Button ${i} GPIO: <input type="number" name="BT${s}" onchange="UI()" class="xs" value="${p}">`; | ||||
| 			c += `<div id="btn${i}">#${i} GPIO: <input type="number" name="BT${s}" onchange="UI()" min="-1" max="${d.max_gpio}" class="xs" value="${p}">`; | ||||
| 			c += ` <select name="BE${s}">` | ||||
| 			c += `<option value="0" ${t==0?"selected":""}>Disabled</option>`; | ||||
| 			c += `<option value="2" ${t==2?"selected":""}>Pushbutton</option>`; | ||||
| @@ -574,8 +576,22 @@ Swap: <select id="xw${s}" name="XW${s}"> | ||||
| 			c += `<option value="8" ${t==8?"selected":""}>Analog inverted</option>`; | ||||
| 			c += `<option value="9" ${t==9?"selected":""}>Touch (switch)</option>`; | ||||
| 			c += `</select>`; | ||||
| 			c += `<span style="cursor: pointer;" onclick="off('BT${s}')"> ✕</span><br>`; | ||||
| 			gId("btns").innerHTML = c; | ||||
| 			c += `<span style="cursor: pointer;" onclick="off('BT${s}')"> ✕</span><br></div>`; | ||||
| 			b.innerHTML = c; | ||||
| 			btnBtn(); | ||||
| 			UI(); | ||||
| 		} | ||||
| 		function remBtn() { | ||||
| 			var b = gId("btns"); | ||||
| 			if (b.children.length <= 1) return; | ||||
| 			b.lastElementChild.remove(); | ||||
| 			btnBtn(); | ||||
| 			UI(); | ||||
| 		} | ||||
| 		function btnBtn() { | ||||
| 			var b = gId("btns"); | ||||
| 			gId("btn_rem").style.display = (b.children.length > 1) ? "inline" : "none"; | ||||
| 			gId("btn_add").style.display = (b.children.length < maxBT) ? "inline" : "none"; | ||||
| 		} | ||||
| 		function tglSi(cs) { | ||||
| 			customStarts = cs; | ||||
| @@ -827,10 +843,16 @@ Swap: <select id="xw${s}" name="XW${s}"> | ||||
| 			<div id="com_entries"></div> | ||||
| 			<hr class="sml"> | ||||
| 			<button type="button" id="com_add" onclick="addCOM()">+</button> | ||||
| 			<button type="button" id="com_rem" onclick="remCOM()">-</button><br> | ||||
| 			<button type="button" id="com_rem" onclick="remCOM()">-</button> | ||||
| 		</div> | ||||
| 		<hr class="sml"> | ||||
| 		<div id="btns"></div> | ||||
| 		<div id="btn_wrap"> | ||||
| 			Buttons: | ||||
| 			<div id="btns"></div> | ||||
| 			<hr class="sml"> | ||||
| 			<button type="button" id="btn_add" onclick="addBtn(gId('btns').children.length,-1,0)">+</button> | ||||
| 			<button type="button" id="btn_rem" onclick="remBtn()">-</button> | ||||
| 		</div> | ||||
| 		Disable internal pull-up/down: <input type="checkbox" name="IP"><br> | ||||
| 		Touch threshold: <input type="number" class="s" min="0" max="100" name="TT" required><br> | ||||
| 		<hr class="sml"> | ||||
|   | ||||
		Reference in New Issue
	
	Block a user
	 Blaž Kristan
					Blaž Kristan