apexify.js 3.3.7 → 3.3.9

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.
Files changed (125) hide show
  1. package/dist/ai/ApexAI.d.ts +62 -0
  2. package/dist/ai/ApexAI.d.ts.map +1 -0
  3. package/dist/ai/ApexAI.js +449 -0
  4. package/dist/ai/ApexAI.js.map +1 -0
  5. package/dist/ai/buttons/drawMenu.d.ts +3 -0
  6. package/dist/ai/buttons/drawMenu.d.ts.map +1 -0
  7. package/dist/ai/buttons/drawMenu.js +274 -0
  8. package/dist/ai/buttons/drawMenu.js.map +1 -0
  9. package/dist/ai/buttons/tools.d.ts +3 -0
  10. package/dist/ai/buttons/tools.d.ts.map +1 -0
  11. package/dist/ai/buttons/tools.js +445 -0
  12. package/dist/ai/buttons/tools.js.map +1 -0
  13. package/dist/ai/functions/aivoice.d.ts +1 -0
  14. package/dist/ai/functions/aivoice.d.ts.map +1 -0
  15. package/dist/ai/functions/aivoice.js +2 -0
  16. package/dist/ai/functions/aivoice.js.map +1 -0
  17. package/dist/ai/functions/chunkString.d.ts +2 -0
  18. package/dist/ai/functions/chunkString.d.ts.map +1 -0
  19. package/dist/ai/functions/chunkString.js +8 -0
  20. package/dist/ai/functions/chunkString.js.map +1 -0
  21. package/dist/ai/functions/draw.d.ts +3 -0
  22. package/dist/ai/functions/draw.d.ts.map +1 -0
  23. package/dist/ai/functions/draw.js +396 -0
  24. package/dist/ai/functions/draw.js.map +1 -0
  25. package/dist/ai/functions/generateVoiceResponse.d.ts +3 -0
  26. package/dist/ai/functions/generateVoiceResponse.d.ts.map +1 -0
  27. package/dist/ai/functions/generateVoiceResponse.js +151 -0
  28. package/dist/ai/functions/generateVoiceResponse.js.map +1 -0
  29. package/dist/ai/functions/imageReader.d.ts +3 -0
  30. package/dist/ai/functions/imageReader.d.ts.map +1 -0
  31. package/dist/ai/functions/imageReader.js +23 -0
  32. package/dist/ai/functions/imageReader.js.map +1 -0
  33. package/dist/ai/functions/readFiles.d.ts +3 -0
  34. package/dist/ai/functions/readFiles.d.ts.map +1 -0
  35. package/dist/ai/functions/readFiles.js +62 -0
  36. package/dist/ai/functions/readFiles.js.map +1 -0
  37. package/dist/ai/functions/readImagess.d.ts +2 -0
  38. package/dist/ai/functions/readImagess.d.ts.map +1 -0
  39. package/dist/ai/functions/readImagess.js +46 -0
  40. package/dist/ai/functions/readImagess.js.map +1 -0
  41. package/dist/ai/functions/shouldDrawImage.d.ts +2 -0
  42. package/dist/ai/functions/shouldDrawImage.d.ts.map +1 -0
  43. package/dist/ai/functions/shouldDrawImage.js +12 -0
  44. package/dist/ai/functions/shouldDrawImage.js.map +1 -0
  45. package/dist/ai/functions/typeWriter.d.ts +2 -0
  46. package/dist/ai/functions/typeWriter.d.ts.map +1 -0
  47. package/dist/ai/functions/typeWriter.js +24 -0
  48. package/dist/ai/functions/typeWriter.js.map +1 -0
  49. package/dist/ai/models.d.ts +9 -0
  50. package/dist/ai/models.d.ts.map +1 -0
  51. package/dist/ai/models.js +575 -0
  52. package/dist/ai/models.js.map +1 -0
  53. package/dist/ai/utils.d.ts +11 -0
  54. package/dist/ai/utils.d.ts.map +1 -0
  55. package/dist/ai/utils.js +24 -0
  56. package/dist/ai/utils.js.map +1 -0
  57. package/dist/canvas/ApexPainter.d.ts +38 -0
  58. package/dist/canvas/ApexPainter.d.ts.map +1 -0
  59. package/dist/canvas/ApexPainter.js +444 -0
  60. package/dist/canvas/ApexPainter.js.map +1 -0
  61. package/dist/canvas/utils/bg.d.ts +23 -0
  62. package/dist/canvas/utils/bg.d.ts.map +1 -0
  63. package/dist/canvas/utils/bg.js +77 -0
  64. package/dist/canvas/utils/bg.js.map +1 -0
  65. package/dist/canvas/utils/charts.d.ts +9 -0
  66. package/dist/canvas/utils/charts.d.ts.map +1 -0
  67. package/dist/canvas/utils/charts.js +473 -0
  68. package/dist/canvas/utils/charts.js.map +1 -0
  69. package/dist/canvas/utils/circular.d.ts +10 -0
  70. package/dist/canvas/utils/circular.d.ts.map +1 -0
  71. package/dist/canvas/utils/circular.js +22 -0
  72. package/dist/canvas/utils/circular.js.map +1 -0
  73. package/dist/canvas/utils/customLines.d.ts +2 -0
  74. package/dist/canvas/utils/customLines.d.ts.map +1 -0
  75. package/dist/canvas/utils/customLines.js +50 -0
  76. package/dist/canvas/utils/customLines.js.map +1 -0
  77. package/dist/canvas/utils/general functions.d.ts +21 -0
  78. package/dist/canvas/utils/general functions.d.ts.map +1 -0
  79. package/dist/canvas/utils/general functions.js +406 -0
  80. package/dist/canvas/utils/general functions.js.map +1 -0
  81. package/dist/canvas/utils/imageProperties.d.ts +60 -0
  82. package/dist/canvas/utils/imageProperties.d.ts.map +1 -0
  83. package/dist/canvas/utils/imageProperties.js +331 -0
  84. package/dist/canvas/utils/imageProperties.js.map +1 -0
  85. package/dist/canvas/utils/radius.d.ts +10 -0
  86. package/dist/canvas/utils/radius.d.ts.map +1 -0
  87. package/dist/canvas/utils/radius.js +31 -0
  88. package/dist/canvas/utils/radius.js.map +1 -0
  89. package/dist/canvas/utils/textProperties.d.ts +18 -0
  90. package/dist/canvas/utils/textProperties.d.ts.map +1 -0
  91. package/dist/canvas/utils/textProperties.js +67 -0
  92. package/dist/canvas/utils/textProperties.js.map +1 -0
  93. package/dist/canvas/utils/types.d.ts +421 -0
  94. package/dist/canvas/utils/types.d.ts.map +1 -0
  95. package/dist/canvas/utils/types.js +5 -0
  96. package/dist/canvas/utils/types.js.map +1 -0
  97. package/dist/canvas/utils/utils.d.ts +20 -0
  98. package/dist/canvas/utils/utils.d.ts.map +1 -0
  99. package/dist/canvas/utils/utils.js +48 -0
  100. package/dist/canvas/utils/utils.js.map +1 -0
  101. package/dist/index.d.ts +11 -0
  102. package/dist/index.d.ts.map +1 -0
  103. package/dist/index.js +63 -0
  104. package/dist/index.js.map +1 -0
  105. package/dist/utils.d.ts +12 -0
  106. package/dist/utils.d.ts.map +1 -0
  107. package/dist/utils.js +12 -0
  108. package/dist/utils.js.map +1 -0
  109. package/lib/ai/functions/aivoice.ts +0 -0
  110. package/lib/ai/functions/draw.ts +65 -64
  111. package/lib/ai/functions/generateVoiceResponse.ts +15 -22
  112. package/lib/ai/functions/readImagess.ts +6 -6
  113. package/lib/ai/functions/typeWriter.ts +0 -2
  114. package/package.json +6 -2
  115. package/.github/ISSUE_TEMPLATE/bug_report.md +0 -38
  116. package/.github/ISSUE_TEMPLATE/feature_request.md +0 -20
  117. package/.github/dependabot.yml +0 -7
  118. package/.tsbuildinfo +0 -1
  119. package/CODE_OF_CONDUCT.md +0 -128
  120. package/SECURITY.md +0 -20
  121. package/change logs.md +0 -19
  122. package/examples/barchart.txt +0 -71
  123. package/examples/linechart.txt +0 -93
  124. package/examples/piechart.txt +0 -67
  125. package/tsconfig.json +0 -21
@@ -0,0 +1,473 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ exports.lineChart = exports.pieChart = exports.verticalBarChart = void 0;
7
+ const canvas_1 = require("@napi-rs/canvas");
8
+ const path_1 = __importDefault(require("path"));
9
+ ////////////////////////////////////////BAR CHARTS////////////////////////////////////////
10
+ async function verticalBarChart(data) {
11
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o;
12
+ try {
13
+ const { chartData, xLabels, yLabels, data: { xAxis, yAxis, keys, xTitle, yTitle, labelStyle } } = data;
14
+ if (!xLabels || !yLabels || !xAxis || !yAxis) {
15
+ throw new Error('Required data is missing.');
16
+ }
17
+ xAxis.forEach(bar => {
18
+ if (bar.position.startsXLabel < Math.min(...xLabels) || bar.position.endsXLabel > Math.max(...xLabels)) {
19
+ throw new Error(`X-axis value range for bar '${bar.label}' is invalid.`);
20
+ }
21
+ if (bar.value < Math.min(...yAxis) || bar.value > Math.max(...yAxis)) {
22
+ throw new Error(`Y-axis value for bar '${bar.label}' is out of range.`);
23
+ }
24
+ });
25
+ const canvasWidth = (chartData === null || chartData === void 0 ? void 0 : chartData.width) || 800;
26
+ const canvasHeight = (chartData === null || chartData === void 0 ? void 0 : chartData.height) || 600;
27
+ let img;
28
+ if (((chartData === null || chartData === void 0 ? void 0 : chartData.widthPerc) || 0.8) > 1 || ((chartData === null || chartData === void 0 ? void 0 : chartData.widthPerc) || 0.8) < 0)
29
+ throw new Error(`widthPerc: Cannor be bigger than 1 or smaller than 0`);
30
+ if (((chartData === null || chartData === void 0 ? void 0 : chartData.heightPerc) || 0.8) > 1 || ((chartData === null || chartData === void 0 ? void 0 : chartData.heightPerc) || 0.8) < 0)
31
+ throw new Error(`widthPerc: Cannor be bigger than 1 or smaller than 0`);
32
+ const chartWidth = canvasWidth * ((chartData === null || chartData === void 0 ? void 0 : chartData.widthPerc) || 0.8);
33
+ const chartHeight = canvasHeight * ((chartData === null || chartData === void 0 ? void 0 : chartData.heightPerc) || 0.8);
34
+ if ((_a = chartData === null || chartData === void 0 ? void 0 : chartData.bg) === null || _a === void 0 ? void 0 : _a.image) {
35
+ try {
36
+ let img;
37
+ if (chartData.bg.image.startsWith('http')) {
38
+ const response = await fetch(chartData.bg.image);
39
+ if (!response.ok) {
40
+ throw new Error("Failed to fetch image.");
41
+ }
42
+ const buffer = await response.arrayBuffer();
43
+ img = await (0, canvas_1.loadImage)(Buffer.from(buffer));
44
+ }
45
+ else {
46
+ const imagePath = path_1.default.join(process.cwd(), chartData.bg.image);
47
+ img = await (0, canvas_1.loadImage)(imagePath);
48
+ }
49
+ }
50
+ catch (error) {
51
+ console.error('Error loading image:', error);
52
+ }
53
+ }
54
+ const canvas = (0, canvas_1.createCanvas)(800, 600);
55
+ const ctx = canvas.getContext('2d');
56
+ if ((_b = chartData === null || chartData === void 0 ? void 0 : chartData.bg) === null || _b === void 0 ? void 0 : _b.image) {
57
+ ctx.drawImage(img, 0, 0, 800, 600);
58
+ }
59
+ else {
60
+ ctx.fillStyle = ((_c = chartData === null || chartData === void 0 ? void 0 : chartData.bg) === null || _c === void 0 ? void 0 : _c.bgColor) || 'white';
61
+ ctx.fillRect(0, 0, canvasWidth, canvasHeight);
62
+ }
63
+ ctx.fillStyle = `${((_d = chartData === null || chartData === void 0 ? void 0 : chartData.title) === null || _d === void 0 ? void 0 : _d.color) || 'black'}`;
64
+ ctx.font = `bold ${((_e = chartData === null || chartData === void 0 ? void 0 : chartData.title) === null || _e === void 0 ? void 0 : _e.size) || 12}px Arial`;
65
+ ctx.fillText(((_f = chartData === null || chartData === void 0 ? void 0 : chartData.title) === null || _f === void 0 ? void 0 : _f.title) || 'Sample Chart', (canvasWidth - ctx.measureText(((_g = chartData === null || chartData === void 0 ? void 0 : chartData.title) === null || _g === void 0 ? void 0 : _g.title) || 'Sample Chart').width) / 2, 30);
66
+ if (keys && Object.keys(keys).length > 0) {
67
+ const keysTopMargin = 70;
68
+ const keysLeftMargin = chartWidth + 60;
69
+ const keyWidth = 20;
70
+ const keyHeight = 20;
71
+ const keySpacing = 10;
72
+ let keyIndex = 0;
73
+ for (const color in keys) {
74
+ const keyX = keysLeftMargin;
75
+ const keyY = keysTopMargin + keyIndex * (keyHeight + keySpacing);
76
+ const keyColor = color || 'blue';
77
+ const keyLabel = keys[color].length > 15 ? keys[color].substring(0, 15) + '...' : keys[color];
78
+ ctx.fillStyle = keyColor;
79
+ ctx.fillRect(keyX, keyY, keyWidth, keyHeight);
80
+ ctx.fillStyle = `${keyColor || 'black'}`;
81
+ ctx.font = '12px Arial';
82
+ ctx.fillText(keyLabel, keyX + keyWidth + 5, keyY + keyHeight - 3);
83
+ keyIndex++;
84
+ }
85
+ }
86
+ const chartTopMargin = 50;
87
+ const chartLeftMargin = 50;
88
+ ctx.strokeStyle = ((_h = chartData === null || chartData === void 0 ? void 0 : chartData.grid) === null || _h === void 0 ? void 0 : _h.color) || 'gray';
89
+ ctx.lineWidth = 1;
90
+ ctx.beginPath();
91
+ ctx.moveTo(chartLeftMargin, chartTopMargin);
92
+ ctx.lineTo(chartLeftMargin, chartTopMargin + chartHeight);
93
+ ctx.lineTo(chartLeftMargin + chartWidth, chartTopMargin + chartHeight);
94
+ ctx.stroke();
95
+ if ((_j = chartData === null || chartData === void 0 ? void 0 : chartData.grid) === null || _j === void 0 ? void 0 : _j.enable) {
96
+ drawGridLines(ctx, chartLeftMargin, chartTopMargin, chartWidth, chartHeight, xLabels, yLabels, chartData.grid);
97
+ }
98
+ ctx.fillStyle = `${((_k = chartData === null || chartData === void 0 ? void 0 : chartData.labels) === null || _k === void 0 ? void 0 : _k.color) || 'black'}`;
99
+ ctx.font = `bold ${((_l = chartData === null || chartData === void 0 ? void 0 : chartData.labels) === null || _l === void 0 ? void 0 : _l.fontSize) || 16}px Arial`;
100
+ xLabels.forEach((label, index) => {
101
+ const x = chartLeftMargin + index * (chartWidth / (xLabels.length - 1));
102
+ const y = chartTopMargin + chartHeight + 20;
103
+ ctx.fillText(String(label), x - ctx.measureText(String(label)).width / 2, y);
104
+ });
105
+ ctx.textAlign = 'right';
106
+ yLabels.forEach((label, index) => {
107
+ const x = chartLeftMargin - 5;
108
+ const y = chartTopMargin + chartHeight - index * (chartHeight / (yLabels.length - 1));
109
+ ctx.fillText(String(label), x, y + 5);
110
+ });
111
+ ctx.fillStyle = `${((_m = chartData === null || chartData === void 0 ? void 0 : chartData.axis) === null || _m === void 0 ? void 0 : _m.color) || 'black'}`;
112
+ ctx.font = `bold ${((_o = chartData === null || chartData === void 0 ? void 0 : chartData.axis) === null || _o === void 0 ? void 0 : _o.size) || 12}px Arial`;
113
+ ctx.fillText(xTitle || 'X Axis', 30 + canvasWidth / 2, canvasHeight - 15);
114
+ ctx.save();
115
+ ctx.translate(10, canvasHeight / 2);
116
+ ctx.rotate(-Math.PI / 2);
117
+ ctx.textAlign = 'center';
118
+ ctx.fillText(yTitle || 'Y Axis', 0, 10);
119
+ ctx.restore();
120
+ xAxis.forEach((bar, index) => {
121
+ var _a, _b, _c, _d;
122
+ const startX = chartLeftMargin + ((((_a = bar.position) === null || _a === void 0 ? void 0 : _a.startsXLabel) - Math.min(...xLabels)) / (Math.max(...xLabels) - Math.min(...xLabels))) * chartWidth;
123
+ const endX = chartLeftMargin + ((((_b = bar.position) === null || _b === void 0 ? void 0 : _b.endsXLabel) - Math.min(...xLabels)) / (Math.max(...xLabels) - Math.min(...xLabels))) * chartWidth;
124
+ const barWidth = endX - startX;
125
+ const barHeight = (bar.value / Math.max(...yAxis)) * chartHeight;
126
+ const y = chartTopMargin + chartHeight - barHeight;
127
+ ctx.fillStyle = bar.barColor || 'blue';
128
+ ctx.fillRect(startX, y, barWidth, barHeight);
129
+ ctx.strokeStyle = ((_c = bar === null || bar === void 0 ? void 0 : bar.stroke) === null || _c === void 0 ? void 0 : _c.color) || 'black';
130
+ ctx.lineWidth = ((_d = bar === null || bar === void 0 ? void 0 : bar.stroke) === null || _d === void 0 ? void 0 : _d.width) || 1;
131
+ ctx.strokeRect(startX, y, barWidth, barHeight);
132
+ ctx.fillStyle = `${(labelStyle === null || labelStyle === void 0 ? void 0 : labelStyle.color) || 'black'}`;
133
+ ctx.textAlign = 'center';
134
+ ctx.font = `bold ${(labelStyle === null || labelStyle === void 0 ? void 0 : labelStyle.size) || 16}px Arial`;
135
+ const labelX = startX + barWidth / 2;
136
+ const labelY = y - 5;
137
+ ctx.fillText(bar.label, labelX, labelY);
138
+ });
139
+ const buffer = canvas.toBuffer('image/png');
140
+ return buffer;
141
+ }
142
+ catch (error) {
143
+ console.error('An error occurred while drawing the bar chart:', error);
144
+ }
145
+ }
146
+ exports.verticalBarChart = verticalBarChart;
147
+ function drawGridLines(ctx, leftMargin, topMargin, width, height, xLabels, yLabels, grid) {
148
+ ctx.strokeStyle = grid.color || 'gray';
149
+ ctx.lineWidth = grid.width || 2;
150
+ xLabels.forEach((label, index) => {
151
+ const x = leftMargin + index * (width / (xLabels.length - 1));
152
+ ctx.beginPath();
153
+ ctx.moveTo(x, topMargin);
154
+ ctx.lineTo(x, topMargin + height);
155
+ ctx.stroke();
156
+ });
157
+ yLabels.forEach((label, index) => {
158
+ const y = topMargin + index * (height / (yLabels.length - 1));
159
+ ctx.beginPath();
160
+ ctx.moveTo(leftMargin, y);
161
+ ctx.lineTo(leftMargin + width, y);
162
+ ctx.stroke();
163
+ });
164
+ }
165
+ ////////////////////////////////////////PIE CHARTS////////////////////////////////////////
166
+ function drawPieChart(ctx, data, canvasConfig, pieDataConfig) {
167
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j;
168
+ const width = (_a = canvasConfig === null || canvasConfig === void 0 ? void 0 : canvasConfig.width) !== null && _a !== void 0 ? _a : 1200;
169
+ const height = (_b = canvasConfig === null || canvasConfig === void 0 ? void 0 : canvasConfig.height) !== null && _b !== void 0 ? _b : 400;
170
+ const centerX = width / 2 + ((pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.x) || 0);
171
+ const centerY = height / 2 + ((pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.y) || 0);
172
+ const radius = (pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.radius) || Math.min(width, height) * 0.35;
173
+ let startAngle = 0;
174
+ const totalValue = data.reduce((acc, { value }) => acc + value, 0);
175
+ for (const { label, color, value } of data) {
176
+ const sliceAngle = (value / totalValue) * (Math.PI * 2);
177
+ const midAngle = startAngle + sliceAngle / 2;
178
+ const labelDistance = ((_c = pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.boxes) === null || _c === void 0 ? void 0 : _c.labelDistance) || 50;
179
+ const labelX = centerX + Math.cos(midAngle) * (radius + labelDistance);
180
+ const labelY = centerY + Math.sin(midAngle) * (radius + labelDistance);
181
+ ctx.strokeStyle = ((_d = pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.boxes) === null || _d === void 0 ? void 0 : _d.strokeColor) || 'black';
182
+ ctx.beginPath();
183
+ ctx.moveTo(centerX, centerY);
184
+ ctx.lineTo(labelX, labelY);
185
+ ctx.stroke();
186
+ const boxWidth = ((_e = pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.boxes) === null || _e === void 0 ? void 0 : _e.width) || 100;
187
+ const boxHeight = ((_f = pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.boxes) === null || _f === void 0 ? void 0 : _f.height) || 40;
188
+ const boxX = labelX - boxWidth / 2;
189
+ const boxY = labelY - boxHeight / 2;
190
+ ctx.fillStyle = ((_g = pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.boxes) === null || _g === void 0 ? void 0 : _g.boxColor) || 'black';
191
+ ctx.beginPath();
192
+ ctx.rect(boxX, boxY, boxWidth, boxHeight);
193
+ ctx.fill();
194
+ ctx.stroke();
195
+ // Draw the label text
196
+ ctx.fillStyle = ((_h = pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.boxes) === null || _h === void 0 ? void 0 : _h.labelColor) || 'black';
197
+ ctx.font = `bold ${((_j = pieDataConfig === null || pieDataConfig === void 0 ? void 0 : pieDataConfig.boxes) === null || _j === void 0 ? void 0 : _j.fontSize) || 14}px Arial`;
198
+ ctx.textAlign = 'center';
199
+ ctx.textBaseline = 'middle';
200
+ ctx.fillText(label, labelX, labelY);
201
+ startAngle += sliceAngle;
202
+ }
203
+ startAngle = 0;
204
+ for (const { color, value } of data) {
205
+ const sliceAngle = (value / totalValue) * (Math.PI * 2);
206
+ ctx.fillStyle = color || 'black';
207
+ ctx.beginPath();
208
+ ctx.moveTo(centerX, centerY);
209
+ ctx.arc(centerX, centerY, radius, startAngle, startAngle + sliceAngle);
210
+ ctx.closePath();
211
+ ctx.fill();
212
+ startAngle += sliceAngle;
213
+ }
214
+ const strokeConfig = pieDataConfig.stroke || { color: 'transparent', size: 0 };
215
+ const { color: strokeColor, size: strokeWidth } = strokeConfig;
216
+ ctx.strokeStyle = strokeColor || 'transparent';
217
+ ctx.lineWidth = strokeWidth || 0;
218
+ ctx.beginPath();
219
+ ctx.arc(centerX, centerY, radius, 0, Math.PI * 2);
220
+ ctx.stroke();
221
+ if (pieDataConfig.title) {
222
+ const { text, color, fontSize, x = 0, y = 0 } = pieDataConfig.title;
223
+ ctx.fillStyle = color || 'black';
224
+ ctx.font = `${fontSize || 20}px Arial`;
225
+ ctx.textAlign = 'center';
226
+ ctx.fillText(text || '', centerX + x, centerY + y);
227
+ }
228
+ }
229
+ function drawKeys(ctx, data, pieConfig) {
230
+ var _a, _b, _c, _d;
231
+ const { bgcolor, width, height, radius, x, y, content } = pieConfig.keyBox || {};
232
+ const keyX = x || 0;
233
+ const keyY = y || 0;
234
+ ctx.fillStyle = bgcolor || 'white';
235
+ ctx.beginPath();
236
+ ctx.moveTo(keyX + (radius || 0), keyY);
237
+ ctx.lineTo(keyX + (width || 0) - (radius || 0), keyY);
238
+ ctx.arcTo(keyX + (width || 0), keyY, keyX + (width || 0), keyY + (radius || 0), radius || 0);
239
+ ctx.lineTo(keyX + (width || 0), keyY + (height || 0) - (radius || 0));
240
+ ctx.arcTo(keyX + (width || 0), keyY + (height || 0), keyX + (width || 0) - (radius || 0), keyY + (height || 0), radius || 0);
241
+ ctx.lineTo(keyX + (radius || 0), keyY + (height || 0));
242
+ ctx.arcTo(keyX, keyY + (height || 0), keyX, keyY + (height || 0) - (radius || 0), radius || 0);
243
+ ctx.lineTo(keyX, keyY + (radius || 0));
244
+ ctx.arcTo(keyX, keyY, keyX + (radius || 0), keyY, radius || 0);
245
+ ctx.closePath();
246
+ ctx.fill();
247
+ ctx.fillStyle = 'black';
248
+ ctx.font = `bold ${((_a = content === null || content === void 0 ? void 0 : content.keyTitle) === null || _a === void 0 ? void 0 : _a.fontSize) || 14}px Arial`;
249
+ const textWidth = ctx.measureText('Keys').width;
250
+ const textX = ((((_b = content === null || content === void 0 ? void 0 : content.keyTitle) === null || _b === void 0 ? void 0 : _b.x) || 0) + 20 + keyX + ((width || 0) - textWidth) / 2) || 0;
251
+ const textY = (keyY + 30 + (((_c = content === null || content === void 0 ? void 0 : content.keyTitle) === null || _c === void 0 ? void 0 : _c.y) || 0)) || 0;
252
+ ctx.fillText('Keys', textX, textY);
253
+ let fontSize = ((_d = content === null || content === void 0 ? void 0 : content.keys) === null || _d === void 0 ? void 0 : _d.fontSize) || Math.min(16, Math.floor((width || 0) / 20));
254
+ ctx.font = `${fontSize}px Arial`;
255
+ data.forEach(({ label, color, key }, index) => {
256
+ var _a, _b;
257
+ ctx.fillStyle = color || 'black';
258
+ ctx.fillRect(keyX + 20, keyY + 60 + index * (fontSize + 10), 20, 20);
259
+ ctx.fillStyle = 'black';
260
+ ctx.fillText(`${key || ''}: ${label || ''}`, (keyX + 95 + (((_a = content === null || content === void 0 ? void 0 : content.keys) === null || _a === void 0 ? void 0 : _a.x) || 0)), (((_b = content === null || content === void 0 ? void 0 : content.keys) === null || _b === void 0 ? void 0 : _b.y) || 0) + keyY + 70 + index * (fontSize + 10));
261
+ });
262
+ }
263
+ async function pieChart(pieChartData) {
264
+ var _a;
265
+ const { data = [], pieConfig = {} } = pieChartData;
266
+ const { canvas = {}, keyBox = {}, pieData = {} } = pieConfig;
267
+ const { width: canvasWidth = 1200, height: canvasHeight = 400, bgcolor: canvasBgcolor = 'gray' } = canvas || {};
268
+ const { width: keyBoxWidth = 200, height: keyBoxHeight = 300, radius: keyBoxRadius = 20, bgcolor: keyBoxBgcolor = '#ffffff', x: keyBoxX = 0, y: keyBoxY = 0, content: keyBoxContent } = keyBox || {};
269
+ const chartCanvas = (0, canvas_1.createCanvas)(canvasWidth, canvasHeight);
270
+ const ctx = chartCanvas.getContext('2d');
271
+ ctx.fillStyle = canvasBgcolor;
272
+ ctx.fillRect(0, 0, canvasWidth, canvasHeight);
273
+ const pieConfigData = (_a = pieConfig.pieData) !== null && _a !== void 0 ? _a : {};
274
+ drawPieChart(ctx, data, canvas, pieConfigData);
275
+ drawKeys(ctx, data, { keyBox: { bgcolor: keyBoxBgcolor, width: keyBoxWidth, height: keyBoxHeight, radius: keyBoxRadius, x: keyBoxX, y: keyBoxY, content: keyBoxContent }, canvas });
276
+ return chartCanvas.toBuffer('image/png');
277
+ }
278
+ exports.pieChart = pieChart;
279
+ ////////////////////////////////////////LINE CHARTS////////////////////////////////////////
280
+ async function lineChart(data) {
281
+ var _a, _b, _c, _d, _e, _f, _g, _h, _j, _k, _l, _m, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _0, _1, _2, _3, _4, _5, _6, _7;
282
+ if (!data || !data.data || !Array.isArray(data.data) || data.data.length === 0 || !data.lineConfig) {
283
+ throw new Error('Invalid data object or missing data properties');
284
+ }
285
+ const lineConfig = data.lineConfig;
286
+ if (!lineConfig.yLabels || !Array.isArray(lineConfig.yLabels) || lineConfig.yLabels.length === 0) {
287
+ throw new Error('Missing or invalid yLabels property in line configuration');
288
+ }
289
+ if (!lineConfig.fillArea || !Array.isArray(lineConfig.fillArea) || lineConfig.fillArea.length !== data.data.length) {
290
+ throw new Error('Missing or invalid fillArea property in line configuration');
291
+ }
292
+ if (!lineConfig.lineColor || !Array.isArray(lineConfig.lineColor) || lineConfig.lineColor.length !== data.data.length) {
293
+ throw new Error('Missing or invalid lineColor property in line configuration');
294
+ }
295
+ if (!lineConfig.plot || typeof lineConfig.plot !== 'object') {
296
+ throw new Error('Missing or invalid plot property in line configuration');
297
+ }
298
+ if (!lineConfig.lineTension || !Array.isArray(lineConfig.lineTension) || lineConfig.lineTension.length !== data.data.length) {
299
+ throw new Error('Missing or invalid lineTension property in line configuration');
300
+ }
301
+ if (!lineConfig.grid || typeof lineConfig.grid !== 'object') {
302
+ throw new Error('Missing or invalid grid property in line configuration');
303
+ }
304
+ const canvasWidth = Math.max(((_b = (_a = data.lineConfig) === null || _a === void 0 ? void 0 : _a.canvas) === null || _b === void 0 ? void 0 : _b.width) || 800, (((_c = data.data[0]) === null || _c === void 0 ? void 0 : _c.length) - 1) * 80 + 100);
305
+ const canvasHeight = Math.max(((_e = (_d = data.lineConfig) === null || _d === void 0 ? void 0 : _d.canvas) === null || _e === void 0 ? void 0 : _e.height) || 600, (lineConfig.yLabels.length - 1) * 60 + 100);
306
+ let img;
307
+ if ((_g = (_f = data.lineConfig) === null || _f === void 0 ? void 0 : _f.canvas) === null || _g === void 0 ? void 0 : _g.image) {
308
+ try {
309
+ if (data.lineConfig.canvas.image.startsWith('http')) {
310
+ const response = await fetch(data.lineConfig.canvas.image);
311
+ if (!response.ok) {
312
+ throw new Error("Failed to fetch image.");
313
+ }
314
+ const buffer = await response.arrayBuffer();
315
+ img = await (0, canvas_1.loadImage)(Buffer.from(buffer));
316
+ }
317
+ else {
318
+ const imagePath = path_1.default.join(process.cwd(), data.lineConfig.canvas.image);
319
+ img = await (0, canvas_1.loadImage)(imagePath);
320
+ }
321
+ }
322
+ catch (error) {
323
+ console.error('Error loading image:', error);
324
+ }
325
+ }
326
+ const canvas = (0, canvas_1.createCanvas)(canvasWidth, canvasHeight);
327
+ const ctx = canvas.getContext('2d');
328
+ const xAxisLabels = data.data[0].map(point => point.label);
329
+ const yAxisLabel = ((_j = (_h = data.lineConfig) === null || _h === void 0 ? void 0 : _h.yaxisLabel) === null || _j === void 0 ? void 0 : _j.label) || 'Y Axis';
330
+ ctx.font = `${((_l = (_k = data.lineConfig) === null || _k === void 0 ? void 0 : _k.yaxisLabel) === null || _l === void 0 ? void 0 : _l.fontSize) || 16} Arial`;
331
+ if ((_o = (_m = data.lineConfig) === null || _m === void 0 ? void 0 : _m.canvas) === null || _o === void 0 ? void 0 : _o.image) {
332
+ ctx.drawImage(img, 0, 0, canvasWidth, canvasHeight);
333
+ }
334
+ else {
335
+ ctx.fillStyle = ((_q = (_p = data.lineConfig) === null || _p === void 0 ? void 0 : _p.canvas) === null || _q === void 0 ? void 0 : _q.bgColor) || '#f0f0f0';
336
+ ctx.fillRect(0, 0, canvasWidth, canvasHeight);
337
+ }
338
+ if ((_r = data.lineConfig) === null || _r === void 0 ? void 0 : _r.grid) {
339
+ const grid = data.lineConfig.grid;
340
+ ctx.strokeStyle = grid.color || '#ccc';
341
+ ctx.lineWidth = grid.width || 1;
342
+ if (grid.type === 'vertical' || grid.type === 'both') {
343
+ for (let i = 1; i < xAxisLabels.length; i++) {
344
+ const x = i * (canvasWidth - 100) / (xAxisLabels.length - 1) + 50;
345
+ ctx.beginPath();
346
+ ctx.moveTo(x, 50);
347
+ ctx.lineTo(x, canvasHeight - 50);
348
+ ctx.stroke();
349
+ }
350
+ }
351
+ if (grid.type === 'horizontal' || grid.type === 'both') {
352
+ for (let i = 1; i < lineConfig.yLabels.length; i++) {
353
+ const y = i * (canvasHeight - 100) / (lineConfig.yLabels.length - 1) + 50;
354
+ ctx.beginPath();
355
+ ctx.moveTo(50, y);
356
+ ctx.lineTo(canvasWidth - 50, y);
357
+ ctx.stroke();
358
+ }
359
+ }
360
+ }
361
+ ctx.save();
362
+ ctx.translate(20, canvasHeight / 2);
363
+ ctx.rotate(-Math.PI / 2);
364
+ ctx.fillStyle = ((_t = (_s = data.lineConfig) === null || _s === void 0 ? void 0 : _s.yaxisLabel) === null || _t === void 0 ? void 0 : _t.color) || 'black';
365
+ ctx.fillText(yAxisLabel, ((_v = (_u = data.lineConfig) === null || _u === void 0 ? void 0 : _u.yaxisLabel) === null || _v === void 0 ? void 0 : _v.y) || 0, ((_x = (_w = data.lineConfig) === null || _w === void 0 ? void 0 : _w.yaxisLabel) === null || _x === void 0 ? void 0 : _x.x) || 0);
366
+ ctx.restore();
367
+ let maxY = 0;
368
+ data.data.forEach(line => {
369
+ const maxLineY = Math.max(...line.map(point => point.y));
370
+ if (maxLineY > maxY)
371
+ maxY = maxLineY;
372
+ });
373
+ const segmentWidth = (canvasWidth - 100) / (xAxisLabels.length - 1);
374
+ ctx.beginPath();
375
+ ctx.moveTo(50, 50);
376
+ ctx.lineTo(50, canvasHeight - 50);
377
+ ctx.lineTo(canvasWidth - 50, canvasHeight - 50);
378
+ ctx.stroke();
379
+ data.data.forEach((line, index) => {
380
+ var _a, _b, _c, _d;
381
+ ctx.beginPath();
382
+ ctx.strokeStyle = (lineConfig === null || lineConfig === void 0 ? void 0 : lineConfig.lineColor[index]) || 'blue';
383
+ ctx.lineWidth = 2;
384
+ const tension = (lineConfig && lineConfig.lineTension && lineConfig.lineTension[index]) || 0.1;
385
+ line.forEach((point, index) => {
386
+ const x = index * segmentWidth + 50;
387
+ const y = canvasHeight - (point.y / maxY) * (canvasHeight - 100) - 50;
388
+ if (index === 0) {
389
+ ctx.moveTo(x, y);
390
+ }
391
+ else {
392
+ const prevX = (index - 1) * segmentWidth + 50;
393
+ const prevY = canvasHeight - (line[index - 1].y / maxY) * (canvasHeight - 100) - 50;
394
+ const cpX1 = prevX + (x - prevX) * tension;
395
+ const cpY1 = prevY;
396
+ const cpX2 = x - (x - prevX) * tension;
397
+ const cpY2 = y;
398
+ ctx.bezierCurveTo(cpX1, cpY1, cpX2, cpY2, x, y);
399
+ }
400
+ });
401
+ ctx.stroke();
402
+ if (lineConfig.fillArea[index]) {
403
+ const lastPoint = line[line.length - 1];
404
+ const lastX = (line.length - 1) * segmentWidth + 50;
405
+ const lastY = canvasHeight - (lastPoint.y / maxY) * (canvasHeight - 100) - 50;
406
+ ctx.lineTo(lastX, canvasHeight - 50);
407
+ ctx.lineTo(50, canvasHeight - 50);
408
+ ctx.closePath();
409
+ ctx.fillStyle = lineConfig.fillArea[index].color || 'rgba(0, 0, 255, 0.1)';
410
+ ctx.fill();
411
+ }
412
+ if (((_a = data.lineConfig) === null || _a === void 0 ? void 0 : _a.plot) && ((_c = (_b = data.lineConfig) === null || _b === void 0 ? void 0 : _b.plot) === null || _c === void 0 ? void 0 : _c.enable)) {
413
+ const plotConfig = (_d = data.lineConfig) === null || _d === void 0 ? void 0 : _d.plot;
414
+ ctx.fillStyle = plotConfig.color ? plotConfig.color[index] || 'red' : 'red';
415
+ line.forEach((point, index) => {
416
+ const x = index * segmentWidth + 50;
417
+ const y = canvasHeight - (point.y / maxY) * (canvasHeight - 100) - 50;
418
+ ctx.beginPath();
419
+ ctx.arc(x, y, plotConfig.size || 4, 0, 2 * Math.PI);
420
+ ctx.fill();
421
+ });
422
+ }
423
+ });
424
+ ctx.fillStyle = ((_z = (_y = data.lineConfig) === null || _y === void 0 ? void 0 : _y.canvas) === null || _z === void 0 ? void 0 : _z.fontColor) || 'black';
425
+ ctx.font = `${((_1 = (_0 = data.lineConfig) === null || _0 === void 0 ? void 0 : _0.canvas) === null || _1 === void 0 ? void 0 : _1.fontSize) || 16}px Arial`;
426
+ ctx.textAlign = 'center';
427
+ ctx.textBaseline = 'top';
428
+ xAxisLabels.forEach((label, index) => {
429
+ const x = index * segmentWidth + 50;
430
+ const y = canvasHeight - 30;
431
+ ctx.fillText(label, x, y);
432
+ });
433
+ ctx.textAlign = 'right';
434
+ ctx.textBaseline = 'middle';
435
+ lineConfig.yLabels.forEach((label, index) => {
436
+ const y = canvasHeight - index * (canvasHeight - 100) / (lineConfig.yLabels.length - 1) - 50;
437
+ ctx.fillText(label, 40, y);
438
+ });
439
+ if (lineConfig.keys && typeof lineConfig.keys === 'object') {
440
+ const keyRadius = ((_2 = lineConfig.keysConfig) === null || _2 === void 0 ? void 0 : _2.radius) || 10;
441
+ const keyPadding = ((_3 = lineConfig.keysConfig) === null || _3 === void 0 ? void 0 : _3.keyPadding) || 30;
442
+ const textPadding = ((_4 = lineConfig.keysConfig) === null || _4 === void 0 ? void 0 : _4.textPadding) || 60;
443
+ const lineLength = 2 * keyRadius + 9 + (((_5 = lineConfig.keysConfig) === null || _5 === void 0 ? void 0 : _5.textPadding) || 0);
444
+ const lineWidth = ((_6 = lineConfig.keysConfig) === null || _6 === void 0 ? void 0 : _6.lineWidth) || 3;
445
+ let totalKeyWidth = 0;
446
+ for (const color in lineConfig.keys) {
447
+ const keyText = lineConfig.keys[color];
448
+ totalKeyWidth += ctx.measureText(keyText).width + keyPadding + (2 * keyRadius) + textPadding;
449
+ }
450
+ let startX = (canvasWidth - totalKeyWidth) / 2;
451
+ for (const color in lineConfig.keys) {
452
+ const keyText = lineConfig.keys[color];
453
+ ctx.beginPath();
454
+ ctx.arc(startX + keyRadius, 20 + keyRadius, keyRadius, 0, 2 * Math.PI);
455
+ ctx.fillStyle = color;
456
+ ctx.fill();
457
+ ctx.closePath();
458
+ ctx.beginPath();
459
+ ctx.moveTo(startX + keyRadius - lineLength / 2, 20 + keyRadius);
460
+ ctx.lineTo(startX + keyRadius + lineLength / 2, 20 + keyRadius);
461
+ ctx.strokeStyle = color;
462
+ ctx.lineWidth = lineWidth;
463
+ ctx.stroke();
464
+ ctx.closePath();
465
+ ctx.fillStyle = ((_7 = lineConfig.keysConfig) === null || _7 === void 0 ? void 0 : _7.fontColor) || 'black';
466
+ ctx.fillText(keyText, startX + (2 * keyRadius) + keyPadding + textPadding, 20 + keyRadius);
467
+ startX += ctx.measureText(keyText).width + keyPadding + (2 * keyRadius) + textPadding + keyPadding;
468
+ }
469
+ }
470
+ return canvas.toBuffer('image/png');
471
+ }
472
+ exports.lineChart = lineChart;
473
+ //# sourceMappingURL=charts.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"charts.js","sourceRoot":"","sources":["../../../lib/canvas/utils/charts.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,10 @@
1
+ /**
2
+ * Applies a circular border to the canvas context.
3
+ * @param ctx The canvas rendering context.
4
+ * @param width The width of the canvas.
5
+ * @param height The height of the canvas.
6
+ * @param radius The radius of the circular border.
7
+ * @returns A void.
8
+ */
9
+ export declare function circularBorder(ctx: any, width: number, height: number, radius?: number): void;
10
+ //# sourceMappingURL=circular.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"circular.d.ts","sourceRoot":"","sources":["../../../lib/canvas/utils/circular.ts"],"names":[],"mappings":"AAAA;;;;;;;GAOG;AACH,wBAAgB,cAAc,CAAC,GAAG,EAAE,GAAG,EAAE,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,GAAE,MAAU,GAAG,IAAI,CAQhG"}
@@ -0,0 +1,22 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.circularBorder = void 0;
4
+ /**
5
+ * Applies a circular border to the canvas context.
6
+ * @param ctx The canvas rendering context.
7
+ * @param width The width of the canvas.
8
+ * @param height The height of the canvas.
9
+ * @param radius The radius of the circular border.
10
+ * @returns A void.
11
+ */
12
+ function circularBorder(ctx, width, height, radius = 0) {
13
+ const minDimension = Math.min(width, height);
14
+ const clipRadius = minDimension / 2 + radius;
15
+ ctx.save();
16
+ ctx.beginPath();
17
+ ctx.arc(width / 2, height / 2, clipRadius, 0, Math.PI * 2);
18
+ ctx.closePath();
19
+ ctx.clip();
20
+ }
21
+ exports.circularBorder = circularBorder;
22
+ //# sourceMappingURL=circular.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"circular.js","sourceRoot":"","sources":["../../../lib/canvas/utils/circular.ts"],"names":[],"mappings":";;;AAAA;;;;;;;GAOG;AACH,SAAgB,cAAc,CAAC,GAAQ,EAAE,KAAa,EAAE,MAAc,EAAE,SAAiB,CAAC;IACtF,MAAM,YAAY,GAAG,IAAI,CAAC,GAAG,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;IAC7C,MAAM,UAAU,GAAG,YAAY,GAAG,CAAC,GAAG,MAAM,CAAC;IAC7C,GAAG,CAAC,IAAI,EAAE,CAAC;IACX,GAAG,CAAC,SAAS,EAAE,CAAC;IAChB,GAAG,CAAC,GAAG,CAAC,KAAK,GAAG,CAAC,EAAE,MAAM,GAAG,CAAC,EAAE,UAAU,EAAE,CAAC,EAAE,IAAI,CAAC,EAAE,GAAG,CAAC,CAAC,CAAC;IAC3D,GAAG,CAAC,SAAS,EAAE,CAAC;IAChB,GAAG,CAAC,IAAI,EAAE,CAAC;AACf,CAAC;AARD,wCAQC"}
@@ -0,0 +1,2 @@
1
+ export declare function customLines(ctx: any, options: any): void;
2
+ //# sourceMappingURL=customLines.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"customLines.d.ts","sourceRoot":"","sources":["../../../lib/canvas/utils/customLines.ts"],"names":[],"mappings":"AACA,wBAAgB,WAAW,CAAE,GAAG,EAAE,GAAG,EAAE,OAAO,EAAE,GAAG,QA+ClD"}
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.customLines = void 0;
4
+ function customLines(ctx, options) {
5
+ for (const customOption of options) {
6
+ ctx.beginPath();
7
+ ctx.moveTo(customOption.startCoordinates.x, customOption.startCoordinates.y);
8
+ ctx.lineTo(customOption.endCoordinates.x, customOption.endCoordinates.y);
9
+ ctx.lineWidth = customOption.lineStyle.width || 1;
10
+ ctx.strokeStyle = customOption.lineStyle.color || 'black';
11
+ if (typeof customOption.lineStyle.lineRadius === 'number') {
12
+ const borderRadius = customOption.lineStyle.lineRadius;
13
+ const dx = customOption.endCoordinates.x - customOption.startCoordinates.x;
14
+ const dy = customOption.endCoordinates.y - customOption.startCoordinates.y;
15
+ const angle = Math.atan2(dy, dx);
16
+ const offsetX = Math.cos(angle) * borderRadius;
17
+ const offsetY = Math.sin(angle) * borderRadius;
18
+ ctx.moveTo(customOption.startCoordinates.x + offsetX, customOption.startCoordinates.y + offsetY);
19
+ ctx.lineTo(customOption.endCoordinates.x - offsetX, customOption.endCoordinates.y - offsetY);
20
+ }
21
+ else if (customOption.lineStyle.lineRadius === 'circular') {
22
+ const dx = customOption.endCoordinates.x - customOption.startCoordinates.x;
23
+ const dy = customOption.endCoordinates.y - customOption.startCoordinates.y;
24
+ const length = Math.sqrt(dx * dx + dy * dy);
25
+ const angle = Math.atan2(dy, dx);
26
+ const halfWidth = customOption.lineStyle.width ? customOption.lineStyle.width / 2 : 1;
27
+ ctx.moveTo(customOption.startCoordinates.x + Math.cos(angle - Math.PI / 2) * halfWidth, customOption.startCoordinates.y + Math.sin(angle - Math.PI / 2) * halfWidth);
28
+ ctx.arc(customOption.startCoordinates.x, customOption.startCoordinates.y, length / 2, angle - Math.PI / 2, angle + Math.PI / 2);
29
+ ctx.lineTo(customOption.endCoordinates.x + Math.cos(angle + Math.PI / 2) * halfWidth, customOption.endCoordinates.y + Math.sin(angle + Math.PI / 2) * halfWidth);
30
+ ctx.arc(customOption.endCoordinates.x, customOption.endCoordinates.y, length / 2, angle + Math.PI / 2, angle - Math.PI / 2, true);
31
+ ctx.closePath();
32
+ }
33
+ ctx.stroke();
34
+ if (customOption.lineStyle.stroke) {
35
+ const stroke = customOption.lineStyle.stroke;
36
+ ctx.strokeStyle = stroke.color || 'black';
37
+ ctx.lineWidth = stroke.width || 1;
38
+ ctx.stroke();
39
+ }
40
+ if (customOption.lineStyle.shadow) {
41
+ const shadow = customOption.lineStyle.shadow;
42
+ ctx.shadowOffsetX = shadow.offsetX || 0;
43
+ ctx.shadowOffsetY = shadow.offsetY || 0;
44
+ ctx.shadowBlur = shadow.blur || 0;
45
+ ctx.shadowColor = shadow.color || 'black';
46
+ }
47
+ }
48
+ }
49
+ exports.customLines = customLines;
50
+ //# sourceMappingURL=customLines.js.map