aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--spec/spec/types/List.js29
-rw-r--r--src/types/List.js5
2 files changed, 34 insertions, 0 deletions
diff --git a/spec/spec/types/List.js b/spec/spec/types/List.js
index a6cab09..35c3886 100644
--- a/spec/spec/types/List.js
+++ b/spec/spec/types/List.js
@@ -73,6 +73,35 @@ describe('List.js', () => {
delete List.prototype.fooBar
})
+ it('keeps Array prototype names prefixed with $', () => {
+ // We're picking a function that we know isn't part of core svg.js
+ // If we implement an 'unshift' function at some point, change this to something else
+ if (List.prototype.hasOwnProperty('unshift')) {
+ fail('List.unshift is already a function - change this test to use a different name!');
+ return;
+ }
+
+ List.extend([ 'unshift' ])
+ expect(new List().unshift).toEqual(any(Function))
+ expect(new List().$unshift).toEqual(Array.prototype.unshift)
+
+ // Check that it works!
+ const sourceArray = [
+ { 'unshift': () => 1 },
+ { 'unshift': () => 2 },
+ { 'unshift': () => 3 }
+ ];
+ const list = new List(sourceArray)
+
+ expect(list).toEqual(sourceArray)
+ expect(list.unshift(0)).toEqual([1,2,3])
+
+ expect(list.$unshift(0)).toEqual(4)
+ expect(list).toEqual([0].concat(sourceArray))
+
+ delete List.prototype.unshift;
+ });
+
it('skips reserved names', () => {
const { constructor, each, toArray } = List.prototype
List.extend(['constructor', 'each', 'toArray'])
diff --git a/src/types/List.js b/src/types/List.js
index bdeb766..22b9027 100644
--- a/src/types/List.js
+++ b/src/types/List.js
@@ -47,6 +47,11 @@ List.extend = function (methods) {
// Don't add private methods
if (name[0] === '_') return obj
+ // Allow access to original Array methods through a prefix
+ if (name in Array.prototype) {
+ obj['$' + name] = Array.prototype[name]
+ }
+
// Relay every call to each()
obj[name] = function (...attrs) {
return this.each(name, ...attrs)