123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384 |
- (function(){
- function splitOnWhitespace(trigger) {
- return trigger.split(/\s+/);
- }
- function parseClassOperation(trimmedValue) {
- var split = splitOnWhitespace(trimmedValue);
- if (split.length > 1) {
- var operation = split[0];
- var classDef = split[1].trim();
- var cssClass;
- var delay;
- if (classDef.indexOf(":") > 0) {
- var splitCssClass = classDef.split(':');
- cssClass = splitCssClass[0];
- delay = htmx.parseInterval(splitCssClass[1]);
- } else {
- cssClass = classDef;
- delay = 100;
- }
- return {
- operation:operation,
- cssClass:cssClass,
- delay:delay
- }
- } else {
- return null;
- }
- }
- function processClassList(elt, classList) {
- var runs = classList.split("&");
- for (var i = 0; i < runs.length; i++) {
- var run = runs[i];
- var currentRunTime = 0;
- var classOperations = run.split(",");
- for (var j = 0; j < classOperations.length; j++) {
- var value = classOperations[j];
- var trimmedValue = value.trim();
- var classOperation = parseClassOperation(trimmedValue);
- if (classOperation) {
- if (classOperation.operation === "toggle") {
- setTimeout(function () {
- setInterval(function () {
- elt.classList[classOperation.operation].call(elt.classList, classOperation.cssClass);
- }, classOperation.delay);
- }, currentRunTime);
- currentRunTime = currentRunTime + classOperation.delay;
- } else {
- currentRunTime = currentRunTime + classOperation.delay;
- setTimeout(function () {
- elt.classList[classOperation.operation].call(elt.classList, classOperation.cssClass);
- }, currentRunTime);
- }
- }
- }
- }
- }
- function maybeProcessClasses(elt) {
- if (elt.getAttribute) {
- var classList = elt.getAttribute("classes") || elt.getAttribute("data-classes");
- if (classList) {
- processClassList(elt, classList);
- }
- }
- }
- htmx.defineExtension('class-tools', {
- onEvent: function (name, evt) {
- if (name === "htmx:afterProcessNode") {
- var elt = evt.detail.elt;
- maybeProcessClasses(elt);
- if (elt.querySelectorAll) {
- var children = elt.querySelectorAll("[classes], [data-classes]");
- for (var i = 0; i < children.length; i++) {
- maybeProcessClasses(children[i]);
- }
- }
- }
- }
- });
- })();
|