@zhaoshijun/compress 1.2.2 → 1.2.4

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/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zhaoshijun/compress",
3
- "version": "1.2.2",
3
+ "version": "1.2.4",
4
4
  "description": "Image compression CLI and Vite plugin",
5
5
  "type": "module",
6
6
  "bin": {
@@ -204,77 +204,85 @@ export async function addImageWatermark(sharpInstance, options) {
204
204
  throw new Error(`Watermark image not found: ${watermarkPath}`);
205
205
  }
206
206
 
207
- const watermarkBuffer = await fs.readFile(watermarkPath);
208
- let watermarkImage = sharp(watermarkBuffer);
209
- const watermarkMeta = await watermarkImage.metadata();
210
-
211
- if (width || height) {
212
- watermarkImage = watermarkImage.resize({
213
- width: width || undefined,
214
- height: height || undefined,
215
- fit: 'inside'
216
- });
217
- }
218
-
219
- if (opacity < 1) {
220
- const tempBuffer = await watermarkImage.toBuffer();
221
- watermarkImage = sharp(tempBuffer).ensureAlpha();
222
- const { data } = await watermarkImage.raw().toBuffer({ resolveWithObject: true });
207
+ try {
208
+ const watermarkBuffer = await fs.readFile(watermarkPath);
209
+ let watermarkImage = sharp(watermarkBuffer);
210
+ const watermarkMeta = await watermarkImage.metadata();
223
211
 
224
- for (let i = 3; i < data.length; i += 4) {
225
- data[i] = Math.floor(data[i] * opacity);
212
+ if (width || height) {
213
+ watermarkImage = watermarkImage.resize({
214
+ width: width || undefined,
215
+ height: height || undefined,
216
+ fit: 'inside'
217
+ });
226
218
  }
227
219
 
228
- watermarkImage = sharp(data, {
229
- raw: {
230
- width: watermarkMeta.width,
231
- height: watermarkMeta.height,
232
- channels: 4
220
+ if (opacity < 1) {
221
+ try {
222
+ const tempBuffer = await watermarkImage.ensureAlpha().png().toBuffer();
223
+ const tempSharp = sharp(tempBuffer);
224
+ const { data, info } = await tempSharp.raw().toBuffer({ resolveWithObject: true });
225
+
226
+ for (let i = 3; i < data.length; i += 4) {
227
+ data[i] = Math.floor(data[i] * opacity);
228
+ }
229
+
230
+ watermarkImage = sharp(data, {
231
+ raw: {
232
+ width: info.width,
233
+ height: info.height,
234
+ channels: 4
235
+ }
236
+ });
237
+ } catch (error) {
238
+ console.warn('Failed to apply opacity, using original image:', error.message);
239
+ }
240
+ }
241
+
242
+ const finalWatermarkBuffer = await watermarkImage.toBuffer();
243
+ const finalWatermarkMeta = await sharp(finalWatermarkBuffer).metadata();
244
+
245
+ let compositeX = x;
246
+ let compositeY = y;
247
+
248
+ if (position !== 'custom') {
249
+ switch (position) {
250
+ case 'top-left':
251
+ compositeX = padding;
252
+ compositeY = padding;
253
+ break;
254
+ case 'top-right':
255
+ compositeX = targetMetadata.width - finalWatermarkMeta.width - padding;
256
+ compositeY = padding;
257
+ break;
258
+ case 'bottom-left':
259
+ compositeX = padding;
260
+ compositeY = targetMetadata.height - finalWatermarkMeta.height - padding;
261
+ break;
262
+ case 'bottom-right':
263
+ compositeX = targetMetadata.width - finalWatermarkMeta.width - padding;
264
+ compositeY = targetMetadata.height - finalWatermarkMeta.height - padding;
265
+ break;
266
+ case 'center':
267
+ compositeX = Math.floor((targetMetadata.width - finalWatermarkMeta.width) / 2);
268
+ compositeY = Math.floor((targetMetadata.height - finalWatermarkMeta.height) / 2);
269
+ break;
233
270
  }
234
- });
235
- }
236
-
237
- const finalWatermarkBuffer = await watermarkImage.toBuffer();
238
- const finalWatermarkMeta = await sharp(finalWatermarkBuffer).metadata();
239
-
240
- let compositeX = x;
241
- let compositeY = y;
242
-
243
- if (position !== 'custom') {
244
- switch (position) {
245
- case 'top-left':
246
- compositeX = padding;
247
- compositeY = padding;
248
- break;
249
- case 'top-right':
250
- compositeX = targetMetadata.width - finalWatermarkMeta.width - padding;
251
- compositeY = padding;
252
- break;
253
- case 'bottom-left':
254
- compositeX = padding;
255
- compositeY = targetMetadata.height - finalWatermarkMeta.height - padding;
256
- break;
257
- case 'bottom-right':
258
- compositeX = targetMetadata.width - finalWatermarkMeta.width - padding;
259
- compositeY = targetMetadata.height - finalWatermarkMeta.height - padding;
260
- break;
261
- case 'center':
262
- compositeX = Math.floor((targetMetadata.width - finalWatermarkMeta.width) / 2);
263
- compositeY = Math.floor((targetMetadata.height - finalWatermarkMeta.height) / 2);
264
- break;
265
271
  }
272
+
273
+ const result = await sharpInstance
274
+ .composite([{
275
+ input: finalWatermarkBuffer,
276
+ left: compositeX,
277
+ top: compositeY,
278
+ blend: 'over'
279
+ }])
280
+ .toBuffer();
281
+
282
+ return result;
283
+ } catch (error) {
284
+ throw new Error(`Failed to load watermark image: ${error.message}`);
266
285
  }
267
-
268
- const result = await sharpInstance
269
- .composite([{
270
- input: finalWatermarkBuffer,
271
- left: compositeX,
272
- top: compositeY,
273
- blend: 'over'
274
- }])
275
- .toBuffer();
276
-
277
- return result;
278
286
  }
279
287
 
280
288
  /**
@@ -335,21 +343,25 @@ export async function addTiledImageWatermark(sharpInstance, options, providedMet
335
343
  }
336
344
 
337
345
  if (opacity < 1) {
338
- const tempBuffer = await watermarkImage.toBuffer();
339
- watermarkImage = sharp(tempBuffer).ensureAlpha();
340
- const { data, info } = await watermarkImage.raw().toBuffer({ resolveWithObject: true });
341
-
342
- for (let i = 3; i < data.length; i += 4) {
343
- data[i] = Math.floor(data[i] * opacity);
344
- }
345
-
346
- watermarkImage = sharp(data, {
347
- raw: {
348
- width: info.width,
349
- height: info.height,
350
- channels: 4
346
+ try {
347
+ const tempBuffer = await watermarkImage.ensureAlpha().png().toBuffer();
348
+ const tempSharp = sharp(tempBuffer);
349
+ const { data, info } = await tempSharp.raw().toBuffer({ resolveWithObject: true });
350
+
351
+ for (let i = 3; i < data.length; i += 4) {
352
+ data[i] = Math.floor(data[i] * opacity);
351
353
  }
352
- });
354
+
355
+ watermarkImage = sharp(data, {
356
+ raw: {
357
+ width: info.width,
358
+ height: info.height,
359
+ channels: 4
360
+ }
361
+ });
362
+ } catch (error) {
363
+ console.warn('Failed to apply opacity, using original image:', error.message);
364
+ }
353
365
  }
354
366
 
355
367
  if (angle !== 0) {