@hypen-space/web 0.2.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 (195) hide show
  1. package/dist/chunk-2s02mkzs.js +32 -0
  2. package/dist/chunk-2s02mkzs.js.map +9 -0
  3. package/dist/src/canvas/accessibility.js +152 -0
  4. package/dist/src/canvas/accessibility.js.map +10 -0
  5. package/dist/src/canvas/events.js +198 -0
  6. package/dist/src/canvas/events.js.map +10 -0
  7. package/dist/src/canvas/index.js +28 -0
  8. package/dist/src/canvas/index.js.map +9 -0
  9. package/dist/src/canvas/input.js +132 -0
  10. package/dist/src/canvas/input.js.map +10 -0
  11. package/dist/src/canvas/layout.js +309 -0
  12. package/dist/src/canvas/layout.js.map +10 -0
  13. package/dist/src/canvas/paint.js +878 -0
  14. package/dist/src/canvas/paint.js.map +10 -0
  15. package/dist/src/canvas/renderer.js +276 -0
  16. package/dist/src/canvas/renderer.js.map +10 -0
  17. package/dist/src/canvas/text.js +118 -0
  18. package/dist/src/canvas/text.js.map +10 -0
  19. package/dist/src/canvas/types.js +2 -0
  20. package/dist/src/canvas/types.js.map +9 -0
  21. package/dist/src/canvas/utils.js +139 -0
  22. package/dist/src/canvas/utils.js.map +10 -0
  23. package/dist/src/dom/applicators/advanced-layout.js +111 -0
  24. package/dist/src/dom/applicators/advanced-layout.js.map +10 -0
  25. package/dist/src/dom/applicators/background.js +54 -0
  26. package/dist/src/dom/applicators/background.js.map +10 -0
  27. package/dist/src/dom/applicators/border.js +33 -0
  28. package/dist/src/dom/applicators/border.js.map +10 -0
  29. package/dist/src/dom/applicators/color.js +36 -0
  30. package/dist/src/dom/applicators/color.js.map +10 -0
  31. package/dist/src/dom/applicators/display.js +57 -0
  32. package/dist/src/dom/applicators/display.js.map +10 -0
  33. package/dist/src/dom/applicators/effects.js +89 -0
  34. package/dist/src/dom/applicators/effects.js.map +10 -0
  35. package/dist/src/dom/applicators/events.js +518 -0
  36. package/dist/src/dom/applicators/events.js.map +10 -0
  37. package/dist/src/dom/applicators/font.js +39 -0
  38. package/dist/src/dom/applicators/font.js.map +10 -0
  39. package/dist/src/dom/applicators/index.js +296 -0
  40. package/dist/src/dom/applicators/index.js.map +10 -0
  41. package/dist/src/dom/applicators/layout.js +86 -0
  42. package/dist/src/dom/applicators/layout.js.map +10 -0
  43. package/dist/src/dom/applicators/margin.js +32 -0
  44. package/dist/src/dom/applicators/margin.js.map +10 -0
  45. package/dist/src/dom/applicators/padding.js +35 -0
  46. package/dist/src/dom/applicators/padding.js.map +10 -0
  47. package/dist/src/dom/applicators/size.js +42 -0
  48. package/dist/src/dom/applicators/size.js.map +10 -0
  49. package/dist/src/dom/applicators/transform.js +92 -0
  50. package/dist/src/dom/applicators/transform.js.map +10 -0
  51. package/dist/src/dom/applicators/transition.js +66 -0
  52. package/dist/src/dom/applicators/transition.js.map +10 -0
  53. package/dist/src/dom/applicators/typography.js +87 -0
  54. package/dist/src/dom/applicators/typography.js.map +10 -0
  55. package/dist/src/dom/canvas/index.js +50 -0
  56. package/dist/src/dom/canvas/index.js.map +10 -0
  57. package/dist/src/dom/components/audio.js +48 -0
  58. package/dist/src/dom/components/audio.js.map +10 -0
  59. package/dist/src/dom/components/avatar.js +58 -0
  60. package/dist/src/dom/components/avatar.js.map +10 -0
  61. package/dist/src/dom/components/badge.js +55 -0
  62. package/dist/src/dom/components/badge.js.map +10 -0
  63. package/dist/src/dom/components/button.js +29 -0
  64. package/dist/src/dom/components/button.js.map +10 -0
  65. package/dist/src/dom/components/card.js +33 -0
  66. package/dist/src/dom/components/card.js.map +10 -0
  67. package/dist/src/dom/components/center.js +32 -0
  68. package/dist/src/dom/components/center.js.map +10 -0
  69. package/dist/src/dom/components/checkbox.js +54 -0
  70. package/dist/src/dom/components/checkbox.js.map +10 -0
  71. package/dist/src/dom/components/column.js +31 -0
  72. package/dist/src/dom/components/column.js.map +10 -0
  73. package/dist/src/dom/components/container.js +29 -0
  74. package/dist/src/dom/components/container.js.map +10 -0
  75. package/dist/src/dom/components/divider.js +45 -0
  76. package/dist/src/dom/components/divider.js.map +10 -0
  77. package/dist/src/dom/components/grid.js +44 -0
  78. package/dist/src/dom/components/grid.js.map +10 -0
  79. package/dist/src/dom/components/heading.js +47 -0
  80. package/dist/src/dom/components/heading.js.map +10 -0
  81. package/dist/src/dom/components/image.js +39 -0
  82. package/dist/src/dom/components/image.js.map +10 -0
  83. package/dist/src/dom/components/index.js +217 -0
  84. package/dist/src/dom/components/index.js.map +10 -0
  85. package/dist/src/dom/components/input.js +41 -0
  86. package/dist/src/dom/components/input.js.map +10 -0
  87. package/dist/src/dom/components/link.js +42 -0
  88. package/dist/src/dom/components/link.js.map +10 -0
  89. package/dist/src/dom/components/list.js +42 -0
  90. package/dist/src/dom/components/list.js.map +10 -0
  91. package/dist/src/dom/components/paragraph.js +35 -0
  92. package/dist/src/dom/components/paragraph.js.map +10 -0
  93. package/dist/src/dom/components/progressbar.js +57 -0
  94. package/dist/src/dom/components/progressbar.js.map +10 -0
  95. package/dist/src/dom/components/route.js +44 -0
  96. package/dist/src/dom/components/route.js.map +10 -0
  97. package/dist/src/dom/components/router.js +33 -0
  98. package/dist/src/dom/components/router.js.map +10 -0
  99. package/dist/src/dom/components/row.js +31 -0
  100. package/dist/src/dom/components/row.js.map +10 -0
  101. package/dist/src/dom/components/select.js +57 -0
  102. package/dist/src/dom/components/select.js.map +10 -0
  103. package/dist/src/dom/components/slider.js +48 -0
  104. package/dist/src/dom/components/slider.js.map +10 -0
  105. package/dist/src/dom/components/spacer.js +30 -0
  106. package/dist/src/dom/components/spacer.js.map +10 -0
  107. package/dist/src/dom/components/spinner.js +65 -0
  108. package/dist/src/dom/components/spinner.js.map +10 -0
  109. package/dist/src/dom/components/stack.js +45 -0
  110. package/dist/src/dom/components/stack.js.map +10 -0
  111. package/dist/src/dom/components/switch.js +83 -0
  112. package/dist/src/dom/components/switch.js.map +10 -0
  113. package/dist/src/dom/components/text.js +37 -0
  114. package/dist/src/dom/components/text.js.map +10 -0
  115. package/dist/src/dom/components/textarea.js +51 -0
  116. package/dist/src/dom/components/textarea.js.map +10 -0
  117. package/dist/src/dom/components/video.js +51 -0
  118. package/dist/src/dom/components/video.js.map +10 -0
  119. package/dist/src/dom/debug.js +170 -0
  120. package/dist/src/dom/debug.js.map +10 -0
  121. package/dist/src/dom/events.js +112 -0
  122. package/dist/src/dom/events.js.map +10 -0
  123. package/dist/src/dom/index.js +73 -0
  124. package/dist/src/dom/index.js.map +9 -0
  125. package/dist/src/dom/renderer.js +277 -0
  126. package/dist/src/dom/renderer.js.map +10 -0
  127. package/dist/src/index.js +89 -0
  128. package/dist/src/index.js.map +9 -0
  129. package/package.json +84 -0
  130. package/src/canvas/QUICKSTART.md +421 -0
  131. package/src/canvas/README.md +376 -0
  132. package/src/canvas/accessibility.ts +218 -0
  133. package/src/canvas/events.ts +307 -0
  134. package/src/canvas/index.ts +35 -0
  135. package/src/canvas/input.ts +210 -0
  136. package/src/canvas/layout.ts +401 -0
  137. package/src/canvas/paint.ts +1321 -0
  138. package/src/canvas/renderer.ts +422 -0
  139. package/src/canvas/text.ts +182 -0
  140. package/src/canvas/types.ts +137 -0
  141. package/src/canvas/utils.ts +218 -0
  142. package/src/dom/README.md +265 -0
  143. package/src/dom/applicators/advanced-layout.ts +128 -0
  144. package/src/dom/applicators/background.ts +50 -0
  145. package/src/dom/applicators/border.ts +19 -0
  146. package/src/dom/applicators/color.ts +23 -0
  147. package/src/dom/applicators/display.ts +54 -0
  148. package/src/dom/applicators/effects.ts +97 -0
  149. package/src/dom/applicators/events.ts +689 -0
  150. package/src/dom/applicators/font.ts +27 -0
  151. package/src/dom/applicators/index.ts +354 -0
  152. package/src/dom/applicators/layout.ts +92 -0
  153. package/src/dom/applicators/margin.ts +18 -0
  154. package/src/dom/applicators/padding.ts +18 -0
  155. package/src/dom/applicators/size.ts +31 -0
  156. package/src/dom/applicators/transform.ts +93 -0
  157. package/src/dom/applicators/transition.ts +65 -0
  158. package/src/dom/applicators/typography.ts +91 -0
  159. package/src/dom/canvas/index.ts +60 -0
  160. package/src/dom/components/audio.ts +45 -0
  161. package/src/dom/components/avatar.ts +49 -0
  162. package/src/dom/components/badge.ts +45 -0
  163. package/src/dom/components/button.ts +13 -0
  164. package/src/dom/components/card.ts +19 -0
  165. package/src/dom/components/center.ts +16 -0
  166. package/src/dom/components/checkbox.ts +54 -0
  167. package/src/dom/components/column.ts +15 -0
  168. package/src/dom/components/container.ts +13 -0
  169. package/src/dom/components/divider.ts +37 -0
  170. package/src/dom/components/grid.ts +40 -0
  171. package/src/dom/components/heading.ts +41 -0
  172. package/src/dom/components/image.ts +27 -0
  173. package/src/dom/components/index.ts +115 -0
  174. package/src/dom/components/input.ts +29 -0
  175. package/src/dom/components/link.ts +35 -0
  176. package/src/dom/components/list.ts +30 -0
  177. package/src/dom/components/paragraph.ts +23 -0
  178. package/src/dom/components/progressbar.ts +51 -0
  179. package/src/dom/components/route.ts +37 -0
  180. package/src/dom/components/router.ts +22 -0
  181. package/src/dom/components/row.ts +15 -0
  182. package/src/dom/components/select.ts +56 -0
  183. package/src/dom/components/slider.ts +45 -0
  184. package/src/dom/components/spacer.ts +16 -0
  185. package/src/dom/components/spinner.ts +60 -0
  186. package/src/dom/components/stack.ts +34 -0
  187. package/src/dom/components/switch.ts +86 -0
  188. package/src/dom/components/text.ts +24 -0
  189. package/src/dom/components/textarea.ts +50 -0
  190. package/src/dom/components/video.ts +50 -0
  191. package/src/dom/debug.ts +247 -0
  192. package/src/dom/events.ts +168 -0
  193. package/src/dom/index.ts +11 -0
  194. package/src/dom/renderer.ts +327 -0
  195. package/src/index.ts +56 -0
@@ -0,0 +1,128 @@
1
+ /**
2
+ * Advanced Layout Applicators (Flexbox, Grid, Positioning)
3
+ */
4
+
5
+ import type { ApplicatorHandler } from "./index.js";
6
+
7
+ export const advancedLayoutHandlers: Record<string, ApplicatorHandler> = {
8
+ // Flexbox properties
9
+ flexDirection: (el, value) => {
10
+ el.style.flexDirection = String(value);
11
+ },
12
+
13
+ flexWrap: (el, value) => {
14
+ el.style.flexWrap = String(value);
15
+ },
16
+
17
+ flexBasis: (el, value) => {
18
+ el.style.flexBasis = typeof value === "number" ? `${value}px` : String(value);
19
+ },
20
+
21
+ justifyContent: (el, value) => {
22
+ el.style.justifyContent = String(value);
23
+ },
24
+
25
+ alignItems: (el, value) => {
26
+ el.style.alignItems = String(value);
27
+ },
28
+
29
+ alignContent: (el, value) => {
30
+ el.style.alignContent = String(value);
31
+ },
32
+
33
+ alignSelf: (el, value) => {
34
+ el.style.alignSelf = String(value);
35
+ },
36
+
37
+ order: (el, value) => {
38
+ el.style.order = String(value);
39
+ },
40
+
41
+ // Grid properties
42
+ gridTemplateColumns: (el, value) => {
43
+ el.style.gridTemplateColumns = String(value);
44
+ },
45
+
46
+ gridTemplateRows: (el, value) => {
47
+ el.style.gridTemplateRows = String(value);
48
+ },
49
+
50
+ gridTemplateAreas: (el, value) => {
51
+ el.style.gridTemplateAreas = String(value);
52
+ },
53
+
54
+ gridColumn: (el, value) => {
55
+ el.style.gridColumn = String(value);
56
+ },
57
+
58
+ gridRow: (el, value) => {
59
+ el.style.gridRow = String(value);
60
+ },
61
+
62
+ gridArea: (el, value) => {
63
+ el.style.gridArea = String(value);
64
+ },
65
+
66
+ gridAutoFlow: (el, value) => {
67
+ el.style.gridAutoFlow = String(value);
68
+ },
69
+
70
+ gridAutoColumns: (el, value) => {
71
+ el.style.gridAutoColumns = String(value);
72
+ },
73
+
74
+ gridAutoRows: (el, value) => {
75
+ el.style.gridAutoRows = String(value);
76
+ },
77
+
78
+ rowGap: (el, value) => {
79
+ el.style.rowGap = typeof value === "number" ? `${value}px` : String(value);
80
+ },
81
+
82
+ columnGap: (el, value) => {
83
+ el.style.columnGap = typeof value === "number" ? `${value}px` : String(value);
84
+ },
85
+
86
+ placeItems: (el, value) => {
87
+ el.style.placeItems = String(value);
88
+ },
89
+
90
+ placeContent: (el, value) => {
91
+ el.style.placeContent = String(value);
92
+ },
93
+
94
+ placeSelf: (el, value) => {
95
+ el.style.placeSelf = String(value);
96
+ },
97
+
98
+ // Positioning
99
+ position: (el, value) => {
100
+ el.style.position = String(value);
101
+ },
102
+
103
+ top: (el, value) => {
104
+ el.style.top = typeof value === "number" ? `${value}px` : String(value);
105
+ },
106
+
107
+ right: (el, value) => {
108
+ el.style.right = typeof value === "number" ? `${value}px` : String(value);
109
+ },
110
+
111
+ bottom: (el, value) => {
112
+ el.style.bottom = typeof value === "number" ? `${value}px` : String(value);
113
+ },
114
+
115
+ left: (el, value) => {
116
+ el.style.left = typeof value === "number" ? `${value}px` : String(value);
117
+ },
118
+
119
+ inset: (el, value) => {
120
+ el.style.inset = typeof value === "number" ? `${value}px` : String(value);
121
+ },
122
+
123
+ zIndex: (el, value) => {
124
+ el.style.zIndex = String(value);
125
+ },
126
+ };
127
+
128
+
@@ -0,0 +1,50 @@
1
+ /**
2
+ * Background Applicators
3
+ */
4
+
5
+ import type { ApplicatorHandler } from "./index.js";
6
+
7
+ export const backgroundHandlers: Record<string, ApplicatorHandler> = {
8
+ backgroundImage: (el, value) => {
9
+ el.style.backgroundImage = String(value);
10
+ },
11
+
12
+ backgroundSize: (el, value) => {
13
+ el.style.backgroundSize = String(value);
14
+ },
15
+
16
+ backgroundPosition: (el, value) => {
17
+ el.style.backgroundPosition = String(value);
18
+ },
19
+
20
+ backgroundRepeat: (el, value) => {
21
+ el.style.backgroundRepeat = String(value);
22
+ },
23
+
24
+ backgroundAttachment: (el, value) => {
25
+ el.style.backgroundAttachment = String(value);
26
+ },
27
+
28
+ backgroundClip: (el, value) => {
29
+ el.style.backgroundClip = String(value);
30
+ },
31
+
32
+ backgroundOrigin: (el, value) => {
33
+ el.style.backgroundOrigin = String(value);
34
+ },
35
+
36
+ // Gradient helpers
37
+ linearGradient: (el, value) => {
38
+ el.style.backgroundImage = `linear-gradient(${value})`;
39
+ },
40
+
41
+ radialGradient: (el, value) => {
42
+ el.style.backgroundImage = `radial-gradient(${value})`;
43
+ },
44
+
45
+ conicGradient: (el, value) => {
46
+ el.style.backgroundImage = `conic-gradient(${value})`;
47
+ },
48
+ };
49
+
50
+
@@ -0,0 +1,19 @@
1
+ /**
2
+ * Border Applicators
3
+ */
4
+
5
+ import type { ApplicatorHandler } from "./index.js";
6
+
7
+ export const borderHandlers: Record<string, ApplicatorHandler> = {
8
+ borderWidth: (el, value) => {
9
+ el.style.borderWidth = typeof value === "number" ? `${value}px` : String(value);
10
+ },
11
+
12
+ borderStyle: (el, value) => {
13
+ el.style.borderStyle = String(value);
14
+ },
15
+
16
+ borderRadius: (el, value) => {
17
+ el.style.borderRadius = typeof value === "number" ? `${value}px` : String(value);
18
+ },
19
+ };
@@ -0,0 +1,23 @@
1
+ /**
2
+ * Color Applicators
3
+ */
4
+
5
+ import type { ApplicatorHandler } from "./index.js";
6
+
7
+ export const colorHandlers: Record<string, ApplicatorHandler> = {
8
+ color: (el, value) => {
9
+ el.style.color = String(value);
10
+ },
11
+
12
+ backgroundColor: (el, value) => {
13
+ el.style.backgroundColor = String(value);
14
+ },
15
+
16
+ borderColor: (el, value) => {
17
+ el.style.borderColor = String(value);
18
+ },
19
+
20
+ opacity: (el, value) => {
21
+ el.style.opacity = String(value);
22
+ },
23
+ };
@@ -0,0 +1,54 @@
1
+ /**
2
+ * Display and Visibility Applicators
3
+ */
4
+
5
+ import type { ApplicatorHandler } from "./index.js";
6
+
7
+ export const displayHandlers: Record<string, ApplicatorHandler> = {
8
+ display: (el, value) => {
9
+ el.style.display = String(value);
10
+ },
11
+
12
+ visibility: (el, value) => {
13
+ el.style.visibility = String(value);
14
+ },
15
+
16
+ overflowX: (el, value) => {
17
+ el.style.overflowX = String(value);
18
+ },
19
+
20
+ overflowY: (el, value) => {
21
+ el.style.overflowY = String(value);
22
+ },
23
+
24
+ pointerEvents: (el, value) => {
25
+ el.style.pointerEvents = String(value);
26
+ },
27
+
28
+ userSelect: (el, value) => {
29
+ el.style.userSelect = String(value);
30
+ },
31
+
32
+ resize: (el, value) => {
33
+ el.style.resize = String(value);
34
+ },
35
+
36
+ boxSizing: (el, value) => {
37
+ el.style.boxSizing = String(value);
38
+ },
39
+
40
+ // Sizing helpers
41
+ aspectRatio: (el, value) => {
42
+ el.style.aspectRatio = String(value);
43
+ },
44
+
45
+ objectFit: (el, value) => {
46
+ el.style.objectFit = String(value);
47
+ },
48
+
49
+ objectPosition: (el, value) => {
50
+ el.style.objectPosition = String(value);
51
+ },
52
+ };
53
+
54
+
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Visual Effects Applicators (Shadows, Filters, Blend Modes)
3
+ */
4
+
5
+ import type { ApplicatorHandler } from "./index.js";
6
+
7
+ export const effectsHandlers: Record<string, ApplicatorHandler> = {
8
+ // Shadow effects
9
+ boxShadow: (el, value) => {
10
+ el.style.boxShadow = String(value);
11
+ },
12
+
13
+ textShadow: (el, value) => {
14
+ el.style.textShadow = String(value);
15
+ },
16
+
17
+ // Filter effects
18
+ filter: (el, value) => {
19
+ el.style.filter = String(value);
20
+ },
21
+
22
+ backdropFilter: (el, value) => {
23
+ el.style.backdropFilter = String(value);
24
+ },
25
+
26
+ // Individual filter functions
27
+ blur: (el, value) => {
28
+ const val = typeof value === "number" ? `${value}px` : String(value);
29
+ const current = el.style.filter || "";
30
+ el.style.filter = current ? `${current} blur(${val})` : `blur(${val})`;
31
+ },
32
+
33
+ brightness: (el, value) => {
34
+ const current = el.style.filter || "";
35
+ el.style.filter = current ? `${current} brightness(${value})` : `brightness(${value})`;
36
+ },
37
+
38
+ contrast: (el, value) => {
39
+ const current = el.style.filter || "";
40
+ el.style.filter = current ? `${current} contrast(${value})` : `contrast(${value})`;
41
+ },
42
+
43
+ grayscale: (el, value) => {
44
+ const current = el.style.filter || "";
45
+ el.style.filter = current ? `${current} grayscale(${value})` : `grayscale(${value})`;
46
+ },
47
+
48
+ hueRotate: (el, value) => {
49
+ const val = String(value);
50
+ const current = el.style.filter || "";
51
+ el.style.filter = current ? `${current} hue-rotate(${val})` : `hue-rotate(${val})`;
52
+ },
53
+
54
+ invert: (el, value) => {
55
+ const current = el.style.filter || "";
56
+ el.style.filter = current ? `${current} invert(${value})` : `invert(${value})`;
57
+ },
58
+
59
+ saturate: (el, value) => {
60
+ const current = el.style.filter || "";
61
+ el.style.filter = current ? `${current} saturate(${value})` : `saturate(${value})`;
62
+ },
63
+
64
+ sepia: (el, value) => {
65
+ const current = el.style.filter || "";
66
+ el.style.filter = current ? `${current} sepia(${value})` : `sepia(${value})`;
67
+ },
68
+
69
+ dropShadow: (el, value) => {
70
+ const current = el.style.filter || "";
71
+ el.style.filter = current ? `${current} drop-shadow(${value})` : `drop-shadow(${value})`;
72
+ },
73
+
74
+ // Blend modes
75
+ mixBlendMode: (el, value) => {
76
+ el.style.mixBlendMode = String(value);
77
+ },
78
+
79
+ backgroundBlendMode: (el, value) => {
80
+ el.style.backgroundBlendMode = String(value);
81
+ },
82
+
83
+ // Clip and mask
84
+ clipPath: (el, value) => {
85
+ el.style.clipPath = String(value);
86
+ },
87
+
88
+ mask: (el, value) => {
89
+ el.style.mask = String(value);
90
+ },
91
+
92
+ maskImage: (el, value) => {
93
+ el.style.maskImage = String(value);
94
+ },
95
+ };
96
+
97
+