@amphore-dev/shades 0.5.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.
Files changed (103) hide show
  1. package/LICENSE +21 -0
  2. package/README.md +317 -0
  3. package/dist/classes/ShadesEngine.d.ts +65 -0
  4. package/dist/classes/ShadesEngine.d.ts.map +1 -0
  5. package/dist/classes/ShadesEngine.js +386 -0
  6. package/dist/classes/ShadesEngine.js.map +1 -0
  7. package/dist/classes/index.d.ts +3 -0
  8. package/dist/classes/index.d.ts.map +1 -0
  9. package/dist/classes/index.js +3 -0
  10. package/dist/classes/index.js.map +1 -0
  11. package/dist/classes/shapes/BaseShape.d.ts +20 -0
  12. package/dist/classes/shapes/BaseShape.d.ts.map +1 -0
  13. package/dist/classes/shapes/BaseShape.js +45 -0
  14. package/dist/classes/shapes/BaseShape.js.map +1 -0
  15. package/dist/classes/shapes/CircleShape.d.ts +11 -0
  16. package/dist/classes/shapes/CircleShape.d.ts.map +1 -0
  17. package/dist/classes/shapes/CircleShape.js +25 -0
  18. package/dist/classes/shapes/CircleShape.js.map +1 -0
  19. package/dist/classes/shapes/ImageShape.d.ts +22 -0
  20. package/dist/classes/shapes/ImageShape.d.ts.map +1 -0
  21. package/dist/classes/shapes/ImageShape.js +107 -0
  22. package/dist/classes/shapes/ImageShape.js.map +1 -0
  23. package/dist/classes/shapes/SpiralShape.d.ts +11 -0
  24. package/dist/classes/shapes/SpiralShape.d.ts.map +1 -0
  25. package/dist/classes/shapes/SpiralShape.js +28 -0
  26. package/dist/classes/shapes/SpiralShape.js.map +1 -0
  27. package/dist/classes/shapes/SquaredShape.d.ts +11 -0
  28. package/dist/classes/shapes/SquaredShape.d.ts.map +1 -0
  29. package/dist/classes/shapes/SquaredShape.js +25 -0
  30. package/dist/classes/shapes/SquaredShape.js.map +1 -0
  31. package/dist/classes/shapes/TextShape.d.ts +16 -0
  32. package/dist/classes/shapes/TextShape.d.ts.map +1 -0
  33. package/dist/classes/shapes/TextShape.js +35 -0
  34. package/dist/classes/shapes/TextShape.js.map +1 -0
  35. package/dist/classes/shapes/TriangleShape.d.ts +11 -0
  36. package/dist/classes/shapes/TriangleShape.d.ts.map +1 -0
  37. package/dist/classes/shapes/TriangleShape.js +46 -0
  38. package/dist/classes/shapes/TriangleShape.js.map +1 -0
  39. package/dist/classes/shapes/index.d.ts +8 -0
  40. package/dist/classes/shapes/index.d.ts.map +1 -0
  41. package/dist/classes/shapes/index.js +10 -0
  42. package/dist/classes/shapes/index.js.map +1 -0
  43. package/dist/constants/CColors.d.ts +6 -0
  44. package/dist/constants/CColors.d.ts.map +1 -0
  45. package/dist/constants/CColors.js +35 -0
  46. package/dist/constants/CColors.js.map +1 -0
  47. package/dist/constants/CFilters.d.ts +8 -0
  48. package/dist/constants/CFilters.d.ts.map +1 -0
  49. package/dist/constants/CFilters.js +15 -0
  50. package/dist/constants/CFilters.js.map +1 -0
  51. package/dist/constants/CShades.d.ts +3 -0
  52. package/dist/constants/CShades.d.ts.map +1 -0
  53. package/dist/constants/CShades.js +10 -0
  54. package/dist/constants/CShades.js.map +1 -0
  55. package/dist/constants/index.d.ts +4 -0
  56. package/dist/constants/index.d.ts.map +1 -0
  57. package/dist/constants/index.js +4 -0
  58. package/dist/constants/index.js.map +1 -0
  59. package/dist/index.d.ts +5 -0
  60. package/dist/index.d.ts.map +1 -0
  61. package/dist/index.js +8 -0
  62. package/dist/index.js.map +1 -0
  63. package/dist/types/TPoints.d.ts +8 -0
  64. package/dist/types/TPoints.d.ts.map +1 -0
  65. package/dist/types/TPoints.js +2 -0
  66. package/dist/types/TPoints.js.map +1 -0
  67. package/dist/types/TShadeItem.d.ts +6 -0
  68. package/dist/types/TShadeItem.d.ts.map +1 -0
  69. package/dist/types/TShadeItem.js +2 -0
  70. package/dist/types/TShadeItem.js.map +1 -0
  71. package/dist/types/TShades.d.ts +11 -0
  72. package/dist/types/TShades.d.ts.map +1 -0
  73. package/dist/types/TShades.js +10 -0
  74. package/dist/types/TShades.js.map +1 -0
  75. package/dist/types/TShadesConfig.d.ts +26 -0
  76. package/dist/types/TShadesConfig.d.ts.map +1 -0
  77. package/dist/types/TShadesConfig.js +2 -0
  78. package/dist/types/TShadesConfig.js.map +1 -0
  79. package/dist/types/TShapeOptions.d.ts +6 -0
  80. package/dist/types/TShapeOptions.d.ts.map +1 -0
  81. package/dist/types/TShapeOptions.js +2 -0
  82. package/dist/types/TShapeOptions.js.map +1 -0
  83. package/dist/types/index.d.ts +6 -0
  84. package/dist/types/index.d.ts.map +1 -0
  85. package/dist/types/index.js +6 -0
  86. package/dist/types/index.js.map +1 -0
  87. package/dist/utils/UColors.d.ts +18 -0
  88. package/dist/utils/UColors.d.ts.map +1 -0
  89. package/dist/utils/UColors.js +44 -0
  90. package/dist/utils/UColors.js.map +1 -0
  91. package/dist/utils/UMaths.d.ts +9 -0
  92. package/dist/utils/UMaths.d.ts.map +1 -0
  93. package/dist/utils/UMaths.js +14 -0
  94. package/dist/utils/UMaths.js.map +1 -0
  95. package/dist/utils/UShadeUtils.d.ts +8 -0
  96. package/dist/utils/UShadeUtils.d.ts.map +1 -0
  97. package/dist/utils/UShadeUtils.js +75 -0
  98. package/dist/utils/UShadeUtils.js.map +1 -0
  99. package/dist/utils/index.d.ts +4 -0
  100. package/dist/utils/index.d.ts.map +1 -0
  101. package/dist/utils/index.js +4 -0
  102. package/dist/utils/index.js.map +1 -0
  103. package/package.json +71 -0
@@ -0,0 +1,107 @@
1
+ import { intToHex, rgbToHex } from "../../utils/UColors.js";
2
+ import { ShadeItem } from "./BaseShape.js";
3
+ /**
4
+ * Image shape that displays images (SVG, PNG, JPG, etc.)
5
+ * More flexible than the original LogoShape - accepts image URLs or HTMLImageElement
6
+ */
7
+ export class ImageShape extends ShadeItem {
8
+ image;
9
+ imageUrl;
10
+ hasImageLoaded = false;
11
+ hexColor;
12
+ constructor(x, y, color, options = {}) {
13
+ super(x, y, color, { filled: true, rotation: false, ...options });
14
+ this.type = "image";
15
+ this.hexColor = rgbToHex(this.color);
16
+ this.loadImage(options.imageSource);
17
+ }
18
+ loadImage(imageSource) {
19
+ if (!imageSource) {
20
+ // Fallback: try to find a Logo element in DOM
21
+ const svg = document.getElementById("Logo");
22
+ if (svg) {
23
+ this.loadFromSVGElement(svg);
24
+ }
25
+ return;
26
+ }
27
+ if (typeof imageSource === "string") {
28
+ // Load from URL
29
+ this.imageUrl = imageSource;
30
+ this.loadFromUrl(imageSource);
31
+ }
32
+ else if (imageSource instanceof HTMLImageElement) {
33
+ // Use existing image element
34
+ this.image = imageSource;
35
+ this.hasImageLoaded = imageSource.complete;
36
+ if (!this.hasImageLoaded) {
37
+ imageSource.onload = () => {
38
+ this.hasImageLoaded = true;
39
+ };
40
+ }
41
+ }
42
+ else {
43
+ // Assume it's an SVG or other HTML element
44
+ this.loadFromSVGElement(imageSource);
45
+ }
46
+ }
47
+ loadFromUrl(url) {
48
+ const img = new Image();
49
+ img.crossOrigin = "anonymous"; // Enable CORS if needed
50
+ img.onload = () => {
51
+ this.hasImageLoaded = true;
52
+ };
53
+ img.onerror = () => {
54
+ console.warn(`Failed to load image from URL: ${url}`);
55
+ };
56
+ img.src = url;
57
+ this.image = img;
58
+ }
59
+ loadFromSVGElement(element) {
60
+ try {
61
+ const serializedSVG = new XMLSerializer().serializeToString(element);
62
+ const img = new Image();
63
+ img.onload = () => {
64
+ this.hasImageLoaded = true;
65
+ };
66
+ img.onerror = () => {
67
+ console.warn("Failed to load SVG element as image");
68
+ };
69
+ img.src =
70
+ "data:image/svg+xml;charset=utf-8;base64, " + btoa(serializedSVG);
71
+ this.image = img;
72
+ }
73
+ catch (error) {
74
+ console.warn("Failed to serialize SVG element:", error);
75
+ }
76
+ }
77
+ setColors = (ctx, gradRatio, i) => {
78
+ this.hexColor =
79
+ rgbToHex(this.color) +
80
+ intToHex(Math.round(255 * ((gradRatio * i) / 100)));
81
+ };
82
+ draw = (ctx, config, offset) => {
83
+ const { gradRatio, nbrShades, center } = config;
84
+ if (!this.hasImageLoaded || !this.image)
85
+ return;
86
+ const heightRatio = (document.body.clientHeight * 0.77) / this.image.height;
87
+ const width = this.image.width * heightRatio;
88
+ const height = this.image.height * heightRatio;
89
+ for (let i = 0; i < nbrShades; i++) {
90
+ this.setColors(ctx, gradRatio, i);
91
+ ctx.fillStyle = this.hexColor;
92
+ ctx.beginPath();
93
+ ctx.drawImage(this.image, center.x +
94
+ this.position.x -
95
+ width / 2 +
96
+ offset.x * (1 - (gradRatio * i) / 100), center.y +
97
+ this.position.y -
98
+ height / 2 +
99
+ offset.y * (1 - (gradRatio * i) / 100), width, height);
100
+ ctx.globalCompositeOperation = "source-in";
101
+ ctx.fillRect(0, 0, document.body.clientWidth, document.body.clientHeight);
102
+ ctx.globalCompositeOperation = "source-over";
103
+ ctx.closePath();
104
+ }
105
+ };
106
+ }
107
+ //# sourceMappingURL=ImageShape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ImageShape.js","sourceRoot":"","sources":["../../../src/classes/shapes/ImageShape.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,wBAAwB,CAAC;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;;;GAGG;AACH,MAAM,OAAO,UAAW,SAAQ,SAAS;IACvC,KAAK,CAAoB;IACzB,QAAQ,CAAU;IAClB,cAAc,GAAY,KAAK,CAAC;IAChC,QAAQ,CAAS;IAEjB,YACE,CAAS,EACT,CAAS,EACT,KAAkB,EAClB,UAEI,EAAE;QAEN,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QAClE,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC;QAEpB,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QACrC,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC;IACtC,CAAC;IAEO,SAAS,CACf,WAAqD;QAErD,IAAI,CAAC,WAAW,EAAE,CAAC;YACjB,8CAA8C;YAC9C,MAAM,GAAG,GAAG,QAAQ,CAAC,cAAc,CAAC,MAAM,CAAgB,CAAC;YAC3D,IAAI,GAAG,EAAE,CAAC;gBACR,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC;YAC/B,CAAC;YACD,OAAO;QACT,CAAC;QAED,IAAI,OAAO,WAAW,KAAK,QAAQ,EAAE,CAAC;YACpC,gBAAgB;YAChB,IAAI,CAAC,QAAQ,GAAG,WAAW,CAAC;YAC5B,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAC;QAChC,CAAC;aAAM,IAAI,WAAW,YAAY,gBAAgB,EAAE,CAAC;YACnD,6BAA6B;YAC7B,IAAI,CAAC,KAAK,GAAG,WAAW,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,WAAW,CAAC,QAAQ,CAAC;YAC3C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;gBACzB,WAAW,CAAC,MAAM,GAAG,GAAG,EAAE;oBACxB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;gBAC7B,CAAC,CAAC;YACJ,CAAC;QACH,CAAC;aAAM,CAAC;YACN,2CAA2C;YAC3C,IAAI,CAAC,kBAAkB,CAAC,WAAW,CAAC,CAAC;QACvC,CAAC;IACH,CAAC;IAEO,WAAW,CAAC,GAAW;QAC7B,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;QACxB,GAAG,CAAC,WAAW,GAAG,WAAW,CAAC,CAAC,wBAAwB;QACvD,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;YAChB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;QAC7B,CAAC,CAAC;QACF,GAAG,CAAC,OAAO,GAAG,GAAG,EAAE;YACjB,OAAO,CAAC,IAAI,CAAC,kCAAkC,GAAG,EAAE,CAAC,CAAC;QACxD,CAAC,CAAC;QACF,GAAG,CAAC,GAAG,GAAG,GAAG,CAAC;QACd,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;IACnB,CAAC;IAEO,kBAAkB,CAAC,OAAoB;QAC7C,IAAI,CAAC;YACH,MAAM,aAAa,GAAG,IAAI,aAAa,EAAE,CAAC,iBAAiB,CAAC,OAAO,CAAC,CAAC;YACrE,MAAM,GAAG,GAAG,IAAI,KAAK,EAAE,CAAC;YACxB,GAAG,CAAC,MAAM,GAAG,GAAG,EAAE;gBAChB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC;YAC7B,CAAC,CAAC;YACF,GAAG,CAAC,OAAO,GAAG,GAAG,EAAE;gBACjB,OAAO,CAAC,IAAI,CAAC,qCAAqC,CAAC,CAAC;YACtD,CAAC,CAAC;YACF,GAAG,CAAC,GAAG;gBACL,2CAA2C,GAAG,IAAI,CAAC,aAAa,CAAC,CAAC;YACpE,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QACnB,CAAC;QAAC,OAAO,KAAK,EAAE,CAAC;YACf,OAAO,CAAC,IAAI,CAAC,kCAAkC,EAAE,KAAK,CAAC,CAAC;QAC1D,CAAC;IACH,CAAC;IAED,SAAS,GAAG,CAAC,GAA6B,EAAE,SAAiB,EAAE,CAAS,EAAE,EAAE;QAC1E,IAAI,CAAC,QAAQ;YACX,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC;gBACpB,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,GAAG,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CAAC,CAAC,CAAC;IACxD,CAAC,CAAC;IAEF,IAAI,GAAG,CACL,GAA6B,EAC7B,MAAoB,EACpB,MAAc,EACd,EAAE;QACF,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;QAEhD,IAAI,CAAC,IAAI,CAAC,cAAc,IAAI,CAAC,IAAI,CAAC,KAAK;YAAE,OAAO;QAEhD,MAAM,WAAW,GAAG,CAAC,QAAQ,CAAC,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC;QAE5E,MAAM,KAAK,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,GAAG,WAAW,CAAC;QAC7C,MAAM,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,WAAW,CAAC;QAE/C,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;YAClC,GAAG,CAAC,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC;YAC9B,GAAG,CAAC,SAAS,EAAE,CAAC;YAChB,GAAG,CAAC,SAAS,CACX,IAAI,CAAC,KAAK,EACV,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACf,KAAK,GAAG,CAAC;gBACT,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACf,MAAM,GAAG,CAAC;gBACV,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,KAAK,EACL,MAAM,CACP,CAAC;YACF,GAAG,CAAC,wBAAwB,GAAG,WAAW,CAAC;YAC3C,GAAG,CAAC,QAAQ,CAAC,CAAC,EAAE,CAAC,EAAE,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,QAAQ,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;YAC1E,GAAG,CAAC,wBAAwB,GAAG,aAAa,CAAC;YAC7C,GAAG,CAAC,SAAS,EAAE,CAAC;QAClB,CAAC;IACH,CAAC,CAAC;CACH"}
@@ -0,0 +1,11 @@
1
+ import { TShadeColor, TShadeConfig, TShapeOptions } from "../../types/index.js";
2
+ import { TPoint } from "../../types/TPoints.js";
3
+ import { ShadeItem } from "./BaseShape.js";
4
+ /**
5
+ * Spiral shape implementation with rotation animation
6
+ */
7
+ export declare class SpiralShape extends ShadeItem {
8
+ constructor(x: number, y: number, color: TShadeColor, options?: TShapeOptions);
9
+ draw: (ctx: CanvasRenderingContext2D, config: TShadeConfig, offset: TPoint) => void;
10
+ }
11
+ //# sourceMappingURL=SpiralShape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SpiralShape.d.ts","sourceRoot":"","sources":["../../../src/classes/shapes/SpiralShape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;;GAEG;AACH,qBAAa,WAAY,SAAQ,SAAS;gBAEtC,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,WAAW,EAClB,OAAO,GAAE,aAAkB;IAO7B,IAAI,GACF,KAAK,wBAAwB,EAC7B,QAAQ,YAAY,EACpB,QAAQ,MAAM,UA0Bd;CACH"}
@@ -0,0 +1,28 @@
1
+ import { ShadeItem } from "./BaseShape.js";
2
+ /**
3
+ * Spiral shape implementation with rotation animation
4
+ */
5
+ export class SpiralShape extends ShadeItem {
6
+ constructor(x, y, color, options = {}) {
7
+ super(x, y, color, { filled: false, rotation: true, ...options });
8
+ this.type = "spiral";
9
+ this.angle = 0;
10
+ }
11
+ draw = (ctx, config, offset) => {
12
+ const { gradRatio, nbrShades, totalWidth, totalHeight, center, width } = config;
13
+ for (let i = 0; i < nbrShades; i++) {
14
+ this.setColors(ctx, gradRatio, i);
15
+ ctx.beginPath();
16
+ ctx.arc(center.x +
17
+ (this.position.x - totalWidth / 2 + width / 2) +
18
+ offset.x * (1 - (gradRatio * i) / 100), center.y +
19
+ (this.position.y - totalHeight / 2 + width / 2) +
20
+ offset.y * (1 - (gradRatio * i) / 100), width / 2, this.angle + ((nbrShades - i) * 8 * Math.PI) / 180, this.angle + ((180 + (nbrShades - i) * 8) * Math.PI) / 180);
21
+ this.drawPath(ctx);
22
+ ctx.closePath();
23
+ if (this.rotation)
24
+ this.angle += ((2 / nbrShades) * Math.PI) / 180;
25
+ }
26
+ };
27
+ }
28
+ //# sourceMappingURL=SpiralShape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SpiralShape.js","sourceRoot":"","sources":["../../../src/classes/shapes/SpiralShape.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;;GAEG;AACH,MAAM,OAAO,WAAY,SAAQ,SAAS;IACxC,YACE,CAAS,EACT,CAAS,EACT,KAAkB,EAClB,UAAyB,EAAE;QAE3B,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QAClE,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;QACrB,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;IACjB,CAAC;IAED,IAAI,GAAG,CACL,GAA6B,EAC7B,MAAoB,EACpB,MAAc,EACd,EAAE;QACF,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,GACpE,MAAM,CAAC;QAET,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;YAElC,GAAG,CAAC,SAAS,EAAE,CAAC;YAChB,GAAG,CAAC,GAAG,CACL,MAAM,CAAC,CAAC;gBACN,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,UAAU,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC9C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,MAAM,CAAC,CAAC;gBACN,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,WAAW,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC/C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,KAAK,GAAG,CAAC,EACT,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,EAClD,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAC3D,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YACnB,GAAG,CAAC,SAAS,EAAE,CAAC;YAEhB,IAAI,IAAI,CAAC,QAAQ;gBAAE,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,CAAC,GAAG,SAAS,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;QACrE,CAAC;IACH,CAAC,CAAC;CACH"}
@@ -0,0 +1,11 @@
1
+ import { TShadeColor, TShadeConfig, TShapeOptions } from "../../types/index.js";
2
+ import { TPoint } from "../../types/TPoints.js";
3
+ import { ShadeItem } from "./BaseShape.js";
4
+ /**
5
+ * Square shape implementation
6
+ */
7
+ export declare class SquaredShape extends ShadeItem {
8
+ constructor(x: number, y: number, color: TShadeColor, options?: TShapeOptions);
9
+ draw: (ctx: CanvasRenderingContext2D, config: TShadeConfig, offset: TPoint) => void;
10
+ }
11
+ //# sourceMappingURL=SquaredShape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SquaredShape.d.ts","sourceRoot":"","sources":["../../../src/classes/shapes/SquaredShape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;;GAEG;AACH,qBAAa,YAAa,SAAQ,SAAS;gBAEvC,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,WAAW,EAClB,OAAO,GAAE,aAAkB;IAM7B,IAAI,GACF,KAAK,wBAAwB,EAC7B,QAAQ,YAAY,EACpB,QAAQ,MAAM,UA8Bd;CACH"}
@@ -0,0 +1,25 @@
1
+ import { ShadeItem } from "./BaseShape.js";
2
+ /**
3
+ * Square shape implementation
4
+ */
5
+ export class SquaredShape extends ShadeItem {
6
+ constructor(x, y, color, options = {}) {
7
+ super(x, y, color, { filled: false, ...options });
8
+ this.type = "square";
9
+ }
10
+ draw = (ctx, config, offset) => {
11
+ const { gradRatio, nbrShades, totalWidth, totalHeight, center, width, height, } = config;
12
+ for (let i = 0; i < nbrShades; i++) {
13
+ this.setColors(ctx, gradRatio, i);
14
+ ctx.beginPath();
15
+ ctx.rect(center.x +
16
+ (this.position.x - totalWidth / 2) +
17
+ offset.x * (1 - (gradRatio * i) / 100), center.y +
18
+ (this.position.y - totalHeight / 2) +
19
+ offset.y * (1 - (gradRatio * i) / 100), width, height);
20
+ this.drawPath(ctx);
21
+ ctx.closePath();
22
+ }
23
+ };
24
+ }
25
+ //# sourceMappingURL=SquaredShape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SquaredShape.js","sourceRoot":"","sources":["../../../src/classes/shapes/SquaredShape.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;;GAEG;AACH,MAAM,OAAO,YAAa,SAAQ,SAAS;IACzC,YACE,CAAS,EACT,CAAS,EACT,KAAkB,EAClB,UAAyB,EAAE;QAE3B,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QAClD,IAAI,CAAC,IAAI,GAAG,QAAQ,CAAC;IACvB,CAAC;IAED,IAAI,GAAG,CACL,GAA6B,EAC7B,MAAoB,EACpB,MAAc,EACd,EAAE;QACF,MAAM,EACJ,SAAS,EACT,SAAS,EACT,UAAU,EACV,WAAW,EACX,MAAM,EACN,KAAK,EACL,MAAM,GACP,GAAG,MAAM,CAAC;QAEX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;YAElC,GAAG,CAAC,SAAS,EAAE,CAAC;YAChB,GAAG,CAAC,IAAI,CACN,MAAM,CAAC,CAAC;gBACN,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,UAAU,GAAG,CAAC,CAAC;gBAClC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,MAAM,CAAC,CAAC;gBACN,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,WAAW,GAAG,CAAC,CAAC;gBACnC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,KAAK,EACL,MAAM,CACP,CAAC;YAEF,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YACnB,GAAG,CAAC,SAAS,EAAE,CAAC;QAClB,CAAC;IACH,CAAC,CAAC;CACH"}
@@ -0,0 +1,16 @@
1
+ import { TShadeColor, TShadeConfig, TShapeOptions } from "../../types/index.js";
2
+ import { TPoint } from "../../types/TPoints.js";
3
+ import { ShadeItem } from "./BaseShape.js";
4
+ /**
5
+ * Text shape implementation for displaying text
6
+ */
7
+ export declare class TextShape extends ShadeItem {
8
+ text: string;
9
+ font: string;
10
+ constructor(x: number, y: number, color: TShadeColor, options?: TShapeOptions & {
11
+ text?: string;
12
+ font?: string;
13
+ });
14
+ draw: (ctx: CanvasRenderingContext2D, config: TShadeConfig, offset: TPoint) => void;
15
+ }
16
+ //# sourceMappingURL=TextShape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextShape.d.ts","sourceRoot":"","sources":["../../../src/classes/shapes/TextShape.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAChD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAK3C;;GAEG;AACH,qBAAa,SAAU,SAAQ,SAAS;IACtC,IAAI,EAAE,MAAM,CAAC;IACb,IAAI,EAAE,MAAM,CAAC;gBAGX,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,WAAW,EAClB,OAAO,GAAE,aAAa,GAAG;QAAE,IAAI,CAAC,EAAE,MAAM,CAAC;QAAC,IAAI,CAAC,EAAE,MAAM,CAAA;KAAO;IAQhE,IAAI,GACF,KAAK,wBAAwB,EAC7B,QAAQ,YAAY,EACpB,QAAQ,MAAM,UAyBd;CACH"}
@@ -0,0 +1,35 @@
1
+ import { random } from "../../utils/UMaths.js";
2
+ import { ShadeItem } from "./BaseShape.js";
3
+ const fontList = ["Remained"];
4
+ const curFont = fontList[random(0, fontList.length - 1, true)]; // Default to monospace for better compatibility
5
+ /**
6
+ * Text shape implementation for displaying text
7
+ */
8
+ export class TextShape extends ShadeItem {
9
+ text;
10
+ font;
11
+ constructor(x, y, color, options = {}) {
12
+ super(x, y, color, { ...options, filled: true });
13
+ this.type = "text";
14
+ this.text = options.text ?? "SHADES";
15
+ this.font = options.font ?? curFont;
16
+ }
17
+ draw = (ctx, config, offset) => {
18
+ const { gradRatio, nbrShades, totalWidth, totalHeight, center, width } = config;
19
+ const text = this.text; // Use the text from the options
20
+ ctx.font = `${width}px ${this.font}`;
21
+ ctx.textBaseline = "middle";
22
+ ctx.textAlign = "center";
23
+ for (let i = 0; i < nbrShades; i++) {
24
+ this.setColors(ctx, gradRatio, i);
25
+ ctx.fillText(text, width / 2 +
26
+ center.x +
27
+ (this.position.x - totalWidth / 2) +
28
+ offset.x * (1 - (gradRatio * i) / 100), config.height / 2 +
29
+ center.y +
30
+ (this.position.y - totalHeight / 2) +
31
+ offset.y * (1 - (gradRatio * i) / 100));
32
+ }
33
+ };
34
+ }
35
+ //# sourceMappingURL=TextShape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TextShape.js","sourceRoot":"","sources":["../../../src/classes/shapes/TextShape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAG/C,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,MAAM,QAAQ,GAAG,CAAC,UAAU,CAAC,CAAC;AAC9B,MAAM,OAAO,GAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,EAAE,QAAQ,CAAC,MAAM,GAAG,CAAC,EAAE,IAAI,CAAC,CAAC,CAAC,CAAC,gDAAgD;AAEhH;;GAEG;AACH,MAAM,OAAO,SAAU,SAAQ,SAAS;IACtC,IAAI,CAAS;IACb,IAAI,CAAS;IAEb,YACE,CAAS,EACT,CAAS,EACT,KAAkB,EAClB,UAA4D,EAAE;QAE9D,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,GAAG,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,CAAC,CAAC;QACjD,IAAI,CAAC,IAAI,GAAG,MAAM,CAAC;QACnB,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,IAAI,QAAQ,CAAC;QACrC,IAAI,CAAC,IAAI,GAAG,OAAO,CAAC,IAAI,IAAI,OAAO,CAAC;IACtC,CAAC;IAED,IAAI,GAAG,CACL,GAA6B,EAC7B,MAAoB,EACpB,MAAc,EACd,EAAE;QACF,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,GACpE,MAAM,CAAC;QAET,MAAM,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC,CAAC,gCAAgC;QACxD,GAAG,CAAC,IAAI,GAAG,GAAG,KAAK,MAAM,IAAI,CAAC,IAAI,EAAE,CAAC;QACrC,GAAG,CAAC,YAAY,GAAG,QAAQ,CAAC;QAC5B,GAAG,CAAC,SAAS,GAAG,QAAQ,CAAC;QAEzB,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;YAElC,GAAG,CAAC,QAAQ,CACV,IAAI,EACJ,KAAK,GAAG,CAAC;gBACP,MAAM,CAAC,CAAC;gBACR,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,UAAU,GAAG,CAAC,CAAC;gBAClC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,MAAM,CAAC,MAAM,GAAG,CAAC;gBACf,MAAM,CAAC,CAAC;gBACR,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,WAAW,GAAG,CAAC,CAAC;gBACnC,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CACzC,CAAC;QACJ,CAAC;IACH,CAAC,CAAC;CACH"}
@@ -0,0 +1,11 @@
1
+ import { TShadeColor, TShadeConfig, TShapeOptions } from "../../types/index.js";
2
+ import { TPoint } from "../../types/TPoints.js";
3
+ import { ShadeItem } from "./BaseShape.js";
4
+ /**
5
+ * Triangle shape implementation with rotation animation
6
+ */
7
+ export declare class TriangleShape extends ShadeItem {
8
+ constructor(x: number, y: number, color: TShadeColor, options?: TShapeOptions);
9
+ draw: (ctx: CanvasRenderingContext2D, config: TShadeConfig, offset: TPoint) => void;
10
+ }
11
+ //# sourceMappingURL=TriangleShape.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TriangleShape.d.ts","sourceRoot":"","sources":["../../../src/classes/shapes/TriangleShape.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,aAAa,EAAE,MAAM,sBAAsB,CAAC;AAChF,OAAO,EAAE,MAAM,EAAE,MAAM,wBAAwB,CAAC;AAEhD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;;GAEG;AACH,qBAAa,aAAc,SAAQ,SAAS;gBAExC,CAAC,EAAE,MAAM,EACT,CAAC,EAAE,MAAM,EACT,KAAK,EAAE,WAAW,EAClB,OAAO,GAAE,aAAkB;IAO7B,IAAI,GACF,KAAK,wBAAwB,EAC7B,QAAQ,YAAY,EACpB,QAAQ,MAAM,UAkDd;CACH"}
@@ -0,0 +1,46 @@
1
+ import { degToRad } from "../../utils/UMaths.js";
2
+ import { ShadeItem } from "./BaseShape.js";
3
+ /**
4
+ * Triangle shape implementation with rotation animation
5
+ */
6
+ export class TriangleShape extends ShadeItem {
7
+ constructor(x, y, color, options = {}) {
8
+ super(x, y, color, { filled: true, rotation: true, ...options });
9
+ this.type = "triangle";
10
+ this.angle = degToRad(90);
11
+ }
12
+ draw = (ctx, config, offset) => {
13
+ const { gradRatio, nbrShades, totalWidth, totalHeight, center, width } = config;
14
+ for (let i = 0; i < nbrShades; i++) {
15
+ this.setColors(ctx, gradRatio, i);
16
+ ctx.beginPath();
17
+ ctx.moveTo(center.x +
18
+ Math.cos(this.angle) * width +
19
+ (this.position.x - totalWidth / 2 + width / 2) +
20
+ offset.x * (1 - (gradRatio * i) / 100), center.y +
21
+ Math.sin(this.angle) * width +
22
+ (this.position.y - totalHeight / 2 + width / 2) +
23
+ offset.y * (1 - (gradRatio * i) / 100));
24
+ ctx.lineTo(center.x +
25
+ Math.cos(this.angle + (2 * Math.PI) / 3) * width +
26
+ (this.position.x - totalWidth / 2 + width / 2) +
27
+ offset.x * (1 - (gradRatio * i) / 100), center.y +
28
+ Math.sin(this.angle + (2 * Math.PI) / 3) * width +
29
+ (this.position.y - totalHeight / 2 + width / 2) +
30
+ offset.y * (1 - (gradRatio * i) / 100));
31
+ ctx.lineTo(center.x +
32
+ Math.cos(this.angle + (4 * Math.PI) / 3) * width +
33
+ (this.position.x - totalWidth / 2 + width / 2) +
34
+ offset.x * (1 - (gradRatio * i) / 100), center.y +
35
+ Math.sin(this.angle + (4 * Math.PI) / 3) * width +
36
+ (this.position.y - totalHeight / 2 + width / 2) +
37
+ offset.y * (1 - (gradRatio * i) / 100));
38
+ ctx.closePath();
39
+ this.drawPath(ctx);
40
+ if (this.rotation) {
41
+ this.angle += ((0.3 / nbrShades) * Math.PI) / 180;
42
+ }
43
+ }
44
+ };
45
+ }
46
+ //# sourceMappingURL=TriangleShape.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TriangleShape.js","sourceRoot":"","sources":["../../../src/classes/shapes/TriangleShape.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,uBAAuB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C;;GAEG;AACH,MAAM,OAAO,aAAc,SAAQ,SAAS;IAC1C,YACE,CAAS,EACT,CAAS,EACT,KAAkB,EAClB,UAAyB,EAAE;QAE3B,KAAK,CAAC,CAAC,EAAE,CAAC,EAAE,KAAK,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE,QAAQ,EAAE,IAAI,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QACjE,IAAI,CAAC,IAAI,GAAG,UAAU,CAAC;QACvB,IAAI,CAAC,KAAK,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IAC5B,CAAC;IAED,IAAI,GAAG,CACL,GAA6B,EAC7B,MAAoB,EACpB,MAAc,EACd,EAAE;QACF,MAAM,EAAE,SAAS,EAAE,SAAS,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,EAAE,KAAK,EAAE,GACpE,MAAM,CAAC;QAET,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,SAAS,EAAE,CAAC,EAAE,EAAE,CAAC;YACnC,IAAI,CAAC,SAAS,CAAC,GAAG,EAAE,SAAS,EAAE,CAAC,CAAC,CAAC;YAElC,GAAG,CAAC,SAAS,EAAE,CAAC;YAEhB,GAAG,CAAC,MAAM,CACR,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,KAAK;gBAC5B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,UAAU,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC9C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,GAAG,KAAK;gBAC5B,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,WAAW,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC/C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CACzC,CAAC;YAEF,GAAG,CAAC,MAAM,CACR,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK;gBAChD,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,UAAU,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC9C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK;gBAChD,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,WAAW,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC/C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CACzC,CAAC;YAEF,GAAG,CAAC,MAAM,CACR,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK;gBAChD,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,UAAU,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC9C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,EACxC,MAAM,CAAC,CAAC;gBACN,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,CAAC,CAAC,GAAG,KAAK;gBAChD,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,GAAG,WAAW,GAAG,CAAC,GAAG,KAAK,GAAG,CAAC,CAAC;gBAC/C,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,SAAS,GAAG,CAAC,CAAC,GAAG,GAAG,CAAC,CACzC,CAAC;YAEF,GAAG,CAAC,SAAS,EAAE,CAAC;YAChB,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;YAEnB,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,IAAI,CAAC,KAAK,IAAI,CAAC,CAAC,GAAG,GAAG,SAAS,CAAC,GAAG,IAAI,CAAC,EAAE,CAAC,GAAG,GAAG,CAAC;YACpD,CAAC;QACH,CAAC;IACH,CAAC,CAAC;CACH"}
@@ -0,0 +1,8 @@
1
+ export { ShadeItem } from "./BaseShape.js";
2
+ export { CircleShape } from "./CircleShape.js";
3
+ export { ImageShape } from "./ImageShape.js";
4
+ export { SpiralShape } from "./SpiralShape.js";
5
+ export { SquaredShape } from "./SquaredShape.js";
6
+ export { TextShape } from "./TextShape.js";
7
+ export { TriangleShape } from "./TriangleShape.js";
8
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/classes/shapes/index.ts"],"names":[],"mappings":"AACA,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAG3C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,10 @@
1
+ // Export base shape class
2
+ export { ShadeItem } from "./BaseShape.js";
3
+ // Export all shape implementations
4
+ export { CircleShape } from "./CircleShape.js";
5
+ export { ImageShape } from "./ImageShape.js";
6
+ export { SpiralShape } from "./SpiralShape.js";
7
+ export { SquaredShape } from "./SquaredShape.js";
8
+ export { TextShape } from "./TextShape.js";
9
+ export { TriangleShape } from "./TriangleShape.js";
10
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/classes/shapes/index.ts"],"names":[],"mappings":"AAAA,0BAA0B;AAC1B,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,mCAAmC;AACnC,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAC7C,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC/C,OAAO,EAAE,YAAY,EAAE,MAAM,mBAAmB,CAAC;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAC3C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC"}
@@ -0,0 +1,6 @@
1
+ import { TShadeColor } from "@/types/TShadeItem.js";
2
+ export declare const HOME_COLORS: TShadeColor[];
3
+ export declare const LIGHT_COLORS: TShadeColor[];
4
+ export declare const DARK_COLORS: TShadeColor[];
5
+ export declare const COLORS: TShadeColor[];
6
+ //# sourceMappingURL=CColors.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CColors.d.ts","sourceRoot":"","sources":["../../src/constants/CColors.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,uBAAuB,CAAC;AAEpD,eAAO,MAAM,WAAW,EAAE,WAAW,EASpC,CAAC;AAEF,eAAO,MAAM,YAAY,EAAE,WAAW,EAiBrC,CAAC;AAEF,eAAO,MAAM,WAAW,EAAE,WAAW,EAKpC,CAAC;AAEF,eAAO,MAAM,MAAM,eAAoD,CAAC"}
@@ -0,0 +1,35 @@
1
+ export const HOME_COLORS = [
2
+ { r: 80, g: 178, b: 192 },
3
+ { r: 241, g: 162, b: 8 },
4
+ { r: 214, g: 40, b: 57 },
5
+ { r: 0, g: 255, b: 255 },
6
+ { r: 252, g: 163, b: 17 },
7
+ { r: 237, g: 37, b: 78 },
8
+ { r: 209, g: 52, b: 91 },
9
+ ];
10
+ export const LIGHT_COLORS = [
11
+ { r: 255, g: 255, b: 255 },
12
+ { r: 0, g: 255, b: 0 },
13
+ { r: 255, g: 0, b: 255 },
14
+ { r: 255, g: 255, b: 0 },
15
+ { r: 255, g: 105, b: 120 },
16
+ { r: 7, g: 190, b: 184 },
17
+ { r: 186, g: 50, b: 79 },
18
+ { r: 23, g: 86, b: 118 },
19
+ { r: 75, g: 163, b: 195 },
20
+ { r: 255, g: 200, b: 87 },
21
+ { r: 250, g: 120, b: 30 },
22
+ { r: 223, g: 41, b: 53 },
23
+ { r: 129, g: 195, b: 215 },
24
+ { r: 49, g: 203, b: 0 },
25
+ { r: 17, g: 152, b: 34 },
26
+ { r: 155, g: 197, b: 91 },
27
+ ];
28
+ export const DARK_COLORS = [
29
+ { r: 0, g: 0, b: 0 },
30
+ { r: 0, g: 0, b: 0 },
31
+ { r: 0, g: 0, b: 0 },
32
+ { r: 0, g: 0, b: 0 },
33
+ ];
34
+ export const COLORS = [...HOME_COLORS, ...LIGHT_COLORS, ...DARK_COLORS];
35
+ //# sourceMappingURL=CColors.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CColors.js","sourceRoot":"","sources":["../../src/constants/CColors.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,8 @@
1
+ import { TShadeColor } from "../types/index.js";
2
+ export declare const SAME_COLOR_FILTER: (mainColor: TShadeColor, itemColor: TShadeColor) => boolean;
3
+ export declare const NO_FILTER: () => boolean;
4
+ export declare const RANDOM_FILTER: () => boolean;
5
+ export declare const RANDOM_50_FILTER: () => boolean;
6
+ export declare const RANDOM_FILTERS: ((mainColor: TShadeColor, itemColor: TShadeColor) => boolean)[];
7
+ export declare const LINE_CAP_TYPES: CanvasLineCap[];
8
+ //# sourceMappingURL=CFilters.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CFilters.d.ts","sourceRoot":"","sources":["../../src/constants/CFilters.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC;AAMhD,eAAO,MAAM,iBAAiB,GAC5B,WAAW,WAAW,EACtB,WAAW,WAAW,YACwB,CAAC;AAEjD,eAAO,MAAM,SAAS,eAAa,CAAC;AACpC,eAAO,MAAM,aAAa,eAAc,CAAC;AACzC,eAAO,MAAM,gBAAgB,eAAiC,CAAC;AAE/D,eAAO,MAAM,cAAc,eARd,WAAW,aACX,WAAW,eAYvB,CAAC;AAEF,eAAO,MAAM,cAAc,EAAE,aAAa,EAAgC,CAAC"}
@@ -0,0 +1,15 @@
1
+ import { rgbToHex } from "../utils/UColors.js";
2
+ import { random } from "../utils/UMaths.js";
3
+ // filters
4
+ export const SAME_COLOR_FILTER = (mainColor, itemColor) => rgbToHex(itemColor) === rgbToHex(mainColor);
5
+ export const NO_FILTER = () => true;
6
+ export const RANDOM_FILTER = () => false;
7
+ export const RANDOM_50_FILTER = () => random(0, 1, true) === 1;
8
+ export const RANDOM_FILTERS = [
9
+ SAME_COLOR_FILTER,
10
+ NO_FILTER,
11
+ RANDOM_FILTER,
12
+ RANDOM_50_FILTER,
13
+ ];
14
+ export const LINE_CAP_TYPES = ["butt", "round", "square"];
15
+ //# sourceMappingURL=CFilters.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CFilters.js","sourceRoot":"","sources":["../../src/constants/CFilters.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,QAAQ,EAAE,MAAM,qBAAqB,CAAC;AAC/C,OAAO,EAAE,MAAM,EAAE,MAAM,oBAAoB,CAAC;AAE5C,UAAU;AACV,MAAM,CAAC,MAAM,iBAAiB,GAAG,CAC/B,SAAsB,EACtB,SAAsB,EACtB,EAAE,CAAC,QAAQ,CAAC,SAAS,CAAC,KAAK,QAAQ,CAAC,SAAS,CAAC,CAAC;AAEjD,MAAM,CAAC,MAAM,SAAS,GAAG,GAAG,EAAE,CAAC,IAAI,CAAC;AACpC,MAAM,CAAC,MAAM,aAAa,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC;AACzC,MAAM,CAAC,MAAM,gBAAgB,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,CAAC,EAAE,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;AAE/D,MAAM,CAAC,MAAM,cAAc,GAAG;IAC5B,iBAAiB;IACjB,SAAS;IACT,aAAa;IACb,gBAAgB;CACjB,CAAC;AAEF,MAAM,CAAC,MAAM,cAAc,GAAoB,CAAC,MAAM,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ export declare const MAX_SHADES_NBR = 30;
2
+ export declare const SHADES_TYPES: string[];
3
+ //# sourceMappingURL=CShades.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CShades.d.ts","sourceRoot":"","sources":["../../src/constants/CShades.ts"],"names":[],"mappings":"AAAA,eAAO,MAAM,cAAc,KAAK,CAAC;AAEjC,eAAO,MAAM,YAAY,EAAE,MAAM,EAOhC,CAAC"}
@@ -0,0 +1,10 @@
1
+ export const MAX_SHADES_NBR = 30;
2
+ export const SHADES_TYPES = [
3
+ "square",
4
+ "circle",
5
+ "text",
6
+ "spiral",
7
+ "triangle",
8
+ // "image",
9
+ ];
10
+ //# sourceMappingURL=CShades.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"CShades.js","sourceRoot":"","sources":["../../src/constants/CShades.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,cAAc,GAAG,EAAE,CAAC;AAEjC,MAAM,CAAC,MAAM,YAAY,GAAa;IACpC,QAAQ;IACR,QAAQ;IACR,MAAM;IACN,QAAQ;IACR,UAAU;IACV,aAAa;CACd,CAAC"}
@@ -0,0 +1,4 @@
1
+ export * from "./CShades.js";
2
+ export * from "./CColors.js";
3
+ export * from "./CFilters.js";
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,eAAe,CAAC"}
@@ -0,0 +1,4 @@
1
+ export * from "./CShades.js";
2
+ export * from "./CColors.js";
3
+ export * from "./CFilters.js";
4
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/constants/index.ts"],"names":[],"mappings":"AAAA,cAAc,cAAc,CAAC;AAC7B,cAAc,cAAc,CAAC;AAC7B,cAAc,eAAe,CAAC"}
@@ -0,0 +1,5 @@
1
+ export * from "./classes/index.js";
2
+ export type * from "./types/index.js";
3
+ export { genConfig, getRandColors, getRandColor } from "./utils/UShadeUtils.js";
4
+ export { HOME_COLORS, MAX_SHADES_NBR } from "./constants/index.js";
5
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AACA,cAAc,oBAAoB,CAAC;AAGnC,mBAAmB,kBAAkB,CAAC;AAGtC,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAIhF,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC"}
package/dist/index.js ADDED
@@ -0,0 +1,8 @@
1
+ // Export main engine class
2
+ export * from "./classes/index.js";
3
+ // Export utility functions for advanced users
4
+ export { genConfig, getRandColors, getRandColor } from "./utils/UShadeUtils.js";
5
+ // Export individual shape classes
6
+ // Export constants
7
+ export { HOME_COLORS, MAX_SHADES_NBR } from "./constants/index.js";
8
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,2BAA2B;AAC3B,cAAc,oBAAoB,CAAC;AAKnC,8CAA8C;AAC9C,OAAO,EAAE,SAAS,EAAE,aAAa,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AAEhF,kCAAkC;AAClC,mBAAmB;AACnB,OAAO,EAAE,WAAW,EAAE,cAAc,EAAE,MAAM,sBAAsB,CAAC"}
@@ -0,0 +1,8 @@
1
+ /**
2
+ * Represents a 2D point with x and y coordinates
3
+ */
4
+ export type TPoint = {
5
+ x: number;
6
+ y: number;
7
+ };
8
+ //# sourceMappingURL=TPoints.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TPoints.d.ts","sourceRoot":"","sources":["../../src/types/TPoints.ts"],"names":[],"mappings":"AAAA;;GAEG;AACH,MAAM,MAAM,MAAM,GAAG;IACnB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=TPoints.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TPoints.js","sourceRoot":"","sources":["../../src/types/TPoints.ts"],"names":[],"mappings":""}
@@ -0,0 +1,6 @@
1
+ export type TShadeColor = {
2
+ r: number;
3
+ g: number;
4
+ b: number;
5
+ };
6
+ //# sourceMappingURL=TShadeItem.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TShadeItem.d.ts","sourceRoot":"","sources":["../../src/types/TShadeItem.ts"],"names":[],"mappings":"AAAA,MAAM,MAAM,WAAW,GAAG;IACxB,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;IACV,CAAC,EAAE,MAAM,CAAC;CACX,CAAC"}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=TShadeItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TShadeItem.js","sourceRoot":"","sources":["../../src/types/TShadeItem.ts"],"names":[],"mappings":""}
@@ -0,0 +1,11 @@
1
+ import { SHADES_TYPES } from "@/constants/CShades.js";
2
+ import { CircleShape, ImageShape, SpiralShape, SquaredShape, TextShape, TriangleShape } from "../classes/index.js";
3
+ export type TShadeType = (typeof SHADES_TYPES)[number] | string;
4
+ export type TShadeTypeConstructor = typeof SquaredShape | typeof CircleShape | typeof TextShape | typeof SpiralShape | typeof ImageShape | typeof TriangleShape;
5
+ type IShadeTypeConstructors = {
6
+ [key in TShadeType]: TShadeTypeConstructor;
7
+ };
8
+ export declare const SHADES_TYPES_CONSTRUCTORS_LIST: IShadeTypeConstructors;
9
+ export type ShadesTypesCodstructors = typeof SHADES_TYPES_CONSTRUCTORS_LIST;
10
+ export {};
11
+ //# sourceMappingURL=TShades.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TShades.d.ts","sourceRoot":"","sources":["../../src/types/TShades.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,wBAAwB,CAAC;AACtD,OAAO,EACL,WAAW,EACX,UAAU,EACV,WAAW,EACX,YAAY,EACZ,SAAS,EACT,aAAa,EACd,MAAM,qBAAqB,CAAC;AAE7B,MAAM,MAAM,UAAU,GAAG,CAAC,OAAO,YAAY,CAAC,CAAC,MAAM,CAAC,GAAG,MAAM,CAAC;AAEhE,MAAM,MAAM,qBAAqB,GAC7B,OAAO,YAAY,GACnB,OAAO,WAAW,GAClB,OAAO,SAAS,GAChB,OAAO,WAAW,GAClB,OAAO,UAAU,GACjB,OAAO,aAAa,CAAC;AAEzB,KAAK,sBAAsB,GAAG;KAC3B,GAAG,IAAI,UAAU,GAAG,qBAAqB;CAC3C,CAAC;AAEF,eAAO,MAAM,8BAA8B,EAAE,sBAO5C,CAAC;AAEF,MAAM,MAAM,uBAAuB,GAAG,OAAO,8BAA8B,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { CircleShape, ImageShape, SpiralShape, SquaredShape, TextShape, TriangleShape, } from "../classes/index.js";
2
+ export const SHADES_TYPES_CONSTRUCTORS_LIST = {
3
+ square: SquaredShape,
4
+ circle: CircleShape,
5
+ text: TextShape,
6
+ spiral: SpiralShape,
7
+ image: ImageShape,
8
+ triangle: TriangleShape,
9
+ };
10
+ //# sourceMappingURL=TShades.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TShades.js","sourceRoot":"","sources":["../../src/types/TShades.ts"],"names":[],"mappings":"AACA,OAAO,EACL,WAAW,EACX,UAAU,EACV,WAAW,EACX,YAAY,EACZ,SAAS,EACT,aAAa,GACd,MAAM,qBAAqB,CAAC;AAgB7B,MAAM,CAAC,MAAM,8BAA8B,GAA2B;IACpE,MAAM,EAAE,YAAY;IACpB,MAAM,EAAE,WAAW;IACnB,IAAI,EAAE,SAAS;IACf,MAAM,EAAE,WAAW;IACnB,KAAK,EAAE,UAAU;IACjB,QAAQ,EAAE,aAAa;CACxB,CAAC"}