Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

ISSUE-4115 - triggers in/out events for sub targets #6013

Merged
Merged
Show file tree
Hide file tree
Changes from 5 commits
Commits
Show all changes
25 commits
Select commit Hold shift + click to select a range
54c5923
Fixes #4115 - triggers in/out events for sub targets; and calls _setC…
jakedowns Dec 3, 2019
b6fa464
added a .__guid property to each object to simplify hoveredTargets an…
jakedowns Dec 4, 2019
3c082a9
Revert "added a .__guid property to each object to simplify hoveredTa…
jakedowns Dec 11, 2019
5fbf4a4
Merge branch 'master' into ISSUE-4115-mouse-over-out-sub-targets
jakedowns Dec 11, 2019
15ab4ba
reverting hoveredTargets to bare bones implementation
jakedowns Dec 11, 2019
38ae830
this is an idea
asturur Dec 14, 2019
bc48c2d
this is an idea
asturur Dec 14, 2019
f3bb7ed
adjustments to PR #6032
jakedowns Dec 15, 2019
69647aa
Merge branch 'sub-targeting-mouse-in-out' into ISSUE-4115-mouse-over-…
jakedowns Dec 15, 2019
4ab6f2a
adjust additional _hoveredTarget management
jakedowns Dec 15, 2019
f24f61f
move _this to where it's needed
jakedowns Dec 15, 2019
bd6590d
more cleanup of lingering stuff from earlier commits
jakedowns Dec 15, 2019
7d40b4d
fix linter error
jakedowns Dec 15, 2019
b4251d0
targets: default to empty array
jakedowns Dec 15, 2019
41978dd
correction to jsdoc array of fabric.Object type declaration
jakedowns Dec 15, 2019
deb64f0
remove genuine unique id GUID getter from object class
jakedowns Dec 15, 2019
426e68c
simplify & optimize for minification
jakedowns Dec 15, 2019
0cd4196
updated _fireEnterLeaveEvents to include subTargets
jakedowns Dec 15, 2019
1909d1f
adjusted _setCursorFromEvent to account for subTargets
jakedowns Dec 15, 2019
7483142
stub in unit test for #4115
jakedowns Dec 15, 2019
c4e53ce
revert change in _onDragOver, call to _fireEnterLeaveEvents should be…
jakedowns Dec 16, 2019
3826d2e
updates after running tests
jakedowns Dec 18, 2019
3714348
rm unused var
jakedowns Dec 18, 2019
dbaf781
replace Array.fill with for loop (IE support)
jakedowns Dec 18, 2019
06e9c7e
update _fireEnterLeaveEvents to match _fireOverOutEvents
jakedowns Dec 18, 2019
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
17 changes: 15 additions & 2 deletions src/canvas.class.js
Original file line number Diff line number Diff line change
Expand Up @@ -1477,8 +1477,21 @@
this.fire('selection:cleared', { target: obj });
obj.fire('deselected');
}
if (this._hoveredTarget === obj) {
this._hoveredTarget = null;
// TODO: need a way to cleanly check if obj is one of _hoveredTargetN and de-ref it
// if (obj === this._hoveredTarget){
// this._hoveredTarget = null;
// }
// is there a more sane way than looping through ALL properties of *this* ?
// i wanted to put them into a ._hoveredTargets[Array]
// but, that complicates the logic of fireSyntheticInOutEvents
jakedowns marked this conversation as resolved.
Show resolved Hide resolved
var keys = Object.keys(this);
for (var i = 0; i < keys.length; i++){
var key = keys[i];
if (key.indexOf('_hoveredTarget') > -1){
if (obj === this[key]){
this[key] = null;
}
}
}
this.callSuper('_onObjectRemoved', obj);
},
Expand Down
55 changes: 43 additions & 12 deletions src/mixins/canvas_events.mixin.js
Original file line number Diff line number Diff line change
Expand Up @@ -166,10 +166,26 @@
* @param {Event} e Event object fired on mousedown
*/
_onMouseOut: function(e) {
console.log('_onMouseOut',e);

// pre-ISSUE-4115
var target = this._hoveredTarget;
this.fire('mouse:out', { target: target, e: e });
this._hoveredTarget = null;
target && target.fire('mouseout', { e: e });

// post-ISSUE-4115
// should we really be firing mouseOut on ALL _hoveredTargets?
// maybe just the top-level one? I dunno...
var keys = Object.keys(this);
for (var i = 0; i < keys.length; i++){
var key = keys[i];
if (key.indexOf('_hoveredTarget') > -1){
var target = this[key];
this.fire('mouse:out', { target: target, e: e });
target && target.fire('mouseout', { e: e });
}
}

if (this._iTextInstances) {
this._iTextInstances.forEach(function(obj) {
if (obj.isEditing) {
Expand All @@ -192,7 +208,16 @@
// side effects we added to it.
if (!this.currentTransform && !this.findTarget(e)) {
this.fire('mouse:over', { target: null, e: e });
this._hoveredTarget = null;
// PRE-ISSUE-4115
// this._hoveredTarget = null;
// POST-ISSUE-4115
var keys = Object.keys(this);
for (var i = 0; i < keys.length; i++){
var key = keys[i];
if (key.indexOf('_hoveredTarget') > -1){
this[key] = null;
}
}
}
},

Expand Down Expand Up @@ -231,7 +256,7 @@
_onDragOver: function(e) {
e.preventDefault();
var target = this._simpleEventHandler('dragover', e);
this._fireEnterLeaveEvents(target, e);
this._fireEnterLeaveEvents([target].concat(this.targets), e);
jakedowns marked this conversation as resolved.
Show resolved Hide resolved
},

/**
Expand Down Expand Up @@ -777,7 +802,7 @@
__onMouseMove: function (e) {
this._handleEvent(e, 'move:before');
this._cacheTransformEventData(e);
var target, pointer;
var target, pointer, _this = this;

if (this.isDrawingMode) {
this._onMouseMoveInDrawingMode(e);
Expand All @@ -803,6 +828,14 @@
target = this.findTarget(e) || null;
this._setCursorFromEvent(e, target);
this._fireOverOutEvents(target, e);
// handle triggering on SubTargets
this.targets.map(function(subTarget,k){
_this._fireOverOutEvents(subTarget, e, '_hoveredTarget' + k);
});
// hoverCursor should come from top-most subtarget
this.targets.slice(0).reverse().map(function(subTarget){
_this._setCursorFromEvent(e, subTarget);
});
}
else {
this._transformObject(e);
Expand All @@ -813,13 +846,13 @@

/**
* Manage the mouseout, mouseover events for the fabric object on the canvas
* @param {Fabric.Object} target the target where the target from the mousemove event
* @param {Event} e Event object fired on mousemove
* @param {String} targetName property on the canvas where the target is stored
* @private
*/
_fireOverOutEvents: function(target, e) {
_fireOverOutEvents: function(target, e, targetName) {
this.fireSyntheticInOutEvents(target, e, {
targetName: '_hoveredTarget',
targetName: targetName || '_hoveredTarget',
canvasEvtOut: 'mouse:out',
evtOut: 'mouseout',
canvasEvtIn: 'mouse:over',
Expand All @@ -843,7 +876,6 @@

/**
* Manage the synthetic in/out events for the fabric objects on the canvas
* @param {Fabric.Object} target the target where the target from the supported events
* @param {Event} e Event object fired
* @param {Object} config configuration for the function to work
* @param {String} config.targetName property on the canvas where the old target is stored
Expand All @@ -857,12 +889,11 @@
var inOpt, outOpt, oldTarget = this[config.targetName], outFires, inFires,
targetChanged = oldTarget !== target, canvasEvtIn = config.canvasEvtIn, canvasEvtOut = config.canvasEvtOut;
if (targetChanged) {
inOpt = { e: e, target: target, previousTarget: oldTarget };
outOpt = { e: e, target: oldTarget, nextTarget: target };
inOpt = {e: e, target: target, previousTarget: oldTarget};
outOpt = {e: e, target: oldTarget, nextTarget: target};
this[config.targetName] = target;
console.log(config.targetName, target); //
}
inFires = target && targetChanged;
outFires = oldTarget && targetChanged;
if (outFires) {
canvasEvtOut && this.fire(canvasEvtOut, outOpt);
oldTarget.fire(config.evtOut, outOpt);
Expand Down
24 changes: 24 additions & 0 deletions src/mixins/canvas_grouping.mixin.js
Original file line number Diff line number Diff line change
Expand Up @@ -53,6 +53,20 @@
if (activeSelection.contains(target)) {
activeSelection.removeWithUpdate(target);
this._hoveredTarget = target;
// ISSUE-4115: clear out any additional hovered targets that were set?
// should we fire mouse:out on those?
var keys = Object.keys(this);
for (var i = 0; i < keys.length; i++){
var key = keys[i];
if (key.indexOf('_hoveredTarget') > -1){
this[key] = null;
}
}
// ISSUE-4115: loop through this.targets and assign them as hovered as well?
// why don't we fire mouse:over here?
for (var i = 0; i < this.targets.length; i++){
this['_hoveredTarget' + i] = this.targets[i];
}
if (activeSelection.size() === 1) {
// activate last remaining object
this._setActiveObject(activeSelection.item(0), e);
Expand All @@ -61,6 +75,15 @@
else {
activeSelection.addWithUpdate(target);
this._hoveredTarget = activeSelection;
// ISSUE-4115: clear out any additional hovered targets that were set?
// should we fire mouse:out on those?
var keys = Object.keys(this);
for (var i = 0; i < keys.length; i++){
var key = keys[i];
if (key.indexOf('_hoveredTarget') > -1){
this[key] = null;
}
}
}
this._fireSelectionEvents(currentActiveObjects, e);
},
Expand All @@ -71,6 +94,7 @@
_createActiveSelection: function(target, e) {
var currentActives = this.getActiveObjects(), group = this._createGroup(target);
this._hoveredTarget = group;
// ISSUE 4115: should we consider subTargets here?
jakedowns marked this conversation as resolved.
Show resolved Hide resolved
this._setActiveObject(group, e);
this._fireSelectionEvents(currentActives, e);
},
Expand Down
19 changes: 19 additions & 0 deletions src/shapes/object.class.js
Original file line number Diff line number Diff line change
Expand Up @@ -2116,4 +2116,23 @@
*/
fabric.Object.__uid = 0;

/**
* A GUID for tracking hovered targets and sub targets
* simply tracking via subTargets[index] is not reliable
*/
function generateGUID() {
// https://stackoverflow.com/questions/8012002/create-a-unique-number-with-javascript-time
return new Date().valueOf().toString(36) + Math.random().toString(36).substr(2);
// return 'xxxxxxxx-xxxx-4xxx-yxxx-xxxxxxxxxxxx'.replace(/[xy]/g, function(c) {
// var r = Math.random() * 16 | 0, v = c == 'x' ? r : (r & 0x3 | 0x8);
// return v.toString(16);
// });
}
fabric.Object.prototype.__defineGetter__('__guid', function(){
if (!this.__myGUID) {
this.__myGUID = generateGUID();
}
return this.__myGUID;
});
jakedowns marked this conversation as resolved.
Show resolved Hide resolved

})(typeof exports !== 'undefined' ? exports : this);
2 changes: 1 addition & 1 deletion test/unit/canvas_events.js
Original file line number Diff line number Diff line change
Expand Up @@ -550,7 +550,7 @@
c._hoveredTarget = obj;
c.currentTransform = {};
c.upperCanvasEl.dispatchEvent(event);
assert.equal(c._hoveredTarget, obj, '_hoveredTarget has been removed');
assert.equal(c._hoveredTarget, obj, '_hoveredTarget has been not removed');
});

QUnit.test('mouseEnter removes __corner', function(assert) {
Expand Down