import "./chunk-V4OQ3NZ2.js";
// ../node_modules/.pnpm/watermark-js-plus@1.6.3/node_modules/watermark-js-plus/dist/index.esm.js
function styleInject(css, ref) {
if (ref === void 0) ref = {};
var insertAt = ref.insertAt;
if (typeof document === "undefined") {
return;
}
var head = document.head || document.getElementsByTagName("head")[0];
var style = document.createElement("style");
style.type = "text/css";
if (insertAt === "top") {
if (head.firstChild) {
head.insertBefore(style, head.firstChild);
} else {
head.appendChild(style);
}
} else {
head.appendChild(style);
}
if (style.styleSheet) {
style.styleSheet.cssText = css;
} else {
style.appendChild(document.createTextNode(css));
}
}
var css_248z = "@keyframes watermark{0%{background-position:0 0}25%{background-position:100% 100%}50%{background-position:100% 0}75%{background-position:0 100%}to{background-position:0 0}}@keyframes watermark-horizontal{0%{background-position-x:0}to{background-position-x:100%}}@keyframes watermark-vertical{0%{background-position-y:0}to{background-position-y:100%}}";
styleInject(css_248z);
var extendStatics = function(d, b) {
extendStatics = Object.setPrototypeOf || { __proto__: [] } instanceof Array && function(d2, b2) {
d2.__proto__ = b2;
} || function(d2, b2) {
for (var p in b2) if (Object.prototype.hasOwnProperty.call(b2, p)) d2[p] = b2[p];
};
return extendStatics(d, b);
};
function __extends(d, b) {
if (typeof b !== "function" && b !== null)
throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
extendStatics(d, b);
function __() {
this.constructor = d;
}
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
}
var __assign = function() {
__assign = Object.assign || function __assign2(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
function __awaiter(thisArg, _arguments, P, generator) {
function adopt(value) {
return value instanceof P ? value : new P(function(resolve) {
resolve(value);
});
}
return new (P || (P = Promise))(function(resolve, reject) {
function fulfilled(value) {
try {
step(generator.next(value));
} catch (e) {
reject(e);
}
}
function rejected(value) {
try {
step(generator["throw"](value));
} catch (e) {
reject(e);
}
}
function step(result) {
result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected);
}
step((generator = generator.apply(thisArg, _arguments || [])).next());
});
}
function __generator(thisArg, body) {
var _ = { label: 0, sent: function() {
if (t[0] & 1) throw t[1];
return t[1];
}, trys: [], ops: [] }, f, y, t, g = Object.create((typeof Iterator === "function" ? Iterator : Object).prototype);
return g.next = verb(0), g["throw"] = verb(1), g["return"] = verb(2), typeof Symbol === "function" && (g[Symbol.iterator] = function() {
return this;
}), g;
function verb(n) {
return function(v) {
return step([n, v]);
};
}
function step(op) {
if (f) throw new TypeError("Generator is already executing.");
while (g && (g = 0, op[0] && (_ = 0)), _) try {
if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
if (y = 0, t) op = [op[0] & 2, t.value];
switch (op[0]) {
case 0:
case 1:
t = op;
break;
case 4:
_.label++;
return { value: op[1], done: false };
case 5:
_.label++;
y = op[1];
op = [0];
continue;
case 7:
op = _.ops.pop();
_.trys.pop();
continue;
default:
if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) {
_ = 0;
continue;
}
if (op[0] === 3 && (!t || op[1] > t[0] && op[1] < t[3])) {
_.label = op[1];
break;
}
if (op[0] === 6 && _.label < t[1]) {
_.label = t[1];
t = op;
break;
}
if (t && _.label < t[2]) {
_.label = t[2];
_.ops.push(op);
break;
}
if (t[2]) _.ops.pop();
_.trys.pop();
continue;
}
op = body.call(thisArg, _);
} catch (e) {
op = [6, e];
y = 0;
} finally {
f = t = 0;
}
if (op[0] & 5) throw op[1];
return { value: op[0] ? op[1] : void 0, done: true };
}
}
var convertImage = function(canvas) {
return canvas.toDataURL("image/png", 1);
};
var isFunction = function(value) {
return typeof value === "function";
};
var isUndefined = function(value) {
return value === void 0;
};
var isString = function(value) {
return typeof value === "string";
};
var createSVGElement = function(tagName, attrs, namespaceURI) {
if (attrs === void 0) {
attrs = {};
}
if (namespaceURI === void 0) {
namespaceURI = "http://www.w3.org/2000/svg";
}
var element = document.createElementNS(namespaceURI, tagName);
for (var attr in attrs) {
element.setAttribute(attr, attrs[attr]);
}
return element;
};
var getMultiLineData = function(ctx, text, maxWidth) {
var result = [];
var str = "";
var word = "";
for (var i = 0, len = text.length; i < len; i++) {
word = text.charAt(i);
if (word === "\n") {
result.push(str);
str = "";
continue;
}
str += word;
if (ctx.measureText(str).width > maxWidth) {
result.push(str.substring(0, str.length - 1));
str = "";
i--;
}
}
result.push(str);
return result;
};
var createCustomContentSVG = function(ctx, options) {
return __awaiter(void 0, void 0, void 0, function() {
var svgElement, bodyElement, rect, rectWidth, rectHeight, width, height, foreignObjectElement;
var _a;
return __generator(this, function(_b) {
switch (_b.label) {
case 0:
svgElement = createSVGElement("svg", {
xmlns: "http://www.w3.org/2000/svg"
});
bodyElement = document.createElement("div");
bodyElement.setAttribute("xmlns", "http://www.w3.org/1999/xhtml");
bodyElement.style.cssText = "\n text-align: center;\n display: flex;\n align-items: center;\n justify-content: center;\n width: 100%;\n height: 100%;\n font: ".concat(ctx.font, ";\n color: ").concat(options.fontColor, ";\n");
bodyElement.innerHTML = "
".concat(options.content, "
");
document.body.appendChild(bodyElement);
return [4, convertImgToBase64(bodyElement)];
case 1:
_b.sent();
rect = (_a = bodyElement.querySelector(".rich-text-content")) === null || _a === void 0 ? void 0 : _a.getBoundingClientRect();
rectWidth = rect === null || rect === void 0 ? void 0 : rect.width;
rectHeight = rect === null || rect === void 0 ? void 0 : rect.height;
document.body.removeChild(bodyElement);
width = options.richTextWidth || rectWidth || options.width;
height = options.richTextHeight || rectHeight || options.height;
svgElement.setAttribute("width", width.toString());
svgElement.setAttribute("height", height.toString());
foreignObjectElement = createSVGElement("foreignObject", {
width: width.toString(),
height: height.toString()
});
foreignObjectElement.appendChild(bodyElement);
svgElement.appendChild(foreignObjectElement);
return [2, {
element: svgElement,
width,
height
}];
}
});
});
};
function convertImgToBase64(bodyElement) {
return __awaiter(this, void 0, void 0, function() {
var imgElements, _loop_1, _i, _a, img;
return __generator(this, function(_b) {
switch (_b.label) {
case 0:
imgElements = bodyElement.querySelectorAll("img");
_loop_1 = function(img2) {
var src, response, blob_1, imgData, error_1;
return __generator(this, function(_c) {
switch (_c.label) {
case 0:
src = img2.getAttribute("src");
if (!src) return [3, 6];
_c.label = 1;
case 1:
_c.trys.push([1, 5, , 6]);
return [4, fetch(src)];
case 2:
response = _c.sent();
return [4, response.blob()];
case 3:
blob_1 = _c.sent();
return [4, new Promise(function(resolve, reject) {
var reader = new FileReader();
reader.onloadend = function() {
return resolve(reader.result);
};
reader.onerror = reject;
reader.readAsDataURL(blob_1);
})];
case 4:
imgData = _c.sent();
if (isString(imgData)) {
img2.setAttribute("src", imgData);
}
return [3, 6];
case 5:
error_1 = _c.sent();
console.error("Error converting ".concat(src, " to base64:"), error_1);
return [3, 6];
case 6:
return [
2
/*return*/
];
}
});
};
_i = 0, _a = Array.from(imgElements);
_b.label = 1;
case 1:
if (!(_i < _a.length)) return [3, 4];
img = _a[_i];
return [5, _loop_1(img)];
case 2:
_b.sent();
_b.label = 3;
case 3:
_i++;
return [3, 1];
case 4:
return [
2
/*return*/
];
}
});
});
}
var convertSVGToImage = function(svg) {
var richContent = svg.outerHTML.replace(/<(img|br|input|hr|embed)(.*?)>/g, "<$1$2/>").replace(/\n/g, "").replace(/\t/g, "").replace(/#/g, "%23");
return "data:image/svg+xml;charset=utf-8,".concat(richContent);
};
var getValue = function(v1, v2) {
if (isUndefined(v1)) {
return v2;
} else {
return v1;
}
};
var loadImage = function(url, width, height) {
if (width === void 0) {
width = void 0;
}
if (height === void 0) {
height = void 0;
}
var image = new Image();
image.setAttribute("crossOrigin", "anonymous");
!isUndefined(width) && (image.width = width);
!isUndefined(height) && (image.height = height);
image.src = url;
return new Promise(function(resolve) {
image.onload = function() {
resolve(image);
};
});
};
var generateMatrix = function(rows, columns, value) {
return Array.from({ length: rows }, function() {
return new Array(columns).fill(value);
});
};
var generateAnimationStyle = function(movable, backgroundRepeat) {
if (!movable) {
return "";
}
var horizontalDuration = Math.random() * (8 - 2) + 2;
var verticalDuration = Math.random() * (4 - 2) + 2;
switch (backgroundRepeat) {
case "repeat":
return "animation: 200s linear 0s infinite alternate watermark !important;";
case "repeat-x":
return "animation: ".concat(horizontalDuration, "s linear 0s infinite alternate watermark-vertical !important;'");
case "repeat-y":
return "animation: ".concat(verticalDuration, "s linear 0s infinite alternate watermark-horizontal !important;'");
case "no-repeat":
return "animation: ".concat(horizontalDuration, "s linear 0s infinite alternate watermark-horizontal, ").concat(verticalDuration, "s linear 0s infinite alternate watermark-vertical !important;");
default:
return "";
}
};
var initialOptions = {
width: 300,
height: 300,
rotate: 45,
layout: "default",
auxiliaryLine: false,
translatePlacement: "middle",
contentType: "text",
content: "hello watermark-js-plus",
textType: "fill",
imageWidth: 0,
imageHeight: 0,
lineHeight: 30,
zIndex: 2147483647,
backgroundPosition: "0 0",
backgroundRepeat: "repeat",
fontSize: "20px",
fontFamily: "sans-serif",
fontStyle: "",
fontVariant: "",
fontColor: "#000",
fontWeight: "normal",
filter: "none",
letterSpacing: "0px",
wordSpacing: "0px",
globalAlpha: 0.5,
mode: "default",
mutationObserve: true,
monitorProtection: false,
movable: false,
parent: "body",
onSuccess: function() {
},
onBeforeDestroy: function() {
},
onDestroyed: function() {
},
onObserveError: function() {
}
};
var generateRecommendOptions = function(canvas, options, args) {
var ctx = canvas.getContext("2d");
if (ctx === null) {
throw new Error("get context error");
}
ctx.font = "".concat(options.fontStyle, " ").concat(options.fontVariant, " ").concat(options.fontWeight, " ").concat(options.fontSize, " ").concat(options.fontFamily);
ctx.filter = options.filter;
ctx.letterSpacing = options.letterSpacing;
ctx.wordSpacing = options.wordSpacing;
if (options === null || options === void 0 ? void 0 : options.rotate) {
options.rotate = (360 - options.rotate % 360) * (Math.PI / 180);
}
if (isUndefined(args.textRowMaxWidth)) {
options.textRowMaxWidth = options.width;
}
var result = {
image: {
rect: {
width: options.imageWidth,
height: options.imageHeight
},
position: {
x: 0,
y: 0
}
},
textLine: {
data: [],
yOffsetValue: 0
},
advancedStyleParams: {
linear: {
x0: 0,
x1: 0
},
radial: {
x0: 0,
y0: 0,
r0: 0,
x1: 0,
y1: 0,
r1: 0
},
conic: {
x: 0,
y: 0,
startAngle: 0
},
pattern: {}
}
};
switch (options.contentType) {
case "text":
result.textLine.data = [options.content];
break;
case "multi-line-text":
result.textLine.data = getMultiLineData(ctx, options.content, options.textRowMaxWidth);
break;
}
var translateX = options.width / 2;
var translateY = options.height / 2;
var textBaseline = "middle";
var textAlign = "center";
if (!isUndefined(args === null || args === void 0 ? void 0 : args.translateX) && !isUndefined(args === null || args === void 0 ? void 0 : args.translateY)) {
translateX = args === null || args === void 0 ? void 0 : args.translateX;
translateY = args === null || args === void 0 ? void 0 : args.translateY;
textBaseline = "top";
textAlign = "left";
} else {
result.advancedStyleParams.linear.x0 = -options.width / 2;
result.advancedStyleParams.linear.x1 = options.width / 2;
result.advancedStyleParams.radial.r0 = 0;
result.advancedStyleParams.radial.r1 = options.width / 2;
}
switch (args.translatePlacement) {
case "top":
translateX = options.width / 2;
translateY = 0;
textBaseline = "top";
result.advancedStyleParams.linear.x0 = -options.width / 2;
result.advancedStyleParams.linear.x1 = options.width / 2;
result.advancedStyleParams.radial.y0 = result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.radial.y1 = result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.conic.y = result.textLine.data.length * options.lineHeight / 2;
break;
case "top-start":
translateX = 0;
translateY = 0;
textBaseline = "top";
textAlign = "start";
result.advancedStyleParams.linear.x0 = 0;
result.advancedStyleParams.linear.x1 = options.width;
result.advancedStyleParams.radial.x0 = options.width / 2;
result.advancedStyleParams.radial.y0 = result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.radial.x1 = options.width / 2;
result.advancedStyleParams.radial.y1 = result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.conic.x = options.width / 2;
result.advancedStyleParams.conic.y = result.textLine.data.length * options.lineHeight / 2;
break;
case "top-end":
translateX = options.width;
translateY = 0;
textBaseline = "top";
textAlign = "end";
result.advancedStyleParams.linear.x0 = 0;
result.advancedStyleParams.linear.x1 = -options.width;
result.advancedStyleParams.radial.x0 = -options.width / 2;
result.advancedStyleParams.radial.y0 = result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.radial.x1 = -options.width / 2;
result.advancedStyleParams.radial.y1 = result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.conic.x = -options.width / 2;
result.advancedStyleParams.conic.y = result.textLine.data.length * options.lineHeight / 2;
break;
case "bottom":
translateX = options.width / 2;
translateY = options.height;
textBaseline = "bottom";
result.advancedStyleParams.linear.x0 = -options.width / 2;
result.advancedStyleParams.linear.x1 = options.width / 2;
result.advancedStyleParams.radial.y0 = -result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.radial.y1 = -result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.conic.x = 0;
result.advancedStyleParams.conic.y = -result.textLine.data.length * options.lineHeight / 2;
break;
case "bottom-start":
translateX = 0;
translateY = options.height;
textBaseline = "bottom";
textAlign = "start";
result.advancedStyleParams.linear.x0 = 0;
result.advancedStyleParams.linear.x1 = options.width;
result.advancedStyleParams.radial.x0 = options.width / 2;
result.advancedStyleParams.radial.y0 = -result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.radial.x1 = options.width / 2;
result.advancedStyleParams.radial.y1 = -result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.conic.x = options.width / 2;
result.advancedStyleParams.conic.y = -result.textLine.data.length * options.lineHeight / 2;
break;
case "bottom-end":
translateX = options.width;
translateY = options.height;
textBaseline = "bottom";
textAlign = "end";
result.advancedStyleParams.linear.x0 = 0;
result.advancedStyleParams.linear.x1 = -options.width;
result.advancedStyleParams.radial.x0 = -options.width / 2;
result.advancedStyleParams.radial.y0 = -result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.radial.x1 = -options.width / 2;
result.advancedStyleParams.radial.y1 = -result.textLine.data.length * options.lineHeight / 2;
result.advancedStyleParams.conic.x = -options.width / 2;
result.advancedStyleParams.conic.y = -result.textLine.data.length * options.lineHeight / 2;
break;
case "left":
translateX = 0;
translateY = options.height / 2;
textAlign = "start";
result.advancedStyleParams.linear.x0 = 0;
result.advancedStyleParams.linear.x1 = options.width;
result.advancedStyleParams.radial.x0 = options.width / 2;
result.advancedStyleParams.radial.x1 = options.width / 2;
result.advancedStyleParams.conic.x = options.width / 2;
result.advancedStyleParams.conic.y = 0;
break;
case "right":
translateX = options.width;
translateY = options.height / 2;
textAlign = "end";
result.advancedStyleParams.linear.x0 = 0;
result.advancedStyleParams.linear.x1 = -options.width;
result.advancedStyleParams.radial.x0 = -options.width / 2;
result.advancedStyleParams.radial.x1 = -options.width / 2;
result.advancedStyleParams.conic.x = -options.width / 2;
result.advancedStyleParams.conic.y = 0;
break;
}
options.translateX = translateX;
options.translateY = translateY;
isUndefined(args === null || args === void 0 ? void 0 : args.textBaseline) && (options.textBaseline = textBaseline);
isUndefined(args === null || args === void 0 ? void 0 : args.textAlign) && (options.textAlign = textAlign);
if (["text", "multi-line-text"].includes(options.contentType)) {
switch (options.textBaseline) {
case "middle":
result.textLine.yOffsetValue = (result.textLine.data.length - 1) * options.lineHeight / 2;
break;
case "bottom":
case "alphabetic":
case "ideographic":
result.textLine.yOffsetValue = (result.textLine.data.length - 1) * options.lineHeight + (options.lineHeight - parseInt(options.fontSize)) / 2;
break;
case "top":
case "hanging":
result.textLine.yOffsetValue = -options.lineHeight / 2 + parseInt(options.fontSize) / 2;
break;
}
}
return result;
};
var protection = function(need) {
if (typeof window === "undefined") {
return;
}
if (need) {
Object.defineProperty(window, "MutationObserver", {
writable: false,
configurable: false
});
}
};
var WatermarkCanvas = (
/** @class */
function() {
function WatermarkCanvas2(args, options) {
this.props = args;
this.options = options;
this.canvas = WatermarkCanvas2.createCanvas(this.options.width, this.options.height);
this.recommendOptions = generateRecommendOptions(this.canvas, this.options, this.props);
}
WatermarkCanvas2.createCanvas = function(width, height) {
var _a;
var ratio = window.devicePixelRatio || 1;
var canvas = document.createElement("canvas");
canvas.width = width * ratio;
canvas.height = height * ratio;
canvas.style.width = "".concat(width, "px");
canvas.style.height = "".concat(height, "px");
(_a = canvas.getContext("2d")) === null || _a === void 0 ? void 0 : _a.setTransform(ratio, 0, 0, ratio, 0, 0);
return canvas;
};
WatermarkCanvas2.clearCanvas = function(canvas) {
var ctx = canvas.getContext("2d");
if (ctx === null) {
throw new Error("get context error");
}
ctx.restore();
ctx.resetTransform();
ctx.clearRect(0, 0, canvas.width, canvas.height);
var ratio = window.devicePixelRatio || 1;
ctx.setTransform(ratio, 0, 0, ratio, 0, 0);
};
WatermarkCanvas2.prototype.getCanvas = function() {
return this.canvas;
};
WatermarkCanvas2.prototype.clear = function() {
WatermarkCanvas2.clearCanvas(this.canvas);
};
WatermarkCanvas2.prototype.draw = function() {
var _this = this;
var ctx = this.canvas.getContext("2d");
if (ctx === null) {
throw new Error("get context error");
}
if (this.options.auxiliaryLine) {
ctx.beginPath();
ctx.rect(0, 0, this.options.width, this.options.height);
ctx.lineWidth = 1;
ctx.strokeStyle = "#000";
ctx.stroke();
ctx.closePath();
ctx.beginPath();
ctx.rect(this.options.translateX, this.options.translateY, 1, 1);
ctx.lineWidth = 1;
ctx.strokeStyle = "#f00";
ctx.stroke();
ctx.closePath();
}
this.setStyle(ctx);
ctx.save();
ctx.translate(this.options.translateX, this.options.translateY);
ctx.rotate(this.options.rotate);
return new Promise(function(resolve) {
switch (_this.options.contentType) {
case "text":
_this.drawText(ctx, resolve);
break;
case "image":
_this.drawImage(ctx, resolve);
break;
case "multi-line-text":
_this.drawMultiLineText(ctx, resolve);
break;
case "rich-text":
_this.drawRichText(ctx, resolve);
break;
}
});
};
WatermarkCanvas2.prototype.setStyle = function(ctx) {
var _a;
var propName = "fillStyle";
if (this.options.textType === "stroke") {
propName = "strokeStyle";
}
var style = this.options.fontColor;
if ((_a = this.options) === null || _a === void 0 ? void 0 : _a.advancedStyle) {
switch (this.options.advancedStyle.type) {
case "linear":
style = this.createLinearGradient(ctx);
break;
case "radial":
style = this.createRadialGradient(ctx);
break;
case "conic":
style = this.createConicGradient(ctx);
break;
case "pattern":
style = this.createPattern(ctx);
break;
}
}
ctx[propName] && style && (ctx[propName] = style);
this.options.textAlign && (ctx.textAlign = this.options.textAlign);
this.options.textBaseline && (ctx.textBaseline = this.options.textBaseline);
ctx.globalAlpha = this.options.globalAlpha;
if (this.options.shadowStyle) {
ctx.shadowBlur = getValue(this.options.shadowStyle.shadowBlur, 0);
ctx.shadowColor = getValue(this.options.shadowStyle.shadowColor, "#00000000");
ctx.shadowOffsetX = getValue(this.options.shadowStyle.shadowOffsetX, 0);
ctx.shadowOffsetY = getValue(this.options.shadowStyle.shadowOffsetY, 0);
}
if (isFunction(this.options.extraDrawFunc)) {
this.options.extraDrawFunc(ctx);
}
};
WatermarkCanvas2.prototype.createLinearGradient = function(ctx) {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
var gradient = ctx.createLinearGradient(getValue((_c = (_b = (_a = this.options.advancedStyle) === null || _a === void 0 ? void 0 : _a.params) === null || _b === void 0 ? void 0 : _b.linear) === null || _c === void 0 ? void 0 : _c.x0, this.recommendOptions.advancedStyleParams.linear.x0), getValue((_f = (_e = (_d = this.options.advancedStyle) === null || _d === void 0 ? void 0 : _d.params) === null || _e === void 0 ? void 0 : _e.linear) === null || _f === void 0 ? void 0 : _f.y0, 0), getValue((_j = (_h = (_g = this.options.advancedStyle) === null || _g === void 0 ? void 0 : _g.params) === null || _h === void 0 ? void 0 : _h.linear) === null || _j === void 0 ? void 0 : _j.x1, this.recommendOptions.advancedStyleParams.linear.x1), getValue((_m = (_l = (_k = this.options.advancedStyle) === null || _k === void 0 ? void 0 : _k.params) === null || _l === void 0 ? void 0 : _l.linear) === null || _m === void 0 ? void 0 : _m.y1, 0));
(_q = (_p = (_o = this.options) === null || _o === void 0 ? void 0 : _o.advancedStyle) === null || _p === void 0 ? void 0 : _p.colorStops) === null || _q === void 0 ? void 0 : _q.forEach(function(item) {
gradient.addColorStop(item.offset, item.color);
});
return gradient;
};
WatermarkCanvas2.prototype.createConicGradient = function(ctx) {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q;
var gradient = ctx.createConicGradient(getValue((_d = (_c = (_b = (_a = this.options) === null || _a === void 0 ? void 0 : _a.advancedStyle) === null || _b === void 0 ? void 0 : _b.params) === null || _c === void 0 ? void 0 : _c.conic) === null || _d === void 0 ? void 0 : _d.startAngle, 0), getValue((_h = (_g = (_f = (_e = this.options) === null || _e === void 0 ? void 0 : _e.advancedStyle) === null || _f === void 0 ? void 0 : _f.params) === null || _g === void 0 ? void 0 : _g.conic) === null || _h === void 0 ? void 0 : _h.x, this.recommendOptions.advancedStyleParams.conic.x), getValue((_m = (_l = (_k = (_j = this.options) === null || _j === void 0 ? void 0 : _j.advancedStyle) === null || _k === void 0 ? void 0 : _k.params) === null || _l === void 0 ? void 0 : _l.conic) === null || _m === void 0 ? void 0 : _m.y, this.recommendOptions.advancedStyleParams.conic.y));
(_q = (_p = (_o = this.options) === null || _o === void 0 ? void 0 : _o.advancedStyle) === null || _p === void 0 ? void 0 : _p.colorStops) === null || _q === void 0 ? void 0 : _q.forEach(function(item) {
gradient.addColorStop(item.offset, item.color);
});
return gradient;
};
WatermarkCanvas2.prototype.createRadialGradient = function(ctx) {
var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2;
var gradient = ctx.createRadialGradient(getValue((_d = (_c = (_b = (_a = this.options) === null || _a === void 0 ? void 0 : _a.advancedStyle) === null || _b === void 0 ? void 0 : _b.params) === null || _c === void 0 ? void 0 : _c.radial) === null || _d === void 0 ? void 0 : _d.x0, this.recommendOptions.advancedStyleParams.radial.x0), getValue((_h = (_g = (_f = (_e = this.options) === null || _e === void 0 ? void 0 : _e.advancedStyle) === null || _f === void 0 ? void 0 : _f.params) === null || _g === void 0 ? void 0 : _g.radial) === null || _h === void 0 ? void 0 : _h.y0, this.recommendOptions.advancedStyleParams.radial.y0), getValue((_m = (_l = (_k = (_j = this.options) === null || _j === void 0 ? void 0 : _j.advancedStyle) === null || _k === void 0 ? void 0 : _k.params) === null || _l === void 0 ? void 0 : _l.radial) === null || _m === void 0 ? void 0 : _m.r0, this.recommendOptions.advancedStyleParams.radial.r0), getValue((_r = (_q = (_p = (_o = this.options) === null || _o === void 0 ? void 0 : _o.advancedStyle) === null || _p === void 0 ? void 0 : _p.params) === null || _q === void 0 ? void 0 : _q.radial) === null || _r === void 0 ? void 0 : _r.x1, this.recommendOptions.advancedStyleParams.radial.x1), getValue((_v = (_u = (_t = (_s = this.options) === null || _s === void 0 ? void 0 : _s.advancedStyle) === null || _t === void 0 ? void 0 : _t.params) === null || _u === void 0 ? void 0 : _u.radial) === null || _v === void 0 ? void 0 : _v.y1, this.recommendOptions.advancedStyleParams.radial.y1), getValue((_z = (_y = (_x = (_w = this.options) === null || _w === void 0 ? void 0 : _w.advancedStyle) === null || _x === void 0 ? void 0 : _x.params) === null || _y === void 0 ? void 0 : _y.radial) === null || _z === void 0 ? void 0 : _z.r1, this.recommendOptions.advancedStyleParams.radial.r1));
(_2 = (_1 = (_0 = this.options) === null || _0 === void 0 ? void 0 : _0.advancedStyle) === null || _1 === void 0 ? void 0 : _1.colorStops) === null || _2 === void 0 ? void 0 : _2.forEach(function(item) {
gradient.addColorStop(item.offset, item.color);
});
return gradient;
};
WatermarkCanvas2.prototype.createPattern = function(ctx) {
var _a, _b, _c, _d, _e, _f, _g, _h;
return ctx.createPattern((_d = (_c = (_b = (_a = this.options) === null || _a === void 0 ? void 0 : _a.advancedStyle) === null || _b === void 0 ? void 0 : _b.params) === null || _c === void 0 ? void 0 : _c.pattern) === null || _d === void 0 ? void 0 : _d.image, ((_h = (_g = (_f = (_e = this.options) === null || _e === void 0 ? void 0 : _e.advancedStyle) === null || _f === void 0 ? void 0 : _f.params) === null || _g === void 0 ? void 0 : _g.pattern) === null || _h === void 0 ? void 0 : _h.repetition) || "");
};
WatermarkCanvas2.prototype.setText = function(ctx, params) {
var methodName = "fillText";
if (this.options.textType === "stroke") {
methodName = "strokeText";
}
ctx[methodName] && ctx[methodName](params.text, params.x, params.y, params.maxWidth);
};
WatermarkCanvas2.prototype.drawText = function(ctx, resolve) {
this.setText(ctx, {
text: this.options.content,
x: 0,
y: 0 - this.recommendOptions.textLine.yOffsetValue,
maxWidth: this.options.textRowMaxWidth || this.options.width
});
resolve(ctx.canvas);
};
WatermarkCanvas2.prototype.drawImage = function(ctx, resolve) {
var _this = this;
loadImage(this.options.image).then(function(image) {
var _a = _this.getImageRect(image), imageWidth = _a.width, imageHeight = _a.height;
var imagePosition = _this.getDrawImagePosition(imageWidth, imageHeight);
ctx.drawImage(image, imagePosition.x, imagePosition.y, imageWidth, imageHeight);
resolve(ctx.canvas);
});
};
WatermarkCanvas2.prototype.drawMultiLineText = function(ctx, resolve) {
var _this = this;
var lines = this.recommendOptions.textLine.data;
var yOffsetValue = this.recommendOptions.textLine.yOffsetValue;
lines.forEach(function(text, index) {
_this.setText(ctx, {
text,
x: 0,
y: _this.options.lineHeight * index - yOffsetValue,
maxWidth: _this.options.textRowMaxWidth || _this.options.width
});
});
resolve(ctx.canvas);
};
WatermarkCanvas2.prototype.drawRichText = function(ctx, resolve) {
return __awaiter(this, void 0, void 0, function() {
var obj;
var _this = this;
return __generator(this, function(_a) {
switch (_a.label) {
case 0:
return [4, createCustomContentSVG(ctx, this.options)];
case 1:
obj = _a.sent();
loadImage(convertSVGToImage(obj.element), obj.width, obj.height).then(function(image) {
var imagePosition = _this.getDrawImagePosition(image.width, image.height);
ctx.drawImage(image, imagePosition.x, imagePosition.y, image.width, image.height);
resolve(ctx.canvas);
});
return [
2
/*return*/
];
}
});
});
};
WatermarkCanvas2.prototype.getImageRect = function(image) {
var rect = { width: this.options.imageWidth || 0, height: this.options.imageHeight || 0 };
switch (true) {
case (rect.width !== 0 && rect.height === 0):
rect.height = rect.width * image.height / image.width;
break;
case (rect.width === 0 && rect.height !== 0):
rect.width = rect.height * image.width / image.height;
break;
case (rect.width === 0 && rect.height === 0):
rect.width = image.width;
rect.height = image.height;
break;
}
return rect;
};
WatermarkCanvas2.prototype.getDrawImagePosition = function(imageWidth, imageHeight) {
var _a, _b;
var result = {
x: -imageWidth / 2,
y: -imageHeight / 2
};
switch (this.options.translatePlacement) {
case "top":
result.x = -imageWidth / 2;
result.y = 0;
break;
case "top-start":
result.x = 0;
result.y = 0;
break;
case "top-end":
result.x = -imageWidth;
result.y = 0;
break;
case "bottom":
result.x = -imageWidth / 2;
result.y = -imageHeight;
break;
case "bottom-start":
result.x = 0;
result.y = -imageHeight;
break;
case "bottom-end":
result.x = -imageWidth;
result.y = -imageHeight;
break;
case "left":
result.x = 0;
result.y = -imageHeight / 2;
break;
case "right":
result.x = -imageWidth;
result.y = -imageHeight / 2;
break;
}
!isUndefined((_a = this.props) === null || _a === void 0 ? void 0 : _a.translateX) && (result.x = 0);
!isUndefined((_b = this.props) === null || _b === void 0 ? void 0 : _b.translateY) && (result.y = 0);
return result;
};
return WatermarkCanvas2;
}()
);
var GridLayout = (
/** @class */
function() {
function GridLayout2(args, partialCanvas) {
var _a, _b, _c, _d;
this.options = args;
this.partialWidth = this.options.width;
this.partialHeight = this.options.height;
this.rows = ((_a = this.options.gridLayoutOptions) === null || _a === void 0 ? void 0 : _a.rows) || 1;
this.cols = ((_b = this.options.gridLayoutOptions) === null || _b === void 0 ? void 0 : _b.cols) || 1;
this.matrix = ((_c = this.options.gridLayoutOptions) === null || _c === void 0 ? void 0 : _c.matrix) || generateMatrix(this.rows, this.cols, 1);
this.gap = ((_d = this.options.gridLayoutOptions) === null || _d === void 0 ? void 0 : _d.gap) || [0, 0];
this.partialCanvas = partialCanvas;
}
GridLayout2.prototype.draw = function() {
var _a, _b, _c, _d, _e, _f, _g, _h;
var layoutCanvas = WatermarkCanvas.createCanvas(((_a = this.options.gridLayoutOptions) === null || _a === void 0 ? void 0 : _a.width) || this.partialWidth * this.cols + this.gap[0] * this.cols, ((_b = this.options.gridLayoutOptions) === null || _b === void 0 ? void 0 : _b.height) || this.partialHeight * this.rows + this.gap[1] * this.rows);
var layoutContext = layoutCanvas.getContext("2d");
if ((_c = this.options.gridLayoutOptions) === null || _c === void 0 ? void 0 : _c.backgroundImage) {
layoutContext === null || layoutContext === void 0 ? void 0 : layoutContext.drawImage((_d = this.options.gridLayoutOptions) === null || _d === void 0 ? void 0 : _d.backgroundImage, 0, 0, (_e = this.options.gridLayoutOptions) === null || _e === void 0 ? void 0 : _e.width, (_f = this.options.gridLayoutOptions) === null || _f === void 0 ? void 0 : _f.height);
}
for (var rowIndex = 0; rowIndex < this.rows; rowIndex++) {
for (var colIndex = 0; colIndex < this.cols; colIndex++) {
if (!((_h = (_g = this.matrix) === null || _g === void 0 ? void 0 : _g[rowIndex]) === null || _h === void 0 ? void 0 : _h[colIndex])) {
continue;
}
layoutContext === null || layoutContext === void 0 ? void 0 : layoutContext.drawImage(this.partialCanvas, this.partialWidth * colIndex + this.gap[0] * colIndex, this.partialHeight * rowIndex + this.gap[1] * rowIndex, this.partialWidth, this.partialHeight);
}
}
return layoutCanvas;
};
return GridLayout2;
}()
);
var renderLayout = function(options, partialCanvas) {
switch (options.layout) {
case "grid":
return new GridLayout(options, partialCanvas).draw();
default:
return partialCanvas;
}
};
var generateBackgroundSize = function(options) {
var _a, _b, _c;
switch (options.layout) {
case "grid": {
var cols = ((_a = options.gridLayoutOptions) === null || _a === void 0 ? void 0 : _a.cols) || 1;
var rows = ((_b = options.gridLayoutOptions) === null || _b === void 0 ? void 0 : _b.rows) || 1;
var gap = ((_c = options.gridLayoutOptions) === null || _c === void 0 ? void 0 : _c.gap) || [0, 0];
return [options.width * cols + gap[0] * cols, options.height * rows + gap[1] * rows];
}
default:
return [options.width, options.height];
}
};
var Watermark = (
/** @class */
function() {
function Watermark2(args) {
if (args === void 0) {
args = {};
}
this.parentElement = document.body;
this.isCreating = false;
this.props = args;
this.options = __assign(__assign({}, initialOptions), args);
this.changeParentElement(this.options.parent);
this.watermarkCanvas = new WatermarkCanvas(this.props, this.options);
protection(this.options.monitorProtection);
}
Watermark2.prototype.changeOptions = function() {
return __awaiter(this, arguments, void 0, function(args, mode, redraw) {
if (args === void 0) {
args = {};
}
if (mode === void 0) {
mode = "overwrite";
}
if (redraw === void 0) {
redraw = true;
}
return __generator(this, function(_a) {
switch (_a.label) {
case 0:
this.initConfigData(args, mode);
protection(this.options.monitorProtection);
if (!redraw) return [3, 2];
this.remove();
return [4, this.create()];
case 1:
_a.sent();
_a.label = 2;
case 2:
return [
2
/*return*/
];
}
});
});
};
Watermark2.prototype.create = function() {
return __awaiter(this, void 0, void 0, function() {
var firstDraw, image, watermarkInnerDom, parentElementType, backgroundSize;
var _a, _b, _c, _d, _e, _f, _g;
return __generator(this, function(_h) {
switch (_h.label) {
case 0:
if (this.isCreating) {
return [
2
/*return*/
];
}
this.isCreating = true;
if (!this.validateUnique()) {
this.isCreating = false;
return [
2
/*return*/
];
}
if (!this.validateContent()) {
this.isCreating = false;
return [
2
/*return*/
];
}
firstDraw = isUndefined(this.watermarkDom);
return [4, (_a = this.watermarkCanvas) === null || _a === void 0 ? void 0 : _a.draw()];
case 1:
_h.sent();
this.layoutCanvas = renderLayout(this.options, (_b = this.watermarkCanvas) === null || _b === void 0 ? void 0 : _b.getCanvas());
image = convertImage(this.layoutCanvas);
(_c = this.watermarkCanvas) === null || _c === void 0 ? void 0 : _c.clear();
this.watermarkDom = document.createElement("div");
watermarkInnerDom = document.createElement("div");
this.watermarkDom.__WATERMARK__ = "watermark";
this.watermarkDom.__WATERMARK__INSTANCE__ = this;
parentElementType = this.checkParentElementType();
this.watermarkDom.style.cssText = "\n z-index:".concat(this.options.zIndex, "!important;display:block!important;visibility:visible!important;transform:none!important;scale:none!important;\n ").concat(parentElementType === "custom" ? "top:0!important;bottom:0!important;left:0!important;right:0!important;height:100%!important;pointer-events:none!important;position:absolute!important;" : "position:relative!important;", "\n ");
backgroundSize = generateBackgroundSize(this.options);
watermarkInnerDom.style.cssText = "\n display:block!important;visibility:visible!important;pointer-events:none;top:0;bottom:0;left:0;right:0;transform:none!important;scale:none!important;\n position:".concat(parentElementType === "root" ? "fixed" : "absolute", "!important;-webkit-print-color-adjust:exact!important;width:100%!important;height:100%!important;\n z-index:").concat(this.options.zIndex, "!important;background-image:url(").concat(image, ")!important;background-repeat:").concat(this.options.backgroundRepeat, "!important;\n background-size:").concat(backgroundSize[0], "px ").concat(backgroundSize[1], "px!important;background-position:").concat(this.options.backgroundPosition, ";\n ").concat(generateAnimationStyle(this.options.movable, this.options.backgroundRepeat), "\n ");
this.watermarkDom.appendChild(watermarkInnerDom);
this.parentElement.appendChild(this.watermarkDom);
if (this.options.mutationObserve) {
try {
this.bindMutationObserve();
} catch (_j) {
(_e = (_d = this.options).onObserveError) === null || _e === void 0 ? void 0 : _e.call(_d);
}
}
firstDraw && ((_g = (_f = this.options).onSuccess) === null || _g === void 0 ? void 0 : _g.call(_f));
this.isCreating = false;
return [
2
/*return*/
];
}
});
});
};
Watermark2.prototype.destroy = function() {
this.remove();
this.watermarkDom = void 0;
};
Watermark2.prototype.check = function() {
return __awaiter(this, void 0, void 0, function() {
return __generator(this, function(_a) {
return [2, this.parentElement.contains(this.watermarkDom)];
});
});
};
Watermark2.prototype.remove = function() {
var _a, _b, _c, _d, _e, _f, _g, _h;
(_b = (_a = this.options).onBeforeDestroy) === null || _b === void 0 ? void 0 : _b.call(_a);
(_c = this.observer) === null || _c === void 0 ? void 0 : _c.disconnect();
(_d = this.parentObserve) === null || _d === void 0 ? void 0 : _d.disconnect();
(_f = (_e = this.watermarkDom) === null || _e === void 0 ? void 0 : _e.parentNode) === null || _f === void 0 ? void 0 : _f.removeChild(this.watermarkDom);
(_h = (_g = this.options).onDestroyed) === null || _h === void 0 ? void 0 : _h.call(_g);
};
Watermark2.prototype.initConfigData = function(args, mode) {
var _this = this;
if (mode === void 0) {
mode = "overwrite";
}
if (mode === "append") {
Object.keys(args).forEach(function(key) {
_this.props && (_this.props[key] = args[key]);
});
} else {
this.props = args;
}
this.options = __assign(__assign({}, initialOptions), this.props);
this.changeParentElement(this.options.parent);
this.watermarkCanvas = new WatermarkCanvas(this.props, this.options);
};
Watermark2.prototype.changeParentElement = function(parent) {
if (typeof parent === "string") {
var parentElement = document.querySelector(parent);
parentElement && (this.parentElement = parentElement);
} else {
this.parentElement = parent;
}
if (!this.parentElement) {
console.error("[WatermarkJsPlus]: please pass a valid parent element.");
}
};
Watermark2.prototype.validateUnique = function() {
var result = true;
Array.from(this.parentElement.childNodes).forEach(function(node) {
if (!result) {
return;
}
if (Object.hasOwnProperty.call(node, "__WATERMARK__")) {
result = false;
}
});
return result;
};
Watermark2.prototype.validateContent = function() {
switch (this.options.contentType) {
case "image":
return Object.hasOwnProperty.call(this.options, "image");
case "multi-line-text":
case "rich-text":
case "text":
return this.options.content.length > 0;
}
};
Watermark2.prototype.checkParentElementType = function() {
if (["html", "body"].includes(this.parentElement.tagName.toLocaleLowerCase())) {
return "root";
}
return "custom";
};
Watermark2.prototype.bindMutationObserve = function() {
var _this = this;
if (!this.watermarkDom) {
return;
}
this.observer = new MutationObserver(function(mutationsList) {
return __awaiter(_this, void 0, void 0, function() {
return __generator(this, function(_a) {
switch (_a.label) {
case 0:
if (!(mutationsList.length > 0)) return [3, 2];
this.remove();
return [4, this.create()];
case 1:
_a.sent();
_a.label = 2;
case 2:
return [
2
/*return*/
];
}
});
});
});
this.observer.observe(this.watermarkDom, {
attributes: true,
// 属性的变动
childList: true,
// 子节点的变动(指新增,删除或者更改)
subtree: true,
// 布尔值,表示是否将该观察器应用于该节点的所有后代节点。
characterData: true
// 节点内容或节点文本的变动。
});
this.parentObserve = new MutationObserver(function(mutationsList) {
return __awaiter(_this, void 0, void 0, function() {
var _i, mutationsList_1, item;
var _a;
return __generator(this, function(_b) {
switch (_b.label) {
case 0:
_i = 0, mutationsList_1 = mutationsList;
_b.label = 1;
case 1:
if (!(_i < mutationsList_1.length)) return [3, 4];
item = mutationsList_1[_i];
if (!((item === null || item === void 0 ? void 0 : item.target) === this.watermarkDom || ((_a = item === null || item === void 0 ? void 0 : item.removedNodes) === null || _a === void 0 ? void 0 : _a[0]) === this.watermarkDom || item.type === "childList" && item.target === this.parentElement && item.target.lastChild !== this.watermarkDom)) return [3, 3];
this.remove();
return [4, this.create()];
case 2:
_b.sent();
_b.label = 3;
case 3:
_i++;
return [3, 1];
case 4:
return [
2
/*return*/
];
}
});
});
});
this.parentObserve.observe(this.parentElement, {
attributes: true,
// 属性的变动
childList: true,
// 子节点的变动(指新增,删除或者更改)
subtree: true,
// 布尔值,表示是否将该观察器应用于该节点的所有后代节点。
characterData: true
// 节点内容或节点文本的变动。
});
};
return Watermark2;
}()
);
var BlindWatermark = (
/** @class */
function(_super) {
__extends(BlindWatermark2, _super);
function BlindWatermark2(props) {
if (props === void 0) {
props = {};
}
var defaultProps = {
globalAlpha: 5e-3,
mode: "blind"
};
return _super.call(this, __assign(__assign({}, props), defaultProps)) || this;
}
BlindWatermark2.prototype.changeOptions = function() {
return __awaiter(this, arguments, void 0, function(args, mode, redraw) {
if (args === void 0) {
args = {};
}
if (mode === void 0) {
mode = "overwrite";
}
if (redraw === void 0) {
redraw = true;
}
return __generator(this, function(_a) {
switch (_a.label) {
case 0:
args.globalAlpha = 5e-3;
args.mode = "blind";
this.initConfigData(args, mode);
protection(this.options.monitorProtection);
if (!redraw) return [3, 2];
this.remove();
return [4, this.create()];
case 1:
_a.sent();
_a.label = 2;
case 2:
return [
2
/*return*/
];
}
});
});
};
BlindWatermark2.decode = function(props) {
var _a = props.url, url = _a === void 0 ? "" : _a, _b = props.fillColor, fillColor = _b === void 0 ? "#000" : _b, _c = props.compositeOperation, compositeOperation = _c === void 0 ? "color-burn" : _c, _d = props.mode, mode = _d === void 0 ? "canvas" : _d, _e = props.compositeTimes, compositeTimes = _e === void 0 ? 3 : _e, onSuccess = props.onSuccess;
if (!url) {
return;
}
if (mode === "canvas") {
var img_1 = new Image();
img_1.src = url;
img_1.addEventListener("load", function() {
var width = img_1.width, height = img_1.height;
var canvas = WatermarkCanvas.createCanvas(width, height);
var ctx = canvas.getContext("2d");
if (!ctx) {
throw new Error("get context error");
}
ctx.drawImage(img_1, 0, 0, width, height);
ctx.globalCompositeOperation = compositeOperation;
ctx.fillStyle = fillColor;
for (var i = 0; i < compositeTimes; i++) {
ctx.fillRect(0, 0, width, height);
}
var resultImage = convertImage(canvas);
if (isFunction(onSuccess)) {
onSuccess === null || onSuccess === void 0 ? void 0 : onSuccess(resultImage);
}
});
}
};
return BlindWatermark2;
}(Watermark)
);
var ImageWatermark = (
/** @class */
function() {
function ImageWatermark2(args) {
if (args === void 0) {
args = {};
}
var _a, _b;
this.drew = false;
this.props = args;
this.options = __assign(__assign({}, initialOptions), args);
if (this.props.crossOrigin) {
(_a = this.props.dom) === null || _a === void 0 ? void 0 : _a.setAttribute("crossOrigin", "anonymous");
}
this.watermarkCanvas = new WatermarkCanvas(this.props, this.options);
this.originalSrc = (_b = this.props.dom) === null || _b === void 0 ? void 0 : _b.src;
this.backgroundImage = this.getBackgroundImage();
}
ImageWatermark2.prototype.create = function() {
return __awaiter(this, void 0, void 0, function() {
var _a, _b, _c, _d, _e;
return __generator(this, function(_f) {
switch (_f.label) {
case 0:
if (this.drew) {
return [
2
/*return*/
];
}
return [4, (_a = this.watermarkCanvas) === null || _a === void 0 ? void 0 : _a.draw()];
case 1:
_f.sent();
this.options.layout = "grid";
this.options.gridLayoutOptions = __assign(__assign({}, this.options.gridLayoutOptions), { width: (_b = this.backgroundImage) === null || _b === void 0 ? void 0 : _b.width, height: (_c = this.backgroundImage) === null || _c === void 0 ? void 0 : _c.height, backgroundImage: this.backgroundImage });
this.layoutCanvas = renderLayout(this.options, (_d = this.watermarkCanvas) === null || _d === void 0 ? void 0 : _d.getCanvas());
this.options.dom.src = convertImage(this.layoutCanvas);
(_e = this.watermarkCanvas) === null || _e === void 0 ? void 0 : _e.clear();
this.drew = true;
return [
2
/*return*/
];
}
});
});
};
ImageWatermark2.prototype.destroy = function() {
this.options.dom.src = this.originalSrc;
this.drew = false;
};
ImageWatermark2.prototype.getBackgroundImage = function() {
if (this.options.dom) {
return this.options.dom;
}
};
return ImageWatermark2;
}()
);
export {
BlindWatermark,
ImageWatermark,
Watermark
};
//# sourceMappingURL=watermark-js-plus.js.map