Skip to content
This repository has been archived by the owner on Jan 5, 2025. It is now read-only.

Commit

Permalink
Merged support for textarea length
Browse files Browse the repository at this point in the history
  • Loading branch information
BarRaider committed Feb 4, 2022
1 parent d9726c7 commit dcf7d40
Showing 1 changed file with 28 additions and 2 deletions.
30 changes: 28 additions & 2 deletions src/sdtools.common.js
Original file line number Diff line number Diff line change
@@ -1,12 +1,14 @@
// ****************************************************************
// * EasyPI v1.3.2
// * EasyPI v1.3.3
// * Author: BarRaider
// *
// * JS library to simplify the communication between the
// * Stream Deck's Property Inspector and the plugin.
// *
// * Project page: https://github.com/BarRaider/streamdeck-easypi
// * Support: http://discord.barraider.com
// *
// * Initially forked from Elgato's common.js file
// ****************************************************************

var websocket = null,
Expand Down Expand Up @@ -35,6 +37,7 @@ function connectElgatoStreamDeckSocket(inPort, inUUID, inRegisterEvent, inInfo,
document.dispatchEvent(event);

loadConfiguration(actionInfo.payload.settings);
initPropertyInspector();
}

function websocketOnOpen() {
Expand All @@ -57,7 +60,7 @@ function websocketOnMessage(evt) {
loadConfiguration(payload.settings);
}
else {
console.log("Unhandled websocketOnMessage: " + jsonObj.event);
console.log("Ignored websocketOnMessage: " + jsonObj.event);
}
}

Expand Down Expand Up @@ -212,8 +215,31 @@ window.addEventListener('beforeunload', function (e) {
// Don't set a returnValue to the event, otherwise Chromium with throw an error.
});

function prepareDOMElements(baseElement) {
baseElement = baseElement || document;

/**
* You could add a 'label' to a textares, e.g. to show the number of charactes already typed
* or contained in the textarea. This helper updates this label for you.
*/
baseElement.querySelectorAll('textarea').forEach((e) => {
const maxl = e.getAttribute('maxlength');
e.targets = baseElement.querySelectorAll(`[for='${e.id}']`);
if (e.targets.length) {
let fn = () => {
for (let x of e.targets) {
x.textContent = maxl ? `${e.value.length}/${maxl}` : `${e.value.length}`;
}
};
fn();
e.onkeyup = fn;
}
});
}

function initPropertyInspector() {
// Place to add functions
prepareDOMElements(document);
}


Expand Down

0 comments on commit dcf7d40

Please sign in to comment.