I would like to be able to watermark a cell in spreadJs with a padlock icon. I want this to be always at the right center of the cell like the image below.
Is this possible?
I can see the below link does something similar, but this is stretched across the whole cell which I don't really want as the cell width and height could be any width and height so this would look odd.
I would like the cell to function as normal and keep all existing style other than having a watermark over the cell of the padlock where needed.
https://help.grapecity.com/spread/SpreadJSWeb/backimage.html
UPDATE
I've just come across the following which I think is a potential for this to work using a custom cell. Does anyone have a simple example they can share where all it is doing is having a custom icon added to an existing cell?
https://help.grapecity.com/spread/SpreadJSWeb/cellcustom.html
SpreadJs support came back to me with the following example which suited my needs in case anyone else is strugglign with this for V12.7
Javascript
var spread;
var sheet;
$(document).ready(function () {
spread = new GC.Spread.Sheets.Workbook(document.getElementById("ss"), { sheetCount: 1 });
sheet = spread.getActiveSheet();
sheet.setColumnCount(5);
sheet.setRowCount(5);
sheet.suspendPaint();
sheet.getCell(0, 0).text("This is Circle text.").cellType(new IconCellType(document.getElementById('icon-lock')));
sheet.getCell(2, 0).text("Orange").cellType(new IconCellType(document.getElementById('icon-lock')));
sheet.resumePaint();
});
function IconCellType(img) {
this.typeName = "IconCellType";
this.img = img;
}
IconCellType.prototype = new GC.Spread.Sheets.CellTypes.Base();
// EllipsisTextCellType.prototype
IconCellType.prototype.paint = function (ctx, value, x, y, w, h, style, context) {
if (!ctx) {
return;
}
ctx.save();
// draw inside the cell's boundary
ctx.rect(x, y, w, h);
ctx.clip();
// draw text
GC.Spread.Sheets.CellTypes.Base.prototype.paint.apply(this, [ctx, value, x+20, y, w-20, h, style, context]);
ctx.beginPath();
// let img = document.getElementById('icon-lock');
ctx.drawImage(this.img, x + 2, y + 2, 16, 16);
ctx.fill();
ctx.stroke();
ctx.restore();
};
HTML
<img id="icon-lock" style="display:none" src=""/>
<h1>SpreadJS</h1>
<div id="ss" style="width: 500px; height: 400px; border: 1px solid gray"></div>
Renders