mirror of
https://github.com/scratchfoundation/paper.js.git
synced 2025-01-20 22:39:50 -05:00
Fixes #580 where resizable views were only taking into account their offset from the top left of the viewport.
This commit is contained in:
parent
f193acf31b
commit
6f1c3145bf
6 changed files with 136 additions and 135 deletions
1
.gitignore
vendored
1
.gitignore
vendored
|
@ -1 +1,2 @@
|
||||||
.DS_Store
|
.DS_Store
|
||||||
|
build/zip
|
||||||
|
|
54
dist/paper-core.js
vendored
54
dist/paper-core.js
vendored
|
@ -9,7 +9,7 @@
|
||||||
*
|
*
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Date: Sat Nov 22 09:01:01 2014 -0800
|
* Date: Tue Dec 2 22:31:20 2014 -0800
|
||||||
*
|
*
|
||||||
***
|
***
|
||||||
*
|
*
|
||||||
|
@ -219,10 +219,8 @@ var Base = new function() {
|
||||||
|| ctor.name === 'Object');
|
|| ctor.name === 'Object');
|
||||||
},
|
},
|
||||||
|
|
||||||
pick: function() {
|
pick: function(a, b) {
|
||||||
for (var i = 0, l = arguments.length; i < l; i++)
|
return a !== undefined ? a : b;
|
||||||
if (arguments[i] !== undefined)
|
|
||||||
return arguments[i];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -257,6 +255,10 @@ Base.inject({
|
||||||
}, []).join(', ') + ' }';
|
}, []).join(', ') + ' }';
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getClassName: function() {
|
||||||
|
return this._class || '';
|
||||||
|
},
|
||||||
|
|
||||||
exportJSON: function(options) {
|
exportJSON: function(options) {
|
||||||
return Base.exportJSON(this, options);
|
return Base.exportJSON(this, options);
|
||||||
},
|
},
|
||||||
|
@ -2833,10 +2835,6 @@ var Item = Base.extend(Emitter, {
|
||||||
return this._id;
|
return this._id;
|
||||||
},
|
},
|
||||||
|
|
||||||
getClassName: function() {
|
|
||||||
return this._class;
|
|
||||||
},
|
|
||||||
|
|
||||||
getName: function() {
|
getName: function() {
|
||||||
return this._name;
|
return this._name;
|
||||||
},
|
},
|
||||||
|
@ -5361,6 +5359,7 @@ var SegmentPoint = Point.extend({
|
||||||
|
|
||||||
var Curve = Base.extend({
|
var Curve = Base.extend({
|
||||||
_class: 'Curve',
|
_class: 'Curve',
|
||||||
|
|
||||||
initialize: function Curve(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7) {
|
initialize: function Curve(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7) {
|
||||||
var count = arguments.length;
|
var count = arguments.length;
|
||||||
if (count === 3) {
|
if (count === 3) {
|
||||||
|
@ -10321,21 +10320,8 @@ var View = Base.extend(Emitter, {
|
||||||
userDrag: none,
|
userDrag: none,
|
||||||
tapHighlightColor: 'rgba(0,0,0,0)'
|
tapHighlightColor: 'rgba(0,0,0,0)'
|
||||||
});
|
});
|
||||||
if (PaperScope.hasAttribute(element, 'resize')) {
|
|
||||||
var offset = DomElement.getOffset(element, true),
|
var getCanvasSize = function() {
|
||||||
that = this;
|
|
||||||
size = DomElement.getViewportBounds(element)
|
|
||||||
.getSize().subtract(offset);
|
|
||||||
this._windowEvents = {
|
|
||||||
resize: function() {
|
|
||||||
if (!DomElement.isInvisible(element))
|
|
||||||
offset = DomElement.getOffset(element, true);
|
|
||||||
that.setViewSize(DomElement.getViewportBounds(element)
|
|
||||||
.getSize().subtract(offset));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
DomEvent.add(window, this._windowEvents);
|
|
||||||
} else {
|
|
||||||
size = DomElement.getSize(element);
|
size = DomElement.getSize(element);
|
||||||
if (size.isNaN() || size.isZero()) {
|
if (size.isNaN() || size.isZero()) {
|
||||||
var getSize = function(name) {
|
var getSize = function(name) {
|
||||||
|
@ -10344,8 +10330,20 @@ var View = Base.extend(Emitter, {
|
||||||
};
|
};
|
||||||
size = new Size(getSize('width'), getSize('height'));
|
size = new Size(getSize('width'), getSize('height'));
|
||||||
}
|
}
|
||||||
|
return size;
|
||||||
|
};
|
||||||
|
|
||||||
|
this._resizable = PaperScope.hasAttribute(element, 'resize');
|
||||||
|
if (this._resizable) {
|
||||||
|
var that = this;
|
||||||
|
this._windowEvents = {
|
||||||
|
resize: function() {
|
||||||
|
that.setViewSize(getCanvasSize());
|
||||||
}
|
}
|
||||||
this._setViewSize(size);
|
};
|
||||||
|
DomEvent.add(window, this._windowEvents);
|
||||||
|
}
|
||||||
|
this._setViewSize(getCanvasSize());
|
||||||
if (PaperScope.hasAttribute(element, 'stats')
|
if (PaperScope.hasAttribute(element, 'stats')
|
||||||
&& typeof Stats !== 'undefined') {
|
&& typeof Stats !== 'undefined') {
|
||||||
this._stats = new Stats();
|
this._stats = new Stats();
|
||||||
|
@ -10760,8 +10758,10 @@ var CanvasView = View.extend({
|
||||||
element.width = width * pixelRatio;
|
element.width = width * pixelRatio;
|
||||||
element.height = height * pixelRatio;
|
element.height = height * pixelRatio;
|
||||||
if (pixelRatio !== 1) {
|
if (pixelRatio !== 1) {
|
||||||
|
if (this._resizable === false) {
|
||||||
style.width = width + 'px';
|
style.width = width + 'px';
|
||||||
style.height = height + 'px';
|
style.height = height + 'px';
|
||||||
|
}
|
||||||
this._context.scale(pixelRatio, pixelRatio);
|
this._context.scale(pixelRatio, pixelRatio);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -11735,11 +11735,11 @@ new function() {
|
||||||
scale = decomposed.scaling;
|
scale = decomposed.scaling;
|
||||||
if (trans && !trans.isZero())
|
if (trans && !trans.isZero())
|
||||||
parts.push('translate(' + formatter.point(trans) + ')');
|
parts.push('translate(' + formatter.point(trans) + ')');
|
||||||
if (angle)
|
|
||||||
parts.push('rotate(' + formatter.number(angle) + ')');
|
|
||||||
if (!Numerical.isZero(scale.x - 1)
|
if (!Numerical.isZero(scale.x - 1)
|
||||||
|| !Numerical.isZero(scale.y - 1))
|
|| !Numerical.isZero(scale.y - 1))
|
||||||
parts.push('scale(' + formatter.point(scale) +')');
|
parts.push('scale(' + formatter.point(scale) +')');
|
||||||
|
if (angle)
|
||||||
|
parts.push('rotate(' + formatter.number(angle) + ')');
|
||||||
attrs.transform = parts.join(' ');
|
attrs.transform = parts.join(' ');
|
||||||
} else {
|
} else {
|
||||||
attrs.transform = 'matrix(' + matrix.getValues().join(',') + ')';
|
attrs.transform = 'matrix(' + matrix.getValues().join(',') + ')';
|
||||||
|
|
54
dist/paper-full.js
vendored
54
dist/paper-full.js
vendored
|
@ -9,7 +9,7 @@
|
||||||
*
|
*
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Date: Sat Nov 22 09:01:01 2014 -0800
|
* Date: Tue Dec 2 22:31:20 2014 -0800
|
||||||
*
|
*
|
||||||
***
|
***
|
||||||
*
|
*
|
||||||
|
@ -219,10 +219,8 @@ var Base = new function() {
|
||||||
|| ctor.name === 'Object');
|
|| ctor.name === 'Object');
|
||||||
},
|
},
|
||||||
|
|
||||||
pick: function() {
|
pick: function(a, b) {
|
||||||
for (var i = 0, l = arguments.length; i < l; i++)
|
return a !== undefined ? a : b;
|
||||||
if (arguments[i] !== undefined)
|
|
||||||
return arguments[i];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -257,6 +255,10 @@ Base.inject({
|
||||||
}, []).join(', ') + ' }';
|
}, []).join(', ') + ' }';
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getClassName: function() {
|
||||||
|
return this._class || '';
|
||||||
|
},
|
||||||
|
|
||||||
exportJSON: function(options) {
|
exportJSON: function(options) {
|
||||||
return Base.exportJSON(this, options);
|
return Base.exportJSON(this, options);
|
||||||
},
|
},
|
||||||
|
@ -2833,10 +2835,6 @@ var Item = Base.extend(Emitter, {
|
||||||
return this._id;
|
return this._id;
|
||||||
},
|
},
|
||||||
|
|
||||||
getClassName: function() {
|
|
||||||
return this._class;
|
|
||||||
},
|
|
||||||
|
|
||||||
getName: function() {
|
getName: function() {
|
||||||
return this._name;
|
return this._name;
|
||||||
},
|
},
|
||||||
|
@ -5361,6 +5359,7 @@ var SegmentPoint = Point.extend({
|
||||||
|
|
||||||
var Curve = Base.extend({
|
var Curve = Base.extend({
|
||||||
_class: 'Curve',
|
_class: 'Curve',
|
||||||
|
|
||||||
initialize: function Curve(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7) {
|
initialize: function Curve(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7) {
|
||||||
var count = arguments.length;
|
var count = arguments.length;
|
||||||
if (count === 3) {
|
if (count === 3) {
|
||||||
|
@ -10321,21 +10320,8 @@ var View = Base.extend(Emitter, {
|
||||||
userDrag: none,
|
userDrag: none,
|
||||||
tapHighlightColor: 'rgba(0,0,0,0)'
|
tapHighlightColor: 'rgba(0,0,0,0)'
|
||||||
});
|
});
|
||||||
if (PaperScope.hasAttribute(element, 'resize')) {
|
|
||||||
var offset = DomElement.getOffset(element, true),
|
var getCanvasSize = function() {
|
||||||
that = this;
|
|
||||||
size = DomElement.getViewportBounds(element)
|
|
||||||
.getSize().subtract(offset);
|
|
||||||
this._windowEvents = {
|
|
||||||
resize: function() {
|
|
||||||
if (!DomElement.isInvisible(element))
|
|
||||||
offset = DomElement.getOffset(element, true);
|
|
||||||
that.setViewSize(DomElement.getViewportBounds(element)
|
|
||||||
.getSize().subtract(offset));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
DomEvent.add(window, this._windowEvents);
|
|
||||||
} else {
|
|
||||||
size = DomElement.getSize(element);
|
size = DomElement.getSize(element);
|
||||||
if (size.isNaN() || size.isZero()) {
|
if (size.isNaN() || size.isZero()) {
|
||||||
var getSize = function(name) {
|
var getSize = function(name) {
|
||||||
|
@ -10344,8 +10330,20 @@ var View = Base.extend(Emitter, {
|
||||||
};
|
};
|
||||||
size = new Size(getSize('width'), getSize('height'));
|
size = new Size(getSize('width'), getSize('height'));
|
||||||
}
|
}
|
||||||
|
return size;
|
||||||
|
};
|
||||||
|
|
||||||
|
this._resizable = PaperScope.hasAttribute(element, 'resize');
|
||||||
|
if (this._resizable) {
|
||||||
|
var that = this;
|
||||||
|
this._windowEvents = {
|
||||||
|
resize: function() {
|
||||||
|
that.setViewSize(getCanvasSize());
|
||||||
}
|
}
|
||||||
this._setViewSize(size);
|
};
|
||||||
|
DomEvent.add(window, this._windowEvents);
|
||||||
|
}
|
||||||
|
this._setViewSize(getCanvasSize());
|
||||||
if (PaperScope.hasAttribute(element, 'stats')
|
if (PaperScope.hasAttribute(element, 'stats')
|
||||||
&& typeof Stats !== 'undefined') {
|
&& typeof Stats !== 'undefined') {
|
||||||
this._stats = new Stats();
|
this._stats = new Stats();
|
||||||
|
@ -10760,8 +10758,10 @@ var CanvasView = View.extend({
|
||||||
element.width = width * pixelRatio;
|
element.width = width * pixelRatio;
|
||||||
element.height = height * pixelRatio;
|
element.height = height * pixelRatio;
|
||||||
if (pixelRatio !== 1) {
|
if (pixelRatio !== 1) {
|
||||||
|
if (this._resizable === false) {
|
||||||
style.width = width + 'px';
|
style.width = width + 'px';
|
||||||
style.height = height + 'px';
|
style.height = height + 'px';
|
||||||
|
}
|
||||||
this._context.scale(pixelRatio, pixelRatio);
|
this._context.scale(pixelRatio, pixelRatio);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -11735,11 +11735,11 @@ new function() {
|
||||||
scale = decomposed.scaling;
|
scale = decomposed.scaling;
|
||||||
if (trans && !trans.isZero())
|
if (trans && !trans.isZero())
|
||||||
parts.push('translate(' + formatter.point(trans) + ')');
|
parts.push('translate(' + formatter.point(trans) + ')');
|
||||||
if (angle)
|
|
||||||
parts.push('rotate(' + formatter.number(angle) + ')');
|
|
||||||
if (!Numerical.isZero(scale.x - 1)
|
if (!Numerical.isZero(scale.x - 1)
|
||||||
|| !Numerical.isZero(scale.y - 1))
|
|| !Numerical.isZero(scale.y - 1))
|
||||||
parts.push('scale(' + formatter.point(scale) +')');
|
parts.push('scale(' + formatter.point(scale) +')');
|
||||||
|
if (angle)
|
||||||
|
parts.push('rotate(' + formatter.number(angle) + ')');
|
||||||
attrs.transform = parts.join(' ');
|
attrs.transform = parts.join(' ');
|
||||||
} else {
|
} else {
|
||||||
attrs.transform = 'matrix(' + matrix.getValues().join(',') + ')';
|
attrs.transform = 'matrix(' + matrix.getValues().join(',') + ')';
|
||||||
|
|
23
dist/paper-node.js
vendored
23
dist/paper-node.js
vendored
|
@ -9,7 +9,7 @@
|
||||||
*
|
*
|
||||||
* All rights reserved.
|
* All rights reserved.
|
||||||
*
|
*
|
||||||
* Date: Sat Nov 22 09:01:01 2014 -0800
|
* Date: Tue Dec 2 22:31:20 2014 -0800
|
||||||
*
|
*
|
||||||
***
|
***
|
||||||
*
|
*
|
||||||
|
@ -219,10 +219,8 @@ var Base = new function() {
|
||||||
|| ctor.name === 'Object');
|
|| ctor.name === 'Object');
|
||||||
},
|
},
|
||||||
|
|
||||||
pick: function() {
|
pick: function(a, b) {
|
||||||
for (var i = 0, l = arguments.length; i < l; i++)
|
return a !== undefined ? a : b;
|
||||||
if (arguments[i] !== undefined)
|
|
||||||
return arguments[i];
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
@ -247,6 +245,10 @@ Base.inject({
|
||||||
}, []).join(', ') + ' }';
|
}, []).join(', ') + ' }';
|
||||||
},
|
},
|
||||||
|
|
||||||
|
getClassName: function() {
|
||||||
|
return this._class || '';
|
||||||
|
},
|
||||||
|
|
||||||
exportJSON: function(options) {
|
exportJSON: function(options) {
|
||||||
return Base.exportJSON(this, options);
|
return Base.exportJSON(this, options);
|
||||||
},
|
},
|
||||||
|
@ -2802,10 +2804,6 @@ var Item = Base.extend(Emitter, {
|
||||||
return this._id;
|
return this._id;
|
||||||
},
|
},
|
||||||
|
|
||||||
getClassName: function() {
|
|
||||||
return this._class;
|
|
||||||
},
|
|
||||||
|
|
||||||
getName: function() {
|
getName: function() {
|
||||||
return this._name;
|
return this._name;
|
||||||
},
|
},
|
||||||
|
@ -5345,6 +5343,7 @@ var SegmentPoint = Point.extend({
|
||||||
|
|
||||||
var Curve = Base.extend({
|
var Curve = Base.extend({
|
||||||
_class: 'Curve',
|
_class: 'Curve',
|
||||||
|
|
||||||
initialize: function Curve(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7) {
|
initialize: function Curve(arg0, arg1, arg2, arg3, arg4, arg5, arg6, arg7) {
|
||||||
var count = arguments.length;
|
var count = arguments.length;
|
||||||
if (count === 3) {
|
if (count === 3) {
|
||||||
|
@ -10481,8 +10480,10 @@ var CanvasView = View.extend({
|
||||||
element.width = width * pixelRatio;
|
element.width = width * pixelRatio;
|
||||||
element.height = height * pixelRatio;
|
element.height = height * pixelRatio;
|
||||||
if (pixelRatio !== 1) {
|
if (pixelRatio !== 1) {
|
||||||
|
if (this._resizable === false) {
|
||||||
style.width = width + 'px';
|
style.width = width + 'px';
|
||||||
style.height = height + 'px';
|
style.height = height + 'px';
|
||||||
|
}
|
||||||
this._context.scale(pixelRatio, pixelRatio);
|
this._context.scale(pixelRatio, pixelRatio);
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
@ -11075,11 +11076,11 @@ new function() {
|
||||||
scale = decomposed.scaling;
|
scale = decomposed.scaling;
|
||||||
if (trans && !trans.isZero())
|
if (trans && !trans.isZero())
|
||||||
parts.push('translate(' + formatter.point(trans) + ')');
|
parts.push('translate(' + formatter.point(trans) + ')');
|
||||||
if (angle)
|
|
||||||
parts.push('rotate(' + formatter.number(angle) + ')');
|
|
||||||
if (!Numerical.isZero(scale.x - 1)
|
if (!Numerical.isZero(scale.x - 1)
|
||||||
|| !Numerical.isZero(scale.y - 1))
|
|| !Numerical.isZero(scale.y - 1))
|
||||||
parts.push('scale(' + formatter.point(scale) +')');
|
parts.push('scale(' + formatter.point(scale) +')');
|
||||||
|
if (angle)
|
||||||
|
parts.push('rotate(' + formatter.number(angle) + ')');
|
||||||
attrs.transform = parts.join(' ');
|
attrs.transform = parts.join(' ');
|
||||||
} else {
|
} else {
|
||||||
attrs.transform = 'matrix(' + matrix.getValues().join(',') + ')';
|
attrs.transform = 'matrix(' + matrix.getValues().join(',') + ')';
|
||||||
|
|
|
@ -69,8 +69,12 @@ var CanvasView = View.extend(/** @lends CanvasView# */{
|
||||||
element.width = width * pixelRatio;
|
element.width = width * pixelRatio;
|
||||||
element.height = height * pixelRatio;
|
element.height = height * pixelRatio;
|
||||||
if (pixelRatio !== 1) {
|
if (pixelRatio !== 1) {
|
||||||
|
// If the canvas is resizable then don't override it otherwise
|
||||||
|
// give it fixed dimensions so it doesn't get resized.
|
||||||
|
if (this._resizable === false) {
|
||||||
style.width = width + 'px';
|
style.width = width + 'px';
|
||||||
style.height = height + 'px';
|
style.height = height + 'px';
|
||||||
|
}
|
||||||
// Now scale the context to counter the fact that we've manually
|
// Now scale the context to counter the fact that we've manually
|
||||||
// scaled our canvas element.
|
// scaled our canvas element.
|
||||||
this._context.scale(pixelRatio, pixelRatio);
|
this._context.scale(pixelRatio, pixelRatio);
|
||||||
|
|
|
@ -52,29 +52,8 @@ var View = Base.extend(Emitter, /** @lends View# */{
|
||||||
userDrag: none,
|
userDrag: none,
|
||||||
tapHighlightColor: 'rgba(0,0,0,0)'
|
tapHighlightColor: 'rgba(0,0,0,0)'
|
||||||
});
|
});
|
||||||
// If the element has the resize attribute, resize the it to fill the
|
|
||||||
// window and resize it again whenever the user resizes the window.
|
var getCanvasSize = function() {
|
||||||
if (PaperScope.hasAttribute(element, 'resize')) {
|
|
||||||
// Subtract element' viewport offset from the total size, to
|
|
||||||
// stretch it in
|
|
||||||
var offset = DomElement.getOffset(element, true),
|
|
||||||
that = this;
|
|
||||||
size = DomElement.getViewportBounds(element)
|
|
||||||
.getSize().subtract(offset);
|
|
||||||
this._windowEvents = {
|
|
||||||
resize: function() {
|
|
||||||
// Only update element offset if it's not invisible, as
|
|
||||||
// otherwise the offset would be wrong.
|
|
||||||
if (!DomElement.isInvisible(element))
|
|
||||||
offset = DomElement.getOffset(element, true);
|
|
||||||
// Set the size now, which internally calls onResize
|
|
||||||
// and redraws the view
|
|
||||||
that.setViewSize(DomElement.getViewportBounds(element)
|
|
||||||
.getSize().subtract(offset));
|
|
||||||
}
|
|
||||||
};
|
|
||||||
DomEvent.add(window, this._windowEvents);
|
|
||||||
} else {
|
|
||||||
// Try visible size first, since that will help handling previously
|
// Try visible size first, since that will help handling previously
|
||||||
// scaled canvases (e.g. when dealing with pixel-ratio)
|
// scaled canvases (e.g. when dealing with pixel-ratio)
|
||||||
size = DomElement.getSize(element);
|
size = DomElement.getSize(element);
|
||||||
|
@ -88,12 +67,28 @@ var View = Base.extend(Emitter, /** @lends View# */{
|
||||||
};
|
};
|
||||||
size = new Size(getSize('width'), getSize('height'));
|
size = new Size(getSize('width'), getSize('height'));
|
||||||
}
|
}
|
||||||
|
return size;
|
||||||
|
};
|
||||||
|
|
||||||
|
// If the element has the resize attribute, listen to resize events and
|
||||||
|
// update its coordinate space accordingly
|
||||||
|
this._resizable = PaperScope.hasAttribute(element, 'resize');
|
||||||
|
if (this._resizable) {
|
||||||
|
var that = this;
|
||||||
|
this._windowEvents = {
|
||||||
|
resize: function() {
|
||||||
|
// setViewSize is aware of a resizable canvas and only updates the
|
||||||
|
// coordinate space based on the physical dimensions and pixel ratio
|
||||||
|
that.setViewSize(getCanvasSize());
|
||||||
|
}
|
||||||
|
};
|
||||||
|
DomEvent.add(window, this._windowEvents);
|
||||||
}
|
}
|
||||||
// Set canvas size even if we just deterined the size from it, since
|
// Set canvas size even if we just deterined the size from it, since
|
||||||
// it might have been set to a % size, in which case it would use some
|
// it might have been set to a % size, in which case it would use some
|
||||||
// default internal size (300x150 on WebKit) and scale up the pixels.
|
// default internal size (300x150 on WebKit) and scale up the pixels.
|
||||||
// We also need this call here for HiDPI support.
|
// We also need this call here for HiDPI support.
|
||||||
this._setViewSize(size);
|
this._setViewSize(getCanvasSize());
|
||||||
// TODO: Test this on IE:
|
// TODO: Test this on IE:
|
||||||
if (PaperScope.hasAttribute(element, 'stats')
|
if (PaperScope.hasAttribute(element, 'stats')
|
||||||
&& typeof Stats !== 'undefined') {
|
&& typeof Stats !== 'undefined') {
|
||||||
|
|
Loading…
Reference in a new issue