@qwickapps/react-framework 1.3.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 (441) hide show
  1. package/LICENSE +44 -0
  2. package/README.md +794 -0
  3. package/dist/components/AccessibilityChecker.d.ts +12 -0
  4. package/dist/components/AccessibilityChecker.d.ts.map +1 -0
  5. package/dist/components/Html.d.ts +48 -0
  6. package/dist/components/Html.d.ts.map +1 -0
  7. package/dist/components/Logo.d.ts +79 -0
  8. package/dist/components/Logo.d.ts.map +1 -0
  9. package/dist/components/Markdown.d.ts +47 -0
  10. package/dist/components/Markdown.d.ts.map +1 -0
  11. package/dist/components/QwickApp.d.ts +56 -0
  12. package/dist/components/QwickApp.d.ts.map +1 -0
  13. package/dist/components/QwickAppsLogo.d.ts +25 -0
  14. package/dist/components/QwickAppsLogo.d.ts.map +1 -0
  15. package/dist/components/ResponsiveMenu.d.ts +38 -0
  16. package/dist/components/ResponsiveMenu.d.ts.map +1 -0
  17. package/dist/components/SafeSpan.d.ts +23 -0
  18. package/dist/components/SafeSpan.d.ts.map +1 -0
  19. package/dist/components/Scaffold.d.ts +57 -0
  20. package/dist/components/Scaffold.d.ts.map +1 -0
  21. package/dist/components/blocks/Article.d.ts +23 -0
  22. package/dist/components/blocks/Article.d.ts.map +1 -0
  23. package/dist/components/blocks/CardListGrid.d.ts +23 -0
  24. package/dist/components/blocks/CardListGrid.d.ts.map +1 -0
  25. package/dist/components/blocks/Code.d.ts +21 -0
  26. package/dist/components/blocks/Code.d.ts.map +1 -0
  27. package/dist/components/blocks/Content.d.ts +24 -0
  28. package/dist/components/blocks/Content.d.ts.map +1 -0
  29. package/dist/components/blocks/CoverImageHeader.d.ts +44 -0
  30. package/dist/components/blocks/CoverImageHeader.d.ts.map +1 -0
  31. package/dist/components/blocks/FeatureCard.d.ts +66 -0
  32. package/dist/components/blocks/FeatureCard.d.ts.map +1 -0
  33. package/dist/components/blocks/FeatureGrid.d.ts +48 -0
  34. package/dist/components/blocks/FeatureGrid.d.ts.map +1 -0
  35. package/dist/components/blocks/Footer.d.ts +56 -0
  36. package/dist/components/blocks/Footer.d.ts.map +1 -0
  37. package/dist/components/blocks/HeroBlock.d.ts +33 -0
  38. package/dist/components/blocks/HeroBlock.d.ts.map +1 -0
  39. package/dist/components/blocks/PageBannerHeader.d.ts +30 -0
  40. package/dist/components/blocks/PageBannerHeader.d.ts.map +1 -0
  41. package/dist/components/blocks/ProductCard.d.ts +57 -0
  42. package/dist/components/blocks/ProductCard.d.ts.map +1 -0
  43. package/dist/components/blocks/Section.d.ts +40 -0
  44. package/dist/components/blocks/Section.d.ts.map +1 -0
  45. package/dist/components/blocks/index.d.ts +37 -0
  46. package/dist/components/blocks/index.d.ts.map +1 -0
  47. package/dist/components/buttons/Button.d.ts +38 -0
  48. package/dist/components/buttons/Button.d.ts.map +1 -0
  49. package/dist/components/buttons/PaletteSwitcher.d.ts +24 -0
  50. package/dist/components/buttons/PaletteSwitcher.d.ts.map +1 -0
  51. package/dist/components/buttons/ThemeSwitcher.d.ts +24 -0
  52. package/dist/components/buttons/ThemeSwitcher.d.ts.map +1 -0
  53. package/dist/components/buttons/index.d.ts +11 -0
  54. package/dist/components/buttons/index.d.ts.map +1 -0
  55. package/dist/components/forms/FormBlock.d.ts +45 -0
  56. package/dist/components/forms/FormBlock.d.ts.map +1 -0
  57. package/dist/components/forms/index.d.ts +8 -0
  58. package/dist/components/forms/index.d.ts.map +1 -0
  59. package/dist/components/index.d.ts +32 -0
  60. package/dist/components/index.d.ts.map +1 -0
  61. package/dist/components/input/ChoiceInputField.d.ts +30 -0
  62. package/dist/components/input/ChoiceInputField.d.ts.map +1 -0
  63. package/dist/components/input/HtmlInputField.d.ts +29 -0
  64. package/dist/components/input/HtmlInputField.d.ts.map +1 -0
  65. package/dist/components/input/SelectInputField.d.ts +29 -0
  66. package/dist/components/input/SelectInputField.d.ts.map +1 -0
  67. package/dist/components/input/TextField.d.ts +18 -0
  68. package/dist/components/input/TextField.d.ts.map +1 -0
  69. package/dist/components/input/TextInputField.d.ts +32 -0
  70. package/dist/components/input/TextInputField.d.ts.map +1 -0
  71. package/dist/components/input/index.d.ts +17 -0
  72. package/dist/components/input/index.d.ts.map +1 -0
  73. package/dist/components/layout/GridCell.d.ts +16 -0
  74. package/dist/components/layout/GridCell.d.ts.map +1 -0
  75. package/dist/components/layout/GridCellWrapper.d.ts +46 -0
  76. package/dist/components/layout/GridCellWrapper.d.ts.map +1 -0
  77. package/dist/components/layout/GridLayout.d.ts +38 -0
  78. package/dist/components/layout/GridLayout.d.ts.map +1 -0
  79. package/dist/components/layout/index.d.ts +12 -0
  80. package/dist/components/layout/index.d.ts.map +1 -0
  81. package/dist/components/menu/Menu.d.ts +1 -0
  82. package/dist/components/menu/Menu.d.ts.map +1 -0
  83. package/dist/components/menu/MenuItem.d.ts +31 -0
  84. package/dist/components/menu/MenuItem.d.ts.map +1 -0
  85. package/dist/components/menu/index.d.ts +7 -0
  86. package/dist/components/menu/index.d.ts.map +1 -0
  87. package/dist/components/pages/FormPage.d.ts +66 -0
  88. package/dist/components/pages/FormPage.d.ts.map +1 -0
  89. package/dist/components/pages/Page.d.ts +124 -0
  90. package/dist/components/pages/Page.d.ts.map +1 -0
  91. package/dist/components/pages/index.d.ts +11 -0
  92. package/dist/components/pages/index.d.ts.map +1 -0
  93. package/dist/contexts/DataContext.d.ts +139 -0
  94. package/dist/contexts/DataContext.d.ts.map +1 -0
  95. package/dist/contexts/DimensionsContext.d.ts +42 -0
  96. package/dist/contexts/DimensionsContext.d.ts.map +1 -0
  97. package/dist/contexts/PaletteContext.d.ts +53 -0
  98. package/dist/contexts/PaletteContext.d.ts.map +1 -0
  99. package/dist/contexts/QwickAppContext.d.ts +71 -0
  100. package/dist/contexts/QwickAppContext.d.ts.map +1 -0
  101. package/dist/contexts/ThemeContext.d.ts +65 -0
  102. package/dist/contexts/ThemeContext.d.ts.map +1 -0
  103. package/dist/contexts/index.d.ts +9 -0
  104. package/dist/contexts/index.d.ts.map +1 -0
  105. package/dist/hooks/index.d.ts +10 -0
  106. package/dist/hooks/index.d.ts.map +1 -0
  107. package/dist/hooks/useBaseProps.d.ts +101 -0
  108. package/dist/hooks/useBaseProps.d.ts.map +1 -0
  109. package/dist/hooks/useDataBinding.d.ts +22 -0
  110. package/dist/hooks/useDataBinding.d.ts.map +1 -0
  111. package/dist/index.css +1 -0
  112. package/dist/index.d.ts +8 -0
  113. package/dist/index.d.ts.map +1 -0
  114. package/dist/index.esm.css +1 -0
  115. package/dist/index.esm.js +24143 -0
  116. package/dist/index.js +24245 -0
  117. package/dist/palettes/PaletteAutumn.d.ts +10 -0
  118. package/dist/palettes/PaletteAutumn.d.ts.map +1 -0
  119. package/dist/palettes/PaletteCosmic.d.ts +10 -0
  120. package/dist/palettes/PaletteCosmic.d.ts.map +1 -0
  121. package/dist/palettes/PaletteDefault.d.ts +10 -0
  122. package/dist/palettes/PaletteDefault.d.ts.map +1 -0
  123. package/dist/palettes/PaletteOcean.d.ts +10 -0
  124. package/dist/palettes/PaletteOcean.d.ts.map +1 -0
  125. package/dist/palettes/PaletteSpring.d.ts +10 -0
  126. package/dist/palettes/PaletteSpring.d.ts.map +1 -0
  127. package/dist/palettes/PaletteWinter.d.ts +10 -0
  128. package/dist/palettes/PaletteWinter.d.ts.map +1 -0
  129. package/dist/palettes/index.d.ts +13 -0
  130. package/dist/palettes/index.d.ts.map +1 -0
  131. package/dist/schemas/ActionSchema.d.ts +21 -0
  132. package/dist/schemas/ActionSchema.d.ts.map +1 -0
  133. package/dist/schemas/ArticleSchema.d.ts +13 -0
  134. package/dist/schemas/ArticleSchema.d.ts.map +1 -0
  135. package/dist/schemas/Builders.d.ts +7 -0
  136. package/dist/schemas/Builders.d.ts.map +1 -0
  137. package/dist/schemas/ButtonSchema.d.ts +19 -0
  138. package/dist/schemas/ButtonSchema.d.ts.map +1 -0
  139. package/dist/schemas/CardListGridSchema.d.ts +17 -0
  140. package/dist/schemas/CardListGridSchema.d.ts.map +1 -0
  141. package/dist/schemas/ChoiceInputFieldSchema.d.ts +18 -0
  142. package/dist/schemas/ChoiceInputFieldSchema.d.ts.map +1 -0
  143. package/dist/schemas/CodeSchema.d.ts +18 -0
  144. package/dist/schemas/CodeSchema.d.ts.map +1 -0
  145. package/dist/schemas/ContentSchema.d.ts +20 -0
  146. package/dist/schemas/ContentSchema.d.ts.map +1 -0
  147. package/dist/schemas/CoverImageHeaderSchema.d.ts +28 -0
  148. package/dist/schemas/CoverImageHeaderSchema.d.ts.map +1 -0
  149. package/dist/schemas/FeatureCardSchema.d.ts +28 -0
  150. package/dist/schemas/FeatureCardSchema.d.ts.map +1 -0
  151. package/dist/schemas/FeatureGridSchema.d.ts +17 -0
  152. package/dist/schemas/FeatureGridSchema.d.ts.map +1 -0
  153. package/dist/schemas/FeatureItemSchema.d.ts +16 -0
  154. package/dist/schemas/FeatureItemSchema.d.ts.map +1 -0
  155. package/dist/schemas/FooterItemSchema.d.ts +15 -0
  156. package/dist/schemas/FooterItemSchema.d.ts.map +1 -0
  157. package/dist/schemas/FooterSchema.d.ts +20 -0
  158. package/dist/schemas/FooterSchema.d.ts.map +1 -0
  159. package/dist/schemas/FooterSectionSchema.d.ts +15 -0
  160. package/dist/schemas/FooterSectionSchema.d.ts.map +1 -0
  161. package/dist/schemas/FormBlockSchema.d.ts +19 -0
  162. package/dist/schemas/FormBlockSchema.d.ts.map +1 -0
  163. package/dist/schemas/HeaderActionSchema.d.ts +17 -0
  164. package/dist/schemas/HeaderActionSchema.d.ts.map +1 -0
  165. package/dist/schemas/HeroBlockSchema.d.ts +22 -0
  166. package/dist/schemas/HeroBlockSchema.d.ts.map +1 -0
  167. package/dist/schemas/HtmlInputFieldSchema.d.ts +18 -0
  168. package/dist/schemas/HtmlInputFieldSchema.d.ts.map +1 -0
  169. package/dist/schemas/MetadataItemSchema.d.ts +13 -0
  170. package/dist/schemas/MetadataItemSchema.d.ts.map +1 -0
  171. package/dist/schemas/PageBannerHeaderSchema.d.ts +28 -0
  172. package/dist/schemas/PageBannerHeaderSchema.d.ts.map +1 -0
  173. package/dist/schemas/PaletteSwitcherSchema.d.ts +16 -0
  174. package/dist/schemas/PaletteSwitcherSchema.d.ts.map +1 -0
  175. package/dist/schemas/ProductCardSchema.d.ts +39 -0
  176. package/dist/schemas/ProductCardSchema.d.ts.map +1 -0
  177. package/dist/schemas/SafeSpanSchema.d.ts +13 -0
  178. package/dist/schemas/SafeSpanSchema.d.ts.map +1 -0
  179. package/dist/schemas/SectionSchema.d.ts +17 -0
  180. package/dist/schemas/SectionSchema.d.ts.map +1 -0
  181. package/dist/schemas/SelectInputFieldSchema.d.ts +27 -0
  182. package/dist/schemas/SelectInputFieldSchema.d.ts.map +1 -0
  183. package/dist/schemas/TextInputFieldSchema.d.ts +22 -0
  184. package/dist/schemas/TextInputFieldSchema.d.ts.map +1 -0
  185. package/dist/schemas/ThemeSwitcherSchema.d.ts +19 -0
  186. package/dist/schemas/ThemeSwitcherSchema.d.ts.map +1 -0
  187. package/dist/schemas/index.d.ts +33 -0
  188. package/dist/schemas/index.d.ts.map +1 -0
  189. package/dist/schemas/types.d.ts +7 -0
  190. package/dist/schemas/types.d.ts.map +1 -0
  191. package/dist/templates/TemplateResolver.d.ts +52 -0
  192. package/dist/templates/TemplateResolver.d.ts.map +1 -0
  193. package/dist/templates/index.d.ts +7 -0
  194. package/dist/templates/index.d.ts.map +1 -0
  195. package/dist/tests/ConsoleWarningTest.d.ts +5 -0
  196. package/dist/tests/ConsoleWarningTest.d.ts.map +1 -0
  197. package/dist/tests/StorageKeyTest.d.ts +6 -0
  198. package/dist/tests/StorageKeyTest.d.ts.map +1 -0
  199. package/dist/tests/ThemeStorageKeyTest.d.ts +6 -0
  200. package/dist/tests/ThemeStorageKeyTest.d.ts.map +1 -0
  201. package/dist/types/CacheProvider.d.ts +18 -0
  202. package/dist/types/CacheProvider.d.ts.map +1 -0
  203. package/dist/types/ContentProxy.d.ts +47 -0
  204. package/dist/types/ContentProxy.d.ts.map +1 -0
  205. package/dist/types/DataBinding.d.ts +7 -0
  206. package/dist/types/DataBinding.d.ts.map +1 -0
  207. package/dist/types/DataProvider.d.ts +7 -0
  208. package/dist/types/DataProvider.d.ts.map +1 -0
  209. package/dist/types/DataTypes.d.ts +185 -0
  210. package/dist/types/DataTypes.d.ts.map +1 -0
  211. package/dist/types/TemplateProvider.d.ts +10 -0
  212. package/dist/types/TemplateProvider.d.ts.map +1 -0
  213. package/dist/types/TemplateResolver.d.ts +23 -0
  214. package/dist/types/TemplateResolver.d.ts.map +1 -0
  215. package/dist/types/index.d.ts +81 -0
  216. package/dist/types/index.d.ts.map +1 -0
  217. package/dist/utils/breakpoints.d.ts +35 -0
  218. package/dist/utils/breakpoints.d.ts.map +1 -0
  219. package/dist/utils/customPaletteManager.d.ts +8 -0
  220. package/dist/utils/customPaletteManager.d.ts.map +1 -0
  221. package/dist/utils/dimensions.d.ts +34 -0
  222. package/dist/utils/dimensions.d.ts.map +1 -0
  223. package/dist/utils/htmlTransform.d.ts +44 -0
  224. package/dist/utils/htmlTransform.d.ts.map +1 -0
  225. package/dist/utils/index.d.ts +15 -0
  226. package/dist/utils/index.d.ts.map +1 -0
  227. package/dist/utils/logger.d.ts +14 -0
  228. package/dist/utils/logger.d.ts.map +1 -0
  229. package/dist/utils/paletteUtils.d.ts +38 -0
  230. package/dist/utils/paletteUtils.d.ts.map +1 -0
  231. package/dist/utils/persistenceUtils.d.ts +31 -0
  232. package/dist/utils/persistenceUtils.d.ts.map +1 -0
  233. package/dist/utils/reactUtils.d.ts +24 -0
  234. package/dist/utils/reactUtils.d.ts.map +1 -0
  235. package/dist/utils/spacing.d.ts +34 -0
  236. package/dist/utils/spacing.d.ts.map +1 -0
  237. package/dist/utils/themePerformanceMonitor.d.ts +32 -0
  238. package/dist/utils/themePerformanceMonitor.d.ts.map +1 -0
  239. package/dist/utils/themeUtils.d.ts +27 -0
  240. package/dist/utils/themeUtils.d.ts.map +1 -0
  241. package/package.json +141 -0
  242. package/src/__tests__/components/Logo.test.js +172 -0
  243. package/src/__tests__/contexts/DataContext.test.js +505 -0
  244. package/src/__tests__/contexts/PaletteContext.test.js +115 -0
  245. package/src/__tests__/contexts/ThemeContext.test.js +123 -0
  246. package/src/__tests__/utils/paletteUtils.test.js +142 -0
  247. package/src/__tests__/utils/themeUtils.test.js +142 -0
  248. package/src/components/AccessibilityChecker.tsx +264 -0
  249. package/src/components/Html.tsx +191 -0
  250. package/src/components/Logo.css +217 -0
  251. package/src/components/Logo.tsx +370 -0
  252. package/src/components/Markdown.tsx +191 -0
  253. package/src/components/QwickApp.css +257 -0
  254. package/src/components/QwickApp.tsx +157 -0
  255. package/src/components/QwickAppsLogo.tsx +77 -0
  256. package/src/components/ResponsiveMenu.css +416 -0
  257. package/src/components/ResponsiveMenu.tsx +310 -0
  258. package/src/components/SafeSpan.tsx +128 -0
  259. package/src/components/Scaffold.css +541 -0
  260. package/src/components/Scaffold.tsx +463 -0
  261. package/src/components/__tests__/Article.test.tsx +419 -0
  262. package/src/components/__tests__/Button.test.tsx +702 -0
  263. package/src/components/__tests__/CardListGrid.test.tsx +478 -0
  264. package/src/components/__tests__/ChoiceInputField.test.tsx +864 -0
  265. package/src/components/__tests__/Code.test.tsx +595 -0
  266. package/src/components/__tests__/Content.integration.test.tsx +193 -0
  267. package/src/components/__tests__/Content.test.tsx +504 -0
  268. package/src/components/__tests__/CoverImageHeader.test.tsx +456 -0
  269. package/src/components/__tests__/FeatureCard.integration.test.tsx +384 -0
  270. package/src/components/__tests__/FeatureGrid.integration.test.tsx +364 -0
  271. package/src/components/__tests__/FeatureGrid.test.tsx +494 -0
  272. package/src/components/__tests__/Footer.test.tsx +544 -0
  273. package/src/components/__tests__/FormBlock.test.tsx +857 -0
  274. package/src/components/__tests__/HeroBlock.integration.test.tsx +272 -0
  275. package/src/components/__tests__/HeroBlock.test.tsx +463 -0
  276. package/src/components/__tests__/Html.test.tsx +174 -0
  277. package/src/components/__tests__/HtmlInputField.test.tsx +856 -0
  278. package/src/components/__tests__/Markdown.test.tsx +233 -0
  279. package/src/components/__tests__/PageBannerHeader.test.tsx +614 -0
  280. package/src/components/__tests__/PaletteSwitcher.test.tsx +864 -0
  281. package/src/components/__tests__/ProductCard.test.tsx +377 -0
  282. package/src/components/__tests__/SafeSpan.integration.test.tsx +123 -0
  283. package/src/components/__tests__/SafeSpan.simple.test.tsx +65 -0
  284. package/src/components/__tests__/SafeSpan.test.tsx +388 -0
  285. package/src/components/__tests__/Section.integration.test.tsx +288 -0
  286. package/src/components/__tests__/Section.test.tsx +494 -0
  287. package/src/components/__tests__/SelectInputField.test.tsx +886 -0
  288. package/src/components/__tests__/TextInputField.test.tsx +749 -0
  289. package/src/components/__tests__/ThemeSwitcher.test.tsx +777 -0
  290. package/src/components/blocks/Article.tsx +194 -0
  291. package/src/components/blocks/CardListGrid.tsx +132 -0
  292. package/src/components/blocks/Code.tsx +313 -0
  293. package/src/components/blocks/Content.tsx +265 -0
  294. package/src/components/blocks/CoverImageHeader.css +17 -0
  295. package/src/components/blocks/CoverImageHeader.tsx +435 -0
  296. package/src/components/blocks/FeatureCard.tsx +321 -0
  297. package/src/components/blocks/FeatureGrid.tsx +147 -0
  298. package/src/components/blocks/Footer.tsx +343 -0
  299. package/src/components/blocks/HeroBlock.tsx +280 -0
  300. package/src/components/blocks/PageBannerHeader.tsx +471 -0
  301. package/src/components/blocks/ProductCard.tsx +472 -0
  302. package/src/components/blocks/Section.tsx +209 -0
  303. package/src/components/blocks/index.ts +37 -0
  304. package/src/components/buttons/Button.tsx +233 -0
  305. package/src/components/buttons/PaletteSwitcher.tsx +268 -0
  306. package/src/components/buttons/ThemeSwitcher.tsx +283 -0
  307. package/src/components/buttons/index.ts +11 -0
  308. package/src/components/forms/FormBlock.tsx +291 -0
  309. package/src/components/forms/index.ts +7 -0
  310. package/src/components/index.ts +37 -0
  311. package/src/components/input/ChoiceInputField.tsx +188 -0
  312. package/src/components/input/HtmlInputField.tsx +326 -0
  313. package/src/components/input/SelectInputField.tsx +197 -0
  314. package/src/components/input/TextField.tsx +47 -0
  315. package/src/components/input/TextInputField.tsx +144 -0
  316. package/src/components/input/index.ts +17 -0
  317. package/src/components/layout/GridCell.tsx +46 -0
  318. package/src/components/layout/GridCellWrapper.tsx +87 -0
  319. package/src/components/layout/GridLayout.tsx +169 -0
  320. package/src/components/layout/index.ts +13 -0
  321. package/src/components/menu/Menu.tsx +0 -0
  322. package/src/components/menu/MenuItem.tsx +32 -0
  323. package/src/components/menu/index.ts +6 -0
  324. package/src/components/pages/FormPage.tsx +108 -0
  325. package/src/components/pages/Page.css +460 -0
  326. package/src/components/pages/Page.tsx +345 -0
  327. package/src/components/pages/index.ts +11 -0
  328. package/src/contexts/DataContext.tsx +355 -0
  329. package/src/contexts/DimensionsContext.tsx +154 -0
  330. package/src/contexts/PaletteContext.tsx +217 -0
  331. package/src/contexts/QwickAppContext.tsx +95 -0
  332. package/src/contexts/ThemeContext.tsx +376 -0
  333. package/src/contexts/index.ts +9 -0
  334. package/src/hooks/__tests__/useDataBinding.test.tsx.disabled +229 -0
  335. package/src/hooks/index.ts +11 -0
  336. package/src/hooks/useBaseProps.ts +267 -0
  337. package/src/hooks/useDataBinding.ts +77 -0
  338. package/src/index.ts +23 -0
  339. package/src/palettes/PaletteAutumn.css +172 -0
  340. package/src/palettes/PaletteAutumn.ts +16 -0
  341. package/src/palettes/PaletteCosmic.css +172 -0
  342. package/src/palettes/PaletteCosmic.ts +16 -0
  343. package/src/palettes/PaletteDefault.css +178 -0
  344. package/src/palettes/PaletteDefault.ts +17 -0
  345. package/src/palettes/PaletteOcean.css +172 -0
  346. package/src/palettes/PaletteOcean.ts +16 -0
  347. package/src/palettes/PaletteSpring.css +160 -0
  348. package/src/palettes/PaletteSpring.ts +16 -0
  349. package/src/palettes/PaletteWinter.css +172 -0
  350. package/src/palettes/PaletteWinter.ts +16 -0
  351. package/src/palettes/index.css +12 -0
  352. package/src/palettes/index.ts +29 -0
  353. package/src/schemas/ActionSchema.ts +140 -0
  354. package/src/schemas/ArticleSchema.ts +35 -0
  355. package/src/schemas/ButtonSchema.ts +99 -0
  356. package/src/schemas/CardListGridSchema.ts +102 -0
  357. package/src/schemas/ChoiceInputFieldSchema.ts +89 -0
  358. package/src/schemas/CodeSchema.ts +88 -0
  359. package/src/schemas/ContentSchema.ts +128 -0
  360. package/src/schemas/CoverImageHeaderSchema.ts +208 -0
  361. package/src/schemas/FeatureCardSchema.ts +161 -0
  362. package/src/schemas/FeatureGridSchema.ts +87 -0
  363. package/src/schemas/FeatureItemSchema.ts +68 -0
  364. package/src/schemas/FooterItemSchema.ts +57 -0
  365. package/src/schemas/FooterSchema.ts +116 -0
  366. package/src/schemas/FooterSectionSchema.ts +50 -0
  367. package/src/schemas/FormBlockSchema.ts +102 -0
  368. package/src/schemas/HeaderActionSchema.ts +83 -0
  369. package/src/schemas/HeroBlockSchema.ts +149 -0
  370. package/src/schemas/HtmlInputFieldSchema.ts +88 -0
  371. package/src/schemas/MetadataItemSchema.ts +35 -0
  372. package/src/schemas/PageBannerHeaderSchema.ts +206 -0
  373. package/src/schemas/PaletteSwitcherSchema.ts +66 -0
  374. package/src/schemas/ProductCardSchema.ts +264 -0
  375. package/src/schemas/SafeSpanSchema.ts +36 -0
  376. package/src/schemas/SectionSchema.ts +106 -0
  377. package/src/schemas/SelectInputFieldSchema.ts +137 -0
  378. package/src/schemas/TextInputFieldSchema.ts +129 -0
  379. package/src/schemas/ThemeSwitcherSchema.ts +97 -0
  380. package/src/schemas/__tests__/builders.test.ts +313 -0
  381. package/src/schemas/index.ts +34 -0
  382. package/src/setupTests.js +60 -0
  383. package/src/stories/Article.stories.tsx +549 -0
  384. package/src/stories/Button.stories.tsx +498 -0
  385. package/src/stories/CardListGrid.stories.tsx +539 -0
  386. package/src/stories/ChoiceInputField.stories.tsx +591 -0
  387. package/src/stories/Code.stories.tsx +711 -0
  388. package/src/stories/Content.stories.tsx +463 -0
  389. package/src/stories/CoverImageHeader.stories.tsx +794 -0
  390. package/src/stories/DataBinding.advanced.stories.tsx +548 -0
  391. package/src/stories/DataBinding.stories.tsx +452 -0
  392. package/src/stories/DataProvider.stories.tsx +1361 -0
  393. package/src/stories/FeatureCard.stories.tsx +642 -0
  394. package/src/stories/FeatureGrid.stories.tsx +669 -0
  395. package/src/stories/Footer.stories.tsx +724 -0
  396. package/src/stories/FormBlock.stories.tsx +834 -0
  397. package/src/stories/HeroBlock.stories.tsx +442 -0
  398. package/src/stories/Html.stories.tsx +264 -0
  399. package/src/stories/HtmlInputField.stories.tsx +558 -0
  400. package/src/stories/Introduction.stories.tsx +721 -0
  401. package/src/stories/LayoutBlocks.stories.tsx +382 -0
  402. package/src/stories/LayoutSystem.stories.tsx +253 -0
  403. package/src/stories/Logo.stories.tsx +400 -0
  404. package/src/stories/Markdown.stories.tsx +349 -0
  405. package/src/stories/Page.stories.tsx +762 -0
  406. package/src/stories/PageBannerHeader.stories.tsx +949 -0
  407. package/src/stories/PaletteSwitcher.stories.tsx +156 -0
  408. package/src/stories/ProductCard.stories.tsx +504 -0
  409. package/src/stories/QwickApp.stories.tsx +461 -0
  410. package/src/stories/ResponsiveMenu.stories.tsx +299 -0
  411. package/src/stories/SafeSpan.stories.tsx +612 -0
  412. package/src/stories/Section.stories.tsx +613 -0
  413. package/src/stories/SelectInputField.stories.tsx +605 -0
  414. package/src/stories/TextInputField.stories.tsx +526 -0
  415. package/src/stories/ThemeSwitcher.stories.tsx +170 -0
  416. package/src/stories/form/FormComponents.stories.tsx +588 -0
  417. package/src/templates/TemplateResolver.ts +156 -0
  418. package/src/templates/index.ts +6 -0
  419. package/src/tests/ConsoleWarningTest.tsx +30 -0
  420. package/src/tests/StorageKeyTest.tsx +110 -0
  421. package/src/tests/ThemeStorageKeyTest.tsx +114 -0
  422. package/src/types/CacheProvider.ts +14 -0
  423. package/src/types/ContentProxy.ts +99 -0
  424. package/src/types/DataTypes.ts +196 -0
  425. package/src/types/TemplateProvider.ts +9 -0
  426. package/src/types/TemplateResolver.ts +26 -0
  427. package/src/types/index.ts +99 -0
  428. package/src/utils/__tests__/createDataDrivenComponent.test.tsx.disabled +193 -0
  429. package/src/utils/__tests__/htmlTransform.test.tsx +255 -0
  430. package/src/utils/breakpoints.ts +87 -0
  431. package/src/utils/customPaletteManager.js +214 -0
  432. package/src/utils/dimensions.ts +147 -0
  433. package/src/utils/htmlTransform.tsx +323 -0
  434. package/src/utils/index.ts +16 -0
  435. package/src/utils/logger.ts +28 -0
  436. package/src/utils/paletteUtils.ts +78 -0
  437. package/src/utils/persistenceUtils.ts +107 -0
  438. package/src/utils/reactUtils.tsx +37 -0
  439. package/src/utils/spacing.ts +155 -0
  440. package/src/utils/themePerformanceMonitor.js +113 -0
  441. package/src/utils/themeUtils.ts +67 -0
@@ -0,0 +1,97 @@
1
+ /**
2
+ * Schema for ThemeSwitcher component - Theme selection control
3
+ *
4
+ * Copyright (c) 2025 QwickApps.com. All rights reserved.
5
+ */
6
+
7
+ import { IsBoolean, IsOptional, IsString, IsIn } from 'class-validator';
8
+ import 'reflect-metadata';
9
+ import { Editor, Field, Schema, Model, FieldType } from '@qwickapps/schema';
10
+
11
+ @Schema('ThemeSwitcher', '1.0.0')
12
+ export class ThemeSwitcherModel extends Model {
13
+ @Field({ defaultValue: false })
14
+ @Editor({
15
+ field_type: FieldType.BOOLEAN,
16
+ label: 'Disabled',
17
+ description: 'Disable the theme switcher button'
18
+ })
19
+ @IsOptional()
20
+ @IsBoolean()
21
+ disabled?: boolean;
22
+
23
+ @Field({ defaultValue: 'medium' })
24
+ @Editor({
25
+ field_type: FieldType.SELECT,
26
+ label: 'Button Size',
27
+ description: 'Size of the theme switcher button'
28
+ })
29
+ @IsOptional()
30
+ @IsString()
31
+ @IsIn(['small', 'medium', 'large'])
32
+ size?: 'small' | 'medium' | 'large';
33
+
34
+ @Field()
35
+ @Editor({
36
+ field_type: FieldType.TEXT,
37
+ label: 'Custom Tooltip',
38
+ description: 'Custom tooltip text override',
39
+ placeholder: 'Current theme: Light'
40
+ })
41
+ @IsOptional()
42
+ @IsString()
43
+ tooltipText?: string;
44
+
45
+ @Field({ defaultValue: true })
46
+ @Editor({
47
+ field_type: FieldType.BOOLEAN,
48
+ label: 'Show Tooltip',
49
+ description: 'Show tooltip on hover'
50
+ })
51
+ @IsOptional()
52
+ @IsBoolean()
53
+ showTooltip?: boolean;
54
+
55
+ @Field({ defaultValue: 'bottom' })
56
+ @Editor({
57
+ field_type: FieldType.SELECT,
58
+ label: 'Menu Position',
59
+ description: 'Position of the theme selection menu'
60
+ })
61
+ @IsOptional()
62
+ @IsString()
63
+ @IsIn(['bottom', 'top', 'left', 'right'])
64
+ menuPosition?: 'bottom' | 'top' | 'left' | 'right';
65
+
66
+ @Field({ defaultValue: true })
67
+ @Editor({
68
+ field_type: FieldType.BOOLEAN,
69
+ label: 'Show Light Theme',
70
+ description: 'Show light theme option in menu'
71
+ })
72
+ @IsOptional()
73
+ @IsBoolean()
74
+ showLightTheme?: boolean;
75
+
76
+ @Field({ defaultValue: true })
77
+ @Editor({
78
+ field_type: FieldType.BOOLEAN,
79
+ label: 'Show Dark Theme',
80
+ description: 'Show dark theme option in menu'
81
+ })
82
+ @IsOptional()
83
+ @IsBoolean()
84
+ showDarkTheme?: boolean;
85
+
86
+ @Field({ defaultValue: true })
87
+ @Editor({
88
+ field_type: FieldType.BOOLEAN,
89
+ label: 'Show System Theme',
90
+ description: 'Show system theme option in menu'
91
+ })
92
+ @IsOptional()
93
+ @IsBoolean()
94
+ showSystemTheme?: boolean;
95
+ }
96
+
97
+ export default ThemeSwitcherModel;
@@ -0,0 +1,313 @@
1
+ /**
2
+ * Unit tests for Schema Builders
3
+ *
4
+ * Tests the fluent API schema builder system to ensure correct
5
+ * schema generation and validation.
6
+ */
7
+
8
+ // import { createSchema, FieldBuilder, ModelBuilder, SchemaBuilder } from '../builders';
9
+ // import { DataType, FieldType } from '../types';
10
+
11
+ describe.skip('FieldBuilder', () => {
12
+ test('creates basic string field', () => {
13
+ const field = new FieldBuilder('testField')
14
+ .string()
15
+ .required()
16
+ .textEditor('Test Field', 'A test field')
17
+ .build();
18
+
19
+ expect(field).toEqual({
20
+ name: 'testField',
21
+ data_type: DataType.STRING,
22
+ required: true,
23
+ editor: {
24
+ field_type: FieldType.TEXT,
25
+ label: 'Test Field',
26
+ description: 'A test field'
27
+ }
28
+ });
29
+ });
30
+
31
+ test('creates number field with validation', () => {
32
+ const field = new FieldBuilder('age')
33
+ .numberEditor('integer', 'Age', 'Your age', 0, 150)
34
+ .required()
35
+ .build();
36
+
37
+ expect(field).toEqual({
38
+ name: 'age',
39
+ data_type: DataType.INTEGER,
40
+ required: true,
41
+ editor: {
42
+ field_type: FieldType.INTEGER,
43
+ label: 'Age',
44
+ description: 'Your age',
45
+ validation: { min: 0, max: 150 }
46
+ }
47
+ });
48
+ });
49
+
50
+ test('creates select field with options', () => {
51
+ const options = [
52
+ { label: 'Red', value: 'red' },
53
+ { label: 'Blue', value: 'blue' }
54
+ ];
55
+
56
+ const field = new FieldBuilder('color')
57
+ .selectSingleEditor(options, 'Color', 'Choose a color')
58
+ .optional()
59
+ .build();
60
+
61
+ expect(field).toEqual({
62
+ name: 'color',
63
+ data_type: DataType.STRING,
64
+ required: false,
65
+ editor: {
66
+ field_type: FieldType.SELECT,
67
+ label: 'Color',
68
+ description: 'Choose a color',
69
+ validation: { options }
70
+ }
71
+ });
72
+ });
73
+
74
+ test('creates object field with auto-inference', () => {
75
+ const field = new FieldBuilder('address')
76
+ .object('Address', 'Address Details', 'Your address information')
77
+ .required()
78
+ .build();
79
+
80
+ expect(field).toEqual({
81
+ name: 'address',
82
+ data_type: DataType.OBJECT,
83
+ required: true,
84
+ type: 'Address',
85
+ editor: {
86
+ field_type: FieldType.OBJECT_FORM,
87
+ label: 'Address Details',
88
+ description: 'Your address information'
89
+ }
90
+ });
91
+ });
92
+
93
+ test('creates array field with auto-inference', () => {
94
+ const field = new FieldBuilder('tags')
95
+ .array(DataType.STRING, 'Tags', 'List of tags')
96
+ .optional()
97
+ .build();
98
+
99
+ expect(field).toEqual({
100
+ name: 'tags',
101
+ data_type: DataType.ARRAY,
102
+ required: false,
103
+ type: DataType.STRING,
104
+ editor: {
105
+ field_type: FieldType.REPEATER,
106
+ label: 'Tags',
107
+ description: 'List of tags'
108
+ }
109
+ });
110
+ });
111
+
112
+ test('creates model array with model repeater', () => {
113
+ const field = new FieldBuilder('items')
114
+ .array('Item', 'Items', 'List of items')
115
+ .required()
116
+ .build();
117
+
118
+ expect(field).toEqual({
119
+ name: 'items',
120
+ data_type: DataType.ARRAY,
121
+ required: true,
122
+ type: 'Item',
123
+ editor: {
124
+ field_type: FieldType.MODEL_REPEATER,
125
+ label: 'Items',
126
+ description: 'List of items'
127
+ }
128
+ });
129
+ });
130
+
131
+ test('throws error when building without data type', () => {
132
+ const builder = new FieldBuilder('invalid');
133
+ expect(() => builder.build()).toThrow("Field 'invalid' must have a data type");
134
+ });
135
+ });
136
+
137
+ describe.skip('ModelBuilder', () => {
138
+ test('creates model with fields', () => {
139
+ const builder = new ModelBuilder('Address');
140
+
141
+ builder.field('street').textEditor('Street', 'Street address').required().build();
142
+ builder.field('city').textEditor('City', 'City name').required().build();
143
+ builder.field('zipCode').textEditor('Zip Code', 'Postal code').optional().build();
144
+
145
+ const model = builder.build();
146
+
147
+ expect(model.name).toBe('Address');
148
+ expect(model.fields).toHaveLength(3);
149
+ expect(model.fields[0].name).toBe('street');
150
+ expect(model.fields[1].name).toBe('city');
151
+ expect(model.fields[2].name).toBe('zipCode');
152
+ });
153
+
154
+ test('throws error when building without name', () => {
155
+ const builder = new (ModelBuilder as any)(undefined);
156
+ expect(() => builder.build()).toThrow('Component must have a name');
157
+ });
158
+ });
159
+
160
+ describe.skip('SchemaBuilder', () => {
161
+ test('creates complete schema with models and fields', () => {
162
+ const schema = createSchema('UserForm', '1.0.0')
163
+ .uses(['AddressSchema.ts'])
164
+ .model('Address', builder => {
165
+ builder.field('street').textEditor('Street').required();
166
+ builder.field('city').textEditor('City').required();
167
+ })
168
+ .field('name').textEditor('Full Name', 'Your full name').required()
169
+ .field('email').emailEditor('Email', 'Your email address').required()
170
+ .field('address').object('Address', 'Address', 'Your address').optional()
171
+ .build();
172
+
173
+ expect(schema).toEqual({
174
+ name: 'UserForm',
175
+ version: '1.0.0',
176
+ uses: ['AddressSchema.ts'],
177
+ models: {
178
+ Address: {
179
+ name: 'Address',
180
+ fields: [
181
+ {
182
+ name: 'street',
183
+ data_type: DataType.STRING,
184
+ required: true,
185
+ editor: {
186
+ field_type: FieldType.TEXT,
187
+ label: 'Street',
188
+ description: ''
189
+ }
190
+ },
191
+ {
192
+ name: 'city',
193
+ data_type: DataType.STRING,
194
+ required: true,
195
+ editor: {
196
+ field_type: FieldType.TEXT,
197
+ label: 'City',
198
+ description: ''
199
+ }
200
+ }
201
+ ]
202
+ }
203
+ },
204
+ fields: [
205
+ {
206
+ name: 'name',
207
+ data_type: DataType.STRING,
208
+ required: true,
209
+ editor: {
210
+ field_type: FieldType.TEXT,
211
+ label: 'Full Name',
212
+ description: 'Your full name'
213
+ }
214
+ },
215
+ {
216
+ name: 'email',
217
+ data_type: DataType.STRING,
218
+ required: true,
219
+ editor: {
220
+ field_type: FieldType.EMAIL,
221
+ label: 'Email',
222
+ description: 'Your email address'
223
+ }
224
+ },
225
+ {
226
+ name: 'address',
227
+ data_type: DataType.OBJECT,
228
+ required: false,
229
+ type: 'Address',
230
+ editor: {
231
+ field_type: FieldType.OBJECT_FORM,
232
+ label: 'Address',
233
+ description: 'Your address'
234
+ }
235
+ }
236
+ ]
237
+ });
238
+ });
239
+
240
+ test('creates minimal schema', () => {
241
+ const schema = createSchema('Simple')
242
+ .field('title').textEditor('Title').required()
243
+ .build();
244
+
245
+ expect(schema.name).toBe('Simple');
246
+ expect(schema.version).toBe('1.0.0'); // default
247
+ expect(schema.fields).toHaveLength(1);
248
+ expect(schema.models).toEqual({});
249
+ });
250
+
251
+ test('throws error when building without name', () => {
252
+ const builder = new (SchemaBuilder as any)(undefined);
253
+ expect(() => builder.build()).toThrow('Schema must have a name');
254
+ });
255
+ });
256
+
257
+ describe.skip('Integration Tests', () => {
258
+ test('creates complex FeatureCard-like schema', () => {
259
+ const schema = createSchema('FeatureCard', '2.0.0')
260
+ .model('Feature', builder => {
261
+ builder.field('id').textEditor('Feature ID').required();
262
+ builder.field('title').textEditor('Title', 'Feature title').required();
263
+ builder.field('description').textAreaEditor('Description', 'Feature description').optional();
264
+ builder.field('icon').textEditor('Icon', 'Icon identifier').optional();
265
+ })
266
+ .model('Action', builder => {
267
+ builder.field('id').textEditor('Action ID').required();
268
+ builder.field('label').textEditor('Label').required();
269
+ builder.field('variant').selectSingleEditor([
270
+ { label: 'Contained', value: 'contained' },
271
+ { label: 'Outlined', value: 'outlined' }
272
+ ], 'Style').optional();
273
+ })
274
+ .field('feature').object('Feature', 'Feature Data').optional()
275
+ .field('features').array(DataType.STRING, 'Features List').optional()
276
+ .field('actions').array('Action', 'Actions').optional()
277
+ .field('variant').selectSingleEditor([
278
+ { label: 'Standard', value: 'standard' },
279
+ { label: 'List', value: 'list' }
280
+ ], 'Card Type').optional()
281
+ .field('elevation').numberEditor('integer', 'Elevation', 'Card elevation (0-24)', 0, 24).optional()
282
+ .build();
283
+
284
+ // Verify schema structure
285
+ expect(schema.name).toBe('FeatureCard');
286
+ expect(schema.version).toBe('2.0.0');
287
+ expect(Object.keys(schema.models || {})).toEqual(['Feature', 'Action']);
288
+ expect(schema.fields).toHaveLength(5);
289
+
290
+ // Verify Feature model
291
+ const featureComponent = schema.models!.Feature;
292
+ expect(featureComponent.fields).toHaveLength(4);
293
+ expect(featureComponent.fields.find(f => f.name === 'title')?.required).toBe(true);
294
+
295
+ // Verify Action model
296
+ const actionComponent = schema.models!.Action;
297
+ expect(actionComponent.fields).toHaveLength(3);
298
+
299
+ // Verify main fields
300
+ const featureField = schema.fields.find(f => f.name === 'feature');
301
+ expect(featureField?.data_type).toBe(DataType.OBJECT);
302
+ expect(featureField?.type).toBe('Feature');
303
+
304
+ const actionsField = schema.fields.find(f => f.name === 'actions');
305
+ expect(actionsField?.data_type).toBe(DataType.ARRAY);
306
+ expect(actionsField?.type).toBe('Action');
307
+
308
+ const elevationField = schema.fields.find(f => f.name === 'elevation');
309
+ expect(elevationField?.data_type).toBe(DataType.INTEGER);
310
+ expect(elevationField?.editor?.validation?.min).toBe(0);
311
+ expect(elevationField?.editor?.validation?.max).toBe(24);
312
+ });
313
+ });
@@ -0,0 +1,34 @@
1
+ /**
2
+ * Schemas Module - Declarative Model schema definitions
3
+ *
4
+ * Exports all Model classes and their type-safe props using the new
5
+ * declarative pattern with @Schema, @Field, and @Editor decorators.
6
+ *
7
+ * Copyright (c) 2025 QwickApps.com. All rights reserved.
8
+ */
9
+
10
+ // Component schema models (declarative pattern)
11
+ export * from './ActionSchema';
12
+ export * from './ArticleSchema';
13
+ export * from './CardListGridSchema';
14
+ export * from './ChoiceInputFieldSchema';
15
+ export * from './CodeSchema';
16
+ export * from './ContentSchema';
17
+ export * from './CoverImageHeaderSchema';
18
+ export * from './FeatureCardSchema';
19
+ export * from './FeatureGridSchema';
20
+ export * from './FeatureItemSchema';
21
+ export * from './FooterItemSchema';
22
+ export * from './FormBlockSchema';
23
+ export * from './FooterSchema';
24
+ export * from './FooterSectionSchema';
25
+ export * from './HeaderActionSchema';
26
+ export * from './HeroBlockSchema';
27
+ export * from './MetadataItemSchema';
28
+ export * from './PageBannerHeaderSchema';
29
+ export * from './PaletteSwitcherSchema';
30
+ export * from './ProductCardSchema';
31
+ export * from './SafeSpanSchema';
32
+ export * from './SectionSchema';
33
+ export * from './TextInputFieldSchema';
34
+ export * from './ThemeSwitcherSchema';
@@ -0,0 +1,60 @@
1
+ // Jest setup for QwickApps Theme System tests
2
+ import '@testing-library/jest-dom';
3
+
4
+ // Mock CSS imports for components
5
+ jest.mock('./components/QwickApp.css', () => ({}));
6
+ jest.mock('./components/Logo.css', () => ({}));
7
+ jest.mock('../theme/palettes/index.css', () => ({}));
8
+
9
+ // Mock window.matchMedia for system theme detection
10
+ const matchMediaMock = jest.fn().mockImplementation(query => ({
11
+ matches: false,
12
+ media: query,
13
+ onchange: null,
14
+ addListener: jest.fn(), // deprecated
15
+ removeListener: jest.fn(), // deprecated
16
+ addEventListener: jest.fn(),
17
+ removeEventListener: jest.fn(),
18
+ dispatchEvent: jest.fn(),
19
+ }));
20
+
21
+ Object.defineProperty(window, 'matchMedia', {
22
+ writable: true,
23
+ value: matchMediaMock,
24
+ });
25
+
26
+ // Mock localStorage with proper Jest spies
27
+ Object.defineProperty(window, 'localStorage', {
28
+ value: {
29
+ getItem: jest.fn(),
30
+ setItem: jest.fn(),
31
+ removeItem: jest.fn(),
32
+ clear: jest.fn(),
33
+ },
34
+ writable: true,
35
+ });
36
+
37
+ // Mock document.documentElement for CSS variable testing
38
+ Object.defineProperty(document, 'documentElement', {
39
+ writable: true,
40
+ value: {
41
+ setAttribute: jest.fn(),
42
+ getAttribute: jest.fn(),
43
+ style: {
44
+ setProperty: jest.fn(),
45
+ },
46
+ },
47
+ });
48
+
49
+ // Mock getComputedStyle
50
+ global.getComputedStyle = jest.fn(() => ({
51
+ getPropertyValue: jest.fn(() => '#000000'),
52
+ }));
53
+
54
+ // Mock SVG getBBox method for Logo component tests
55
+ Element.prototype.getBBox = jest.fn(() => ({
56
+ x: 0,
57
+ y: 0,
58
+ width: 100,
59
+ height: 20
60
+ }));