From 3b62ed024494cb73ddb37669eaa7a00e15934dcf Mon Sep 17 00:00:00 2001 From: Adam Goldsmith Date: Thu, 21 Sep 2017 12:03:43 -0400 Subject: [PATCH] Make scaling happen on doubletap, and be more persistent --- script.js | 22 +++++++--------------- 1 file changed, 7 insertions(+), 15 deletions(-) diff --git a/script.js b/script.js index 1ce1a92..d0244ea 100644 --- a/script.js +++ b/script.js @@ -42,19 +42,10 @@ let cardInteract = interact('.card', {ignoreFrom: '.in-list'}) onmove: dragMoveListener }) - .on('hold', event => { - let target = event.target, - transform = target.style.transform; - // Scale up for visibility - if (transform.includes("scale(2)")) { - // translate the element - target.style.webkitTransform = - target.style.transform = transform.replace(" scale(2)", ""); - } - else { - target.style.webkitTransform = - target.style.transform = transform + ' scale(2)'; - } + .on('doubletap', event => { + let scale = parseFloat(event.target.getAttribute('data-scale')) === 2 ? 1 : 2; + event.target.setAttribute('data-scale', scale); + dragMoveListener({target: event.target, dx: 0, dy: 0}); }); interact('.card-pile') @@ -188,11 +179,12 @@ function dragMoveListener (event) { // keep the dragged position in the data-x/data-y attributes x = (parseFloat(target.getAttribute('data-x')) || 0) + event.dx, y = (parseFloat(target.getAttribute('data-y')) || 0) + event.dy; + scale = (parseFloat(target.getAttribute('data-scale')) || 1); - // translate the element + // translate and scale the element target.style.webkitTransform = target.style.transform = - 'translate(' + x + 'px, ' + y + 'px)'; + 'translate(' + x + 'px, ' + y + 'px) scale(' + scale + ')'; // raise to top target.parentElement.removeChild(target);