|  |  | @ -54,21 +54,6 @@ function each (obj, fn) { | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  | } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  | function getOffsets (el) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   let left = 0 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   let top = 0 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   while (el !== null) { |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     console.log(el) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     console.log(el.offsetLeft, el.offsetTop) |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     left += el.offsetLeft |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     top += el.offsetTop |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |     el = el.offsetParent |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  |   return [left, top] |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | } |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |  | 
			
		
	
		
		
			
				
					
					|  |  |  | module.exports = class ColorTriangle { |  |  |  | module.exports = class ColorTriangle { | 
			
		
	
		
		
			
				
					
					|  |  |  |   /**************** |  |  |  |   /**************** | 
			
		
	
		
		
			
				
					
					|  |  |  |    * ColorTriangle * |  |  |  |    * ColorTriangle * | 
			
		
	
	
		
		
			
				
					|  |  | @ -305,12 +290,35 @@ module.exports = class ColorTriangle { | 
			
		
	
		
		
			
				
					
					|  |  |  |   // The Element and the DOM
 |  |  |  |   // The Element and the DOM
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   inject (parent) { |  |  |  |   inject (parent) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     parent.appendChild(this.container) |  |  |  |     parent.appendChild(this.container) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |   _getRelativeCoordinates (evt) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     let pos = {} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     let offset = {} | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     let ref | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     // FIXME this doesn't really work with scroll
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     // this.triangle is the canvas element
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     ref = this.triangle.offsetParent | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     // calculate canvas position on page
 |  |  |  |     pos.x = evt.touches ? evt.touches[0].pageX : evt.pageX | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     const offsets = getOffsets(this.triangle) |  |  |  |     pos.y = evt.touches ? evt.touches[0].pageY : evt.pageY | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     this.offset = { |  |  |  | 
 | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       x: offsets[0], |  |  |  |     offset.left = this.triangle.offsetLeft | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |       y: offsets[1] |  |  |  |     offset.top = this.triangle.offsetTop | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     while (ref) { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       offset.left += ref.offsetLeft | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       offset.top += ref.offsetTop | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       ref = ref.offsetParent | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |     return { | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       x: pos.x - offset.left, | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       y: pos.y - offset.top | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -379,11 +387,14 @@ module.exports = class ColorTriangle { | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       doc.body.addEventListener('mousemove', mousemove, false) |  |  |  |       doc.body.addEventListener('mousemove', mousemove, false) | 
			
		
	
		
		
			
				
					
					|  |  |  |       doc.body.addEventListener('mouseup', mouseup, false) |  |  |  |       doc.body.addEventListener('mouseup', mouseup, false) | 
			
		
	
		
		
			
				
					
					|  |  |  |       this._map(evt.pageX, evt.pageY) |  |  |  | 
 | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       let xy = this._getRelativeCoordinates(evt) | 
			
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       this._map(xy.x, xy.y) | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     let mousemove = (evt) => { |  |  |  |     let mousemove = (evt) => { | 
			
		
	
		
		
			
				
					
					|  |  |  |       this._move(evt.pageX, evt.pageY) |  |  |  |       let xy = this._getRelativeCoordinates(evt) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |  |  |  |  |       this._move(xy.x, xy.y) | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     let mouseup = (evt) => { |  |  |  |     let mouseup = (evt) => { | 
			
		
	
	
		
		
			
				
					|  |  | @ -400,23 +411,22 @@ module.exports = class ColorTriangle { | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |   _map (x, y) { |  |  |  |   _map (x, y) { | 
			
		
	
		
		
			
				
					
					|  |  |  |     const ox = x |  |  |  |     let x0 = x | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     const oy = y |  |  |  |     let y0 = y | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  |     x -= this.wheelRadius | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     x -= this.offset.x + this.wheelRadius |  |  |  |     y -= this.wheelRadius | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     y -= this.offset.y + this.wheelRadius |  |  |  |  | 
			
		
	
		
		
	
		
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     const r = M.sqrt(x * x + y * y) // Pythagoras
 |  |  |  |     const r = M.sqrt(x * x + y * y) // Pythagoras
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (r > this.triangleRadius && r < this.wheelRadius) { |  |  |  |     if (r > this.triangleRadius && r < this.wheelRadius) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       // Wheel
 |  |  |  |       // Wheel
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       this.down = 'wheel' |  |  |  |       this.down = 'wheel' | 
			
		
	
		
		
			
				
					
					|  |  |  |       this._fireEvent('dragstart') |  |  |  |       this._fireEvent('dragstart') | 
			
		
	
		
		
			
				
					
					|  |  |  |       this._move(ox, oy) |  |  |  |       this._move(x0, y0) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } else if (r < this.triangleRadius) { |  |  |  |     } else if (r < this.triangleRadius) { | 
			
		
	
		
		
			
				
					
					|  |  |  |       // Inner circle
 |  |  |  |       // Inner circle
 | 
			
		
	
		
		
			
				
					
					|  |  |  |       this.down = 'triangle' |  |  |  |       this.down = 'triangle' | 
			
		
	
		
		
			
				
					
					|  |  |  |       this._fireEvent('dragstart') |  |  |  |       this._fireEvent('dragstart') | 
			
		
	
		
		
			
				
					
					|  |  |  |       this._move(ox, oy) |  |  |  |       this._move(x0, y0) | 
			
				
				
			
		
	
		
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  |   } |  |  |  |   } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
	
		
		
			
				
					|  |  | @ -425,8 +435,8 @@ module.exports = class ColorTriangle { | 
			
		
	
		
		
			
				
					
					|  |  |  |       return |  |  |  |       return | 
			
		
	
		
		
			
				
					
					|  |  |  |     } |  |  |  |     } | 
			
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     x -= this.offset.x + this.wheelRadius |  |  |  |     x -= this.wheelRadius | 
			
				
				
			
		
	
		
		
			
				
					
					|  |  |  |     y -= this.offset.y + this.wheelRadius |  |  |  |     y -= this.wheelRadius | 
			
				
				
			
		
	
		
		
	
		
		
	
		
		
			
				
					
					|  |  |  | 
 |  |  |  | 
 | 
			
		
	
		
		
			
				
					
					|  |  |  |     let rad = M.atan2(-y, x) |  |  |  |     let rad = M.atan2(-y, x) | 
			
		
	
		
		
			
				
					
					|  |  |  |     if (rad < 0) { |  |  |  |     if (rad < 0) { | 
			
		
	
	
		
		
			
				
					|  |  | 
 |