@egova-mobile/app-media-utils 0.0.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/image/image-processor.d.ts +18 -0
- package/dist/image/image-util.d.ts +57 -0
- package/dist/image/watermark.d.ts +71 -0
- package/dist/index.cjs.js +1522 -0
- package/dist/index.d.ts +3 -0
- package/dist/index.esm.mjs +1512 -0
- package/dist/utils/date.d.ts +29 -0
- package/dist/utils/index.d.ts +4 -0
- package/dist/utils/system-check.d.ts +4 -0
- package/dist/utils/type-check.d.ts +15 -0
- package/dist/utils/type-parse.d.ts +12 -0
- package/package.json +44 -0
|
@@ -0,0 +1,1522 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
var __create = Object.create;
|
|
3
|
+
var __defProp = Object.defineProperty;
|
|
4
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
5
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
6
|
+
var __getProtoOf = Object.getPrototypeOf;
|
|
7
|
+
var __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
8
|
+
var __commonJS = (cb, mod) => function __require() {
|
|
9
|
+
return mod || (0, cb[__getOwnPropNames(cb)[0]])((mod = { exports: {} }).exports, mod), mod.exports;
|
|
10
|
+
};
|
|
11
|
+
var __export = (target, all) => {
|
|
12
|
+
for (var name in all)
|
|
13
|
+
__defProp(target, name, { get: all[name], enumerable: true });
|
|
14
|
+
};
|
|
15
|
+
var __copyProps = (to, from, except, desc) => {
|
|
16
|
+
if (from && typeof from === "object" || typeof from === "function") {
|
|
17
|
+
for (let key of __getOwnPropNames(from))
|
|
18
|
+
if (!__hasOwnProp.call(to, key) && key !== except)
|
|
19
|
+
__defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
20
|
+
}
|
|
21
|
+
return to;
|
|
22
|
+
};
|
|
23
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
24
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
25
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
26
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
27
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
28
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: true }) : target,
|
|
29
|
+
mod
|
|
30
|
+
));
|
|
31
|
+
var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
|
|
32
|
+
var __async = (__this, __arguments, generator) => {
|
|
33
|
+
return new Promise((resolve, reject) => {
|
|
34
|
+
var fulfilled = (value) => {
|
|
35
|
+
try {
|
|
36
|
+
step(generator.next(value));
|
|
37
|
+
} catch (e) {
|
|
38
|
+
reject(e);
|
|
39
|
+
}
|
|
40
|
+
};
|
|
41
|
+
var rejected = (value) => {
|
|
42
|
+
try {
|
|
43
|
+
step(generator.throw(value));
|
|
44
|
+
} catch (e) {
|
|
45
|
+
reject(e);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
var step = (x) => x.done ? resolve(x.value) : Promise.resolve(x.value).then(fulfilled, rejected);
|
|
49
|
+
step((generator = generator.apply(__this, __arguments)).next());
|
|
50
|
+
});
|
|
51
|
+
};
|
|
52
|
+
|
|
53
|
+
// ../../node_modules/.pnpm/dayjs@1.11.10/node_modules/dayjs/dayjs.min.js
|
|
54
|
+
var require_dayjs_min = __commonJS({
|
|
55
|
+
"../../node_modules/.pnpm/dayjs@1.11.10/node_modules/dayjs/dayjs.min.js"(exports, module2) {
|
|
56
|
+
!function(t, e) {
|
|
57
|
+
"object" == typeof exports && "undefined" != typeof module2 ? module2.exports = e() : "function" == typeof define && define.amd ? define(e) : (t = "undefined" != typeof globalThis ? globalThis : t || self).dayjs = e();
|
|
58
|
+
}(exports, function() {
|
|
59
|
+
"use strict";
|
|
60
|
+
var t = 1e3, e = 6e4, n = 36e5, r = "millisecond", i = "second", s = "minute", u = "hour", a = "day", o = "week", c = "month", f = "quarter", h = "year", d = "date", l = "Invalid Date", $ = /^(\d{4})[-/]?(\d{1,2})?[-/]?(\d{0,2})[Tt\s]*(\d{1,2})?:?(\d{1,2})?:?(\d{1,2})?[.:]?(\d+)?$/, y = /\[([^\]]+)]|Y{1,4}|M{1,4}|D{1,2}|d{1,4}|H{1,2}|h{1,2}|a|A|m{1,2}|s{1,2}|Z{1,2}|SSS/g, M = { name: "en", weekdays: "Sunday_Monday_Tuesday_Wednesday_Thursday_Friday_Saturday".split("_"), months: "January_February_March_April_May_June_July_August_September_October_November_December".split("_"), ordinal: function(t2) {
|
|
61
|
+
var e2 = ["th", "st", "nd", "rd"], n2 = t2 % 100;
|
|
62
|
+
return "[" + t2 + (e2[(n2 - 20) % 10] || e2[n2] || e2[0]) + "]";
|
|
63
|
+
} }, m = function(t2, e2, n2) {
|
|
64
|
+
var r2 = String(t2);
|
|
65
|
+
return !r2 || r2.length >= e2 ? t2 : "" + Array(e2 + 1 - r2.length).join(n2) + t2;
|
|
66
|
+
}, v = { s: m, z: function(t2) {
|
|
67
|
+
var e2 = -t2.utcOffset(), n2 = Math.abs(e2), r2 = Math.floor(n2 / 60), i2 = n2 % 60;
|
|
68
|
+
return (e2 <= 0 ? "+" : "-") + m(r2, 2, "0") + ":" + m(i2, 2, "0");
|
|
69
|
+
}, m: function t2(e2, n2) {
|
|
70
|
+
if (e2.date() < n2.date())
|
|
71
|
+
return -t2(n2, e2);
|
|
72
|
+
var r2 = 12 * (n2.year() - e2.year()) + (n2.month() - e2.month()), i2 = e2.clone().add(r2, c), s2 = n2 - i2 < 0, u2 = e2.clone().add(r2 + (s2 ? -1 : 1), c);
|
|
73
|
+
return +(-(r2 + (n2 - i2) / (s2 ? i2 - u2 : u2 - i2)) || 0);
|
|
74
|
+
}, a: function(t2) {
|
|
75
|
+
return t2 < 0 ? Math.ceil(t2) || 0 : Math.floor(t2);
|
|
76
|
+
}, p: function(t2) {
|
|
77
|
+
return { M: c, y: h, w: o, d: a, D: d, h: u, m: s, s: i, ms: r, Q: f }[t2] || String(t2 || "").toLowerCase().replace(/s$/, "");
|
|
78
|
+
}, u: function(t2) {
|
|
79
|
+
return void 0 === t2;
|
|
80
|
+
} }, g = "en", D = {};
|
|
81
|
+
D[g] = M;
|
|
82
|
+
var p = "$isDayjsObject", S = function(t2) {
|
|
83
|
+
return t2 instanceof _ || !(!t2 || !t2[p]);
|
|
84
|
+
}, w = function t2(e2, n2, r2) {
|
|
85
|
+
var i2;
|
|
86
|
+
if (!e2)
|
|
87
|
+
return g;
|
|
88
|
+
if ("string" == typeof e2) {
|
|
89
|
+
var s2 = e2.toLowerCase();
|
|
90
|
+
D[s2] && (i2 = s2), n2 && (D[s2] = n2, i2 = s2);
|
|
91
|
+
var u2 = e2.split("-");
|
|
92
|
+
if (!i2 && u2.length > 1)
|
|
93
|
+
return t2(u2[0]);
|
|
94
|
+
} else {
|
|
95
|
+
var a2 = e2.name;
|
|
96
|
+
D[a2] = e2, i2 = a2;
|
|
97
|
+
}
|
|
98
|
+
return !r2 && i2 && (g = i2), i2 || !r2 && g;
|
|
99
|
+
}, O = function(t2, e2) {
|
|
100
|
+
if (S(t2))
|
|
101
|
+
return t2.clone();
|
|
102
|
+
var n2 = "object" == typeof e2 ? e2 : {};
|
|
103
|
+
return n2.date = t2, n2.args = arguments, new _(n2);
|
|
104
|
+
}, b = v;
|
|
105
|
+
b.l = w, b.i = S, b.w = function(t2, e2) {
|
|
106
|
+
return O(t2, { locale: e2.$L, utc: e2.$u, x: e2.$x, $offset: e2.$offset });
|
|
107
|
+
};
|
|
108
|
+
var _ = function() {
|
|
109
|
+
function M2(t2) {
|
|
110
|
+
this.$L = w(t2.locale, null, true), this.parse(t2), this.$x = this.$x || t2.x || {}, this[p] = true;
|
|
111
|
+
}
|
|
112
|
+
var m2 = M2.prototype;
|
|
113
|
+
return m2.parse = function(t2) {
|
|
114
|
+
this.$d = function(t3) {
|
|
115
|
+
var e2 = t3.date, n2 = t3.utc;
|
|
116
|
+
if (null === e2)
|
|
117
|
+
return /* @__PURE__ */ new Date(NaN);
|
|
118
|
+
if (b.u(e2))
|
|
119
|
+
return /* @__PURE__ */ new Date();
|
|
120
|
+
if (e2 instanceof Date)
|
|
121
|
+
return new Date(e2);
|
|
122
|
+
if ("string" == typeof e2 && !/Z$/i.test(e2)) {
|
|
123
|
+
var r2 = e2.match($);
|
|
124
|
+
if (r2) {
|
|
125
|
+
var i2 = r2[2] - 1 || 0, s2 = (r2[7] || "0").substring(0, 3);
|
|
126
|
+
return n2 ? new Date(Date.UTC(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2)) : new Date(r2[1], i2, r2[3] || 1, r2[4] || 0, r2[5] || 0, r2[6] || 0, s2);
|
|
127
|
+
}
|
|
128
|
+
}
|
|
129
|
+
return new Date(e2);
|
|
130
|
+
}(t2), this.init();
|
|
131
|
+
}, m2.init = function() {
|
|
132
|
+
var t2 = this.$d;
|
|
133
|
+
this.$y = t2.getFullYear(), this.$M = t2.getMonth(), this.$D = t2.getDate(), this.$W = t2.getDay(), this.$H = t2.getHours(), this.$m = t2.getMinutes(), this.$s = t2.getSeconds(), this.$ms = t2.getMilliseconds();
|
|
134
|
+
}, m2.$utils = function() {
|
|
135
|
+
return b;
|
|
136
|
+
}, m2.isValid = function() {
|
|
137
|
+
return !(this.$d.toString() === l);
|
|
138
|
+
}, m2.isSame = function(t2, e2) {
|
|
139
|
+
var n2 = O(t2);
|
|
140
|
+
return this.startOf(e2) <= n2 && n2 <= this.endOf(e2);
|
|
141
|
+
}, m2.isAfter = function(t2, e2) {
|
|
142
|
+
return O(t2) < this.startOf(e2);
|
|
143
|
+
}, m2.isBefore = function(t2, e2) {
|
|
144
|
+
return this.endOf(e2) < O(t2);
|
|
145
|
+
}, m2.$g = function(t2, e2, n2) {
|
|
146
|
+
return b.u(t2) ? this[e2] : this.set(n2, t2);
|
|
147
|
+
}, m2.unix = function() {
|
|
148
|
+
return Math.floor(this.valueOf() / 1e3);
|
|
149
|
+
}, m2.valueOf = function() {
|
|
150
|
+
return this.$d.getTime();
|
|
151
|
+
}, m2.startOf = function(t2, e2) {
|
|
152
|
+
var n2 = this, r2 = !!b.u(e2) || e2, f2 = b.p(t2), l2 = function(t3, e3) {
|
|
153
|
+
var i2 = b.w(n2.$u ? Date.UTC(n2.$y, e3, t3) : new Date(n2.$y, e3, t3), n2);
|
|
154
|
+
return r2 ? i2 : i2.endOf(a);
|
|
155
|
+
}, $2 = function(t3, e3) {
|
|
156
|
+
return b.w(n2.toDate()[t3].apply(n2.toDate("s"), (r2 ? [0, 0, 0, 0] : [23, 59, 59, 999]).slice(e3)), n2);
|
|
157
|
+
}, y2 = this.$W, M3 = this.$M, m3 = this.$D, v2 = "set" + (this.$u ? "UTC" : "");
|
|
158
|
+
switch (f2) {
|
|
159
|
+
case h:
|
|
160
|
+
return r2 ? l2(1, 0) : l2(31, 11);
|
|
161
|
+
case c:
|
|
162
|
+
return r2 ? l2(1, M3) : l2(0, M3 + 1);
|
|
163
|
+
case o:
|
|
164
|
+
var g2 = this.$locale().weekStart || 0, D2 = (y2 < g2 ? y2 + 7 : y2) - g2;
|
|
165
|
+
return l2(r2 ? m3 - D2 : m3 + (6 - D2), M3);
|
|
166
|
+
case a:
|
|
167
|
+
case d:
|
|
168
|
+
return $2(v2 + "Hours", 0);
|
|
169
|
+
case u:
|
|
170
|
+
return $2(v2 + "Minutes", 1);
|
|
171
|
+
case s:
|
|
172
|
+
return $2(v2 + "Seconds", 2);
|
|
173
|
+
case i:
|
|
174
|
+
return $2(v2 + "Milliseconds", 3);
|
|
175
|
+
default:
|
|
176
|
+
return this.clone();
|
|
177
|
+
}
|
|
178
|
+
}, m2.endOf = function(t2) {
|
|
179
|
+
return this.startOf(t2, false);
|
|
180
|
+
}, m2.$set = function(t2, e2) {
|
|
181
|
+
var n2, o2 = b.p(t2), f2 = "set" + (this.$u ? "UTC" : ""), l2 = (n2 = {}, n2[a] = f2 + "Date", n2[d] = f2 + "Date", n2[c] = f2 + "Month", n2[h] = f2 + "FullYear", n2[u] = f2 + "Hours", n2[s] = f2 + "Minutes", n2[i] = f2 + "Seconds", n2[r] = f2 + "Milliseconds", n2)[o2], $2 = o2 === a ? this.$D + (e2 - this.$W) : e2;
|
|
182
|
+
if (o2 === c || o2 === h) {
|
|
183
|
+
var y2 = this.clone().set(d, 1);
|
|
184
|
+
y2.$d[l2]($2), y2.init(), this.$d = y2.set(d, Math.min(this.$D, y2.daysInMonth())).$d;
|
|
185
|
+
} else
|
|
186
|
+
l2 && this.$d[l2]($2);
|
|
187
|
+
return this.init(), this;
|
|
188
|
+
}, m2.set = function(t2, e2) {
|
|
189
|
+
return this.clone().$set(t2, e2);
|
|
190
|
+
}, m2.get = function(t2) {
|
|
191
|
+
return this[b.p(t2)]();
|
|
192
|
+
}, m2.add = function(r2, f2) {
|
|
193
|
+
var d2, l2 = this;
|
|
194
|
+
r2 = Number(r2);
|
|
195
|
+
var $2 = b.p(f2), y2 = function(t2) {
|
|
196
|
+
var e2 = O(l2);
|
|
197
|
+
return b.w(e2.date(e2.date() + Math.round(t2 * r2)), l2);
|
|
198
|
+
};
|
|
199
|
+
if ($2 === c)
|
|
200
|
+
return this.set(c, this.$M + r2);
|
|
201
|
+
if ($2 === h)
|
|
202
|
+
return this.set(h, this.$y + r2);
|
|
203
|
+
if ($2 === a)
|
|
204
|
+
return y2(1);
|
|
205
|
+
if ($2 === o)
|
|
206
|
+
return y2(7);
|
|
207
|
+
var M3 = (d2 = {}, d2[s] = e, d2[u] = n, d2[i] = t, d2)[$2] || 1, m3 = this.$d.getTime() + r2 * M3;
|
|
208
|
+
return b.w(m3, this);
|
|
209
|
+
}, m2.subtract = function(t2, e2) {
|
|
210
|
+
return this.add(-1 * t2, e2);
|
|
211
|
+
}, m2.format = function(t2) {
|
|
212
|
+
var e2 = this, n2 = this.$locale();
|
|
213
|
+
if (!this.isValid())
|
|
214
|
+
return n2.invalidDate || l;
|
|
215
|
+
var r2 = t2 || "YYYY-MM-DDTHH:mm:ssZ", i2 = b.z(this), s2 = this.$H, u2 = this.$m, a2 = this.$M, o2 = n2.weekdays, c2 = n2.months, f2 = n2.meridiem, h2 = function(t3, n3, i3, s3) {
|
|
216
|
+
return t3 && (t3[n3] || t3(e2, r2)) || i3[n3].slice(0, s3);
|
|
217
|
+
}, d2 = function(t3) {
|
|
218
|
+
return b.s(s2 % 12 || 12, t3, "0");
|
|
219
|
+
}, $2 = f2 || function(t3, e3, n3) {
|
|
220
|
+
var r3 = t3 < 12 ? "AM" : "PM";
|
|
221
|
+
return n3 ? r3.toLowerCase() : r3;
|
|
222
|
+
};
|
|
223
|
+
return r2.replace(y, function(t3, r3) {
|
|
224
|
+
return r3 || function(t4) {
|
|
225
|
+
switch (t4) {
|
|
226
|
+
case "YY":
|
|
227
|
+
return String(e2.$y).slice(-2);
|
|
228
|
+
case "YYYY":
|
|
229
|
+
return b.s(e2.$y, 4, "0");
|
|
230
|
+
case "M":
|
|
231
|
+
return a2 + 1;
|
|
232
|
+
case "MM":
|
|
233
|
+
return b.s(a2 + 1, 2, "0");
|
|
234
|
+
case "MMM":
|
|
235
|
+
return h2(n2.monthsShort, a2, c2, 3);
|
|
236
|
+
case "MMMM":
|
|
237
|
+
return h2(c2, a2);
|
|
238
|
+
case "D":
|
|
239
|
+
return e2.$D;
|
|
240
|
+
case "DD":
|
|
241
|
+
return b.s(e2.$D, 2, "0");
|
|
242
|
+
case "d":
|
|
243
|
+
return String(e2.$W);
|
|
244
|
+
case "dd":
|
|
245
|
+
return h2(n2.weekdaysMin, e2.$W, o2, 2);
|
|
246
|
+
case "ddd":
|
|
247
|
+
return h2(n2.weekdaysShort, e2.$W, o2, 3);
|
|
248
|
+
case "dddd":
|
|
249
|
+
return o2[e2.$W];
|
|
250
|
+
case "H":
|
|
251
|
+
return String(s2);
|
|
252
|
+
case "HH":
|
|
253
|
+
return b.s(s2, 2, "0");
|
|
254
|
+
case "h":
|
|
255
|
+
return d2(1);
|
|
256
|
+
case "hh":
|
|
257
|
+
return d2(2);
|
|
258
|
+
case "a":
|
|
259
|
+
return $2(s2, u2, true);
|
|
260
|
+
case "A":
|
|
261
|
+
return $2(s2, u2, false);
|
|
262
|
+
case "m":
|
|
263
|
+
return String(u2);
|
|
264
|
+
case "mm":
|
|
265
|
+
return b.s(u2, 2, "0");
|
|
266
|
+
case "s":
|
|
267
|
+
return String(e2.$s);
|
|
268
|
+
case "ss":
|
|
269
|
+
return b.s(e2.$s, 2, "0");
|
|
270
|
+
case "SSS":
|
|
271
|
+
return b.s(e2.$ms, 3, "0");
|
|
272
|
+
case "Z":
|
|
273
|
+
return i2;
|
|
274
|
+
}
|
|
275
|
+
return null;
|
|
276
|
+
}(t3) || i2.replace(":", "");
|
|
277
|
+
});
|
|
278
|
+
}, m2.utcOffset = function() {
|
|
279
|
+
return 15 * -Math.round(this.$d.getTimezoneOffset() / 15);
|
|
280
|
+
}, m2.diff = function(r2, d2, l2) {
|
|
281
|
+
var $2, y2 = this, M3 = b.p(d2), m3 = O(r2), v2 = (m3.utcOffset() - this.utcOffset()) * e, g2 = this - m3, D2 = function() {
|
|
282
|
+
return b.m(y2, m3);
|
|
283
|
+
};
|
|
284
|
+
switch (M3) {
|
|
285
|
+
case h:
|
|
286
|
+
$2 = D2() / 12;
|
|
287
|
+
break;
|
|
288
|
+
case c:
|
|
289
|
+
$2 = D2();
|
|
290
|
+
break;
|
|
291
|
+
case f:
|
|
292
|
+
$2 = D2() / 3;
|
|
293
|
+
break;
|
|
294
|
+
case o:
|
|
295
|
+
$2 = (g2 - v2) / 6048e5;
|
|
296
|
+
break;
|
|
297
|
+
case a:
|
|
298
|
+
$2 = (g2 - v2) / 864e5;
|
|
299
|
+
break;
|
|
300
|
+
case u:
|
|
301
|
+
$2 = g2 / n;
|
|
302
|
+
break;
|
|
303
|
+
case s:
|
|
304
|
+
$2 = g2 / e;
|
|
305
|
+
break;
|
|
306
|
+
case i:
|
|
307
|
+
$2 = g2 / t;
|
|
308
|
+
break;
|
|
309
|
+
default:
|
|
310
|
+
$2 = g2;
|
|
311
|
+
}
|
|
312
|
+
return l2 ? $2 : b.a($2);
|
|
313
|
+
}, m2.daysInMonth = function() {
|
|
314
|
+
return this.endOf(c).$D;
|
|
315
|
+
}, m2.$locale = function() {
|
|
316
|
+
return D[this.$L];
|
|
317
|
+
}, m2.locale = function(t2, e2) {
|
|
318
|
+
if (!t2)
|
|
319
|
+
return this.$L;
|
|
320
|
+
var n2 = this.clone(), r2 = w(t2, e2, true);
|
|
321
|
+
return r2 && (n2.$L = r2), n2;
|
|
322
|
+
}, m2.clone = function() {
|
|
323
|
+
return b.w(this.$d, this);
|
|
324
|
+
}, m2.toDate = function() {
|
|
325
|
+
return new Date(this.valueOf());
|
|
326
|
+
}, m2.toJSON = function() {
|
|
327
|
+
return this.isValid() ? this.toISOString() : null;
|
|
328
|
+
}, m2.toISOString = function() {
|
|
329
|
+
return this.$d.toISOString();
|
|
330
|
+
}, m2.toString = function() {
|
|
331
|
+
return this.$d.toUTCString();
|
|
332
|
+
}, M2;
|
|
333
|
+
}(), k = _.prototype;
|
|
334
|
+
return O.prototype = k, [["$ms", r], ["$s", i], ["$m", s], ["$H", u], ["$W", a], ["$M", c], ["$y", h], ["$D", d]].forEach(function(t2) {
|
|
335
|
+
k[t2[1]] = function(e2) {
|
|
336
|
+
return this.$g(e2, t2[0], t2[1]);
|
|
337
|
+
};
|
|
338
|
+
}), O.extend = function(t2, e2) {
|
|
339
|
+
return t2.$i || (t2(e2, _, O), t2.$i = true), O;
|
|
340
|
+
}, O.locale = w, O.isDayjs = S, O.unix = function(t2) {
|
|
341
|
+
return O(1e3 * t2);
|
|
342
|
+
}, O.en = D[g], O.Ls = D, O.p = {}, O;
|
|
343
|
+
});
|
|
344
|
+
}
|
|
345
|
+
});
|
|
346
|
+
|
|
347
|
+
// ../../node_modules/.pnpm/dayjs@1.11.10/node_modules/dayjs/locale/zh-cn.js
|
|
348
|
+
var require_zh_cn = __commonJS({
|
|
349
|
+
"../../node_modules/.pnpm/dayjs@1.11.10/node_modules/dayjs/locale/zh-cn.js"(exports, module2) {
|
|
350
|
+
!function(e, _) {
|
|
351
|
+
"object" == typeof exports && "undefined" != typeof module2 ? module2.exports = _(require_dayjs_min()) : "function" == typeof define && define.amd ? define(["dayjs"], _) : (e = "undefined" != typeof globalThis ? globalThis : e || self).dayjs_locale_zh_cn = _(e.dayjs);
|
|
352
|
+
}(exports, function(e) {
|
|
353
|
+
"use strict";
|
|
354
|
+
function _(e2) {
|
|
355
|
+
return e2 && "object" == typeof e2 && "default" in e2 ? e2 : { default: e2 };
|
|
356
|
+
}
|
|
357
|
+
var t = _(e), d = { name: "zh-cn", weekdays: "星期日_星期一_星期二_星期三_星期四_星期五_星期六".split("_"), weekdaysShort: "周日_周一_周二_周三_周四_周五_周六".split("_"), weekdaysMin: "日_一_二_三_四_五_六".split("_"), months: "一月_二月_三月_四月_五月_六月_七月_八月_九月_十月_十一月_十二月".split("_"), monthsShort: "1月_2月_3月_4月_5月_6月_7月_8月_9月_10月_11月_12月".split("_"), ordinal: function(e2, _2) {
|
|
358
|
+
return "W" === _2 ? e2 + "周" : e2 + "日";
|
|
359
|
+
}, weekStart: 1, yearStart: 4, formats: { LT: "HH:mm", LTS: "HH:mm:ss", L: "YYYY/MM/DD", LL: "YYYY年M月D日", LLL: "YYYY年M月D日Ah点mm分", LLLL: "YYYY年M月D日ddddAh点mm分", l: "YYYY/M/D", ll: "YYYY年M月D日", lll: "YYYY年M月D日 HH:mm", llll: "YYYY年M月D日dddd HH:mm" }, relativeTime: { future: "%s内", past: "%s前", s: "几秒", m: "1 分钟", mm: "%d 分钟", h: "1 小时", hh: "%d 小时", d: "1 天", dd: "%d 天", M: "1 个月", MM: "%d 个月", y: "1 年", yy: "%d 年" }, meridiem: function(e2, _2) {
|
|
360
|
+
var t2 = 100 * e2 + _2;
|
|
361
|
+
return t2 < 600 ? "凌晨" : t2 < 900 ? "早上" : t2 < 1100 ? "上午" : t2 < 1300 ? "中午" : t2 < 1800 ? "下午" : "晚上";
|
|
362
|
+
} };
|
|
363
|
+
return t.default.locale(d, null, true), d;
|
|
364
|
+
});
|
|
365
|
+
}
|
|
366
|
+
});
|
|
367
|
+
|
|
368
|
+
// src/index.ts
|
|
369
|
+
var src_exports = {};
|
|
370
|
+
__export(src_exports, {
|
|
371
|
+
CompressOptions: () => CompressOptions,
|
|
372
|
+
ImageProcessor: () => ImageProcessor,
|
|
373
|
+
ResizeOptions: () => ResizeOptions,
|
|
374
|
+
WatermarkContext: () => WatermarkContext,
|
|
375
|
+
WatermarkOptions: () => WatermarkOptions,
|
|
376
|
+
canvas2File: () => canvas2File,
|
|
377
|
+
canvas2Image: () => canvas2Image,
|
|
378
|
+
checkWatermarkConfigSupported: () => checkWatermarkConfigSupported,
|
|
379
|
+
file2DataURL: () => file2DataURL,
|
|
380
|
+
file2Image: () => file2Image,
|
|
381
|
+
image2Canvas: () => image2Canvas,
|
|
382
|
+
image2file: () => image2file,
|
|
383
|
+
resize: () => resize
|
|
384
|
+
});
|
|
385
|
+
module.exports = __toCommonJS(src_exports);
|
|
386
|
+
|
|
387
|
+
// src/utils/type-check.ts
|
|
388
|
+
function checkDataType(tgt, type) {
|
|
389
|
+
const dataType = Object.prototype.toString.call(tgt).replace(/\[object (\w+)\]/, "$1").toLowerCase();
|
|
390
|
+
return type ? dataType === type : dataType;
|
|
391
|
+
}
|
|
392
|
+
function checkIsUndefined(tgt) {
|
|
393
|
+
return checkDataType(tgt, "undefined");
|
|
394
|
+
}
|
|
395
|
+
function checkIsNull(tgt) {
|
|
396
|
+
return checkDataType(tgt, "null");
|
|
397
|
+
}
|
|
398
|
+
function checkIsUndefinedOrNull(tgt) {
|
|
399
|
+
return checkIsUndefined(tgt) || checkIsNull(tgt);
|
|
400
|
+
}
|
|
401
|
+
function checkIsString(tgt) {
|
|
402
|
+
return checkDataType(tgt, "string");
|
|
403
|
+
}
|
|
404
|
+
function checkIsStringValid(tgt) {
|
|
405
|
+
if (checkDataType(tgt, "string")) {
|
|
406
|
+
return tgt !== "";
|
|
407
|
+
} else {
|
|
408
|
+
return false;
|
|
409
|
+
}
|
|
410
|
+
}
|
|
411
|
+
function checkIsRegExp(tgt) {
|
|
412
|
+
return checkDataType(tgt, "regexp");
|
|
413
|
+
}
|
|
414
|
+
|
|
415
|
+
// src/utils/type-parse.ts
|
|
416
|
+
function parseInteger(obj, defaultValue) {
|
|
417
|
+
let result = parseInt(obj, 10);
|
|
418
|
+
if (isNaN(result)) {
|
|
419
|
+
result = defaultValue || 0;
|
|
420
|
+
}
|
|
421
|
+
return result;
|
|
422
|
+
}
|
|
423
|
+
function parseDecimal(obj, defaultValue) {
|
|
424
|
+
let result = parseFloat(obj);
|
|
425
|
+
if (isNaN(result)) {
|
|
426
|
+
result = defaultValue || 0;
|
|
427
|
+
}
|
|
428
|
+
return result;
|
|
429
|
+
}
|
|
430
|
+
|
|
431
|
+
// src/utils/date.ts
|
|
432
|
+
var FORMAT = {
|
|
433
|
+
//英文简写如:12:01
|
|
434
|
+
FORMAT_HM: "HH:mm",
|
|
435
|
+
//英文简写如:1-12 12:01
|
|
436
|
+
FORMAT_MDHM: "MM-dd HH:mm",
|
|
437
|
+
//中文简写如:1月12日
|
|
438
|
+
FORMAT_MD_CN: "MM月dd日",
|
|
439
|
+
//中文简写如:1月12日
|
|
440
|
+
FORMAT_MD: "MM-dd",
|
|
441
|
+
//英文简写(默认)如:2010-12-01
|
|
442
|
+
FORMAT_YMD: "yyyy-MM-dd",
|
|
443
|
+
FORMAT_YMD_SLASH: "yyyy/MM/dd",
|
|
444
|
+
//英文简写(默认)如:2010-12
|
|
445
|
+
FORMAT_YM: "yyyy-MM",
|
|
446
|
+
//英文全称 如:2010-12-01 23:15
|
|
447
|
+
FORMAT_YMDHM: "yyyy-MM-dd HH:mm",
|
|
448
|
+
//英文全称 如:2010-12-01 23:15:06
|
|
449
|
+
FORMAT_YMDHMS: "yyyy-MM-dd HH:mm:ss",
|
|
450
|
+
//英文全称 如:2010-12-01 23:15:06
|
|
451
|
+
FORMAT_YMDHMSMS: "yyyy-MM-dd HH:mm:ss msms",
|
|
452
|
+
//中文简写 如:2010年12月
|
|
453
|
+
FORMAT_YM_CN: "yyyy年MM月",
|
|
454
|
+
//中文简写 如:2010年12月01日
|
|
455
|
+
FORMAT_YMD_CN: "yyyy年MM月dd日",
|
|
456
|
+
//中文简写 如:2010年12月01日 12时
|
|
457
|
+
FORMAT_YMDH_CN: "yyyy年MM月dd日 HH时",
|
|
458
|
+
//中文简写 如:12月01日 12时
|
|
459
|
+
FORMAT_MDH_CN: "MM月dd日 HH时",
|
|
460
|
+
//中文简写 如:2010年12月01日 12时12分
|
|
461
|
+
FORMAT_YMDHM_CN: "yyyy年MM月dd日 HH时mm分",
|
|
462
|
+
//中文全称 如:2010年12月01日 23时15分06秒
|
|
463
|
+
FORMAT_YMDHMS_CN: "yyyy年MM月dd日 HH时mm分ss秒"
|
|
464
|
+
};
|
|
465
|
+
|
|
466
|
+
// src/utils/system-check.ts
|
|
467
|
+
function checkIsAndroid() {
|
|
468
|
+
return /android/.test(navigator.userAgent.toLowerCase());
|
|
469
|
+
}
|
|
470
|
+
function checkIsIOS() {
|
|
471
|
+
return /ios|iphone|ipad|ipod/.test(navigator.userAgent.toLowerCase());
|
|
472
|
+
}
|
|
473
|
+
function checkIsWindows() {
|
|
474
|
+
return navigator.platform.indexOf("Win") > -1;
|
|
475
|
+
}
|
|
476
|
+
|
|
477
|
+
// src/image/watermark.ts
|
|
478
|
+
var import_dayjs = __toESM(require_dayjs_min());
|
|
479
|
+
var import_zh_cn = __toESM(require_zh_cn());
|
|
480
|
+
import_dayjs.default.locale("zh-cn");
|
|
481
|
+
var Point = class {
|
|
482
|
+
constructor(x, y) {
|
|
483
|
+
this.x = x;
|
|
484
|
+
this.y = y;
|
|
485
|
+
}
|
|
486
|
+
};
|
|
487
|
+
var Size = class {
|
|
488
|
+
constructor(width, height) {
|
|
489
|
+
this.width = width;
|
|
490
|
+
this.height = height;
|
|
491
|
+
}
|
|
492
|
+
};
|
|
493
|
+
var clamp = (value, min, max) => Math.min(Math.max(value, min), max);
|
|
494
|
+
var subString = (str, startIndex, length) => {
|
|
495
|
+
if (checkIsUndefinedOrNull(length)) {
|
|
496
|
+
return str.substring(startIndex);
|
|
497
|
+
} else {
|
|
498
|
+
return str.substring(startIndex, startIndex + length);
|
|
499
|
+
}
|
|
500
|
+
};
|
|
501
|
+
var DEFAULT_ADDRESS_ICON = "";
|
|
502
|
+
var ColorMap = {
|
|
503
|
+
transparent: "#00000000",
|
|
504
|
+
white: "#FFFFFF",
|
|
505
|
+
black: "#000000",
|
|
506
|
+
darkgray: "#444444",
|
|
507
|
+
gray: "#888888",
|
|
508
|
+
lightgray: "#CCCCCC",
|
|
509
|
+
darkgrey: "#444444",
|
|
510
|
+
grey: "#888888",
|
|
511
|
+
lightgrey: "#CCCCCC",
|
|
512
|
+
red: "#FF0000",
|
|
513
|
+
green: "#00FF00",
|
|
514
|
+
blue: "#0000FF",
|
|
515
|
+
yellow: "#FFFF00",
|
|
516
|
+
cyan: "#00FFFF",
|
|
517
|
+
magenta: "#FF00FF",
|
|
518
|
+
aqua: "#00FFFF",
|
|
519
|
+
fuchsia: "#FF00FF",
|
|
520
|
+
lime: "#00FF00",
|
|
521
|
+
maroon: "#800000",
|
|
522
|
+
navy: "#000080",
|
|
523
|
+
olive: "#808000",
|
|
524
|
+
purple: "#800080",
|
|
525
|
+
silver: "#C0C0C0",
|
|
526
|
+
teal: "#008080",
|
|
527
|
+
orange: "#FF9933"
|
|
528
|
+
};
|
|
529
|
+
function getColorValue(key) {
|
|
530
|
+
for (const k of Object.getOwnPropertyNames(ColorMap)) {
|
|
531
|
+
if (k === key) {
|
|
532
|
+
return ColorMap[k];
|
|
533
|
+
}
|
|
534
|
+
}
|
|
535
|
+
return null;
|
|
536
|
+
}
|
|
537
|
+
var CONTENT_PADDING = 10;
|
|
538
|
+
var DEFAULT_PADDING = 2;
|
|
539
|
+
var DEFAULT_FONT_SIZE = 25;
|
|
540
|
+
var DEFAULT_CANVAS_SIZE = 480;
|
|
541
|
+
var DEFAULT_BACKGROUND_OPACITY = 128;
|
|
542
|
+
var LOGO_DEFAULT_PADDING = 4;
|
|
543
|
+
var WatermarkStyle = class {
|
|
544
|
+
//是否是简化配置
|
|
545
|
+
/**
|
|
546
|
+
* Watermark Style
|
|
547
|
+
* @param fontName
|
|
548
|
+
* @param fontWeight
|
|
549
|
+
* @param fontColor
|
|
550
|
+
* @param fontSize
|
|
551
|
+
* @param backgroundColor
|
|
552
|
+
* @param backgroundOpacity
|
|
553
|
+
* @param paddingTop
|
|
554
|
+
* @param paddingBottom
|
|
555
|
+
* @param position
|
|
556
|
+
* @param scale
|
|
557
|
+
* @param simplified
|
|
558
|
+
*/
|
|
559
|
+
constructor(fontName, fontWeight, fontColor, fontSize, backgroundColor, backgroundOpacity, paddingTop, paddingBottom, position, scale, simplified) {
|
|
560
|
+
this.fontName = fontName;
|
|
561
|
+
this.fontWeight = fontWeight;
|
|
562
|
+
this.fontColor = fontColor;
|
|
563
|
+
this.fontSize = fontSize;
|
|
564
|
+
this.backgroundColor = backgroundColor;
|
|
565
|
+
this.backgroundOpacity = backgroundOpacity;
|
|
566
|
+
this.paddingTop = paddingTop;
|
|
567
|
+
this.paddingBottom = paddingBottom;
|
|
568
|
+
this.position = position;
|
|
569
|
+
this.scale = scale;
|
|
570
|
+
this.simplified = simplified;
|
|
571
|
+
}
|
|
572
|
+
};
|
|
573
|
+
var WatermarkImage = class {
|
|
574
|
+
constructor(image = "", width = 20, height = 20, position = 0 /* POSITION_LEFT */) {
|
|
575
|
+
this.image = image;
|
|
576
|
+
this.width = width;
|
|
577
|
+
this.height = height;
|
|
578
|
+
this.position = position;
|
|
579
|
+
}
|
|
580
|
+
};
|
|
581
|
+
var Watermark = class {
|
|
582
|
+
/**
|
|
583
|
+
* 水印对象,包含需要渲染的文本、图像,以及相应的style
|
|
584
|
+
* @param content
|
|
585
|
+
* @param watermarkStyle
|
|
586
|
+
*/
|
|
587
|
+
constructor(content, watermarkStyle, watermarkImage) {
|
|
588
|
+
this.content = content;
|
|
589
|
+
this.style = watermarkStyle;
|
|
590
|
+
this.watermarkImage = watermarkImage;
|
|
591
|
+
}
|
|
592
|
+
};
|
|
593
|
+
var WatermarkContext = class {
|
|
594
|
+
/**
|
|
595
|
+
* 打水印需要的环境信息
|
|
596
|
+
* @param address
|
|
597
|
+
* @param watermarkTime
|
|
598
|
+
* @param humanName
|
|
599
|
+
* @param projectName
|
|
600
|
+
* @param logo
|
|
601
|
+
*/
|
|
602
|
+
constructor(params) {
|
|
603
|
+
this.address = params.address;
|
|
604
|
+
this.watermarkTime = params.watermarkTime;
|
|
605
|
+
this.humanName = params.humanName;
|
|
606
|
+
this.projectName = params.projectName;
|
|
607
|
+
this.logo = params.logo;
|
|
608
|
+
this.applicationName = params.applicationName;
|
|
609
|
+
this.pixel = params.pixel;
|
|
610
|
+
this.width = params.width;
|
|
611
|
+
this.height = params.height;
|
|
612
|
+
}
|
|
613
|
+
};
|
|
614
|
+
var WatermarkOptions = class {
|
|
615
|
+
/**
|
|
616
|
+
* 水印配置项
|
|
617
|
+
* @param enabled, 是否开启水印
|
|
618
|
+
* @param watermarkConfigString,水印配置的字符串
|
|
619
|
+
* @param context,打水印需要的环境信息
|
|
620
|
+
*/
|
|
621
|
+
constructor(params) {
|
|
622
|
+
this.enabled = params.enabled;
|
|
623
|
+
this.watermarkConfigString = params.watermarkConfigString;
|
|
624
|
+
this.context = params.context;
|
|
625
|
+
}
|
|
626
|
+
};
|
|
627
|
+
function getHeitiFontFamily(fontFamily = "") {
|
|
628
|
+
let defaultFontFamily;
|
|
629
|
+
if (checkIsWindows()) {
|
|
630
|
+
if (fontFamily.includes("黑体")) {
|
|
631
|
+
fontFamily = "";
|
|
632
|
+
}
|
|
633
|
+
defaultFontFamily = "'Roboto Black', 'Droid Sans'";
|
|
634
|
+
} else if (checkIsIOS()) {
|
|
635
|
+
if (fontFamily.includes("黑体")) {
|
|
636
|
+
fontFamily = "";
|
|
637
|
+
}
|
|
638
|
+
defaultFontFamily = "'PingFang SC Medium'";
|
|
639
|
+
} else if (checkIsAndroid()) {
|
|
640
|
+
defaultFontFamily = "'Roboto Black', 'Droid Sans'";
|
|
641
|
+
} else {
|
|
642
|
+
defaultFontFamily = '"PingFang SC Medium", "Hiragino Sans GB", "Microsoft YaHei", "WenQuanYi Micro Hei", sans-serif';
|
|
643
|
+
}
|
|
644
|
+
return fontFamily ? `${fontFamily}, ${defaultFontFamily}` : defaultFontFamily;
|
|
645
|
+
}
|
|
646
|
+
function parseWatermarkStyle(styleString, canvasSize) {
|
|
647
|
+
if (!checkIsStringValid(styleString)) {
|
|
648
|
+
return null;
|
|
649
|
+
}
|
|
650
|
+
const styleParts = styleString.split("$");
|
|
651
|
+
if (styleParts.length <= 0) {
|
|
652
|
+
return null;
|
|
653
|
+
}
|
|
654
|
+
const scale = Math.min(canvasSize.width, canvasSize.height) / DEFAULT_CANVAS_SIZE;
|
|
655
|
+
if (parseInteger(styleParts[0], -1) !== -1) {
|
|
656
|
+
const fontSize = Math.round(
|
|
657
|
+
parseDecimal(styleParts[0], DEFAULT_FONT_SIZE) * scale
|
|
658
|
+
);
|
|
659
|
+
let position = "lefttop" /* LeftTop */;
|
|
660
|
+
if (styleParts[1]) {
|
|
661
|
+
position = styleParts[1];
|
|
662
|
+
}
|
|
663
|
+
let paddingTop = DEFAULT_PADDING * scale;
|
|
664
|
+
let paddingBottom = DEFAULT_PADDING * scale;
|
|
665
|
+
if (styleParts[2]) {
|
|
666
|
+
const paddingParts = styleParts[2].split("_");
|
|
667
|
+
paddingTop = parseInteger(paddingParts[0], DEFAULT_PADDING) * scale;
|
|
668
|
+
if (paddingParts[1]) {
|
|
669
|
+
paddingBottom = parseInteger(paddingParts[1], DEFAULT_PADDING) * scale;
|
|
670
|
+
}
|
|
671
|
+
}
|
|
672
|
+
const fontName = getHeitiFontFamily();
|
|
673
|
+
const fontWeight = "normal" /* Normal */;
|
|
674
|
+
const fontColor = ColorMap.transparent;
|
|
675
|
+
const backgroundColor = ColorMap.transparent;
|
|
676
|
+
const backgroundOpacity = 128;
|
|
677
|
+
return new WatermarkStyle(
|
|
678
|
+
fontName,
|
|
679
|
+
fontWeight,
|
|
680
|
+
fontColor,
|
|
681
|
+
fontSize,
|
|
682
|
+
backgroundColor,
|
|
683
|
+
backgroundOpacity,
|
|
684
|
+
paddingTop,
|
|
685
|
+
paddingBottom,
|
|
686
|
+
position,
|
|
687
|
+
scale,
|
|
688
|
+
true
|
|
689
|
+
);
|
|
690
|
+
} else {
|
|
691
|
+
const fontName = getHeitiFontFamily(styleParts[0]);
|
|
692
|
+
let fontWeight = "normal" /* Normal */;
|
|
693
|
+
if (styleParts[1]) {
|
|
694
|
+
fontWeight = styleParts[1];
|
|
695
|
+
}
|
|
696
|
+
let fontColor = ColorMap.white;
|
|
697
|
+
if (styleParts[2]) {
|
|
698
|
+
const color = getColorValue(styleParts[2]);
|
|
699
|
+
if (color) {
|
|
700
|
+
fontColor = color;
|
|
701
|
+
}
|
|
702
|
+
}
|
|
703
|
+
let fontSize = Math.round(DEFAULT_FONT_SIZE * scale);
|
|
704
|
+
if (styleParts[3]) {
|
|
705
|
+
fontSize = Math.round(
|
|
706
|
+
parseDecimal(styleParts[3], DEFAULT_FONT_SIZE) * scale
|
|
707
|
+
);
|
|
708
|
+
}
|
|
709
|
+
let backgroundColor = ColorMap.blue;
|
|
710
|
+
if (styleParts[4]) {
|
|
711
|
+
const color = getColorValue(styleParts[4]);
|
|
712
|
+
if (color) {
|
|
713
|
+
backgroundColor = color;
|
|
714
|
+
}
|
|
715
|
+
}
|
|
716
|
+
let position = "lefttop" /* LeftTop */;
|
|
717
|
+
if (styleParts[5]) {
|
|
718
|
+
position = styleParts[5];
|
|
719
|
+
}
|
|
720
|
+
let backgroundOpacity = 255;
|
|
721
|
+
if (styleParts[6]) {
|
|
722
|
+
let opacity = parseInteger(styleParts[6], DEFAULT_BACKGROUND_OPACITY);
|
|
723
|
+
opacity = clamp(opacity, 0, 255);
|
|
724
|
+
backgroundOpacity = opacity;
|
|
725
|
+
}
|
|
726
|
+
let paddingTop = DEFAULT_PADDING * scale;
|
|
727
|
+
let paddingBottom = DEFAULT_PADDING * scale;
|
|
728
|
+
if (styleParts[7]) {
|
|
729
|
+
const paddingParts = styleParts[7].split("_");
|
|
730
|
+
paddingTop = parseInteger(paddingParts[0], DEFAULT_PADDING) * scale;
|
|
731
|
+
if (paddingParts[1]) {
|
|
732
|
+
paddingBottom = parseInteger(paddingParts[1], DEFAULT_PADDING) * scale;
|
|
733
|
+
}
|
|
734
|
+
}
|
|
735
|
+
return new WatermarkStyle(
|
|
736
|
+
fontName,
|
|
737
|
+
fontWeight,
|
|
738
|
+
fontColor,
|
|
739
|
+
fontSize,
|
|
740
|
+
backgroundColor,
|
|
741
|
+
backgroundOpacity,
|
|
742
|
+
paddingTop,
|
|
743
|
+
paddingBottom,
|
|
744
|
+
position,
|
|
745
|
+
scale,
|
|
746
|
+
false
|
|
747
|
+
);
|
|
748
|
+
}
|
|
749
|
+
}
|
|
750
|
+
var TextScanner = class {
|
|
751
|
+
/**
|
|
752
|
+
* The content to scan
|
|
753
|
+
* @param text
|
|
754
|
+
*/
|
|
755
|
+
constructor(text) {
|
|
756
|
+
this.text = text;
|
|
757
|
+
this.cursor = 0;
|
|
758
|
+
}
|
|
759
|
+
hasNext(obj) {
|
|
760
|
+
if (checkIsUndefinedOrNull(obj)) {
|
|
761
|
+
return this.cursor < this.text.length;
|
|
762
|
+
} else if (checkIsString(obj)) {
|
|
763
|
+
const str = obj;
|
|
764
|
+
const current = subString(this.text, this.cursor, str.length);
|
|
765
|
+
if (current === str) {
|
|
766
|
+
return true;
|
|
767
|
+
}
|
|
768
|
+
} else if (checkIsRegExp(obj)) {
|
|
769
|
+
const regex = obj;
|
|
770
|
+
const subText = subString(this.text, this.cursor);
|
|
771
|
+
const matchResults = subText.match(regex);
|
|
772
|
+
if (matchResults) {
|
|
773
|
+
if (matchResults.index === 0) {
|
|
774
|
+
return true;
|
|
775
|
+
}
|
|
776
|
+
}
|
|
777
|
+
}
|
|
778
|
+
return false;
|
|
779
|
+
}
|
|
780
|
+
next(obj) {
|
|
781
|
+
if (checkIsUndefinedOrNull(obj)) {
|
|
782
|
+
return subString(this.text, this.cursor, 1);
|
|
783
|
+
} else if (checkIsString(obj)) {
|
|
784
|
+
const str = obj;
|
|
785
|
+
if (subString(this.text, this.cursor, str.length) === str) {
|
|
786
|
+
return str;
|
|
787
|
+
}
|
|
788
|
+
} else if (checkIsRegExp(obj)) {
|
|
789
|
+
const regex = obj;
|
|
790
|
+
const subText = subString(this.text, this.cursor);
|
|
791
|
+
const matchResults = subText.match(regex);
|
|
792
|
+
if (matchResults) {
|
|
793
|
+
if (matchResults.index === 0) {
|
|
794
|
+
return matchResults;
|
|
795
|
+
}
|
|
796
|
+
}
|
|
797
|
+
}
|
|
798
|
+
return null;
|
|
799
|
+
}
|
|
800
|
+
skip(obj) {
|
|
801
|
+
if (checkIsUndefinedOrNull(obj)) {
|
|
802
|
+
this.cursor += 1;
|
|
803
|
+
} else if (checkIsStringValid(obj)) {
|
|
804
|
+
const str = obj;
|
|
805
|
+
this.cursor += str.length;
|
|
806
|
+
}
|
|
807
|
+
return this;
|
|
808
|
+
}
|
|
809
|
+
};
|
|
810
|
+
function transformFormatString(format) {
|
|
811
|
+
let transformString = format;
|
|
812
|
+
if (format.includes("d")) {
|
|
813
|
+
transformString = transformString.replace(/d/g, "D");
|
|
814
|
+
}
|
|
815
|
+
if (format.includes("y")) {
|
|
816
|
+
transformString = transformString.replace(/y/g, "Y");
|
|
817
|
+
}
|
|
818
|
+
if (format.includes("E")) {
|
|
819
|
+
transformString = transformString.replace(/E/g, "d");
|
|
820
|
+
}
|
|
821
|
+
return transformString;
|
|
822
|
+
}
|
|
823
|
+
function buildContent(contentConfigString, watermarkContext, style, canvasSize) {
|
|
824
|
+
let content = "";
|
|
825
|
+
const watermarkImage = new WatermarkImage();
|
|
826
|
+
if (contentConfigString.includes("{logo")) {
|
|
827
|
+
const start = contentConfigString.indexOf("{logo");
|
|
828
|
+
const end = contentConfigString.indexOf("}", start);
|
|
829
|
+
if (end != -1) {
|
|
830
|
+
const logoConfigWithBrace = contentConfigString.substring(start, end + 1);
|
|
831
|
+
if (contentConfigString.startsWith(logoConfigWithBrace) || contentConfigString.endsWith(logoConfigWithBrace)) {
|
|
832
|
+
if (contentConfigString.startsWith(logoConfigWithBrace)) {
|
|
833
|
+
watermarkImage.position = 0 /* POSITION_LEFT */;
|
|
834
|
+
} else {
|
|
835
|
+
watermarkImage.position = 1 /* POSITION_RIGHT */;
|
|
836
|
+
}
|
|
837
|
+
const imgWidthHeight = (style == null ? void 0 : style.fontSize) || 20;
|
|
838
|
+
watermarkImage.image = watermarkContext.logo;
|
|
839
|
+
watermarkImage.height = imgWidthHeight;
|
|
840
|
+
watermarkImage.width = imgWidthHeight;
|
|
841
|
+
}
|
|
842
|
+
contentConfigString = contentConfigString.replace(
|
|
843
|
+
logoConfigWithBrace,
|
|
844
|
+
""
|
|
845
|
+
);
|
|
846
|
+
}
|
|
847
|
+
}
|
|
848
|
+
const scanner = new TextScanner(contentConfigString);
|
|
849
|
+
let steps = 0;
|
|
850
|
+
while (scanner.hasNext() && /* 防止scanner代码错误产生无限循环,设置一个最大scan步数*/
|
|
851
|
+
steps < contentConfigString.length) {
|
|
852
|
+
const dateRegex = new RegExp("date{(.*?)}|date" /* Date */);
|
|
853
|
+
if (scanner.hasNext(dateRegex)) {
|
|
854
|
+
const regexResult = scanner.next(dateRegex);
|
|
855
|
+
if (regexResult) {
|
|
856
|
+
const matchResults = regexResult;
|
|
857
|
+
let format = FORMAT.FORMAT_YMD;
|
|
858
|
+
if (matchResults && matchResults.length >= 2) {
|
|
859
|
+
if (checkIsStringValid(matchResults[1])) {
|
|
860
|
+
format = matchResults[1];
|
|
861
|
+
}
|
|
862
|
+
}
|
|
863
|
+
content += (0, import_dayjs.default)(watermarkContext.watermarkTime).format(
|
|
864
|
+
transformFormatString(format)
|
|
865
|
+
);
|
|
866
|
+
scanner.skip(matchResults.input);
|
|
867
|
+
}
|
|
868
|
+
} else if (scanner.hasNext("time" /* Time */)) {
|
|
869
|
+
const value = (0, import_dayjs.default)(watermarkContext.watermarkTime).format(
|
|
870
|
+
FORMAT.FORMAT_HM
|
|
871
|
+
);
|
|
872
|
+
content += value;
|
|
873
|
+
scanner.skip("time" /* Time */);
|
|
874
|
+
} else if (scanner.hasNext("address" /* Address */)) {
|
|
875
|
+
content += watermarkContext.address;
|
|
876
|
+
if (!watermarkImage.image) {
|
|
877
|
+
const imgWidthHeight = (style == null ? void 0 : style.fontSize) || 20;
|
|
878
|
+
watermarkImage.image = DEFAULT_ADDRESS_ICON;
|
|
879
|
+
watermarkImage.height = imgWidthHeight;
|
|
880
|
+
watermarkImage.width = imgWidthHeight;
|
|
881
|
+
}
|
|
882
|
+
scanner.skip("address" /* Address */);
|
|
883
|
+
} else if (scanner.hasNext("humanname" /* HumanName */)) {
|
|
884
|
+
content += watermarkContext.humanName;
|
|
885
|
+
scanner.skip("humanname" /* HumanName */);
|
|
886
|
+
} else if (scanner.hasNext("projectName" /* ProjectName */)) {
|
|
887
|
+
content += watermarkContext.projectName;
|
|
888
|
+
scanner.skip("projectName" /* ProjectName */);
|
|
889
|
+
} else if (scanner.hasNext("applicationName" /* ApplicationName */)) {
|
|
890
|
+
content += watermarkContext.applicationName;
|
|
891
|
+
scanner.skip("applicationName" /* ApplicationName */);
|
|
892
|
+
} else if (scanner.hasNext("pixel" /* Pixel */)) {
|
|
893
|
+
content += `${canvasSize.width} * ${canvasSize.height}`;
|
|
894
|
+
scanner.skip("pixel" /* Pixel */);
|
|
895
|
+
} else if (scanner.hasNext("width" /* Width */)) {
|
|
896
|
+
content += canvasSize.width;
|
|
897
|
+
scanner.skip("width" /* Width */);
|
|
898
|
+
} else if (scanner.hasNext("height" /* Height */)) {
|
|
899
|
+
content += canvasSize.height;
|
|
900
|
+
scanner.skip("height" /* Height */);
|
|
901
|
+
} else {
|
|
902
|
+
const nextChar = scanner.next();
|
|
903
|
+
if (checkIsString(nextChar)) {
|
|
904
|
+
content += nextChar;
|
|
905
|
+
}
|
|
906
|
+
scanner.skip();
|
|
907
|
+
}
|
|
908
|
+
steps++;
|
|
909
|
+
}
|
|
910
|
+
return { content, watermarkImage };
|
|
911
|
+
}
|
|
912
|
+
function parseWatermarks(watermarkConfigString, canvasSize, watermarkContext) {
|
|
913
|
+
const watermarks = [];
|
|
914
|
+
const configStringArray = watermarkConfigString.split("###");
|
|
915
|
+
for (let i = 0; i < configStringArray.length; i++) {
|
|
916
|
+
const configString = configStringArray[i];
|
|
917
|
+
const configParts = configString.split("*#*");
|
|
918
|
+
if (configParts.length === 2) {
|
|
919
|
+
const styleString = configParts[0];
|
|
920
|
+
const contentString = configParts[1];
|
|
921
|
+
const style = parseWatermarkStyle(styleString, canvasSize);
|
|
922
|
+
const data = buildContent(
|
|
923
|
+
contentString,
|
|
924
|
+
watermarkContext,
|
|
925
|
+
style,
|
|
926
|
+
canvasSize
|
|
927
|
+
);
|
|
928
|
+
if (style && (data.content || data.watermarkImage.image)) {
|
|
929
|
+
const watermark = new Watermark(
|
|
930
|
+
data.content,
|
|
931
|
+
style,
|
|
932
|
+
data.watermarkImage
|
|
933
|
+
);
|
|
934
|
+
watermarks.push(watermark);
|
|
935
|
+
}
|
|
936
|
+
}
|
|
937
|
+
}
|
|
938
|
+
return watermarks;
|
|
939
|
+
}
|
|
940
|
+
var Tile = class {
|
|
941
|
+
constructor(origin, size, lineHeight, lineWidths, lines, style, watermarkImage) {
|
|
942
|
+
this.origin = origin;
|
|
943
|
+
this.size = size;
|
|
944
|
+
this.lineHeight = lineHeight;
|
|
945
|
+
this.lineWidths = lineWidths;
|
|
946
|
+
this.lines = lines;
|
|
947
|
+
this.style = style;
|
|
948
|
+
this.watermarkImage = watermarkImage;
|
|
949
|
+
}
|
|
950
|
+
};
|
|
951
|
+
function getCanvasScale(canvas, len) {
|
|
952
|
+
const min = Math.min(canvas.width, canvas.height);
|
|
953
|
+
return min / DEFAULT_CANVAS_SIZE * len;
|
|
954
|
+
}
|
|
955
|
+
function buildTile(canvas, watermark) {
|
|
956
|
+
const { content, style, watermarkImage } = watermark;
|
|
957
|
+
const origin = new Point(0, 0);
|
|
958
|
+
const size = new Size(0, 0);
|
|
959
|
+
const lines = [];
|
|
960
|
+
const ctx = canvas.getContext("2d");
|
|
961
|
+
if (!ctx) {
|
|
962
|
+
return null;
|
|
963
|
+
}
|
|
964
|
+
let imageWidth = 0;
|
|
965
|
+
if (watermarkImage.image) {
|
|
966
|
+
imageWidth = watermarkImage.width + LOGO_DEFAULT_PADDING * style.scale;
|
|
967
|
+
}
|
|
968
|
+
ctx.font = `${style.fontWeight} ${style.fontSize}px ${style.fontName}`;
|
|
969
|
+
const contentPadding = getCanvasScale(canvas, CONTENT_PADDING);
|
|
970
|
+
const contentWidth = canvas.width - contentPadding * 2 - imageWidth;
|
|
971
|
+
const lineHeight = ctx.measureText("M").width;
|
|
972
|
+
const lineWidths = [];
|
|
973
|
+
let temp = "";
|
|
974
|
+
let lastWidth = 0;
|
|
975
|
+
for (let i = 0; i < content.length; i++) {
|
|
976
|
+
const lineWidth = ctx.measureText(temp).width;
|
|
977
|
+
if (lineWidth >= contentWidth) {
|
|
978
|
+
const line = temp.substring(0, temp.length - 1);
|
|
979
|
+
const preLineWidth = ctx.measureText(line).width;
|
|
980
|
+
lines.push(line);
|
|
981
|
+
lineWidths.push(preLineWidth);
|
|
982
|
+
temp = temp.substring(temp.length - 1);
|
|
983
|
+
}
|
|
984
|
+
lastWidth = lineWidth;
|
|
985
|
+
temp += content[i];
|
|
986
|
+
}
|
|
987
|
+
lines.push(temp);
|
|
988
|
+
lineWidths.push(lastWidth);
|
|
989
|
+
size.width = contentWidth;
|
|
990
|
+
size.height = lines.length * lineHeight;
|
|
991
|
+
return new Tile(
|
|
992
|
+
origin,
|
|
993
|
+
size,
|
|
994
|
+
lineHeight,
|
|
995
|
+
lineWidths,
|
|
996
|
+
lines,
|
|
997
|
+
style,
|
|
998
|
+
watermarkImage
|
|
999
|
+
);
|
|
1000
|
+
}
|
|
1001
|
+
function getAxisPoint(canvasWidth, width, tile, origin, line) {
|
|
1002
|
+
const { style, watermarkImage, lines, lineHeight } = tile;
|
|
1003
|
+
const padding = (CONTENT_PADDING + DEFAULT_PADDING) * style.scale;
|
|
1004
|
+
let axisPoint = new Point(padding, origin.y);
|
|
1005
|
+
if (style.position.startsWith("center")) {
|
|
1006
|
+
axisPoint = new Point(canvasWidth / 2, origin.y);
|
|
1007
|
+
} else if (style.position.startsWith("right")) {
|
|
1008
|
+
axisPoint = new Point(canvasWidth - padding, origin.y);
|
|
1009
|
+
}
|
|
1010
|
+
const imagePoint = new Point(axisPoint.x, axisPoint.y);
|
|
1011
|
+
if (watermarkImage.image) {
|
|
1012
|
+
const maxWidth = Math.max(...tile.lineWidths);
|
|
1013
|
+
if (watermarkImage.position === 0 /* POSITION_LEFT */) {
|
|
1014
|
+
if (style.position.startsWith("left")) {
|
|
1015
|
+
axisPoint.x = axisPoint.x + watermarkImage.width + LOGO_DEFAULT_PADDING * style.scale;
|
|
1016
|
+
} else if (style.position.startsWith("center")) {
|
|
1017
|
+
if (line) {
|
|
1018
|
+
axisPoint.x = axisPoint.x + watermarkImage.width / 2 + LOGO_DEFAULT_PADDING / 2 * style.scale;
|
|
1019
|
+
imagePoint.x = lines.length === 1 ? imagePoint.x - width / 2 - watermarkImage.width - LOGO_DEFAULT_PADDING / 2 * style.scale : imagePoint.x - maxWidth / 2 - watermarkImage.width / 2 - LOGO_DEFAULT_PADDING / 2 * style.scale;
|
|
1020
|
+
} else {
|
|
1021
|
+
imagePoint.x = imagePoint.x - watermarkImage.width / 2;
|
|
1022
|
+
}
|
|
1023
|
+
} else {
|
|
1024
|
+
if (line) {
|
|
1025
|
+
imagePoint.x = lines.length === 1 ? imagePoint.x - width - 2 * watermarkImage.width - LOGO_DEFAULT_PADDING / 2 * style.scale : imagePoint.x - maxWidth - watermarkImage.width - LOGO_DEFAULT_PADDING / 2 * style.scale;
|
|
1026
|
+
} else {
|
|
1027
|
+
imagePoint.x = imagePoint.x - watermarkImage.width;
|
|
1028
|
+
}
|
|
1029
|
+
}
|
|
1030
|
+
} else {
|
|
1031
|
+
if (style.position.startsWith("left")) {
|
|
1032
|
+
imagePoint.x = lines.length === 1 ? axisPoint.x + width + watermarkImage.width + LOGO_DEFAULT_PADDING * style.scale : axisPoint.x + maxWidth + LOGO_DEFAULT_PADDING * style.scale;
|
|
1033
|
+
} else if (style.position.startsWith("center")) {
|
|
1034
|
+
axisPoint.x = axisPoint.x - watermarkImage.width / 2;
|
|
1035
|
+
imagePoint.x = lines.length === 1 ? imagePoint.x + width / 2 + LOGO_DEFAULT_PADDING * style.scale : imagePoint.x + maxWidth / 2 - watermarkImage.width / 2 + LOGO_DEFAULT_PADDING * style.scale;
|
|
1036
|
+
} else {
|
|
1037
|
+
axisPoint.x = axisPoint.x - watermarkImage.width;
|
|
1038
|
+
imagePoint.x = imagePoint.x - watermarkImage.width + LOGO_DEFAULT_PADDING / 2 * style.scale;
|
|
1039
|
+
}
|
|
1040
|
+
}
|
|
1041
|
+
if (lines.length > 1) {
|
|
1042
|
+
imagePoint.y = imagePoint.y + lines.length * lineHeight / 2 - watermarkImage.height / 2;
|
|
1043
|
+
}
|
|
1044
|
+
}
|
|
1045
|
+
return {
|
|
1046
|
+
text: axisPoint,
|
|
1047
|
+
image: imagePoint
|
|
1048
|
+
};
|
|
1049
|
+
}
|
|
1050
|
+
function getTextAlign(style) {
|
|
1051
|
+
let align = "left";
|
|
1052
|
+
if (style.position.startsWith("center")) {
|
|
1053
|
+
align = "center";
|
|
1054
|
+
} else if (style.position.startsWith("right")) {
|
|
1055
|
+
align = "right";
|
|
1056
|
+
}
|
|
1057
|
+
return align;
|
|
1058
|
+
}
|
|
1059
|
+
function loadImage(url) {
|
|
1060
|
+
return new Promise((resolve, reject) => {
|
|
1061
|
+
const img = new Image();
|
|
1062
|
+
img.src = url;
|
|
1063
|
+
img.crossOrigin = "anonymous";
|
|
1064
|
+
img.onload = function(e) {
|
|
1065
|
+
if (img.complete) {
|
|
1066
|
+
resolve(img);
|
|
1067
|
+
} else {
|
|
1068
|
+
console.error(e);
|
|
1069
|
+
reject(new Error("文件加载失败"));
|
|
1070
|
+
}
|
|
1071
|
+
};
|
|
1072
|
+
});
|
|
1073
|
+
}
|
|
1074
|
+
function drawLine(canvas, line, width, origin, tile, drawImage) {
|
|
1075
|
+
return __async(this, null, function* () {
|
|
1076
|
+
const ctx = canvas.getContext("2d");
|
|
1077
|
+
if (!ctx) {
|
|
1078
|
+
return;
|
|
1079
|
+
}
|
|
1080
|
+
const { style, watermarkImage } = tile;
|
|
1081
|
+
ctx.textBaseline = "top";
|
|
1082
|
+
ctx.font = `${style.fontWeight} ${style.fontSize}px ${style.fontName}`;
|
|
1083
|
+
const point = getAxisPoint(canvas.width, width, tile, origin, line);
|
|
1084
|
+
ctx.textAlign = getTextAlign(style);
|
|
1085
|
+
if (watermarkImage.image && drawImage) {
|
|
1086
|
+
const image = yield loadImage(watermarkImage.image);
|
|
1087
|
+
ctx.drawImage(
|
|
1088
|
+
image,
|
|
1089
|
+
Math.round(point.image.x),
|
|
1090
|
+
Math.round(point.image.y),
|
|
1091
|
+
watermarkImage.width,
|
|
1092
|
+
watermarkImage.height
|
|
1093
|
+
);
|
|
1094
|
+
}
|
|
1095
|
+
if (style.simplified) {
|
|
1096
|
+
ctx.shadowBlur = 4;
|
|
1097
|
+
ctx.shadowColor = "rgba(0, 0, 0, 0.5)";
|
|
1098
|
+
const offset = clamp(style.fontSize / 40, 2, 4);
|
|
1099
|
+
ctx.shadowOffsetY = offset;
|
|
1100
|
+
ctx.shadowOffsetX = offset;
|
|
1101
|
+
ctx.fillStyle = "rgba(255,255,255, 0.5)";
|
|
1102
|
+
} else {
|
|
1103
|
+
ctx.fillStyle = style.fontColor;
|
|
1104
|
+
}
|
|
1105
|
+
ctx.fillText(line, Math.round(point.text.x), Math.round(point.text.y));
|
|
1106
|
+
});
|
|
1107
|
+
}
|
|
1108
|
+
function hexToRGB(hex, alpha) {
|
|
1109
|
+
const r = parseInt(hex.slice(1, 3), 16), g = parseInt(hex.slice(3, 5), 16), b = parseInt(hex.slice(5, 7), 16);
|
|
1110
|
+
if (alpha) {
|
|
1111
|
+
return "rgba(" + r + ", " + g + ", " + b + ", " + alpha + ")";
|
|
1112
|
+
} else {
|
|
1113
|
+
return "rgb(" + r + ", " + g + ", " + b + ")";
|
|
1114
|
+
}
|
|
1115
|
+
}
|
|
1116
|
+
function drawBackground(canvas, tile) {
|
|
1117
|
+
const ctx = canvas.getContext("2d");
|
|
1118
|
+
if (!ctx) {
|
|
1119
|
+
return;
|
|
1120
|
+
}
|
|
1121
|
+
let { backgroundColor } = tile.style;
|
|
1122
|
+
let backgroundOpacity = parseDecimal(
|
|
1123
|
+
String(tile.style.backgroundOpacity),
|
|
1124
|
+
-1
|
|
1125
|
+
);
|
|
1126
|
+
if (backgroundOpacity > 255) {
|
|
1127
|
+
backgroundOpacity = 255;
|
|
1128
|
+
}
|
|
1129
|
+
const { style } = tile;
|
|
1130
|
+
const { paddingTop, paddingBottom } = style;
|
|
1131
|
+
if (backgroundColor !== "transparent") {
|
|
1132
|
+
if (backgroundColor.startsWith("#") && backgroundOpacity >= 0) {
|
|
1133
|
+
backgroundColor = hexToRGB(backgroundColor, backgroundOpacity / 255);
|
|
1134
|
+
}
|
|
1135
|
+
ctx.fillStyle = backgroundColor;
|
|
1136
|
+
const padding = (CONTENT_PADDING + DEFAULT_PADDING) * style.scale;
|
|
1137
|
+
const paddingScale = tile.style.fontSize / DEFAULT_FONT_SIZE;
|
|
1138
|
+
for (let j = 0; j < tile.lineWidths.length; j++) {
|
|
1139
|
+
const { lineHeight } = tile;
|
|
1140
|
+
const lineWidth = tile.lineWidths[j];
|
|
1141
|
+
let paddingRight = 30 * paddingScale;
|
|
1142
|
+
let paddingLeft = 10 * paddingScale;
|
|
1143
|
+
let axisPoint = new Point(padding - paddingLeft, tile.origin.y);
|
|
1144
|
+
if (style.position.startsWith("center")) {
|
|
1145
|
+
paddingLeft = 20 * paddingScale;
|
|
1146
|
+
paddingRight = 20 * paddingScale;
|
|
1147
|
+
axisPoint = new Point(
|
|
1148
|
+
(canvas.width - lineWidth) / 2 - paddingLeft,
|
|
1149
|
+
tile.origin.y
|
|
1150
|
+
);
|
|
1151
|
+
} else if (style.position.startsWith("right")) {
|
|
1152
|
+
paddingLeft = 30 * paddingScale;
|
|
1153
|
+
paddingRight = 10 * paddingScale;
|
|
1154
|
+
axisPoint = new Point(
|
|
1155
|
+
canvas.width - lineWidth - padding - paddingLeft,
|
|
1156
|
+
tile.origin.y
|
|
1157
|
+
);
|
|
1158
|
+
}
|
|
1159
|
+
if (j === 0) {
|
|
1160
|
+
const top = checkIsWindows() ? paddingTop + 6 * style.scale : paddingTop;
|
|
1161
|
+
ctx.fillRect(
|
|
1162
|
+
axisPoint.x,
|
|
1163
|
+
axisPoint.y - paddingTop > 0 ? axisPoint.y - top : 0,
|
|
1164
|
+
paddingLeft + lineWidth + paddingRight,
|
|
1165
|
+
top
|
|
1166
|
+
);
|
|
1167
|
+
}
|
|
1168
|
+
ctx.fillRect(
|
|
1169
|
+
axisPoint.x,
|
|
1170
|
+
axisPoint.y + j * lineHeight,
|
|
1171
|
+
paddingLeft + lineWidth + paddingRight,
|
|
1172
|
+
lineHeight
|
|
1173
|
+
);
|
|
1174
|
+
if (j === tile.lineWidths.length - 1) {
|
|
1175
|
+
const bottom = checkIsIOS() ? paddingBottom + 4 * style.scale : paddingBottom;
|
|
1176
|
+
ctx.fillRect(
|
|
1177
|
+
axisPoint.x,
|
|
1178
|
+
axisPoint.y + (j + 1) * lineHeight,
|
|
1179
|
+
paddingLeft + lineWidth + paddingRight,
|
|
1180
|
+
bottom
|
|
1181
|
+
);
|
|
1182
|
+
}
|
|
1183
|
+
}
|
|
1184
|
+
}
|
|
1185
|
+
}
|
|
1186
|
+
function drawTile(canvas, tile) {
|
|
1187
|
+
return __async(this, null, function* () {
|
|
1188
|
+
if (!tile.style.simplified) {
|
|
1189
|
+
drawBackground(canvas, tile);
|
|
1190
|
+
}
|
|
1191
|
+
for (let i = 0; i < tile.lines.length; i++) {
|
|
1192
|
+
const origin = new Point(
|
|
1193
|
+
tile.origin.x,
|
|
1194
|
+
i * tile.lineHeight + tile.origin.y
|
|
1195
|
+
);
|
|
1196
|
+
yield drawLine(
|
|
1197
|
+
canvas,
|
|
1198
|
+
tile.lines[i],
|
|
1199
|
+
tile.lineWidths[i],
|
|
1200
|
+
origin,
|
|
1201
|
+
tile,
|
|
1202
|
+
i === 0
|
|
1203
|
+
);
|
|
1204
|
+
}
|
|
1205
|
+
});
|
|
1206
|
+
}
|
|
1207
|
+
function drawGroupedWatermarks(canvas, watermarks, groupPosition) {
|
|
1208
|
+
return __async(this, null, function* () {
|
|
1209
|
+
if (!watermarks || watermarks.length === 0) {
|
|
1210
|
+
return;
|
|
1211
|
+
}
|
|
1212
|
+
const tiles = [];
|
|
1213
|
+
let totalHeight = 0;
|
|
1214
|
+
for (let i = 0; i < watermarks.length; i++) {
|
|
1215
|
+
const watermark = watermarks[i];
|
|
1216
|
+
const tile = buildTile(canvas, watermark);
|
|
1217
|
+
if (tile) {
|
|
1218
|
+
tiles.push(tile);
|
|
1219
|
+
totalHeight += tile.size.height + CONTENT_PADDING;
|
|
1220
|
+
}
|
|
1221
|
+
}
|
|
1222
|
+
if (totalHeight <= 0) {
|
|
1223
|
+
console.error("watermarks height " + totalHeight);
|
|
1224
|
+
console.error(JSON.stringify(watermarks));
|
|
1225
|
+
return;
|
|
1226
|
+
}
|
|
1227
|
+
const contentPadding = getCanvasScale(canvas, CONTENT_PADDING);
|
|
1228
|
+
let baseOrigin = new Point(contentPadding, contentPadding);
|
|
1229
|
+
if (groupPosition === "center" /* Center */) {
|
|
1230
|
+
baseOrigin = new Point(
|
|
1231
|
+
contentPadding,
|
|
1232
|
+
Math.round((canvas.height - totalHeight) / 2)
|
|
1233
|
+
);
|
|
1234
|
+
} else if (groupPosition === "bottom" /* Bottom */) {
|
|
1235
|
+
baseOrigin = new Point(
|
|
1236
|
+
contentPadding,
|
|
1237
|
+
canvas.height - totalHeight - contentPadding
|
|
1238
|
+
);
|
|
1239
|
+
} else if (groupPosition === "top" /* Top */) {
|
|
1240
|
+
baseOrigin = new Point(contentPadding, contentPadding);
|
|
1241
|
+
}
|
|
1242
|
+
let lastMarginTop = 0;
|
|
1243
|
+
for (let i = 0; i < tiles.length; i++) {
|
|
1244
|
+
const tile = tiles[i];
|
|
1245
|
+
lastMarginTop += tile.style.paddingTop;
|
|
1246
|
+
tile.origin = new Point(
|
|
1247
|
+
tile.origin.x + baseOrigin.x,
|
|
1248
|
+
lastMarginTop + baseOrigin.y
|
|
1249
|
+
);
|
|
1250
|
+
lastMarginTop += tile.size.height;
|
|
1251
|
+
lastMarginTop += tile.style.paddingBottom;
|
|
1252
|
+
}
|
|
1253
|
+
for (let i = 0; i < tiles.length; i++) {
|
|
1254
|
+
const tile = tiles[i];
|
|
1255
|
+
yield drawTile(canvas, tile);
|
|
1256
|
+
}
|
|
1257
|
+
});
|
|
1258
|
+
}
|
|
1259
|
+
function groupingWatermarks(watermarks) {
|
|
1260
|
+
const topList = [];
|
|
1261
|
+
const centerList = [];
|
|
1262
|
+
const bottomList = [];
|
|
1263
|
+
for (let i = 0; i < watermarks.length; i++) {
|
|
1264
|
+
const watermark = watermarks[i];
|
|
1265
|
+
if (watermark.style.position.endsWith("top")) {
|
|
1266
|
+
topList.push(watermark);
|
|
1267
|
+
} else if (watermark.style.position.endsWith("center")) {
|
|
1268
|
+
centerList.push(watermark);
|
|
1269
|
+
} else if (watermark.style.position.endsWith("bottom")) {
|
|
1270
|
+
bottomList.push(watermark);
|
|
1271
|
+
}
|
|
1272
|
+
}
|
|
1273
|
+
return {
|
|
1274
|
+
["top" /* Top */]: topList,
|
|
1275
|
+
["center" /* Center */]: centerList,
|
|
1276
|
+
["bottom" /* Bottom */]: bottomList
|
|
1277
|
+
};
|
|
1278
|
+
}
|
|
1279
|
+
function renderWatermark(canvas, options) {
|
|
1280
|
+
return __async(this, null, function* () {
|
|
1281
|
+
if (!options.enabled || options.watermarkConfigString === "no") {
|
|
1282
|
+
return Promise.resolve(canvas);
|
|
1283
|
+
}
|
|
1284
|
+
let { watermarkConfigString } = options;
|
|
1285
|
+
if (watermarkConfigString === "default") {
|
|
1286
|
+
watermarkConfigString = "50$lefttop$50*#*time###25$lefttop*#*date";
|
|
1287
|
+
}
|
|
1288
|
+
const watermarks = parseWatermarks(
|
|
1289
|
+
watermarkConfigString,
|
|
1290
|
+
new Size(canvas.width, canvas.height),
|
|
1291
|
+
options.context
|
|
1292
|
+
);
|
|
1293
|
+
const groupedWatermarks = groupingWatermarks(watermarks);
|
|
1294
|
+
yield drawGroupedWatermarks(
|
|
1295
|
+
canvas,
|
|
1296
|
+
groupedWatermarks["top" /* Top */],
|
|
1297
|
+
"top" /* Top */
|
|
1298
|
+
);
|
|
1299
|
+
yield drawGroupedWatermarks(
|
|
1300
|
+
canvas,
|
|
1301
|
+
groupedWatermarks["center" /* Center */],
|
|
1302
|
+
"center" /* Center */
|
|
1303
|
+
);
|
|
1304
|
+
yield drawGroupedWatermarks(
|
|
1305
|
+
canvas,
|
|
1306
|
+
groupedWatermarks["bottom" /* Bottom */],
|
|
1307
|
+
"bottom" /* Bottom */
|
|
1308
|
+
);
|
|
1309
|
+
return Promise.resolve(canvas);
|
|
1310
|
+
});
|
|
1311
|
+
}
|
|
1312
|
+
function checkWatermarkConfigSupported(watermarkConfigString) {
|
|
1313
|
+
const configStringArray = watermarkConfigString.split("###");
|
|
1314
|
+
for (let i = 0; i < configStringArray.length; i++) {
|
|
1315
|
+
const configString = configStringArray[i];
|
|
1316
|
+
const configParts = configString.split("*#*");
|
|
1317
|
+
if (configParts.length === 2) {
|
|
1318
|
+
const styleString = configParts[0];
|
|
1319
|
+
const styleParts = styleString.split("$");
|
|
1320
|
+
if (styleParts.length <= 0) {
|
|
1321
|
+
console.error("水印配置不合法");
|
|
1322
|
+
return false;
|
|
1323
|
+
}
|
|
1324
|
+
}
|
|
1325
|
+
}
|
|
1326
|
+
return true;
|
|
1327
|
+
}
|
|
1328
|
+
|
|
1329
|
+
// src/image/image-util.ts
|
|
1330
|
+
function file2DataURL(file) {
|
|
1331
|
+
return new Promise((resolve, reject) => {
|
|
1332
|
+
const a = new FileReader();
|
|
1333
|
+
a.onload = function(res) {
|
|
1334
|
+
if (res && res.target) {
|
|
1335
|
+
resolve(res.target.result);
|
|
1336
|
+
} else {
|
|
1337
|
+
reject(new Error("读取文件url失败"));
|
|
1338
|
+
}
|
|
1339
|
+
};
|
|
1340
|
+
a.readAsDataURL(file);
|
|
1341
|
+
});
|
|
1342
|
+
}
|
|
1343
|
+
function file2Image(file) {
|
|
1344
|
+
return new Promise((resolve, reject) => {
|
|
1345
|
+
file2DataURL(file).then((url) => {
|
|
1346
|
+
const img = new Image();
|
|
1347
|
+
img.src = url;
|
|
1348
|
+
img.onload = function() {
|
|
1349
|
+
if (img.complete) {
|
|
1350
|
+
resolve(img);
|
|
1351
|
+
} else {
|
|
1352
|
+
reject(new Error("文件加载失败"));
|
|
1353
|
+
}
|
|
1354
|
+
};
|
|
1355
|
+
}).catch(reject);
|
|
1356
|
+
});
|
|
1357
|
+
}
|
|
1358
|
+
function image2file(img, fileName, lastModified, type = "image/jpeg", quality = 0.8) {
|
|
1359
|
+
return image2Canvas(img, type).then((canvas) => {
|
|
1360
|
+
return canvas2File(canvas, fileName, lastModified, type, quality);
|
|
1361
|
+
});
|
|
1362
|
+
}
|
|
1363
|
+
function image2Canvas(img, type, width, height) {
|
|
1364
|
+
const canvas = document.createElement("canvas");
|
|
1365
|
+
const _width = width || img.width;
|
|
1366
|
+
const _height = height || img.height;
|
|
1367
|
+
canvas.width = _width;
|
|
1368
|
+
canvas.height = _height;
|
|
1369
|
+
const ctx = canvas.getContext("2d");
|
|
1370
|
+
if (ctx) {
|
|
1371
|
+
ctx.fillStyle = "transparent";
|
|
1372
|
+
if (type === "image/jpeg") {
|
|
1373
|
+
ctx.fillStyle = "#fff";
|
|
1374
|
+
}
|
|
1375
|
+
ctx.drawImage(img, 0, 0, _width, _height);
|
|
1376
|
+
return Promise.resolve(canvas);
|
|
1377
|
+
} else {
|
|
1378
|
+
return Promise.reject(null);
|
|
1379
|
+
}
|
|
1380
|
+
}
|
|
1381
|
+
function canvas2Image(canvas, type = "image/jpeg", quality = 0.8) {
|
|
1382
|
+
const image = new Image();
|
|
1383
|
+
image.src = canvas.toDataURL(type, quality);
|
|
1384
|
+
return Promise.resolve(image);
|
|
1385
|
+
}
|
|
1386
|
+
function canvas2File(canvas, fileName, lastModified, type = "image/jpeg", quality = 0.8) {
|
|
1387
|
+
return new Promise((resolve, reject) => {
|
|
1388
|
+
canvas.toBlob(
|
|
1389
|
+
(blob) => {
|
|
1390
|
+
if (!blob) {
|
|
1391
|
+
reject(new Error("canvas文件导出失败"));
|
|
1392
|
+
} else {
|
|
1393
|
+
const file = new File([blob], fileName, { lastModified, type });
|
|
1394
|
+
resolve(file);
|
|
1395
|
+
}
|
|
1396
|
+
},
|
|
1397
|
+
type,
|
|
1398
|
+
quality
|
|
1399
|
+
);
|
|
1400
|
+
});
|
|
1401
|
+
}
|
|
1402
|
+
function resize(img, {
|
|
1403
|
+
inputType = "image/jpeg",
|
|
1404
|
+
imageWidth = -1,
|
|
1405
|
+
imageHeight = -1,
|
|
1406
|
+
sideLengthLimit = 640,
|
|
1407
|
+
baseOnShortSide = true,
|
|
1408
|
+
// 是否以短边为基准缩放
|
|
1409
|
+
resultType = "image"
|
|
1410
|
+
}) {
|
|
1411
|
+
let scale = 1;
|
|
1412
|
+
const scaleBaseFunc = baseOnShortSide ? Math.min : Math.max;
|
|
1413
|
+
if (imageWidth > 0 && imageHeight > 0) {
|
|
1414
|
+
scale = sideLengthLimit / scaleBaseFunc(imageWidth, imageHeight);
|
|
1415
|
+
} else if (img.width > 0 && img.height > 0) {
|
|
1416
|
+
scale = sideLengthLimit / scaleBaseFunc(img.width, img.height);
|
|
1417
|
+
imageWidth = img.width;
|
|
1418
|
+
imageHeight = img.height;
|
|
1419
|
+
} else {
|
|
1420
|
+
return Promise.reject(new Error("image width/height 无效"));
|
|
1421
|
+
}
|
|
1422
|
+
const targetWidth = scale > 1 ? imageWidth : imageWidth * scale;
|
|
1423
|
+
const targetHeight = scale > 1 ? imageHeight : imageHeight * scale;
|
|
1424
|
+
if (resultType === "image") {
|
|
1425
|
+
return image2Canvas(img, inputType, targetWidth, targetHeight).then(
|
|
1426
|
+
(canvas) => {
|
|
1427
|
+
return canvas2Image(canvas);
|
|
1428
|
+
}
|
|
1429
|
+
);
|
|
1430
|
+
} else {
|
|
1431
|
+
return image2Canvas(img, inputType, targetWidth, targetHeight);
|
|
1432
|
+
}
|
|
1433
|
+
}
|
|
1434
|
+
|
|
1435
|
+
// src/image/image-processor.ts
|
|
1436
|
+
var MAX_SIDE_LENGTH = 1920;
|
|
1437
|
+
var MIN_SIDE_LENGTH = 480;
|
|
1438
|
+
var PHOTO_FILE_SIZE_LIMIT = 1e3;
|
|
1439
|
+
var DEFAULT_JPEG_QUALITY = 0.8;
|
|
1440
|
+
var MIN_JPEG_QUALITY = 0.1;
|
|
1441
|
+
var JPEG_QUALITY_STEP = 0.05;
|
|
1442
|
+
var ResizeOptions = class {
|
|
1443
|
+
// 最大边长
|
|
1444
|
+
constructor(maxSideLength) {
|
|
1445
|
+
if (checkIsUndefinedOrNull(maxSideLength)) {
|
|
1446
|
+
this.maxSideLength = MAX_SIDE_LENGTH;
|
|
1447
|
+
} else {
|
|
1448
|
+
this.maxSideLength = maxSideLength;
|
|
1449
|
+
if (this.maxSideLength > MAX_SIDE_LENGTH) {
|
|
1450
|
+
this.maxSideLength = MAX_SIDE_LENGTH;
|
|
1451
|
+
} else if (this.maxSideLength < MIN_SIDE_LENGTH) {
|
|
1452
|
+
this.maxSideLength = MIN_SIDE_LENGTH;
|
|
1453
|
+
}
|
|
1454
|
+
}
|
|
1455
|
+
}
|
|
1456
|
+
};
|
|
1457
|
+
var CompressOptions = class {
|
|
1458
|
+
// 图片大小限制,单位kb
|
|
1459
|
+
constructor(photoFileSizeLimit) {
|
|
1460
|
+
if (checkIsUndefinedOrNull(photoFileSizeLimit)) {
|
|
1461
|
+
this.photoFileSizeLimit = PHOTO_FILE_SIZE_LIMIT;
|
|
1462
|
+
} else {
|
|
1463
|
+
this.photoFileSizeLimit = photoFileSizeLimit;
|
|
1464
|
+
}
|
|
1465
|
+
}
|
|
1466
|
+
};
|
|
1467
|
+
var ImageProcessor = class {
|
|
1468
|
+
// 压缩图片的配置
|
|
1469
|
+
constructor(file, resizeOptions, watermarkOptions, compressOptions) {
|
|
1470
|
+
this.file = file;
|
|
1471
|
+
this.resizeOptions = resizeOptions;
|
|
1472
|
+
this.watermarkOptions = watermarkOptions;
|
|
1473
|
+
this.compressOptions = compressOptions;
|
|
1474
|
+
}
|
|
1475
|
+
process() {
|
|
1476
|
+
const filename = this.file.name;
|
|
1477
|
+
const { lastModified } = this.file;
|
|
1478
|
+
let fileType = this.file.type;
|
|
1479
|
+
if (this.file.size > this.compressOptions.photoFileSizeLimit * 1024) {
|
|
1480
|
+
fileType = "image/jpeg";
|
|
1481
|
+
}
|
|
1482
|
+
if (fileType === "image/gif") {
|
|
1483
|
+
fileType = "image/png";
|
|
1484
|
+
}
|
|
1485
|
+
return file2Image(this.file).then((img) => {
|
|
1486
|
+
return resize(img, {
|
|
1487
|
+
inputType: fileType,
|
|
1488
|
+
sideLengthLimit: this.resizeOptions.maxSideLength,
|
|
1489
|
+
resultType: "canvas"
|
|
1490
|
+
});
|
|
1491
|
+
}).then((result) => __async(this, null, function* () {
|
|
1492
|
+
const canvas = result;
|
|
1493
|
+
return yield renderWatermark(canvas, this.watermarkOptions);
|
|
1494
|
+
})).then((canvas) => {
|
|
1495
|
+
const exportFilename = filename.replace(/\./g, "-") + ".jpg";
|
|
1496
|
+
return this.compress(
|
|
1497
|
+
canvas,
|
|
1498
|
+
exportFilename,
|
|
1499
|
+
lastModified,
|
|
1500
|
+
fileType,
|
|
1501
|
+
DEFAULT_JPEG_QUALITY
|
|
1502
|
+
);
|
|
1503
|
+
});
|
|
1504
|
+
}
|
|
1505
|
+
compress(canvas, filename, lastModified, type, quality) {
|
|
1506
|
+
return canvas2File(canvas, filename, lastModified, type, quality).then(
|
|
1507
|
+
(file) => {
|
|
1508
|
+
if (file.size > this.compressOptions.photoFileSizeLimit * 1024 && quality - JPEG_QUALITY_STEP > MIN_JPEG_QUALITY) {
|
|
1509
|
+
return this.compress(
|
|
1510
|
+
canvas,
|
|
1511
|
+
filename,
|
|
1512
|
+
lastModified,
|
|
1513
|
+
type,
|
|
1514
|
+
quality - JPEG_QUALITY_STEP
|
|
1515
|
+
);
|
|
1516
|
+
} else {
|
|
1517
|
+
return Promise.resolve(file);
|
|
1518
|
+
}
|
|
1519
|
+
}
|
|
1520
|
+
);
|
|
1521
|
+
}
|
|
1522
|
+
};
|