ThreadDragImage = document.createElement("img") ThreadDragImage.src = """""" DragCanvas = document.createElement("canvas") DragCanvas.style.position = "absolute" document.body.appendChild(DragCanvas) SystemTrayCanvas = document.createElement("canvas") CanvasUtils = roundRect: (ctx, x, y, width, height, radius = 5, fill, stroke = true) -> ctx.beginPath() ctx.moveTo(x + radius, y) ctx.lineTo(x + width - radius, y) ctx.quadraticCurveTo(x + width, y, x + width, y + radius) ctx.lineTo(x + width, y + height - radius) ctx.quadraticCurveTo(x + width, y + height, x + width - radius, y + height) ctx.lineTo(x + radius, y + height) ctx.quadraticCurveTo(x, y + height, x, y + height - radius) ctx.lineTo(x, y + radius) ctx.quadraticCurveTo(x, y, x + radius, y) ctx.closePath() ctx.stroke() if stroke ctx.fill() if fill canvasWithThreadDragImage: (count) -> canvas = DragCanvas # Make sure the canvas has a 2x pixel density on retina displays scale = window.devicePixelRatio canvas.width = 58 * scale canvas.height = 55 * scale canvas.style.width = "58px" canvas.style.height = "55px" # necessary for setDragImage to work ctx = canvas.getContext('2d') # mail background image if count > 1 ctx.rotate(-20*Math.PI/180) ctx.drawImage(ThreadDragImage, -10*scale, 2*scale, 48*scale, 48*scale) ctx.rotate(20*Math.PI/180) ctx.drawImage(ThreadDragImage, 0, 0, 48*scale, 48*scale) # count bubble dotGradient = ctx.createLinearGradient(0, 0, 0, 15 * scale) dotGradient.addColorStop(0, "rgb(116, 124, 143)") dotGradient.addColorStop(1, "rgb(67, 77, 104)") ctx.strokeStyle = "rgba(39, 48, 68, 0.6)" ctx.lineWidth = 1 ctx.fillStyle = dotGradient textX = 49 text = "#{count}" if (count < 10) CanvasUtils.roundRect(ctx, 41 * scale, 1 * scale, 16 * scale, 14 * scale, 7 * scale, true, true) else if (count < 100) CanvasUtils.roundRect(ctx, 37 * scale, 1 * scale, 20 * scale, 14 * scale, 7 * scale, true, true) textX = 46 else CanvasUtils.roundRect(ctx, 33 * scale, 1 * scale, 25 * scale, 14 * scale, 7 * scale, true, true) text = "99+" textX = 46 # count text ctx.fillStyle = "rgba(255,255,255,0.9)" ctx.font = "#{11 * scale}px sans-serif" ctx.textAlign = "center" ctx.fillText(text, textX * scale, 12 * scale, 30 * scale) return DragCanvas measureTextInCanvas: (text, font) -> canvas = document.createElement('canvas') context = canvas.getContext('2d') context.font = font return Math.ceil(context.measureText(text).width) canvasWithSystemTrayIconAndText: (img, text) -> canvas = SystemTrayCanvas w = img.width h = img.height font = '26px Nylas-Pro, sans-serif' textWidth = if text.length > 0 then CanvasUtils.measureTextInCanvas(text, font) + 2 else 0 canvas.width = w + textWidth canvas.height = h context = canvas.getContext('2d') context.font = font context.fillStyle = 'black' context.textAlign = 'start' context.textBaseline = 'middle' context.drawImage(img, 0, 0) # Place after img, vertically aligned context.fillText(text, w, h / 2) return canvas module.exports = CanvasUtils