mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-11 02:30:21 +08:00
73 lines
5.6 KiB
CoffeeScript
73 lines
5.6 KiB
CoffeeScript
ThreadDragImage = document.createElement("img")
|
|
ThreadDragImage.src = """"""
|
|
|
|
DragCanvas = document.createElement("canvas")
|
|
DragCanvas.style.position = "absolute"
|
|
document.body.appendChild(DragCanvas)
|
|
|
|
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
|
|
|
|
module.exports = CanvasUtils
|