jquery.byteLimit: Trigger 'change' event after limitting
authorBartosz Dziewoński <matma.rex@gmail.com>
Thu, 20 Aug 2015 15:27:42 +0000 (17:27 +0200)
committerBartosz Dziewoński <matma.rex@gmail.com>
Thu, 20 Aug 2015 15:27:42 +0000 (17:27 +0200)
For better interoperability with scripts that are unaware of it.

Since jquery.byteLimit itself listens to the 'change' event,
tweak the conditions to avoid getting stuck in an infinite loop.

Change-Id: Ie782d14ba7d676b248109a3179bbec19552dfc52

resources/src/jquery/jquery.byteLimit.js

index e2315d2..5ffcae8 100644 (file)
                        }
                }
 
-               newVal = inpParts.join( '' );
-
                return {
-                       newVal: newVal,
-                       trimmed: true
+                       newVal: inpParts.join( '' ),
+                       // For pathological fn() that always returns a value longer than the limit, we might have
+                       // ended up not trimming - check for this case to avoid infinite loops
+                       trimmed: newVal !== inpParts.join( '' )
                };
        }
 
                                // This is a side-effect of limiting after the fact.
                                if ( res.trimmed === true ) {
                                        this.value = res.newVal;
+                                       // Trigger a 'change' event to let other scripts attached to this node know that the value
+                                       // was changed. This will also call ourselves again, but that's okay, it'll be a no-op.
+                                       $el.trigger( 'change' );
                                }
                                // Always adjust prevSafeVal to reflect the input value. Not doing this could cause
                                // trimValueForByteLength to compare the new value to an empty string instead of the