apexify.js 4.6.2 → 4.7.0
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/cjs/ai/ApexModules.d.ts.map +1 -1
- package/dist/cjs/ai/ApexModules.js +56 -7
- package/dist/cjs/ai/ApexModules.js.map +1 -1
- package/dist/cjs/ai/functions/readFiles.js +1 -1
- package/dist/cjs/ai/functions/readFiles.js.map +1 -1
- package/dist/cjs/ai/modals-chat/electronHub/chatmodels.d.ts.map +1 -1
- package/dist/cjs/ai/modals-chat/electronHub/chatmodels.js +2 -1
- package/dist/cjs/ai/modals-chat/electronHub/chatmodels.js.map +1 -1
- package/dist/cjs/ai/modals-chat/electronHub/speechModels.d.ts.map +1 -1
- package/dist/cjs/ai/modals-chat/electronHub/speechModels.js +1 -1
- package/dist/cjs/ai/modals-chat/electronHub/speechModels.js.map +1 -1
- package/dist/cjs/canvas/ApexPainter.d.ts.map +1 -1
- package/dist/cjs/canvas/ApexPainter.js +27 -28
- package/dist/cjs/canvas/ApexPainter.js.map +1 -1
- package/dist/cjs/canvas/Themes/Level-Up/levelup.d.ts +11 -0
- package/dist/cjs/canvas/Themes/Level-Up/levelup.d.ts.map +1 -0
- package/dist/cjs/canvas/Themes/Level-Up/levelup.js +163 -0
- package/dist/cjs/canvas/Themes/Level-Up/levelup.js.map +1 -0
- package/dist/cjs/canvas/utils/Background/bg.d.ts +17 -10
- package/dist/cjs/canvas/utils/Background/bg.d.ts.map +1 -1
- package/dist/cjs/canvas/utils/Background/bg.js +102 -27
- package/dist/cjs/canvas/utils/Background/bg.js.map +1 -1
- package/dist/cjs/canvas/utils/Custom/customLines.d.ts.map +1 -1
- package/dist/cjs/canvas/utils/Custom/customLines.js +43 -19
- package/dist/cjs/canvas/utils/Custom/customLines.js.map +1 -1
- package/dist/cjs/canvas/utils/General/general functions.d.ts +6 -1
- package/dist/cjs/canvas/utils/General/general functions.d.ts.map +1 -1
- package/dist/cjs/canvas/utils/General/general functions.js +19 -20
- package/dist/cjs/canvas/utils/General/general functions.js.map +1 -1
- package/dist/cjs/canvas/utils/Image/imageProperties.d.ts +3 -9
- package/dist/cjs/canvas/utils/Image/imageProperties.d.ts.map +1 -1
- package/dist/cjs/canvas/utils/Image/imageProperties.js +220 -214
- package/dist/cjs/canvas/utils/Image/imageProperties.js.map +1 -1
- package/dist/cjs/canvas/utils/Texts/textProperties.d.ts +12 -14
- package/dist/cjs/canvas/utils/Texts/textProperties.d.ts.map +1 -1
- package/dist/cjs/canvas/utils/Texts/textProperties.js +100 -91
- package/dist/cjs/canvas/utils/Texts/textProperties.js.map +1 -1
- package/dist/cjs/canvas/utils/types.d.ts +89 -109
- package/dist/cjs/canvas/utils/types.d.ts.map +1 -1
- package/dist/cjs/canvas/utils/types.js.map +1 -1
- package/dist/cjs/canvas/utils/utils.d.ts +2 -4
- package/dist/cjs/canvas/utils/utils.d.ts.map +1 -1
- package/dist/cjs/canvas/utils/utils.js +2 -5
- package/dist/cjs/canvas/utils/utils.js.map +1 -1
- package/dist/cjs/index.d.ts.map +1 -1
- package/dist/cjs/index.js +31 -3
- package/dist/cjs/index.js.map +1 -1
- package/dist/cjs/tsconfig.cjs.tsbuildinfo +1 -1
- package/dist/esm/ai/ApexModules.d.ts.map +1 -1
- package/dist/esm/ai/ApexModules.js +56 -7
- package/dist/esm/ai/ApexModules.js.map +1 -1
- package/dist/esm/ai/functions/readFiles.js +1 -1
- package/dist/esm/ai/functions/readFiles.js.map +1 -1
- package/dist/esm/ai/modals-chat/electronHub/chatmodels.d.ts.map +1 -1
- package/dist/esm/ai/modals-chat/electronHub/chatmodels.js +2 -1
- package/dist/esm/ai/modals-chat/electronHub/chatmodels.js.map +1 -1
- package/dist/esm/ai/modals-chat/electronHub/speechModels.d.ts.map +1 -1
- package/dist/esm/ai/modals-chat/electronHub/speechModels.js +1 -1
- package/dist/esm/ai/modals-chat/electronHub/speechModels.js.map +1 -1
- package/dist/esm/canvas/ApexPainter.d.ts.map +1 -1
- package/dist/esm/canvas/ApexPainter.js +27 -28
- package/dist/esm/canvas/ApexPainter.js.map +1 -1
- package/dist/esm/canvas/Themes/Level-Up/levelup.d.ts +11 -0
- package/dist/esm/canvas/Themes/Level-Up/levelup.d.ts.map +1 -0
- package/dist/esm/canvas/Themes/Level-Up/levelup.js +163 -0
- package/dist/esm/canvas/Themes/Level-Up/levelup.js.map +1 -0
- package/dist/esm/canvas/utils/Background/bg.d.ts +17 -10
- package/dist/esm/canvas/utils/Background/bg.d.ts.map +1 -1
- package/dist/esm/canvas/utils/Background/bg.js +102 -27
- package/dist/esm/canvas/utils/Background/bg.js.map +1 -1
- package/dist/esm/canvas/utils/Custom/customLines.d.ts.map +1 -1
- package/dist/esm/canvas/utils/Custom/customLines.js +43 -19
- package/dist/esm/canvas/utils/Custom/customLines.js.map +1 -1
- package/dist/esm/canvas/utils/General/general functions.d.ts +6 -1
- package/dist/esm/canvas/utils/General/general functions.d.ts.map +1 -1
- package/dist/esm/canvas/utils/General/general functions.js +19 -20
- package/dist/esm/canvas/utils/General/general functions.js.map +1 -1
- package/dist/esm/canvas/utils/Image/imageProperties.d.ts +3 -9
- package/dist/esm/canvas/utils/Image/imageProperties.d.ts.map +1 -1
- package/dist/esm/canvas/utils/Image/imageProperties.js +220 -214
- package/dist/esm/canvas/utils/Image/imageProperties.js.map +1 -1
- package/dist/esm/canvas/utils/Texts/textProperties.d.ts +12 -14
- package/dist/esm/canvas/utils/Texts/textProperties.d.ts.map +1 -1
- package/dist/esm/canvas/utils/Texts/textProperties.js +100 -91
- package/dist/esm/canvas/utils/Texts/textProperties.js.map +1 -1
- package/dist/esm/canvas/utils/types.d.ts +89 -109
- package/dist/esm/canvas/utils/types.d.ts.map +1 -1
- package/dist/esm/canvas/utils/types.js.map +1 -1
- package/dist/esm/canvas/utils/utils.d.ts +2 -4
- package/dist/esm/canvas/utils/utils.d.ts.map +1 -1
- package/dist/esm/canvas/utils/utils.js +2 -5
- package/dist/esm/canvas/utils/utils.js.map +1 -1
- package/dist/esm/index.d.ts.map +1 -1
- package/dist/esm/index.js +31 -3
- package/dist/esm/index.js.map +1 -1
- package/dist/esm/tsconfig.esm.tsbuildinfo +1 -1
- package/lib/ai/ApexModules.ts +83 -11
- package/lib/ai/functions/readFiles.ts +1 -1
- package/lib/ai/modals-chat/electronHub/chatmodels.ts +4 -2
- package/lib/ai/modals-chat/electronHub/speechModels.ts +2 -1
- package/lib/canvas/ApexPainter.ts +52 -61
- package/lib/canvas/Themes/Level-Up/levelup.ts +183 -0
- package/lib/canvas/utils/Background/bg.ts +179 -65
- package/lib/canvas/utils/Custom/customLines.ts +53 -20
- package/lib/canvas/utils/General/general functions.ts +21 -29
- package/lib/canvas/utils/Image/imageProperties.ts +399 -318
- package/lib/canvas/utils/Texts/textProperties.ts +213 -162
- package/lib/canvas/utils/types.ts +74 -107
- package/lib/canvas/utils/utils.ts +2 -5
- package/lib/index.ts +38 -10
- package/package.json +3 -2
- package/dist/cjs/canvas/utils/Background/circular.d.ts +0 -3
- package/dist/cjs/canvas/utils/Background/circular.d.ts.map +0 -1
- package/dist/cjs/canvas/utils/Background/circular.js +0 -13
- package/dist/cjs/canvas/utils/Background/circular.js.map +0 -1
- package/dist/cjs/canvas/utils/Background/radius.d.ts +0 -18
- package/dist/cjs/canvas/utils/Background/radius.d.ts.map +0 -1
- package/dist/cjs/canvas/utils/Background/radius.js +0 -104
- package/dist/cjs/canvas/utils/Background/radius.js.map +0 -1
- package/dist/esm/canvas/utils/Background/circular.d.ts +0 -3
- package/dist/esm/canvas/utils/Background/circular.d.ts.map +0 -1
- package/dist/esm/canvas/utils/Background/circular.js +0 -13
- package/dist/esm/canvas/utils/Background/circular.js.map +0 -1
- package/dist/esm/canvas/utils/Background/radius.d.ts +0 -18
- package/dist/esm/canvas/utils/Background/radius.d.ts.map +0 -1
- package/dist/esm/canvas/utils/Background/radius.js +0 -104
- package/dist/esm/canvas/utils/Background/radius.js.map +0 -1
- package/lib/canvas/utils/Background/circular.ts +0 -17
- package/lib/canvas/utils/Background/radius.ts +0 -102
|
@@ -0,0 +1,163 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.level_up_1 = level_up_1;
|
|
4
|
+
const index_1 = require("../../../index");
|
|
5
|
+
const Image = new index_1.ApexPainter();
|
|
6
|
+
/**
|
|
7
|
+
* Generates a level-up card.
|
|
8
|
+
* @param {string} userPfp - User profile picture URL.
|
|
9
|
+
* @param {string} username - Username.
|
|
10
|
+
* @param {string} [levelUpmsg="Well done user. You had leveled up 🔥🔥"] - Custom level-up message.
|
|
11
|
+
* @param {string} prevLevel - Previous level before leveling up.
|
|
12
|
+
* @param {string} nextLevel - Next level after leveling up.
|
|
13
|
+
* @returns {Promise<Buffer>} - The generated level-up image.
|
|
14
|
+
*/
|
|
15
|
+
async function level_up_1(userPfp, username, levelUpmsg = "Well done user. You had leveled up 🔥🔥", prevLevel, nextLevel) {
|
|
16
|
+
/** Helper function to detect Arabic text */
|
|
17
|
+
const isArabic = (text) => /[\u0600-\u06FF]/.test(text);
|
|
18
|
+
/** Helper function to shuffle an array */
|
|
19
|
+
function shuffleArray(array) {
|
|
20
|
+
return array.sort(() => Math.random() - 0.5);
|
|
21
|
+
}
|
|
22
|
+
/** Extracts and returns random colors from the dominant colors */
|
|
23
|
+
function getRandomColors(colors) {
|
|
24
|
+
if (colors.length === 0)
|
|
25
|
+
return ["rgb(0, 255, 247)", "rgb(157, 0, 255)", "rgb(255, 94, 0)"];
|
|
26
|
+
return shuffleArray(colors).slice(0, 5).map(c => `rgb(${c.color})`);
|
|
27
|
+
}
|
|
28
|
+
// 1. **Canvas Configuration**
|
|
29
|
+
const canvasConfig = {
|
|
30
|
+
customBg: './bg.png',
|
|
31
|
+
width: 1599, height: 876,
|
|
32
|
+
zoom: {}
|
|
33
|
+
};
|
|
34
|
+
const bg = await Image.createCanvas(canvasConfig);
|
|
35
|
+
// 2. **Extract Dominant Colors for Gradients**
|
|
36
|
+
const dominantColors = await Image.colorAnalysis(userPfp);
|
|
37
|
+
const gradientColors = getRandomColors(dominantColors).map((color, index) => ({
|
|
38
|
+
stop: index / 4, color
|
|
39
|
+
}));
|
|
40
|
+
const shadowGradient = [...gradientColors];
|
|
41
|
+
// 3. **User Profile Picture Configuration**
|
|
42
|
+
const imgs = [{
|
|
43
|
+
source: userPfp,
|
|
44
|
+
width: 240, height: 240,
|
|
45
|
+
x: 235, y: 235,
|
|
46
|
+
blur: 0.4,
|
|
47
|
+
borderRadius: 'circular',
|
|
48
|
+
stroke: {
|
|
49
|
+
width: 8, position: 5, blur: 0.5,
|
|
50
|
+
borderRadius: 'circular',
|
|
51
|
+
gradient: {
|
|
52
|
+
type: 'linear',
|
|
53
|
+
startX: 200, startY: 200,
|
|
54
|
+
endX: 290, endY: 290,
|
|
55
|
+
colors: gradientColors
|
|
56
|
+
}
|
|
57
|
+
},
|
|
58
|
+
shadow: {
|
|
59
|
+
gradient: {
|
|
60
|
+
type: 'linear',
|
|
61
|
+
startX: 220, startY: 220,
|
|
62
|
+
endX: 270, endY: 270,
|
|
63
|
+
colors: shadowGradient
|
|
64
|
+
},
|
|
65
|
+
opacity: 0.7,
|
|
66
|
+
blur: 25,
|
|
67
|
+
borderRadius: 90,
|
|
68
|
+
offsetX: 0, offsetY: 0,
|
|
69
|
+
}
|
|
70
|
+
}];
|
|
71
|
+
const img = await Image.createImage(imgs, bg);
|
|
72
|
+
// 4. **Username Text Handling**
|
|
73
|
+
const maxLength = isArabic(username) ? 12 : 10;
|
|
74
|
+
let displayName = username.length > maxLength
|
|
75
|
+
? isArabic(username)
|
|
76
|
+
? '...' + username.slice(-maxLength)
|
|
77
|
+
: username.slice(0, maxLength - 3) + '...'
|
|
78
|
+
: username;
|
|
79
|
+
let xPos = isArabic(username) ? Math.max(480 - (displayName.length - 4) * 3, 190) - 30 : 300 - Math.min((displayName.length - 3) * 10, 110);
|
|
80
|
+
// 5. **Message Text Alignment**
|
|
81
|
+
const container = { width: 590, height: 235, x: 810, y: 520 };
|
|
82
|
+
const fontName = isArabic(levelUpmsg) ? 'Segoe UI' : 'Segoe UI Emoji';
|
|
83
|
+
const textX = isArabic(levelUpmsg) ? container.x + 290 : container.x + 285;
|
|
84
|
+
// 6. **Dynamic Level Positioning Function**
|
|
85
|
+
function getLevelPosition(level, isNext) {
|
|
86
|
+
let x = isNext ? 1320 : 885;
|
|
87
|
+
let y = 455;
|
|
88
|
+
let fontSize = 72;
|
|
89
|
+
if (level.length === 3) {
|
|
90
|
+
x = isNext ? 1323 : 888;
|
|
91
|
+
y = 455;
|
|
92
|
+
fontSize = 63;
|
|
93
|
+
}
|
|
94
|
+
return { x, y, fontSize };
|
|
95
|
+
}
|
|
96
|
+
const prevLevelConfig = getLevelPosition(prevLevel, false);
|
|
97
|
+
const nextLevelConfig = getLevelPosition(nextLevel, true);
|
|
98
|
+
// 7. **Text Elements Configuration**
|
|
99
|
+
const txts = [
|
|
100
|
+
{
|
|
101
|
+
text: displayName,
|
|
102
|
+
x: xPos, y: 600,
|
|
103
|
+
fontSize: 54,
|
|
104
|
+
fontName: 'Segoe UI',
|
|
105
|
+
textAlign: isArabic(username) ? 'right' : 'left',
|
|
106
|
+
gradient: {
|
|
107
|
+
type: 'linear',
|
|
108
|
+
startX: 0, startY: 0,
|
|
109
|
+
endX: 0, endY: 50,
|
|
110
|
+
colors: [
|
|
111
|
+
{ stop: 0, color: '#ffffff' },
|
|
112
|
+
{ stop: 1, color: '#66e6ff' }
|
|
113
|
+
]
|
|
114
|
+
},
|
|
115
|
+
stroke: { width: 3, color: '#9d00ff' },
|
|
116
|
+
shadow: { color: '#66e6ff', opacity: 0.4, blur: 8, offsetX: 0, offsetY: 0 }
|
|
117
|
+
},
|
|
118
|
+
{
|
|
119
|
+
text: levelUpmsg,
|
|
120
|
+
x: textX, y: container.y + 60,
|
|
121
|
+
fontSize: 34,
|
|
122
|
+
fontName: fontName,
|
|
123
|
+
textAlign: 'center',
|
|
124
|
+
maxWidth: container.width - 30,
|
|
125
|
+
lineHeight: 42,
|
|
126
|
+
maxHeight: container.height - 30,
|
|
127
|
+
gradient: {
|
|
128
|
+
type: 'linear',
|
|
129
|
+
startX: 0, startY: 0,
|
|
130
|
+
endX: 0, endY: 50,
|
|
131
|
+
colors: [
|
|
132
|
+
{ stop: 0, color: '#f9ff00' },
|
|
133
|
+
{ stop: 1, color: '#ff6a00' }
|
|
134
|
+
]
|
|
135
|
+
},
|
|
136
|
+
stroke: { width: 2, color: '#ff9d00' },
|
|
137
|
+
shadow: { color: '#ffcc00', opacity: 0.5, blur: 10, offsetX: 0, offsetY: 0 }
|
|
138
|
+
},
|
|
139
|
+
{
|
|
140
|
+
text: prevLevel,
|
|
141
|
+
x: prevLevelConfig.x, y: prevLevelConfig.y,
|
|
142
|
+
fontSize: prevLevelConfig.fontSize,
|
|
143
|
+
fontName: "Bahnschrift",
|
|
144
|
+
textAlign: "center",
|
|
145
|
+
gradient: { type: "linear", startX: 0, startY: 0, endX: 0, endY: 80, colors: [{ stop: 0, color: "#00FFFF" }, { stop: 1, color: "#007BFF" }] },
|
|
146
|
+
stroke: { width: 6, color: "#0033FF" },
|
|
147
|
+
shadow: { color: "#00BFFF", opacity: 0.6, blur: 15, offsetX: 0, offsetY: 0 }
|
|
148
|
+
},
|
|
149
|
+
{
|
|
150
|
+
text: nextLevel,
|
|
151
|
+
x: nextLevelConfig.x, y: nextLevelConfig.y,
|
|
152
|
+
fontSize: nextLevelConfig.fontSize,
|
|
153
|
+
fontName: "Bahnschrift",
|
|
154
|
+
textAlign: "center",
|
|
155
|
+
gradient: { type: "linear", startX: 0, startY: 0, endX: 0, endY: 80, colors: [{ stop: 0, color: "#00FFFF" }, { stop: 1, color: "#007BFF" }] },
|
|
156
|
+
stroke: { width: 6, color: "#0033FF" },
|
|
157
|
+
shadow: { color: "#00BFFF", opacity: 0.6, blur: 15, offsetX: 0, offsetY: 0 }
|
|
158
|
+
}
|
|
159
|
+
];
|
|
160
|
+
// 8. **Render Final Image**
|
|
161
|
+
return await Image.createText(txts, img);
|
|
162
|
+
}
|
|
163
|
+
//# sourceMappingURL=levelup.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"levelup.js","sourceRoot":"","sources":["../../../../../lib/canvas/Themes/Level-Up/levelup.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,24 +1,31 @@
|
|
|
1
1
|
import { SKRSContext2D } from "@napi-rs/canvas";
|
|
2
|
-
import { CanvasConfig } from
|
|
2
|
+
import { CanvasConfig } from "../types";
|
|
3
|
+
interface ZoomConfig {
|
|
4
|
+
scale?: number;
|
|
5
|
+
x?: number;
|
|
6
|
+
y?: number;
|
|
7
|
+
}
|
|
3
8
|
/**
|
|
4
|
-
* Draws a gradient background on the canvas.
|
|
5
|
-
* No zoom logic is applied.
|
|
9
|
+
* Draws a gradient background on the canvas with optional zoom support.
|
|
6
10
|
* @param ctx The canvas rendering context.
|
|
7
11
|
* @param canvas The canvas configuration object.
|
|
12
|
+
* @param zoom Optional zoom configuration.
|
|
8
13
|
*/
|
|
9
|
-
export declare function drawBackgroundGradient(ctx: SKRSContext2D, canvas: CanvasConfig): Promise<void>;
|
|
14
|
+
export declare function drawBackgroundGradient(ctx: SKRSContext2D, canvas: CanvasConfig, zoom?: ZoomConfig, blur?: number): Promise<void>;
|
|
10
15
|
/**
|
|
11
|
-
* Draws a solid background color on the canvas.
|
|
12
|
-
* No zoom logic is applied.
|
|
16
|
+
* Draws a solid background color on the canvas with optional zoom effect.
|
|
13
17
|
* @param ctx The canvas rendering context.
|
|
14
18
|
* @param canvas The canvas configuration object.
|
|
19
|
+
* @param zoom Optional zoom configuration.
|
|
15
20
|
*/
|
|
16
|
-
export declare function drawBackgroundColor(ctx: SKRSContext2D, canvas: CanvasConfig): Promise<void>;
|
|
21
|
+
export declare function drawBackgroundColor(ctx: SKRSContext2D, canvas: CanvasConfig, zoom?: ZoomConfig, blur?: number): Promise<void>;
|
|
17
22
|
/**
|
|
18
|
-
* Draws a custom background image on the canvas.
|
|
19
|
-
* No zoom logic is applied.
|
|
23
|
+
* Draws a custom background image on the canvas with optional zoom functionality.
|
|
20
24
|
* @param ctx The canvas rendering context.
|
|
21
25
|
* @param canvas The canvas configuration object.
|
|
26
|
+
* @param zoom Optional zoom configuration.
|
|
22
27
|
*/
|
|
23
|
-
export declare function customBackground(ctx: SKRSContext2D, canvas: CanvasConfig): Promise<void>;
|
|
28
|
+
export declare function customBackground(ctx: SKRSContext2D, canvas: CanvasConfig, zoom?: ZoomConfig, blur?: number): Promise<void>;
|
|
29
|
+
export declare function backgroundRadius(ctx: SKRSContext2D, x: number, y: number, width: number, height: number, borderRadius: number | "circular", borderPosition?: string): void;
|
|
30
|
+
export {};
|
|
24
31
|
//# sourceMappingURL=bg.d.ts.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bg.d.ts","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Background/bg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;
|
|
1
|
+
{"version":3,"file":"bg.d.ts","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Background/bg.ts"],"names":[],"mappings":"AAAA,OAAO,EAAa,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAC3D,OAAO,EAAE,YAAY,EAAE,MAAM,UAAU,CAAC;AAGxC,UAAU,UAAU;IAChB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,CAAC,CAAC,EAAE,MAAM,CAAC;IACX,CAAC,CAAC,EAAE,MAAM,CAAC;CACd;AAED;;;;;GAKG;AACH,wBAAsB,sBAAsB,CACxC,GAAG,EAAE,aAAa,EAClB,MAAM,EAAE,YAAY,EACpB,IAAI,CAAC,EAAE,UAAU,EACjB,IAAI,CAAC,EAAE,MAAM,GACd,OAAO,CAAC,IAAI,CAAC,CAiDf;AAED;;;;;GAKG;AACH,wBAAsB,mBAAmB,CACrC,GAAG,EAAE,aAAa,EAClB,MAAM,EAAE,YAAY,EACpB,IAAI,CAAC,EAAE,UAAU,EACjB,IAAI,CAAC,EAAE,MAAM,GACd,OAAO,CAAC,IAAI,CAAC,CA2Bf;AAED;;;;;GAKG;AACH,wBAAsB,gBAAgB,CAClC,GAAG,EAAE,aAAa,EAClB,MAAM,EAAE,YAAY,EACpB,IAAI,CAAC,EAAE,UAAU,EACjB,IAAI,CAAC,EAAE,MAAM,GACd,OAAO,CAAC,IAAI,CAAC,CAyCf;AAED,wBAAgB,gBAAgB,CAC5B,GAAG,EAAE,aAAa,EAClB,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,MAAM,EACb,MAAM,EAAE,MAAM,EACd,YAAY,EAAE,MAAM,GAAG,UAAU,EACjC,cAAc,GAAE,MAAc,GAC7B,IAAI,CAmCN"}
|
|
@@ -6,81 +6,156 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
6
6
|
exports.drawBackgroundGradient = drawBackgroundGradient;
|
|
7
7
|
exports.drawBackgroundColor = drawBackgroundColor;
|
|
8
8
|
exports.customBackground = customBackground;
|
|
9
|
+
exports.backgroundRadius = backgroundRadius;
|
|
9
10
|
const canvas_1 = require("@napi-rs/canvas");
|
|
10
11
|
const path_1 = __importDefault(require("path"));
|
|
11
12
|
/**
|
|
12
|
-
* Draws a gradient background on the canvas.
|
|
13
|
-
* No zoom logic is applied.
|
|
13
|
+
* Draws a gradient background on the canvas with optional zoom support.
|
|
14
14
|
* @param ctx The canvas rendering context.
|
|
15
15
|
* @param canvas The canvas configuration object.
|
|
16
|
+
* @param zoom Optional zoom configuration.
|
|
16
17
|
*/
|
|
17
|
-
async function drawBackgroundGradient(ctx, canvas) {
|
|
18
|
+
async function drawBackgroundGradient(ctx, canvas, zoom, blur) {
|
|
18
19
|
if (canvas.gradientBg) {
|
|
19
20
|
const { type, startX = 0, startY = 0, endX = canvas.width || 500, endY = canvas.height || 500, startRadius = 0, endRadius = 0, colors } = canvas.gradientBg;
|
|
20
21
|
if (!colors || colors.length === 0) {
|
|
21
|
-
throw new Error(
|
|
22
|
+
throw new Error("You need to provide colors for the gradient.");
|
|
22
23
|
}
|
|
23
24
|
let gradient;
|
|
24
|
-
if (type ===
|
|
25
|
-
|
|
25
|
+
if (type === "linear" || type === undefined) {
|
|
26
|
+
let finalStartX = startX, finalStartY = startY, finalEndX = endX, finalEndY = endY;
|
|
27
|
+
if (zoom) {
|
|
28
|
+
const scale = Math.max(1, zoom.scale || 1);
|
|
29
|
+
finalStartX = (zoom.x || 0) - (endX - startX) / (2 * scale);
|
|
30
|
+
finalStartY = (zoom.y || 0) - (endY - startY) / (2 * scale);
|
|
31
|
+
finalEndX = (zoom.x || 0) + (endX - startX) / (2 * scale);
|
|
32
|
+
finalEndY = (zoom.y || 0) + (endY - startY) / (2 * scale);
|
|
33
|
+
}
|
|
34
|
+
gradient = ctx.createLinearGradient(finalStartX, finalStartY, finalEndX, finalEndY);
|
|
26
35
|
}
|
|
27
|
-
else if (type ===
|
|
36
|
+
else if (type === "radial") {
|
|
28
37
|
gradient = ctx.createRadialGradient(startX, startY, startRadius, endX, endY, endRadius);
|
|
29
38
|
}
|
|
30
39
|
else {
|
|
31
|
-
throw new Error(
|
|
40
|
+
throw new Error("Unsupported gradient type.");
|
|
32
41
|
}
|
|
33
42
|
for (const { stop, color } of colors) {
|
|
34
43
|
gradient.addColorStop(stop, color);
|
|
35
44
|
}
|
|
36
|
-
|
|
37
|
-
|
|
45
|
+
if (blur) {
|
|
46
|
+
ctx.filter = `blur(${blur}px)`;
|
|
47
|
+
}
|
|
38
48
|
ctx.fillStyle = gradient;
|
|
39
|
-
ctx.fillRect(0, 0,
|
|
49
|
+
ctx.fillRect(0, 0, canvas.width || 500, canvas.height || 500);
|
|
50
|
+
ctx.filter = "none";
|
|
40
51
|
}
|
|
41
52
|
}
|
|
42
53
|
/**
|
|
43
|
-
* Draws a solid background color on the canvas.
|
|
44
|
-
* No zoom logic is applied.
|
|
54
|
+
* Draws a solid background color on the canvas with optional zoom effect.
|
|
45
55
|
* @param ctx The canvas rendering context.
|
|
46
56
|
* @param canvas The canvas configuration object.
|
|
57
|
+
* @param zoom Optional zoom configuration.
|
|
47
58
|
*/
|
|
48
|
-
async function drawBackgroundColor(ctx, canvas) {
|
|
59
|
+
async function drawBackgroundColor(ctx, canvas, zoom, blur) {
|
|
49
60
|
const canvasWidth = canvas.width || 500;
|
|
50
61
|
const canvasHeight = canvas.height || 500;
|
|
51
|
-
|
|
52
|
-
if (
|
|
62
|
+
ctx.save();
|
|
63
|
+
if (blur) {
|
|
64
|
+
ctx.filter = `blur(${blur}px)`;
|
|
65
|
+
}
|
|
66
|
+
if (zoom) {
|
|
67
|
+
const scale = Math.max(1, zoom.scale || 1);
|
|
68
|
+
const zoomedWidth = canvasWidth / scale;
|
|
69
|
+
const zoomedHeight = canvasHeight / scale;
|
|
70
|
+
ctx.scale(scale, scale);
|
|
71
|
+
ctx.translate((zoom.x || 0) + zoomedWidth / 2, (zoom.y || 0) + zoomedHeight / 2);
|
|
72
|
+
}
|
|
73
|
+
if (canvas.colorBg !== "transparent") {
|
|
53
74
|
ctx.fillStyle = canvas.colorBg;
|
|
54
75
|
ctx.fillRect(0, 0, canvasWidth, canvasHeight);
|
|
55
76
|
}
|
|
77
|
+
ctx.filter = "none";
|
|
78
|
+
ctx.restore();
|
|
56
79
|
}
|
|
57
80
|
/**
|
|
58
|
-
* Draws a custom background image on the canvas.
|
|
59
|
-
* No zoom logic is applied.
|
|
81
|
+
* Draws a custom background image on the canvas with optional zoom functionality.
|
|
60
82
|
* @param ctx The canvas rendering context.
|
|
61
83
|
* @param canvas The canvas configuration object.
|
|
84
|
+
* @param zoom Optional zoom configuration.
|
|
62
85
|
*/
|
|
63
|
-
async function customBackground(ctx, canvas) {
|
|
86
|
+
async function customBackground(ctx, canvas, zoom, blur) {
|
|
64
87
|
if (canvas.customBg) {
|
|
65
88
|
try {
|
|
66
89
|
let imageBuffer;
|
|
67
|
-
if (canvas.customBg.startsWith(
|
|
90
|
+
if (canvas.customBg.startsWith("http")) {
|
|
68
91
|
imageBuffer = canvas.customBg;
|
|
69
92
|
}
|
|
70
93
|
else {
|
|
71
94
|
imageBuffer = path_1.default.join(process.cwd(), canvas.customBg);
|
|
72
95
|
}
|
|
73
96
|
const image = await (0, canvas_1.loadImage)(imageBuffer);
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
const canvasWidth = canvas.width ||
|
|
77
|
-
const canvasHeight = canvas.height ||
|
|
78
|
-
|
|
79
|
-
|
|
97
|
+
const imgWidth = image.width;
|
|
98
|
+
const imgHeight = image.height;
|
|
99
|
+
const canvasWidth = canvas.width || imgWidth;
|
|
100
|
+
const canvasHeight = canvas.height || imgHeight;
|
|
101
|
+
if (blur) {
|
|
102
|
+
ctx.filter = `blur(${blur}px)`;
|
|
103
|
+
}
|
|
104
|
+
if (zoom) {
|
|
105
|
+
const scale = Math.max(1, zoom.scale || 1);
|
|
106
|
+
const cropWidth = imgWidth / scale;
|
|
107
|
+
const cropHeight = imgHeight / scale;
|
|
108
|
+
let sx = (zoom.x || 0) - cropWidth / 2;
|
|
109
|
+
let sy = (zoom.y || 0) - cropHeight / 2;
|
|
110
|
+
sx = Math.max(0, Math.min(sx, imgWidth - cropWidth));
|
|
111
|
+
sy = Math.max(0, Math.min(sy, imgHeight - cropHeight));
|
|
112
|
+
ctx.drawImage(image, sx, sy, cropWidth, cropHeight, 0, 0, canvasWidth, canvasHeight);
|
|
113
|
+
}
|
|
114
|
+
else {
|
|
115
|
+
ctx.drawImage(image, 0, 0, canvasWidth, canvasHeight);
|
|
116
|
+
}
|
|
117
|
+
ctx.filter = "none";
|
|
80
118
|
}
|
|
81
119
|
catch (error) {
|
|
82
|
-
console.error(
|
|
120
|
+
console.error("Error loading custom background image:", error.message);
|
|
83
121
|
}
|
|
84
122
|
}
|
|
85
123
|
}
|
|
124
|
+
function backgroundRadius(ctx, x, y, width, height, borderRadius, borderPosition = "all") {
|
|
125
|
+
ctx.beginPath();
|
|
126
|
+
if (borderRadius === "circular") {
|
|
127
|
+
const circleRadius = Math.min(width, height) / 2;
|
|
128
|
+
ctx.arc(x + width / 2, y + height / 2, circleRadius, 0, 2 * Math.PI);
|
|
129
|
+
}
|
|
130
|
+
else if (typeof borderRadius === "number" && borderRadius > 0) {
|
|
131
|
+
const br = Math.min(borderRadius, width / 2, height / 2);
|
|
132
|
+
const selectedPositions = new Set(borderPosition.toLowerCase().split(",").map((s) => s.trim()));
|
|
133
|
+
const roundTopLeft = selectedPositions.has("all") || selectedPositions.has("top-left") || (selectedPositions.has("top") && selectedPositions.has("left"));
|
|
134
|
+
const roundTopRight = selectedPositions.has("all") || selectedPositions.has("top-right") || (selectedPositions.has("top") && selectedPositions.has("right"));
|
|
135
|
+
const roundBottomRight = selectedPositions.has("all") || selectedPositions.has("bottom-right") || (selectedPositions.has("bottom") && selectedPositions.has("right"));
|
|
136
|
+
const roundBottomLeft = selectedPositions.has("all") || selectedPositions.has("bottom-left") || (selectedPositions.has("bottom") && selectedPositions.has("left"));
|
|
137
|
+
const tl = roundTopLeft ? br : 0;
|
|
138
|
+
const tr = roundTopRight ? br : 0;
|
|
139
|
+
const brR = roundBottomRight ? br : 0;
|
|
140
|
+
const bl = roundBottomLeft ? br : 0;
|
|
141
|
+
ctx.moveTo(x + tl, y);
|
|
142
|
+
ctx.lineTo(x + width - tr, y);
|
|
143
|
+
if (tr > 0)
|
|
144
|
+
ctx.arc(x + width - tr, y + tr, tr, -Math.PI / 2, 0, false);
|
|
145
|
+
ctx.lineTo(x + width, y + height - brR);
|
|
146
|
+
if (brR > 0)
|
|
147
|
+
ctx.arc(x + width - brR, y + height - brR, brR, 0, Math.PI / 2, false);
|
|
148
|
+
ctx.lineTo(x + bl, y + height);
|
|
149
|
+
if (bl > 0)
|
|
150
|
+
ctx.arc(x + bl, y + height - bl, bl, Math.PI / 2, Math.PI, false);
|
|
151
|
+
ctx.lineTo(x, y + tl);
|
|
152
|
+
if (tl > 0)
|
|
153
|
+
ctx.arc(x + tl, y + tl, tl, Math.PI, -Math.PI / 2, false);
|
|
154
|
+
}
|
|
155
|
+
else {
|
|
156
|
+
ctx.rect(x, y, width, height);
|
|
157
|
+
}
|
|
158
|
+
ctx.closePath();
|
|
159
|
+
ctx.clip();
|
|
160
|
+
}
|
|
86
161
|
//# sourceMappingURL=bg.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"bg.js","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Background/bg.ts"],"names":[],"mappings":";;;;;
|
|
1
|
+
{"version":3,"file":"bg.js","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Background/bg.ts"],"names":[],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"customLines.d.ts","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Custom/customLines.ts"],"names":[],"mappings":"
|
|
1
|
+
{"version":3,"file":"customLines.d.ts","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Custom/customLines.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAEzC,wBAAgB,WAAW,CAAC,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,aAAa,EAAE,QA6F7D"}
|
|
@@ -1,6 +1,7 @@
|
|
|
1
1
|
"use strict";
|
|
2
2
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
3
|
exports.customLines = customLines;
|
|
4
|
+
const imageProperties_1 = require("../Image/imageProperties");
|
|
4
5
|
function customLines(ctx, options) {
|
|
5
6
|
let previousEndCoordinates = null;
|
|
6
7
|
let currentStyle = null;
|
|
@@ -17,7 +18,7 @@ function customLines(ctx, options) {
|
|
|
17
18
|
}
|
|
18
19
|
if (!isSingleLine && inSingleLineSequence) {
|
|
19
20
|
ctx.stroke();
|
|
20
|
-
|
|
21
|
+
applyStroke(ctx, currentStyle, startCoordinates, endCoordinates);
|
|
21
22
|
inSingleLineSequence = false;
|
|
22
23
|
currentStyle = null;
|
|
23
24
|
}
|
|
@@ -31,7 +32,12 @@ function customLines(ctx, options) {
|
|
|
31
32
|
ctx.lineTo(endCoordinates.x, endCoordinates.y);
|
|
32
33
|
const appliedStyle = inSingleLineSequence ? currentStyle : lineStyle;
|
|
33
34
|
ctx.lineWidth = appliedStyle?.width || 1;
|
|
34
|
-
|
|
35
|
+
if (appliedStyle?.gradient) {
|
|
36
|
+
ctx.strokeStyle = (0, imageProperties_1.createGradient)(ctx, appliedStyle.gradient, start.x, start.y, endCoordinates.x, endCoordinates.y);
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
ctx.strokeStyle = appliedStyle?.color || 'black';
|
|
40
|
+
}
|
|
35
41
|
ctx.lineJoin = appliedStyle?.lineJoin || 'miter';
|
|
36
42
|
ctx.lineCap = appliedStyle?.lineCap || 'butt';
|
|
37
43
|
if (appliedStyle?.lineDash) {
|
|
@@ -41,31 +47,31 @@ function customLines(ctx, options) {
|
|
|
41
47
|
else {
|
|
42
48
|
ctx.setLineDash([]);
|
|
43
49
|
}
|
|
44
|
-
if (typeof appliedStyle?.lineRadius === 'number') {
|
|
45
|
-
const
|
|
50
|
+
if (typeof appliedStyle?.lineRadius === 'number' && appliedStyle.lineRadius > 0) {
|
|
51
|
+
const radius = appliedStyle.lineRadius;
|
|
46
52
|
const dx = endCoordinates.x - start.x;
|
|
47
53
|
const dy = endCoordinates.y - start.y;
|
|
48
54
|
const angle = Math.atan2(dy, dx);
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
ctx.
|
|
52
|
-
ctx.
|
|
55
|
+
ctx.lineCap = "round";
|
|
56
|
+
ctx.stroke();
|
|
57
|
+
ctx.beginPath();
|
|
58
|
+
ctx.arc(start.x, start.y, radius, angle + Math.PI / 2, angle - Math.PI / 2, true);
|
|
59
|
+
ctx.arc(endCoordinates.x, endCoordinates.y, radius, angle - Math.PI / 2, angle + Math.PI / 2, false);
|
|
60
|
+
ctx.fill();
|
|
53
61
|
}
|
|
54
62
|
else if (appliedStyle?.lineRadius === 'circular') {
|
|
55
63
|
const dx = endCoordinates.x - start.x;
|
|
56
64
|
const dy = endCoordinates.y - start.y;
|
|
57
65
|
const length = Math.sqrt(dx * dx + dy * dy);
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
ctx.
|
|
61
|
-
ctx.arc(start.x, start.y, length / 2, angle - Math.PI / 2, angle + Math.PI / 2);
|
|
62
|
-
ctx.lineTo(endCoordinates.x + Math.cos(angle + Math.PI / 2) * halfWidth, endCoordinates.y + Math.sin(angle + Math.PI / 2) * halfWidth);
|
|
63
|
-
ctx.arc(endCoordinates.x, endCoordinates.y, length / 2, angle + Math.PI / 2, angle - Math.PI / 2, true);
|
|
66
|
+
ctx.beginPath();
|
|
67
|
+
ctx.arcTo(start.x, start.y, endCoordinates.x, endCoordinates.y, length / 2);
|
|
68
|
+
ctx.arcTo(endCoordinates.x, endCoordinates.y, start.x, start.y, length / 2);
|
|
64
69
|
ctx.closePath();
|
|
70
|
+
ctx.stroke();
|
|
65
71
|
}
|
|
66
72
|
if (!inSingleLineSequence || i === options.length - 1) {
|
|
67
73
|
ctx.stroke();
|
|
68
|
-
|
|
74
|
+
applyStroke(ctx, appliedStyle, startCoordinates, endCoordinates);
|
|
69
75
|
}
|
|
70
76
|
previousEndCoordinates = endCoordinates;
|
|
71
77
|
if (!isSingleLine) {
|
|
@@ -74,12 +80,30 @@ function customLines(ctx, options) {
|
|
|
74
80
|
}
|
|
75
81
|
}
|
|
76
82
|
}
|
|
77
|
-
function
|
|
83
|
+
function applyStroke(ctx, style, start, end) {
|
|
78
84
|
if (style.stroke) {
|
|
79
|
-
const { color, width } = style.stroke;
|
|
80
|
-
ctx.strokeStyle
|
|
81
|
-
ctx.lineWidth
|
|
85
|
+
const { color, width, gradient, lineRadius, lineCap } = style.stroke;
|
|
86
|
+
const prevStrokeStyle = ctx.strokeStyle;
|
|
87
|
+
const prevLineWidth = ctx.lineWidth;
|
|
88
|
+
const prevLineCap = ctx.lineCap;
|
|
89
|
+
if (gradient) {
|
|
90
|
+
ctx.strokeStyle = (0, imageProperties_1.createGradient)(ctx, gradient, start.x, start.y, end.x, end.y);
|
|
91
|
+
}
|
|
92
|
+
else {
|
|
93
|
+
ctx.strokeStyle = color || prevStrokeStyle;
|
|
94
|
+
}
|
|
95
|
+
ctx.lineWidth = width || prevLineWidth;
|
|
96
|
+
ctx.lineCap = lineCap || prevLineCap;
|
|
82
97
|
ctx.stroke();
|
|
98
|
+
if (typeof lineRadius === 'number' && lineRadius > 0) {
|
|
99
|
+
ctx.beginPath();
|
|
100
|
+
ctx.arc(start.x, start.y, lineRadius, 0, Math.PI * 2);
|
|
101
|
+
ctx.arc(end.x, end.y, lineRadius, 0, Math.PI * 2);
|
|
102
|
+
ctx.fill();
|
|
103
|
+
}
|
|
104
|
+
ctx.strokeStyle = prevStrokeStyle;
|
|
105
|
+
ctx.lineWidth = prevLineWidth;
|
|
106
|
+
ctx.lineCap = prevLineCap;
|
|
83
107
|
}
|
|
84
108
|
}
|
|
85
109
|
//# sourceMappingURL=customLines.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"customLines.js","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Custom/customLines.ts"],"names":[],"mappings":";;
|
|
1
|
+
{"version":3,"file":"customLines.js","sourceRoot":"","sources":["../../../../../lib/canvas/utils/Custom/customLines.ts"],"names":[],"mappings":"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"}
|
|
@@ -3,7 +3,6 @@ import { cropOptions, ResizeOptions } from '../types';
|
|
|
3
3
|
export declare function loadImages(imagePath: string): Promise<sharp.Sharp>;
|
|
4
4
|
/**
|
|
5
5
|
* Resizes an image using Sharp with additional options for quality, kernel, and withoutEnlargement.
|
|
6
|
-
*
|
|
7
6
|
* @param resizeOptions - The options for resizing.
|
|
8
7
|
* @returns A Promise that resolves with the resized image as a Buffer.
|
|
9
8
|
*/
|
|
@@ -21,6 +20,12 @@ export declare function cropInner(options: cropOptions): Promise<Buffer>;
|
|
|
21
20
|
* The polygon is defined by the coordinates (with optional bezier smoothing using tension).
|
|
22
21
|
*/
|
|
23
22
|
export declare function cropOuter(options: cropOptions): Promise<Buffer>;
|
|
23
|
+
/**
|
|
24
|
+
* Detects dominant colors from an image.
|
|
25
|
+
*
|
|
26
|
+
* @param imagePath - Local path or URL of the image.
|
|
27
|
+
* @returns A sorted array of dominant colors with their frequency.
|
|
28
|
+
*/
|
|
24
29
|
export declare function detectColors(imagePath: string): Promise<{
|
|
25
30
|
color: string;
|
|
26
31
|
frequency: string;
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"general functions.d.ts","sourceRoot":"","sources":["../../../../../lib/canvas/utils/General/general functions.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAKtD,wBAAsB,UAAU,CAAC,SAAS,EAAE,MAAM,wBAqBjD;AAGD
|
|
1
|
+
{"version":3,"file":"general functions.d.ts","sourceRoot":"","sources":["../../../../../lib/canvas/utils/General/general functions.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,WAAW,EAAE,aAAa,EAAE,MAAM,UAAU,CAAC;AAKtD,wBAAsB,UAAU,CAAC,SAAS,EAAE,MAAM,wBAqBjD;AAGD;;;;GAIG;AACH,wBAAsB,WAAW,CAAC,aAAa,EAAE,aAAa,GAAG,OAAO,CAAC,MAAM,CAAC,CA6B/E;AAED,wBAAsB,SAAS,CAAC,SAAS,EAAE,MAAM,EAAE,YAAY,EAAE,MAAM,oCAiCtE;AAED,wBAAsB,iBAAiB,CAAC,SAAS,EAAE,MAAM,EAAE,eAAe,CAAC,EAAE,GAAG,EAAE,OAAO,GAAE,MAAU,gBA8BpG;AA2DD,wBAAsB,UAAU,CAAC,SAAS,EAAE,MAAM,EAAE,OAAO,EAAE,GAAG,EAAE,oCA2DjE;AAGD;;;GAGG;AACH,wBAAsB,SAAS,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CAgErE;AAED;;;GAGG;AACH,wBAAsB,SAAS,CAAC,OAAO,EAAE,WAAW,GAAG,OAAO,CAAC,MAAM,CAAC,CA4CrE;AAGD;;;;;GAKG;AACH,wBAAsB,YAAY,CAAC,SAAS,EAAE,MAAM,GAAG,OAAO,CAAC;IAAE,KAAK,EAAE,MAAM,CAAC;IAAC,SAAS,EAAE,MAAM,CAAA;CAAE,EAAE,CAAC,CA6CrG;AAED,wBAAsB,WAAW,CAAC,cAAc,EAAE,MAAM,EAAE,aAAa,EAAE;IAAE,GAAG,EAAE,MAAM,CAAC;IAAC,KAAK,EAAE,MAAM,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CAwClJ;AAED,wBAAsB,SAAS,CAAC,MAAM,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,GAAG,SAAS,CAAC,CA4B5F"}
|