@platformos/platformos-check-common 0.0.2

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 (708) hide show
  1. package/CHANGELOG.md +9 -0
  2. package/README.md +92 -0
  3. package/dist/AugmentedThemeDocset.d.ts +12 -0
  4. package/dist/AugmentedThemeDocset.js +126 -0
  5. package/dist/AugmentedThemeDocset.js.map +1 -0
  6. package/dist/JSONValidator.d.ts +20 -0
  7. package/dist/JSONValidator.js +76 -0
  8. package/dist/JSONValidator.js.map +1 -0
  9. package/dist/checks/app-block-missing-schema/index.d.ts +2 -0
  10. package/dist/checks/app-block-missing-schema/index.js +46 -0
  11. package/dist/checks/app-block-missing-schema/index.js.map +1 -0
  12. package/dist/checks/app-block-valid-tags/index.d.ts +10 -0
  13. package/dist/checks/app-block-valid-tags/index.js +49 -0
  14. package/dist/checks/app-block-valid-tags/index.js.map +1 -0
  15. package/dist/checks/asset-preload/index.d.ts +2 -0
  16. package/dist/checks/asset-preload/index.js +56 -0
  17. package/dist/checks/asset-preload/index.js.map +1 -0
  18. package/dist/checks/asset-size-app-block-css/index.d.ts +6 -0
  19. package/dist/checks/asset-size-app-block-css/index.js +64 -0
  20. package/dist/checks/asset-size-app-block-css/index.js.map +1 -0
  21. package/dist/checks/asset-size-app-block-javascript/index.d.ts +6 -0
  22. package/dist/checks/asset-size-app-block-javascript/index.js +64 -0
  23. package/dist/checks/asset-size-app-block-javascript/index.js.map +1 -0
  24. package/dist/checks/asset-size-css/index.d.ts +6 -0
  25. package/dist/checks/asset-size-css/index.js +125 -0
  26. package/dist/checks/asset-size-css/index.js.map +1 -0
  27. package/dist/checks/asset-size-javascript/index.d.ts +6 -0
  28. package/dist/checks/asset-size-javascript/index.js +110 -0
  29. package/dist/checks/asset-size-javascript/index.js.map +1 -0
  30. package/dist/checks/block-id-usage/index.d.ts +2 -0
  31. package/dist/checks/block-id-usage/index.js +60 -0
  32. package/dist/checks/block-id-usage/index.js.map +1 -0
  33. package/dist/checks/cdn-preconnect/index.d.ts +2 -0
  34. package/dist/checks/cdn-preconnect/index.js +44 -0
  35. package/dist/checks/cdn-preconnect/index.js.map +1 -0
  36. package/dist/checks/content-for-header-modification/index.d.ts +2 -0
  37. package/dist/checks/content-for-header-modification/index.js +66 -0
  38. package/dist/checks/content-for-header-modification/index.js.map +1 -0
  39. package/dist/checks/deprecate-bgsizes/index.d.ts +2 -0
  40. package/dist/checks/deprecate-bgsizes/index.js +46 -0
  41. package/dist/checks/deprecate-bgsizes/index.js.map +1 -0
  42. package/dist/checks/deprecate-lazysizes/index.d.ts +2 -0
  43. package/dist/checks/deprecate-lazysizes/index.js +52 -0
  44. package/dist/checks/deprecate-lazysizes/index.js.map +1 -0
  45. package/dist/checks/deprecated-filter/fixes.d.ts +8 -0
  46. package/dist/checks/deprecated-filter/fixes.js +205 -0
  47. package/dist/checks/deprecated-filter/fixes.js.map +1 -0
  48. package/dist/checks/deprecated-filter/index.d.ts +2 -0
  49. package/dist/checks/deprecated-filter/index.js +93 -0
  50. package/dist/checks/deprecated-filter/index.js.map +1 -0
  51. package/dist/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.d.ts +1 -0
  52. package/dist/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.js +1347 -0
  53. package/dist/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.js.map +1 -0
  54. package/dist/checks/deprecated-fonts-on-sections-and-blocks/index.d.ts +2 -0
  55. package/dist/checks/deprecated-fonts-on-sections-and-blocks/index.js +156 -0
  56. package/dist/checks/deprecated-fonts-on-sections-and-blocks/index.js.map +1 -0
  57. package/dist/checks/deprecated-fonts-on-settings-schema/index.d.ts +2 -0
  58. package/dist/checks/deprecated-fonts-on-settings-schema/index.js +56 -0
  59. package/dist/checks/deprecated-fonts-on-settings-schema/index.js.map +1 -0
  60. package/dist/checks/deprecated-tag/index.d.ts +2 -0
  61. package/dist/checks/deprecated-tag/index.js +48 -0
  62. package/dist/checks/deprecated-tag/index.js.map +1 -0
  63. package/dist/checks/duplicate-content-for-arguments/index.d.ts +2 -0
  64. package/dist/checks/duplicate-content-for-arguments/index.js +39 -0
  65. package/dist/checks/duplicate-content-for-arguments/index.js.map +1 -0
  66. package/dist/checks/duplicate-function-arguments/index.d.ts +2 -0
  67. package/dist/checks/duplicate-function-arguments/index.js +40 -0
  68. package/dist/checks/duplicate-function-arguments/index.js.map +1 -0
  69. package/dist/checks/duplicate-render-partial-arguments/index.d.ts +2 -0
  70. package/dist/checks/duplicate-render-partial-arguments/index.js +43 -0
  71. package/dist/checks/duplicate-render-partial-arguments/index.js.map +1 -0
  72. package/dist/checks/empty-block-content/index.d.ts +2 -0
  73. package/dist/checks/empty-block-content/index.js +60 -0
  74. package/dist/checks/empty-block-content/index.js.map +1 -0
  75. package/dist/checks/graphql/index.d.ts +2 -0
  76. package/dist/checks/graphql/index.js +58 -0
  77. package/dist/checks/graphql/index.js.map +1 -0
  78. package/dist/checks/graphql-variables/index.d.ts +8 -0
  79. package/dist/checks/graphql-variables/index.js +91 -0
  80. package/dist/checks/graphql-variables/index.js.map +1 -0
  81. package/dist/checks/hardcoded-routes/index.d.ts +2 -0
  82. package/dist/checks/hardcoded-routes/index.js +89 -0
  83. package/dist/checks/hardcoded-routes/index.js.map +1 -0
  84. package/dist/checks/img-width-and-height/index.d.ts +2 -0
  85. package/dist/checks/img-width-and-height/index.js +46 -0
  86. package/dist/checks/img-width-and-height/index.js.map +1 -0
  87. package/dist/checks/index.d.ts +8 -0
  88. package/dist/checks/index.js +154 -0
  89. package/dist/checks/index.js.map +1 -0
  90. package/dist/checks/invalid-hash-assign-target/index.d.ts +2 -0
  91. package/dist/checks/invalid-hash-assign-target/index.js +252 -0
  92. package/dist/checks/invalid-hash-assign-target/index.js.map +1 -0
  93. package/dist/checks/json-missing-block/index.d.ts +2 -0
  94. package/dist/checks/json-missing-block/index.js +48 -0
  95. package/dist/checks/json-missing-block/index.js.map +1 -0
  96. package/dist/checks/json-missing-block/missing-block-utils.d.ts +4 -0
  97. package/dist/checks/json-missing-block/missing-block-utils.js +87 -0
  98. package/dist/checks/json-missing-block/missing-block-utils.js.map +1 -0
  99. package/dist/checks/json-syntax-error/index.d.ts +2 -0
  100. package/dist/checks/json-syntax-error/index.js +92 -0
  101. package/dist/checks/json-syntax-error/index.js.map +1 -0
  102. package/dist/checks/liquid-free-settings/index.d.ts +2 -0
  103. package/dist/checks/liquid-free-settings/index.js +64 -0
  104. package/dist/checks/liquid-free-settings/index.js.map +1 -0
  105. package/dist/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.d.ts +3 -0
  106. package/dist/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.js +23 -0
  107. package/dist/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.js.map +1 -0
  108. package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.d.ts +3 -0
  109. package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.js +136 -0
  110. package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.js.map +1 -0
  111. package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.d.ts +3 -0
  112. package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.js +26 -0
  113. package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.js.map +1 -0
  114. package/dist/checks/liquid-html-syntax-error/checks/InvalidEchoValue.d.ts +3 -0
  115. package/dist/checks/liquid-html-syntax-error/checks/InvalidEchoValue.js +59 -0
  116. package/dist/checks/liquid-html-syntax-error/checks/InvalidEchoValue.js.map +1 -0
  117. package/dist/checks/liquid-html-syntax-error/checks/InvalidFilterName.d.ts +3 -0
  118. package/dist/checks/liquid-html-syntax-error/checks/InvalidFilterName.js +66 -0
  119. package/dist/checks/liquid-html-syntax-error/checks/InvalidFilterName.js.map +1 -0
  120. package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.d.ts +3 -0
  121. package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.js +73 -0
  122. package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.js.map +1 -0
  123. package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopRange.d.ts +4 -0
  124. package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopRange.js +54 -0
  125. package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopRange.js.map +1 -0
  126. package/dist/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.d.ts +3 -0
  127. package/dist/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.js +71 -0
  128. package/dist/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.js.map +1 -0
  129. package/dist/checks/liquid-html-syntax-error/checks/MultipleAssignValues.d.ts +3 -0
  130. package/dist/checks/liquid-html-syntax-error/checks/MultipleAssignValues.js +69 -0
  131. package/dist/checks/liquid-html-syntax-error/checks/MultipleAssignValues.js.map +1 -0
  132. package/dist/checks/liquid-html-syntax-error/checks/utils.d.ts +15 -0
  133. package/dist/checks/liquid-html-syntax-error/checks/utils.js +58 -0
  134. package/dist/checks/liquid-html-syntax-error/checks/utils.js.map +1 -0
  135. package/dist/checks/liquid-html-syntax-error/index.d.ts +2 -0
  136. package/dist/checks/liquid-html-syntax-error/index.js +131 -0
  137. package/dist/checks/liquid-html-syntax-error/index.js.map +1 -0
  138. package/dist/checks/matching-translations/index.d.ts +2 -0
  139. package/dist/checks/matching-translations/index.js +146 -0
  140. package/dist/checks/matching-translations/index.js.map +1 -0
  141. package/dist/checks/metadata-params/index.d.ts +2 -0
  142. package/dist/checks/metadata-params/index.js +96 -0
  143. package/dist/checks/metadata-params/index.js.map +1 -0
  144. package/dist/checks/missing-asset/index.d.ts +2 -0
  145. package/dist/checks/missing-asset/index.js +44 -0
  146. package/dist/checks/missing-asset/index.js.map +1 -0
  147. package/dist/checks/missing-content-for-arguments/index.d.ts +2 -0
  148. package/dist/checks/missing-content-for-arguments/index.js +36 -0
  149. package/dist/checks/missing-content-for-arguments/index.js.map +1 -0
  150. package/dist/checks/missing-template/index.d.ts +6 -0
  151. package/dist/checks/missing-template/index.js +70 -0
  152. package/dist/checks/missing-template/index.js.map +1 -0
  153. package/dist/checks/orphaned-partial/index.d.ts +2 -0
  154. package/dist/checks/orphaned-partial/index.js +42 -0
  155. package/dist/checks/orphaned-partial/index.js.map +1 -0
  156. package/dist/checks/pagination-size/index.d.ts +7 -0
  157. package/dist/checks/pagination-size/index.js +89 -0
  158. package/dist/checks/pagination-size/index.js.map +1 -0
  159. package/dist/checks/parser-blocking-script/index.d.ts +2 -0
  160. package/dist/checks/parser-blocking-script/index.js +81 -0
  161. package/dist/checks/parser-blocking-script/index.js.map +1 -0
  162. package/dist/checks/parser-blocking-script/suggestions.d.ts +4 -0
  163. package/dist/checks/parser-blocking-script/suggestions.js +22 -0
  164. package/dist/checks/parser-blocking-script/suggestions.js.map +1 -0
  165. package/dist/checks/remote-asset/index.d.ts +6 -0
  166. package/dist/checks/remote-asset/index.js +189 -0
  167. package/dist/checks/remote-asset/index.js.map +1 -0
  168. package/dist/checks/reserved-doc-param-names/index.d.ts +2 -0
  169. package/dist/checks/reserved-doc-param-names/index.js +46 -0
  170. package/dist/checks/reserved-doc-param-names/index.js.map +1 -0
  171. package/dist/checks/schema-presets-block-order/index.d.ts +2 -0
  172. package/dist/checks/schema-presets-block-order/index.js +108 -0
  173. package/dist/checks/schema-presets-block-order/index.js.map +1 -0
  174. package/dist/checks/schema-presets-static-blocks/index.d.ts +2 -0
  175. package/dist/checks/schema-presets-static-blocks/index.js +109 -0
  176. package/dist/checks/schema-presets-static-blocks/index.js.map +1 -0
  177. package/dist/checks/static-stylesheet-and-javascript-tags/index.d.ts +2 -0
  178. package/dist/checks/static-stylesheet-and-javascript-tags/index.js +42 -0
  179. package/dist/checks/static-stylesheet-and-javascript-tags/index.js.map +1 -0
  180. package/dist/checks/translation-key-exists/index.d.ts +2 -0
  181. package/dist/checks/translation-key-exists/index.js +67 -0
  182. package/dist/checks/translation-key-exists/index.js.map +1 -0
  183. package/dist/checks/unclosed-html-element/index.d.ts +2 -0
  184. package/dist/checks/unclosed-html-element/index.js +252 -0
  185. package/dist/checks/unclosed-html-element/index.js.map +1 -0
  186. package/dist/checks/undefined-object/index.d.ts +2 -0
  187. package/dist/checks/undefined-object/index.js +255 -0
  188. package/dist/checks/undefined-object/index.js.map +1 -0
  189. package/dist/checks/unique-doc-param-names/index.d.ts +2 -0
  190. package/dist/checks/unique-doc-param-names/index.js +37 -0
  191. package/dist/checks/unique-doc-param-names/index.js.map +1 -0
  192. package/dist/checks/unique-settings-id/index.d.ts +2 -0
  193. package/dist/checks/unique-settings-id/index.js +69 -0
  194. package/dist/checks/unique-settings-id/index.js.map +1 -0
  195. package/dist/checks/unique-settings-id/test-data.d.ts +2 -0
  196. package/dist/checks/unique-settings-id/test-data.js +1194 -0
  197. package/dist/checks/unique-settings-id/test-data.js.map +1 -0
  198. package/dist/checks/unique-static-block-id/index.d.ts +2 -0
  199. package/dist/checks/unique-static-block-id/index.js +56 -0
  200. package/dist/checks/unique-static-block-id/index.js.map +1 -0
  201. package/dist/checks/unknown-filter/index.d.ts +2 -0
  202. package/dist/checks/unknown-filter/index.js +38 -0
  203. package/dist/checks/unknown-filter/index.js.map +1 -0
  204. package/dist/checks/unknown-property/index.d.ts +2 -0
  205. package/dist/checks/unknown-property/index.js +361 -0
  206. package/dist/checks/unknown-property/index.js.map +1 -0
  207. package/dist/checks/unknown-property/property-shape.d.ts +41 -0
  208. package/dist/checks/unknown-property/property-shape.js +267 -0
  209. package/dist/checks/unknown-property/property-shape.js.map +1 -0
  210. package/dist/checks/unrecognized-content-for-arguments/index.d.ts +2 -0
  211. package/dist/checks/unrecognized-content-for-arguments/index.js +43 -0
  212. package/dist/checks/unrecognized-content-for-arguments/index.js.map +1 -0
  213. package/dist/checks/unrecognized-render-partial-arguments/index.d.ts +2 -0
  214. package/dist/checks/unrecognized-render-partial-arguments/index.js +59 -0
  215. package/dist/checks/unrecognized-render-partial-arguments/index.js.map +1 -0
  216. package/dist/checks/unused-assign/index.d.ts +2 -0
  217. package/dist/checks/unused-assign/index.js +77 -0
  218. package/dist/checks/unused-assign/index.js.map +1 -0
  219. package/dist/checks/unused-doc-param/index.d.ts +2 -0
  220. package/dist/checks/unused-doc-param/index.js +55 -0
  221. package/dist/checks/unused-doc-param/index.js.map +1 -0
  222. package/dist/checks/utils.d.ts +22 -0
  223. package/dist/checks/utils.js +74 -0
  224. package/dist/checks/utils.js.map +1 -0
  225. package/dist/checks/valid-block-target/index.d.ts +2 -0
  226. package/dist/checks/valid-block-target/index.js +99 -0
  227. package/dist/checks/valid-block-target/index.js.map +1 -0
  228. package/dist/checks/valid-content-for-argument-types/index.d.ts +2 -0
  229. package/dist/checks/valid-content-for-argument-types/index.js +35 -0
  230. package/dist/checks/valid-content-for-argument-types/index.js.map +1 -0
  231. package/dist/checks/valid-content-for-arguments/index.d.ts +2 -0
  232. package/dist/checks/valid-content-for-arguments/index.js +82 -0
  233. package/dist/checks/valid-content-for-arguments/index.js.map +1 -0
  234. package/dist/checks/valid-doc-param-types/index.d.ts +2 -0
  235. package/dist/checks/valid-doc-param-types/index.js +61 -0
  236. package/dist/checks/valid-doc-param-types/index.js.map +1 -0
  237. package/dist/checks/valid-html-translation/index.d.ts +2 -0
  238. package/dist/checks/valid-html-translation/index.js +46 -0
  239. package/dist/checks/valid-html-translation/index.js.map +1 -0
  240. package/dist/checks/valid-json/index.d.ts +2 -0
  241. package/dist/checks/valid-json/index.js +36 -0
  242. package/dist/checks/valid-json/index.js.map +1 -0
  243. package/dist/checks/valid-local-blocks/index.d.ts +2 -0
  244. package/dist/checks/valid-local-blocks/index.js +66 -0
  245. package/dist/checks/valid-local-blocks/index.js.map +1 -0
  246. package/dist/checks/valid-local-blocks/valid-block-utils.d.ts +13 -0
  247. package/dist/checks/valid-local-blocks/valid-block-utils.js +74 -0
  248. package/dist/checks/valid-local-blocks/valid-block-utils.js.map +1 -0
  249. package/dist/checks/valid-render-partial-argument-types/index.d.ts +2 -0
  250. package/dist/checks/valid-render-partial-argument-types/index.js +66 -0
  251. package/dist/checks/valid-render-partial-argument-types/index.js.map +1 -0
  252. package/dist/checks/valid-schema/index.d.ts +2 -0
  253. package/dist/checks/valid-schema/index.js +40 -0
  254. package/dist/checks/valid-schema/index.js.map +1 -0
  255. package/dist/checks/valid-schema-name/index.d.ts +2 -0
  256. package/dist/checks/valid-schema-name/index.js +74 -0
  257. package/dist/checks/valid-schema-name/index.js.map +1 -0
  258. package/dist/checks/valid-settings-key/index.d.ts +2 -0
  259. package/dist/checks/valid-settings-key/index.js +90 -0
  260. package/dist/checks/valid-settings-key/index.js.map +1 -0
  261. package/dist/checks/valid-static-block-type/index.d.ts +2 -0
  262. package/dist/checks/valid-static-block-type/index.js +54 -0
  263. package/dist/checks/valid-static-block-type/index.js.map +1 -0
  264. package/dist/checks/valid-visible-if/index.d.ts +3 -0
  265. package/dist/checks/valid-visible-if/index.js +146 -0
  266. package/dist/checks/valid-visible-if/index.js.map +1 -0
  267. package/dist/checks/valid-visible-if/visible-if-utils.d.ts +14 -0
  268. package/dist/checks/valid-visible-if/visible-if-utils.js +125 -0
  269. package/dist/checks/valid-visible-if/visible-if-utils.js.map +1 -0
  270. package/dist/checks/variable-name/index.d.ts +6 -0
  271. package/dist/checks/variable-name/index.js +93 -0
  272. package/dist/checks/variable-name/index.js.map +1 -0
  273. package/dist/context-utils.d.ts +15 -0
  274. package/dist/context-utils.js +185 -0
  275. package/dist/context-utils.js.map +1 -0
  276. package/dist/create-safe-check.d.ts +2 -0
  277. package/dist/create-safe-check.js +15 -0
  278. package/dist/create-safe-check.js.map +1 -0
  279. package/dist/disabled-checks/index.d.ts +7 -0
  280. package/dist/disabled-checks/index.js +145 -0
  281. package/dist/disabled-checks/index.js.map +1 -0
  282. package/dist/disabled-checks/test-checks.d.ts +3 -0
  283. package/dist/disabled-checks/test-checks.js +59 -0
  284. package/dist/disabled-checks/test-checks.js.map +1 -0
  285. package/dist/doc-generator/DocBlockGenerator.d.ts +16 -0
  286. package/dist/doc-generator/DocBlockGenerator.js +464 -0
  287. package/dist/doc-generator/DocBlockGenerator.js.map +1 -0
  288. package/dist/doc-generator/index.d.ts +1 -0
  289. package/dist/doc-generator/index.js +6 -0
  290. package/dist/doc-generator/index.js.map +1 -0
  291. package/dist/find-root.d.ts +18 -0
  292. package/dist/find-root.js +81 -0
  293. package/dist/find-root.js.map +1 -0
  294. package/dist/fixes/apply-fix-to-string.d.ts +2 -0
  295. package/dist/fixes/apply-fix-to-string.js +50 -0
  296. package/dist/fixes/apply-fix-to-string.js.map +1 -0
  297. package/dist/fixes/autofix.d.ts +9 -0
  298. package/dist/fixes/autofix.js +30 -0
  299. package/dist/fixes/autofix.js.map +1 -0
  300. package/dist/fixes/corrector.d.ts +0 -0
  301. package/dist/fixes/corrector.js +2 -0
  302. package/dist/fixes/corrector.js.map +1 -0
  303. package/dist/fixes/correctors/base-corrector.d.ts +4 -0
  304. package/dist/fixes/correctors/base-corrector.js +3 -0
  305. package/dist/fixes/correctors/base-corrector.js.map +1 -0
  306. package/dist/fixes/correctors/graphql-corrector.d.ts +56 -0
  307. package/dist/fixes/correctors/graphql-corrector.js +78 -0
  308. package/dist/fixes/correctors/graphql-corrector.js.map +1 -0
  309. package/dist/fixes/correctors/index.d.ts +6 -0
  310. package/dist/fixes/correctors/index.js +30 -0
  311. package/dist/fixes/correctors/index.js.map +1 -0
  312. package/dist/fixes/correctors/json-corrector.d.ts +39 -0
  313. package/dist/fixes/correctors/json-corrector.js +86 -0
  314. package/dist/fixes/correctors/json-corrector.js.map +1 -0
  315. package/dist/fixes/correctors/string-corrector.d.ts +56 -0
  316. package/dist/fixes/correctors/string-corrector.js +78 -0
  317. package/dist/fixes/correctors/string-corrector.js.map +1 -0
  318. package/dist/fixes/index.d.ts +4 -0
  319. package/dist/fixes/index.js +14 -0
  320. package/dist/fixes/index.js.map +1 -0
  321. package/dist/fixes/utils.d.ts +2 -0
  322. package/dist/fixes/utils.js +9 -0
  323. package/dist/fixes/utils.js.map +1 -0
  324. package/dist/ignore.d.ts +2 -0
  325. package/dist/ignore.js +20 -0
  326. package/dist/ignore.js.map +1 -0
  327. package/dist/index.d.ts +23 -0
  328. package/dist/index.js +211 -0
  329. package/dist/index.js.map +1 -0
  330. package/dist/json.d.ts +17 -0
  331. package/dist/json.js +79 -0
  332. package/dist/json.js.map +1 -0
  333. package/dist/jsonc/parse.d.ts +25 -0
  334. package/dist/jsonc/parse.js +101 -0
  335. package/dist/jsonc/parse.js.map +1 -0
  336. package/dist/jsonc/types.d.ts +37 -0
  337. package/dist/jsonc/types.js +3 -0
  338. package/dist/jsonc/types.js.map +1 -0
  339. package/dist/liquid-doc/arguments.d.ts +36 -0
  340. package/dist/liquid-doc/arguments.js +239 -0
  341. package/dist/liquid-doc/arguments.js.map +1 -0
  342. package/dist/liquid-doc/liquidDoc.d.ts +33 -0
  343. package/dist/liquid-doc/liquidDoc.js +94 -0
  344. package/dist/liquid-doc/liquidDoc.js.map +1 -0
  345. package/dist/liquid-doc/utils.d.ts +49 -0
  346. package/dist/liquid-doc/utils.js +119 -0
  347. package/dist/liquid-doc/utils.js.map +1 -0
  348. package/dist/path.d.ts +10 -0
  349. package/dist/path.js +47 -0
  350. package/dist/path.js.map +1 -0
  351. package/dist/tags/content-for.d.ts +3 -0
  352. package/dist/tags/content-for.js +27 -0
  353. package/dist/tags/content-for.js.map +1 -0
  354. package/dist/test/MockFileSystem.d.ts +12 -0
  355. package/dist/test/MockFileSystem.js +109 -0
  356. package/dist/test/MockFileSystem.js.map +1 -0
  357. package/dist/test/MockTheme.d.ts +16 -0
  358. package/dist/test/MockTheme.js +16 -0
  359. package/dist/test/MockTheme.js.map +1 -0
  360. package/dist/test/chai-offer-fix-assertion.d.ts +22 -0
  361. package/dist/test/chai-offer-fix-assertion.js +20 -0
  362. package/dist/test/chai-offer-fix-assertion.js.map +1 -0
  363. package/dist/test/chai-suggest-assertion.d.ts +22 -0
  364. package/dist/test/chai-suggest-assertion.js +29 -0
  365. package/dist/test/chai-suggest-assertion.js.map +1 -0
  366. package/dist/test/contain-offense.d.ts +12 -0
  367. package/dist/test/contain-offense.js +36 -0
  368. package/dist/test/contain-offense.js.map +1 -0
  369. package/dist/test/index.d.ts +3 -0
  370. package/dist/test/index.js +20 -0
  371. package/dist/test/index.js.map +1 -0
  372. package/dist/test/test-helper.d.ts +14 -0
  373. package/dist/test/test-helper.js +289 -0
  374. package/dist/test/test-helper.js.map +1 -0
  375. package/dist/test/test-setup.d.ts +9 -0
  376. package/dist/test/test-setup.js +26 -0
  377. package/dist/test/test-setup.js.map +1 -0
  378. package/dist/to-schema.d.ts +16 -0
  379. package/dist/to-schema.js +218 -0
  380. package/dist/to-schema.js.map +1 -0
  381. package/dist/to-source-code.d.ts +5 -0
  382. package/dist/to-source-code.js +103 -0
  383. package/dist/to-source-code.js.map +1 -0
  384. package/dist/tsconfig.tsbuildinfo +1 -0
  385. package/dist/types/schema-prop-factory.d.ts +76 -0
  386. package/dist/types/schema-prop-factory.js +84 -0
  387. package/dist/types/schema-prop-factory.js.map +1 -0
  388. package/dist/types/schemas/index.d.ts +5 -0
  389. package/dist/types/schemas/index.js +6 -0
  390. package/dist/types/schemas/index.js.map +1 -0
  391. package/dist/types/schemas/preset.d.ts +38 -0
  392. package/dist/types/schemas/preset.js +3 -0
  393. package/dist/types/schemas/preset.js.map +1 -0
  394. package/dist/types/schemas/section.d.ts +49 -0
  395. package/dist/types/schemas/section.js +3 -0
  396. package/dist/types/schemas/section.js.map +1 -0
  397. package/dist/types/schemas/setting.d.ts +216 -0
  398. package/dist/types/schemas/setting.js +3 -0
  399. package/dist/types/schemas/setting.js.map +1 -0
  400. package/dist/types/schemas/template.d.ts +30 -0
  401. package/dist/types/schemas/template.js +3 -0
  402. package/dist/types/schemas/template.js.map +1 -0
  403. package/dist/types/schemas/theme-block.d.ts +24 -0
  404. package/dist/types/schemas/theme-block.js +3 -0
  405. package/dist/types/schemas/theme-block.js.map +1 -0
  406. package/dist/types/theme-liquid-docs.d.ts +131 -0
  407. package/dist/types/theme-liquid-docs.js +3 -0
  408. package/dist/types/theme-liquid-docs.js.map +1 -0
  409. package/dist/types/theme-schemas.d.ts +70 -0
  410. package/dist/types/theme-schemas.js +25 -0
  411. package/dist/types/theme-schemas.js.map +1 -0
  412. package/dist/types.d.ts +469 -0
  413. package/dist/types.js +55 -0
  414. package/dist/types.js.map +1 -0
  415. package/dist/utils/array.d.ts +5 -0
  416. package/dist/utils/array.js +28 -0
  417. package/dist/utils/array.js.map +1 -0
  418. package/dist/utils/block.d.ts +22 -0
  419. package/dist/utils/block.js +179 -0
  420. package/dist/utils/block.js.map +1 -0
  421. package/dist/utils/error.d.ts +2 -0
  422. package/dist/utils/error.js +44 -0
  423. package/dist/utils/error.js.map +1 -0
  424. package/dist/utils/file-utils.d.ts +6 -0
  425. package/dist/utils/file-utils.js +46 -0
  426. package/dist/utils/file-utils.js.map +1 -0
  427. package/dist/utils/index.d.ts +8 -0
  428. package/dist/utils/index.js +25 -0
  429. package/dist/utils/index.js.map +1 -0
  430. package/dist/utils/indexBy.d.ts +5 -0
  431. package/dist/utils/indexBy.js +15 -0
  432. package/dist/utils/indexBy.js.map +1 -0
  433. package/dist/utils/markup.d.ts +2 -0
  434. package/dist/utils/markup.js +10 -0
  435. package/dist/utils/markup.js.map +1 -0
  436. package/dist/utils/memo.d.ts +34 -0
  437. package/dist/utils/memo.js +61 -0
  438. package/dist/utils/memo.js.map +1 -0
  439. package/dist/utils/object.d.ts +1 -0
  440. package/dist/utils/object.js +7 -0
  441. package/dist/utils/object.js.map +1 -0
  442. package/dist/utils/position.d.ts +3 -0
  443. package/dist/utils/position.js +20 -0
  444. package/dist/utils/position.js.map +1 -0
  445. package/dist/utils/types.d.ts +52 -0
  446. package/dist/utils/types.js +23 -0
  447. package/dist/utils/types.js.map +1 -0
  448. package/dist/visitor.d.ts +24 -0
  449. package/dist/visitor.js +119 -0
  450. package/dist/visitor.js.map +1 -0
  451. package/dist/visitors/index.d.ts +2 -0
  452. package/dist/visitors/index.js +8 -0
  453. package/dist/visitors/index.js.map +1 -0
  454. package/dist/visitors/json.d.ts +2 -0
  455. package/dist/visitors/json.js +39 -0
  456. package/dist/visitors/json.js.map +1 -0
  457. package/dist/visitors/liquid.d.ts +2 -0
  458. package/dist/visitors/liquid.js +39 -0
  459. package/dist/visitors/liquid.js.map +1 -0
  460. package/package.json +45 -0
  461. package/src/AugmentedThemeDocset.spec.ts +148 -0
  462. package/src/AugmentedThemeDocset.ts +148 -0
  463. package/src/JSONValidator.ts +82 -0
  464. package/src/checks/app-block-missing-schema/index.spec.ts +121 -0
  465. package/src/checks/app-block-missing-schema/index.ts +46 -0
  466. package/src/checks/app-block-valid-tags/index.spec.ts +96 -0
  467. package/src/checks/app-block-valid-tags/index.ts +54 -0
  468. package/src/checks/asset-preload/index.spec.ts +78 -0
  469. package/src/checks/asset-preload/index.ts +65 -0
  470. package/src/checks/asset-size-app-block-css/index.spec.ts +88 -0
  471. package/src/checks/asset-size-app-block-css/index.ts +78 -0
  472. package/src/checks/asset-size-app-block-javascript/index.spec.ts +66 -0
  473. package/src/checks/asset-size-app-block-javascript/index.ts +78 -0
  474. package/src/checks/asset-size-css/index.spec.ts +166 -0
  475. package/src/checks/asset-size-css/index.ts +160 -0
  476. package/src/checks/asset-size-javascript/index.spec.ts +184 -0
  477. package/src/checks/asset-size-javascript/index.ts +144 -0
  478. package/src/checks/block-id-usage/index.spec.ts +76 -0
  479. package/src/checks/block-id-usage/index.ts +72 -0
  480. package/src/checks/cdn-preconnect/index.spec.ts +40 -0
  481. package/src/checks/cdn-preconnect/index.ts +43 -0
  482. package/src/checks/content-for-header-modification/index.spec.ts +65 -0
  483. package/src/checks/content-for-header-modification/index.ts +72 -0
  484. package/src/checks/deprecate-bgsizes/index.spec.ts +41 -0
  485. package/src/checks/deprecate-bgsizes/index.ts +49 -0
  486. package/src/checks/deprecate-lazysizes/index.spec.ts +26 -0
  487. package/src/checks/deprecate-lazysizes/index.ts +58 -0
  488. package/src/checks/deprecated-filter/fixes.ts +264 -0
  489. package/src/checks/deprecated-filter/index.spec.ts +274 -0
  490. package/src/checks/deprecated-filter/index.ts +113 -0
  491. package/src/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.ts +1343 -0
  492. package/src/checks/deprecated-fonts-on-sections-and-blocks/index.spec.ts +613 -0
  493. package/src/checks/deprecated-fonts-on-sections-and-blocks/index.ts +284 -0
  494. package/src/checks/deprecated-fonts-on-settings-schema/index.spec.ts +102 -0
  495. package/src/checks/deprecated-fonts-on-settings-schema/index.ts +66 -0
  496. package/src/checks/deprecated-tag/index.spec.ts +68 -0
  497. package/src/checks/deprecated-tag/index.ts +46 -0
  498. package/src/checks/duplicate-content-for-arguments/index.spec.ts +98 -0
  499. package/src/checks/duplicate-content-for-arguments/index.ts +43 -0
  500. package/src/checks/duplicate-function-arguments/index.spec.ts +98 -0
  501. package/src/checks/duplicate-function-arguments/index.ts +44 -0
  502. package/src/checks/duplicate-render-partial-arguments/index.spec.ts +120 -0
  503. package/src/checks/duplicate-render-partial-arguments/index.ts +48 -0
  504. package/src/checks/empty-block-content/index.spec.ts +117 -0
  505. package/src/checks/empty-block-content/index.ts +60 -0
  506. package/src/checks/graphql/index.ts +64 -0
  507. package/src/checks/graphql-variables/index.ts +113 -0
  508. package/src/checks/hardcoded-routes/index.spec.ts +58 -0
  509. package/src/checks/hardcoded-routes/index.ts +100 -0
  510. package/src/checks/img-width-and-height/index.spec.ts +79 -0
  511. package/src/checks/img-width-and-height/index.ts +52 -0
  512. package/src/checks/index.ts +160 -0
  513. package/src/checks/invalid-hash-assign-target/index.spec.ts +176 -0
  514. package/src/checks/invalid-hash-assign-target/index.ts +306 -0
  515. package/src/checks/json-missing-block/index.spec.ts +435 -0
  516. package/src/checks/json-missing-block/index.ts +56 -0
  517. package/src/checks/json-missing-block/missing-block-utils.ts +147 -0
  518. package/src/checks/json-syntax-error/index.spec.ts +64 -0
  519. package/src/checks/json-syntax-error/index.ts +92 -0
  520. package/src/checks/liquid-free-settings/index.spec.ts +180 -0
  521. package/src/checks/liquid-free-settings/index.ts +79 -0
  522. package/src/checks/liquid-html-syntax-error/checks/InvalidBooleanExpression.spec.ts +43 -0
  523. package/src/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.ts +29 -0
  524. package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.spec.ts +385 -0
  525. package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.ts +165 -0
  526. package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.spec.ts +52 -0
  527. package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.ts +39 -0
  528. package/src/checks/liquid-html-syntax-error/checks/InvalidEchoValue.spec.ts +108 -0
  529. package/src/checks/liquid-html-syntax-error/checks/InvalidEchoValue.ts +74 -0
  530. package/src/checks/liquid-html-syntax-error/checks/InvalidFilterName.spec.ts +223 -0
  531. package/src/checks/liquid-html-syntax-error/checks/InvalidFilterName.ts +92 -0
  532. package/src/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.spec.ts +145 -0
  533. package/src/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.ts +116 -0
  534. package/src/checks/liquid-html-syntax-error/checks/InvalidLoopRange.spec.ts +84 -0
  535. package/src/checks/liquid-html-syntax-error/checks/InvalidLoopRange.ts +79 -0
  536. package/src/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.spec.ts +184 -0
  537. package/src/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.ts +91 -0
  538. package/src/checks/liquid-html-syntax-error/checks/MultipleAssignValues.spec.ts +82 -0
  539. package/src/checks/liquid-html-syntax-error/checks/MultipleAssignValues.ts +86 -0
  540. package/src/checks/liquid-html-syntax-error/checks/utils.spec.ts +82 -0
  541. package/src/checks/liquid-html-syntax-error/checks/utils.ts +66 -0
  542. package/src/checks/liquid-html-syntax-error/index.spec.ts +129 -0
  543. package/src/checks/liquid-html-syntax-error/index.ts +152 -0
  544. package/src/checks/matching-translations/index.spec.ts +400 -0
  545. package/src/checks/matching-translations/index.ts +175 -0
  546. package/src/checks/metadata-params/index.spec.ts +103 -0
  547. package/src/checks/metadata-params/index.ts +119 -0
  548. package/src/checks/missing-asset/index.spec.ts +59 -0
  549. package/src/checks/missing-asset/index.ts +48 -0
  550. package/src/checks/missing-content-for-arguments/index.spec.ts +144 -0
  551. package/src/checks/missing-content-for-arguments/index.ts +46 -0
  552. package/src/checks/missing-template/index.spec.ts +61 -0
  553. package/src/checks/missing-template/index.ts +101 -0
  554. package/src/checks/orphaned-partial/index.spec.ts +58 -0
  555. package/src/checks/orphaned-partial/index.ts +43 -0
  556. package/src/checks/pagination-size/index.spec.ts +158 -0
  557. package/src/checks/pagination-size/index.ts +104 -0
  558. package/src/checks/parser-blocking-script/index.spec.ts +225 -0
  559. package/src/checks/parser-blocking-script/index.ts +91 -0
  560. package/src/checks/parser-blocking-script/suggestions.ts +42 -0
  561. package/src/checks/remote-asset/index.spec.ts +280 -0
  562. package/src/checks/remote-asset/index.ts +238 -0
  563. package/src/checks/reserved-doc-param-names/index.spec.ts +62 -0
  564. package/src/checks/reserved-doc-param-names/index.ts +57 -0
  565. package/src/checks/schema-presets-block-order/index.spec.ts +344 -0
  566. package/src/checks/schema-presets-block-order/index.ts +154 -0
  567. package/src/checks/schema-presets-static-blocks/index.spec.ts +145 -0
  568. package/src/checks/schema-presets-static-blocks/index.ts +126 -0
  569. package/src/checks/static-stylesheet-and-javascript-tags/index.spec.ts +257 -0
  570. package/src/checks/static-stylesheet-and-javascript-tags/index.ts +48 -0
  571. package/src/checks/translation-key-exists/index.spec.ts +44 -0
  572. package/src/checks/translation-key-exists/index.ts +78 -0
  573. package/src/checks/unclosed-html-element/index.spec.ts +260 -0
  574. package/src/checks/unclosed-html-element/index.ts +296 -0
  575. package/src/checks/undefined-object/index.spec.ts +519 -0
  576. package/src/checks/undefined-object/index.ts +336 -0
  577. package/src/checks/unique-doc-param-names/index.spec.ts +35 -0
  578. package/src/checks/unique-doc-param-names/index.ts +39 -0
  579. package/src/checks/unique-settings-id/index.spec.ts +24 -0
  580. package/src/checks/unique-settings-id/index.ts +84 -0
  581. package/src/checks/unique-settings-id/test-data.ts +1191 -0
  582. package/src/checks/unique-static-block-id/index.spec.ts +55 -0
  583. package/src/checks/unique-static-block-id/index.ts +60 -0
  584. package/src/checks/unknown-filter/index.spec.ts +59 -0
  585. package/src/checks/unknown-filter/index.ts +38 -0
  586. package/src/checks/unknown-property/index.spec.ts +234 -0
  587. package/src/checks/unknown-property/index.ts +468 -0
  588. package/src/checks/unknown-property/property-shape.ts +315 -0
  589. package/src/checks/unrecognized-content-for-arguments/index.spec.ts +145 -0
  590. package/src/checks/unrecognized-content-for-arguments/index.ts +55 -0
  591. package/src/checks/unrecognized-render-partial-arguments/index.spec.ts +184 -0
  592. package/src/checks/unrecognized-render-partial-arguments/index.ts +76 -0
  593. package/src/checks/unused-assign/index.spec.ts +160 -0
  594. package/src/checks/unused-assign/index.ts +87 -0
  595. package/src/checks/unused-doc-param/index.spec.ts +89 -0
  596. package/src/checks/unused-doc-param/index.ts +59 -0
  597. package/src/checks/utils.ts +117 -0
  598. package/src/checks/valid-block-target/index.spec.ts +1396 -0
  599. package/src/checks/valid-block-target/index.ts +142 -0
  600. package/src/checks/valid-content-for-argument-types/index.spec.ts +382 -0
  601. package/src/checks/valid-content-for-argument-types/index.ts +42 -0
  602. package/src/checks/valid-content-for-arguments/index.spec.ts +107 -0
  603. package/src/checks/valid-content-for-arguments/index.ts +98 -0
  604. package/src/checks/valid-doc-param-types/index.spec.ts +75 -0
  605. package/src/checks/valid-doc-param-types/index.ts +71 -0
  606. package/src/checks/valid-html-translation/index.spec.ts +74 -0
  607. package/src/checks/valid-html-translation/index.ts +45 -0
  608. package/src/checks/valid-json/index.spec.ts +102 -0
  609. package/src/checks/valid-json/index.ts +34 -0
  610. package/src/checks/valid-local-blocks/index.spec.ts +286 -0
  611. package/src/checks/valid-local-blocks/index.ts +100 -0
  612. package/src/checks/valid-local-blocks/valid-block-utils.ts +97 -0
  613. package/src/checks/valid-render-partial-argument-types/index.spec.ts +468 -0
  614. package/src/checks/valid-render-partial-argument-types/index.ts +89 -0
  615. package/src/checks/valid-schema/index.spec.ts +174 -0
  616. package/src/checks/valid-schema/index.ts +41 -0
  617. package/src/checks/valid-schema-name/index.spec.ts +112 -0
  618. package/src/checks/valid-schema-name/index.ts +75 -0
  619. package/src/checks/valid-settings-key/index.spec.ts +321 -0
  620. package/src/checks/valid-settings-key/index.ts +144 -0
  621. package/src/checks/valid-static-block-type/index.spec.ts +38 -0
  622. package/src/checks/valid-static-block-type/index.ts +58 -0
  623. package/src/checks/valid-visible-if/index.spec.ts +619 -0
  624. package/src/checks/valid-visible-if/index.ts +184 -0
  625. package/src/checks/valid-visible-if/visible-if-utils.ts +158 -0
  626. package/src/checks/variable-name/index.spec.ts +62 -0
  627. package/src/checks/variable-name/index.ts +115 -0
  628. package/src/context-utils.spec.ts +103 -0
  629. package/src/context-utils.ts +220 -0
  630. package/src/create-safe-check.ts +13 -0
  631. package/src/disabled-checks/index.spec.ts +262 -0
  632. package/src/disabled-checks/index.ts +189 -0
  633. package/src/disabled-checks/test-checks.ts +60 -0
  634. package/src/find-root.ts +60 -0
  635. package/src/fixes/apply-fix-to-string.spec.ts +52 -0
  636. package/src/fixes/apply-fix-to-string.ts +59 -0
  637. package/src/fixes/autofix.spec.ts +85 -0
  638. package/src/fixes/autofix.ts +41 -0
  639. package/src/fixes/corrector.ts +0 -0
  640. package/src/fixes/correctors/base-corrector.ts +5 -0
  641. package/src/fixes/correctors/graphql-corrector.ts +78 -0
  642. package/src/fixes/correctors/index.ts +29 -0
  643. package/src/fixes/correctors/json-corrector.spec.ts +111 -0
  644. package/src/fixes/correctors/json-corrector.ts +106 -0
  645. package/src/fixes/correctors/string-corrector.ts +78 -0
  646. package/src/fixes/index.ts +4 -0
  647. package/src/fixes/utils.ts +6 -0
  648. package/src/ignore.spec.ts +202 -0
  649. package/src/ignore.ts +23 -0
  650. package/src/index.spec.ts +8 -0
  651. package/src/index.ts +234 -0
  652. package/src/json.spec.ts +140 -0
  653. package/src/json.ts +81 -0
  654. package/src/jsonc/parse.spec.ts +118 -0
  655. package/src/jsonc/parse.ts +121 -0
  656. package/src/jsonc/types.ts +47 -0
  657. package/src/liquid-doc/arguments.spec.ts +146 -0
  658. package/src/liquid-doc/arguments.ts +315 -0
  659. package/src/liquid-doc/liquidDoc.spec.ts +296 -0
  660. package/src/liquid-doc/liquidDoc.ts +147 -0
  661. package/src/liquid-doc/utils.spec.ts +23 -0
  662. package/src/liquid-doc/utils.ts +125 -0
  663. package/src/path.ts +45 -0
  664. package/src/tags/content-for.ts +25 -0
  665. package/src/test/MockFileSystem.spec.ts +71 -0
  666. package/src/test/MockFileSystem.ts +87 -0
  667. package/src/test/MockTheme.ts +17 -0
  668. package/src/test/chai-offer-fix-assertion.spec.ts +53 -0
  669. package/src/test/chai-offer-fix-assertion.ts +45 -0
  670. package/src/test/chai-suggest-assertion.spec.ts +53 -0
  671. package/src/test/chai-suggest-assertion.ts +62 -0
  672. package/src/test/contain-offense.spec.ts +74 -0
  673. package/src/test/contain-offense.ts +54 -0
  674. package/src/test/index.ts +3 -0
  675. package/src/test/test-helper.ts +327 -0
  676. package/src/test/test-setup.ts +36 -0
  677. package/src/to-schema.ts +231 -0
  678. package/src/to-source-code.ts +75 -0
  679. package/src/types/schema-prop-factory.ts +112 -0
  680. package/src/types/schemas/index.ts +5 -0
  681. package/src/types/schemas/preset.ts +52 -0
  682. package/src/types/schemas/section.ts +86 -0
  683. package/src/types/schemas/setting.ts +320 -0
  684. package/src/types/schemas/template.ts +34 -0
  685. package/src/types/schemas/theme-block.ts +34 -0
  686. package/src/types/theme-liquid-docs.ts +184 -0
  687. package/src/types/theme-schemas.ts +80 -0
  688. package/src/types.ts +617 -0
  689. package/src/utils/array.ts +31 -0
  690. package/src/utils/block.ts +300 -0
  691. package/src/utils/error.spec.ts +71 -0
  692. package/src/utils/error.ts +48 -0
  693. package/src/utils/file-utils.ts +58 -0
  694. package/src/utils/index.ts +8 -0
  695. package/src/utils/indexBy.ts +14 -0
  696. package/src/utils/markup.ts +10 -0
  697. package/src/utils/memo.spec.ts +83 -0
  698. package/src/utils/memo.ts +80 -0
  699. package/src/utils/object.ts +3 -0
  700. package/src/utils/position.ts +16 -0
  701. package/src/utils/types.ts +57 -0
  702. package/src/visitor.spec.ts +163 -0
  703. package/src/visitor.ts +161 -0
  704. package/src/visitors/index.ts +2 -0
  705. package/src/visitors/json.ts +41 -0
  706. package/src/visitors/liquid.ts +40 -0
  707. package/tsconfig.build.json +8 -0
  708. package/tsconfig.json +31 -0
@@ -0,0 +1,1396 @@
1
+ import { expect, describe, it } from 'vitest';
2
+ import { ValidBlockTarget } from './index';
3
+ import { check, MockTheme } from '../../test';
4
+ import { Preset, Setting } from '../../types/schemas';
5
+
6
+ describe('Module: ValidBlockTarget', () => {
7
+ const paths = ['sections', 'blocks'];
8
+
9
+ describe('File Existence Tests', () => {
10
+ paths.forEach((path) => {
11
+ it(`should ignore @app and @theme block types in ${path} bucket`, async () => {
12
+ const theme: MockTheme = {
13
+ [`${path}/app-theme.liquid`]: `
14
+ {% schema %}
15
+ {
16
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
17
+ "blocks": [
18
+ {
19
+ "type": "@app"
20
+ },
21
+ {
22
+ "type": "@theme"
23
+ }
24
+ ]
25
+ }
26
+ {% endschema %}
27
+ `,
28
+ };
29
+
30
+ const offenses = await check(theme, [ValidBlockTarget]);
31
+ expect(offenses).to.be.empty;
32
+ });
33
+
34
+ it(`should not report any errors when all block files exist (${path} bucket)`, async () => {
35
+ const theme: MockTheme = {
36
+ 'blocks/text.liquid': '',
37
+ [`${path}/valid.liquid`]: `
38
+ {% schema %}
39
+ {
40
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
41
+ "blocks": [
42
+ {
43
+ "type": "text"
44
+ }
45
+ ]
46
+ }
47
+ {% endschema %}
48
+ `,
49
+ };
50
+
51
+ const offenses = await check(theme, [ValidBlockTarget]);
52
+ expect(offenses).to.be.empty;
53
+ });
54
+
55
+ it(`should report errors when root level block file does not exist (${path} bucket)`, async () => {
56
+ const theme: MockTheme = {
57
+ [`${path}/invalid-section.liquid`]: `
58
+ {% schema %}
59
+ {
60
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
61
+ "blocks": [
62
+ {
63
+ "type": "invalid"
64
+ }
65
+ ]
66
+ }
67
+ {% endschema %}
68
+ `,
69
+ };
70
+
71
+ const offenses = await check(theme, [ValidBlockTarget]);
72
+ expect(offenses).to.have.length(1);
73
+ expect(offenses[0].message).to.equal("Theme block 'blocks/invalid.liquid' does not exist.");
74
+ });
75
+
76
+ it(`should report an error when a preset defined block file does not exist (${path} bucket)`, async () => {
77
+ const theme: MockTheme = {
78
+ [`${path}/invalid-block.liquid`]: `
79
+ {% schema %}
80
+ {
81
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
82
+ "blocks": [
83
+ {
84
+ "type": "@theme"
85
+ }
86
+ ],
87
+ "presets": [
88
+ {
89
+ "name": "Default",
90
+ "blocks": [
91
+ {
92
+ "type": "missing_block"
93
+ }
94
+ ]
95
+ }
96
+ ]
97
+ }
98
+ {% endschema %}
99
+ `,
100
+ };
101
+
102
+ const offenses = await check(theme, [ValidBlockTarget]);
103
+ expect(offenses).to.have.length(1);
104
+ expect(offenses[0].message).to.equal(
105
+ "Theme block 'blocks/missing_block.liquid' does not exist.",
106
+ );
107
+ });
108
+
109
+ if (path === 'sections') {
110
+ it(`should report an error when default defined block file does not exist`, async () => {
111
+ const theme: MockTheme = {
112
+ [`${path}/invalid-file.liquid`]: `
113
+ {% schema %}
114
+ {
115
+ "name": "Section name",
116
+ "blocks": [
117
+ {
118
+ "type": "@theme"
119
+ }
120
+ ],
121
+ "default": {
122
+ "title": "Default",
123
+ "blocks": [
124
+ {
125
+ "name": "some block",
126
+ "type": "missing_block"
127
+ }
128
+ ]
129
+ }
130
+ }
131
+ {% endschema %}
132
+ `,
133
+ };
134
+
135
+ const offenses = await check(theme, [ValidBlockTarget]);
136
+ expect(offenses).to.have.length(1);
137
+ expect(offenses).to.containOffense(
138
+ "Theme block 'blocks/missing_block.liquid' does not exist.",
139
+ );
140
+ });
141
+ }
142
+
143
+ it(`should not report subsequent errors in present defined blocks if error in root level (${path} bucket)`, async () => {
144
+ const theme: MockTheme = {
145
+ [`${path}/invalid-block.liquid`]: `
146
+ {% schema %}
147
+ {
148
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
149
+ "blocks": [
150
+ {
151
+ "type": "invalid"
152
+ }
153
+ ],
154
+ "presets": [
155
+ {
156
+ "name": "Default",
157
+ "blocks": [
158
+ {
159
+ "type": "text"
160
+ }
161
+ ]
162
+ }
163
+ ]
164
+ }
165
+ {% endschema %}
166
+ `,
167
+ };
168
+
169
+ const offenses = await check(theme, [ValidBlockTarget]);
170
+ expect(offenses).to.have.length(1);
171
+ expect(offenses[0].message).to.equal("Theme block 'blocks/invalid.liquid' does not exist.");
172
+ });
173
+
174
+ it(`should report an error when a preset defined block file does not exist with hash-style presets (${path} bucket)`, async () => {
175
+ const theme: MockTheme = {
176
+ [`${path}/invalid-block.liquid`]: `
177
+ {% schema %}
178
+ {
179
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
180
+ "blocks": [
181
+ {
182
+ "type": "@theme"
183
+ }
184
+ ],
185
+ "presets": [
186
+ {
187
+ "name": "Default",
188
+ "blocks": {
189
+ "missing_block_hash": {
190
+ "type": "missing_block"
191
+ }
192
+ },
193
+ "block_order": ["missing_block_hash"]
194
+ }
195
+ ]
196
+ }
197
+ {% endschema %}
198
+ `,
199
+ };
200
+
201
+ const offenses = await check(theme, [ValidBlockTarget]);
202
+ expect(offenses).to.have.length(1);
203
+ expect(offenses[0].message).to.equal(
204
+ "Theme block 'blocks/missing_block.liquid' does not exist.",
205
+ );
206
+ });
207
+
208
+ it(`should not report an error when a preset defined block file exists with hash-style presets (${path} bucket)`, async () => {
209
+ const theme: MockTheme = {
210
+ 'blocks/text.liquid': '',
211
+ [`${path}/invalid-block.liquid`]: `
212
+ {% schema %}
213
+ {
214
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
215
+ "blocks": [
216
+ {
217
+ "type": "@theme"
218
+ }
219
+ ],
220
+ "presets": [
221
+ {
222
+ "name": "Default",
223
+ "blocks": {
224
+ "text_block": {
225
+ "type": "text"
226
+ }
227
+ },
228
+ "block_order": ["text_block"]
229
+ }
230
+ ]
231
+ }
232
+ {% endschema %}
233
+ `,
234
+ };
235
+
236
+ const offenses = await check(theme, [ValidBlockTarget]);
237
+ expect(offenses).to.be.empty;
238
+ });
239
+ });
240
+
241
+ it('should not report errors for locally scoped blocks at root level', async () => {
242
+ const theme: MockTheme = {
243
+ 'sections/local-blocks.liquid': `
244
+ {% schema %}
245
+ {
246
+ "name": "Section name",
247
+ "blocks": [
248
+ {
249
+ "type": "local_block",
250
+ "name": "Local block"
251
+ }
252
+ ]
253
+ }
254
+ {% endschema %}
255
+ `,
256
+ };
257
+
258
+ const offenses = await check(theme, [ValidBlockTarget]);
259
+ expect(offenses).to.be.empty;
260
+ });
261
+ });
262
+
263
+ describe('Allowed Targeting Tests', () => {
264
+ paths.forEach((path) => {
265
+ it(`should report an error when a preset defined block is not specified at root level (${path} bucket)`, async () => {
266
+ const theme: MockTheme = {
267
+ 'blocks/text.liquid': '',
268
+ [`${path}/invalid-preset.liquid`]: `
269
+ {% schema %}
270
+ {
271
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
272
+ "blocks": [
273
+ {
274
+ "type": "text"
275
+ }
276
+ ],
277
+ "presets": [
278
+ {
279
+ "name": "Default preset",
280
+ "blocks": [
281
+ {
282
+ "type": "invalid_preset_block"
283
+ }
284
+ ]
285
+ }
286
+ ]
287
+ }
288
+ {% endschema %}
289
+ `,
290
+ };
291
+
292
+ const offenses = await check(theme, [ValidBlockTarget]);
293
+ expect(offenses).to.have.length(2);
294
+ expect(offenses).to.containOffense(
295
+ 'Theme block type "invalid_preset_block" must be allowed in "blocks" at the root of this schema.',
296
+ );
297
+ expect(offenses).to.containOffense(
298
+ "Theme block 'blocks/invalid_preset_block.liquid' does not exist.",
299
+ );
300
+ });
301
+
302
+ if (path === 'sections') {
303
+ it(`should report an error when a default defined block is not specified at root level`, async () => {
304
+ const theme: MockTheme = {
305
+ 'blocks/text.liquid': '',
306
+ [`${path}/invalid-preset.liquid`]: `
307
+ {% schema %}
308
+ {
309
+ "name": "Section name",
310
+ "blocks": [
311
+ {
312
+ "type": "text"
313
+ }
314
+ ],
315
+ "default": {
316
+ "name": "Default",
317
+ "blocks": [
318
+ {
319
+ "name": "invalid_preset_block",
320
+ "type": "invalid_preset_block"
321
+ }
322
+ ]
323
+ }
324
+ }
325
+ {% endschema %}
326
+ `,
327
+ };
328
+
329
+ const offenses = await check(theme, [ValidBlockTarget]);
330
+ expect(offenses).to.have.length(2);
331
+ expect(offenses).to.containOffense(
332
+ 'Theme block type "invalid_preset_block" must be allowed in "blocks" at the root of this schema.',
333
+ );
334
+ expect(offenses).to.containOffense(
335
+ "Theme block 'blocks/invalid_preset_block.liquid' does not exist.",
336
+ );
337
+ });
338
+ }
339
+
340
+ it(`should report errors in presets for private blocks even when @theme is specified at root level (${path} bucket)`, async () => {
341
+ const theme: MockTheme = {
342
+ 'blocks/_private.liquid': '',
343
+ [`${path}/private-blocks.liquid`]: `
344
+ {% schema %}
345
+ {
346
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
347
+ "blocks": [
348
+ {
349
+ "type": "@theme"
350
+ }
351
+ ],
352
+ "presets": [
353
+ {
354
+ "name": "Default",
355
+ "blocks": [
356
+ {
357
+ "type": "_private"
358
+ }
359
+ ]
360
+ }
361
+ ]
362
+ }
363
+ {% endschema %}
364
+ `,
365
+ };
366
+
367
+ const offenses = await check(theme, [ValidBlockTarget]);
368
+ expect(offenses).to.have.length(1);
369
+ expect(offenses).to.containOffense(
370
+ 'Theme block type "_private" is a private block so it must be explicitly allowed in "blocks" at the root of this schema.',
371
+ );
372
+ });
373
+
374
+ if (path === 'sections') {
375
+ it(`should report errors in default for private blocks even when @theme is specified at root level`, async () => {
376
+ const theme: MockTheme = {
377
+ 'blocks/_private.liquid': '',
378
+ [`${path}/private-blocks.liquid`]: `
379
+ {% schema %}
380
+ {
381
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
382
+ "blocks": [
383
+ {
384
+ "type": "@theme"
385
+ }
386
+ ],
387
+ "default": {
388
+ "name": "Default",
389
+ "blocks": [
390
+ {
391
+ "name": "private",
392
+ "type": "_private"
393
+ }
394
+ ]
395
+ }
396
+ }
397
+ {% endschema %}
398
+ `,
399
+ };
400
+
401
+ const offenses = await check(theme, [ValidBlockTarget]);
402
+ expect(offenses).to.have.length(1);
403
+ expect(offenses).to.containOffense(
404
+ 'Theme block type "_private" is a private block so it must be explicitly allowed in "blocks" at the root of this schema.',
405
+ );
406
+ });
407
+ }
408
+
409
+ it(`should report errors with correct indices (${path} bucket)`, async () => {
410
+ const theme: MockTheme = {
411
+ [`${path}/private-blocks.liquid`]: `
412
+ {% schema %}
413
+ {
414
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
415
+ "blocks": [
416
+ {
417
+ "type": "@theme"
418
+ }
419
+ ],
420
+ "presets": [
421
+ {
422
+ "name": "Default",
423
+ "blocks": [
424
+ {
425
+ "type": "_private"
426
+ }
427
+ ]
428
+ }
429
+ ]
430
+ }
431
+ {% endschema %}
432
+ `,
433
+ };
434
+
435
+ const offenses = await check(theme, [ValidBlockTarget]);
436
+ expect(offenses).to.have.length(2);
437
+
438
+ for (const offense of offenses) {
439
+ const content = theme[`${path}/private-blocks.liquid`];
440
+ const erroredContent = content.slice(offense.start.index, offense.end.index);
441
+ expect(erroredContent).to.equal('"_private"');
442
+ }
443
+ });
444
+
445
+ it(`should not report errors for private blocks when listed at root level (${path} bucket)`, async () => {
446
+ const theme: MockTheme = {
447
+ 'blocks/_private.liquid': '',
448
+ [`${path}/private-blocks.liquid`]: `
449
+ {% schema %}
450
+ {
451
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
452
+ "blocks": [
453
+ {
454
+ "type": "_private"
455
+ }
456
+ ],
457
+ "presets": [
458
+ {
459
+ "name": "Default",
460
+ "blocks": [
461
+ {
462
+ "type": "_private"
463
+ }
464
+ ]
465
+ }
466
+ ]
467
+ }
468
+ {% endschema %}
469
+ `,
470
+ };
471
+
472
+ const offenses = await check(theme, [ValidBlockTarget]);
473
+ expect(offenses).to.be.empty;
474
+ });
475
+
476
+ it(`should handle mixed private and public blocks correctly (${path} bucket)`, async () => {
477
+ const theme: MockTheme = {
478
+ 'blocks/_private.liquid': '',
479
+ 'blocks/custom.liquid': '',
480
+ [`${path}/mixed-blocks.liquid`]: `
481
+ {% schema %}
482
+ {
483
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
484
+ "blocks": [
485
+ {
486
+ "type": "@theme"
487
+ },
488
+ {
489
+ "type": "_private"
490
+ }
491
+ ],
492
+ "presets": [
493
+ {
494
+ "name": "Default",
495
+ "blocks": [
496
+ {
497
+ "type": "_private"
498
+ },
499
+ {
500
+ "type": "custom"
501
+ }
502
+ ]
503
+ }
504
+ ]
505
+ }
506
+ {% endschema %}
507
+ `,
508
+ };
509
+
510
+ const offenses = await check(theme, [ValidBlockTarget]);
511
+ expect(offenses).to.be.empty;
512
+ });
513
+
514
+ it(`should report an error when a preset defined block is not specified at root level with hash-style presets (${path} bucket)`, async () => {
515
+ const theme: MockTheme = {
516
+ 'blocks/text.liquid': '',
517
+ [`${path}/invalid-preset.liquid`]: `
518
+ {% schema %}
519
+ {
520
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
521
+ "blocks": [
522
+ {
523
+ "type": "text"
524
+ }
525
+ ],
526
+ "presets": [
527
+ {
528
+ "name": "Default preset",
529
+ "blocks": {
530
+ "invalid_preset_block_hash": {
531
+ "type": "invalid_preset_block"
532
+ }
533
+ },
534
+ "block_order": ["invalid_preset_block_hash"]
535
+ }
536
+ ]
537
+ }
538
+ {% endschema %}
539
+ `,
540
+ };
541
+
542
+ const offenses = await check(theme, [ValidBlockTarget]);
543
+ expect(offenses).to.have.length(2);
544
+ expect(offenses).to.containOffense(
545
+ 'Theme block type "invalid_preset_block" must be allowed in "blocks" at the root of this schema.',
546
+ );
547
+ expect(offenses).to.containOffense(
548
+ "Theme block 'blocks/invalid_preset_block.liquid' does not exist.",
549
+ );
550
+ });
551
+
552
+ it(`should report errors for private blocks even when @theme is specified at root level with hash-style presets (${path} bucket)`, async () => {
553
+ const theme: MockTheme = {
554
+ 'blocks/_private.liquid': '',
555
+ [`${path}/private-blocks.liquid`]: `
556
+ {% schema %}
557
+ {
558
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
559
+ "blocks": [
560
+ {
561
+ "type": "@theme"
562
+ }
563
+ ],
564
+ "presets": [
565
+ {
566
+ "name": "Default",
567
+ "blocks": {
568
+ "private_hash": {
569
+ "type": "_private"
570
+ }
571
+ },
572
+ "block_order": ["private_hash"]
573
+ }
574
+ ]
575
+ }
576
+ {% endschema %}
577
+ `,
578
+ };
579
+
580
+ const offenses = await check(theme, [ValidBlockTarget]);
581
+ expect(offenses).to.have.length(1);
582
+ expect(offenses[0].message).to.equal(
583
+ 'Theme block type "_private" is a private block so it must be explicitly allowed in "blocks" at the root of this schema.',
584
+ );
585
+ });
586
+
587
+ it(`should not report errors for private blocks when listed at root level with hash-style presets (${path} bucket)`, async () => {
588
+ const theme: MockTheme = {
589
+ 'blocks/_private.liquid': '',
590
+ [`${path}/private-blocks.liquid`]: `
591
+ {% schema %}
592
+ {
593
+ "name": "${path === 'sections' ? 'Section' : 'Block'} name",
594
+ "blocks": [
595
+ {
596
+ "type": "_private"
597
+ }
598
+ ],
599
+ "presets": [
600
+ {
601
+ "name": "Default",
602
+ "blocks": {
603
+ "private_hash": {
604
+ "type": "_private"
605
+ }
606
+ },
607
+ "block_order": ["private_hash"]
608
+ }
609
+ ]
610
+ }
611
+ {% endschema %}
612
+ `,
613
+ };
614
+
615
+ const offenses = await check(theme, [ValidBlockTarget]);
616
+ expect(offenses).to.be.empty;
617
+ });
618
+
619
+ it(`should report errors for nested blocks when they are not allowed (${path} bucket)`, async () => {
620
+ const theme: MockTheme = {
621
+ 'blocks/image.liquid': '',
622
+ 'blocks/group.liquid': '',
623
+ 'blocks/text.liquid': '',
624
+ 'blocks/slide.liquid': `
625
+ {% schema %}
626
+ {
627
+ "name": "Slide",
628
+ "blocks": [
629
+ {
630
+ "type": "text"
631
+ },
632
+ {
633
+ "type": "image"
634
+ }
635
+ ]
636
+ }
637
+ {% endschema %}
638
+ `,
639
+ [`${path}/slideshow.liquid`]: `
640
+ {% schema %}
641
+ {
642
+ "name": "Slideshow",
643
+ "blocks": [
644
+ {
645
+ "type": "slide"
646
+ }
647
+ ],
648
+ "presets": [
649
+ {
650
+ "name": "Default",
651
+ "blocks": [
652
+ {
653
+ "type": "slide",
654
+ "blocks": [
655
+ {
656
+ "type": "group"
657
+ }
658
+ ]
659
+ }
660
+ ]
661
+ }
662
+ ]
663
+ }
664
+ {% endschema %}
665
+ `,
666
+ };
667
+
668
+ const offenses = await check(theme, [ValidBlockTarget]);
669
+ expect(offenses).to.have.length(1);
670
+ expect(offenses[0].message).to.equal(
671
+ 'Block type "group" is not allowed in "slide" blocks. Allowed types are: text, image.',
672
+ );
673
+ });
674
+
675
+ it(`should report errors for nested private blocks when they are not allowed (${path} bucket)`, async () => {
676
+ const theme: MockTheme = {
677
+ 'blocks/image.liquid': '',
678
+ 'blocks/_private.liquid': '',
679
+ 'blocks/text.liquid': '',
680
+ 'blocks/slide.liquid': `
681
+ {% schema %}
682
+ {
683
+ "name": "Slide",
684
+ "blocks": [
685
+ {
686
+ "type": "text"
687
+ },
688
+ {
689
+ "type": "image"
690
+ }
691
+ ]
692
+ }
693
+ {% endschema %}
694
+ `,
695
+ [`${path}/slideshow.liquid`]: `
696
+ {% schema %}
697
+ {
698
+ "name": "Slideshow",
699
+ "blocks": [
700
+ {
701
+ "type": "slide"
702
+ }
703
+ ],
704
+ "presets": [
705
+ {
706
+ "name": "Default",
707
+ "blocks": [
708
+ {
709
+ "type": "slide",
710
+ "blocks": [
711
+ {
712
+ "type": "_private"
713
+ }
714
+ ]
715
+ }
716
+ ]
717
+ }
718
+ ]
719
+ }
720
+ {% endschema %}
721
+ `,
722
+ };
723
+
724
+ const offenses = await check(theme, [ValidBlockTarget]);
725
+ expect(offenses).to.have.length(1);
726
+ expect(offenses[0].message).to.equal(
727
+ 'Private block type "_private" is not allowed in "slide" blocks.',
728
+ );
729
+ });
730
+
731
+ it(`should report errors for nested blocks when they are not allowed with hash-style presets (${path} bucket)`, async () => {
732
+ const theme: MockTheme = {
733
+ 'blocks/image.liquid': '',
734
+ 'blocks/group.liquid': '',
735
+ 'blocks/text.liquid': '',
736
+ 'blocks/slide.liquid': `
737
+ {% schema %}
738
+ {
739
+ "name": "Slide",
740
+ "blocks": [
741
+ {
742
+ "type": "text"
743
+ },
744
+ {
745
+ "type": "image"
746
+ }
747
+ ]
748
+ }
749
+ {% endschema %}
750
+ `,
751
+ [`${path}/slideshow.liquid`]: `
752
+ {% schema %}
753
+ {
754
+ "name": "Slideshow",
755
+ "blocks": [
756
+ {
757
+ "type": "slide"
758
+ }
759
+ ],
760
+ "presets": [
761
+ {
762
+ "name": "Default",
763
+ "blocks": {
764
+ "slide_hash": {
765
+ "type": "slide",
766
+ "blocks": {
767
+ "group_hash": {
768
+ "type": "group"
769
+ }
770
+ }
771
+ }
772
+ }
773
+ }
774
+ ]
775
+ }
776
+ {% endschema %}
777
+ `,
778
+ };
779
+
780
+ const offenses = await check(theme, [ValidBlockTarget]);
781
+ expect(offenses).to.have.length(1);
782
+ expect(offenses[0].message).to.equal(
783
+ 'Block type "group" is not allowed in "slide" blocks. Allowed types are: text, image.',
784
+ );
785
+ });
786
+
787
+ it(`should report errors for further nested blocks when they are not allowed (${path} bucket)`, async () => {
788
+ const theme: MockTheme = {
789
+ 'blocks/image.liquid': '',
790
+ 'blocks/group.liquid': `
791
+ {% schema %}
792
+ {
793
+ "name": "Group",
794
+ "blocks": [
795
+ {
796
+ "type": "text"
797
+ }
798
+ ]
799
+ }
800
+ {% endschema %}
801
+ `,
802
+ 'blocks/text.liquid': '',
803
+ 'blocks/slide.liquid': `
804
+ {% schema %}
805
+ {
806
+ "name": "Slide",
807
+ "blocks": [
808
+ {
809
+ "type": "group"
810
+ }
811
+ ]
812
+ }
813
+ {% endschema %}
814
+ `,
815
+ [`${path}/slideshow.liquid`]: `
816
+ {% schema %}
817
+ {
818
+ "name": "Slideshow",
819
+ "blocks": [
820
+ {
821
+ "type": "slide"
822
+ }
823
+ ],
824
+ "presets": [
825
+ {
826
+ "name": "Default",
827
+ "blocks": [
828
+ {
829
+ "type": "slide",
830
+ "blocks": [
831
+ {
832
+ "type": "group",
833
+ "blocks": [
834
+ {
835
+ "type": "image"
836
+ }
837
+ ]
838
+ }
839
+ ]
840
+ }
841
+ ]
842
+ }
843
+ ]
844
+ }
845
+ {% endschema %}
846
+ `,
847
+ };
848
+
849
+ const offenses = await check(theme, [ValidBlockTarget]);
850
+ expect(offenses).to.have.length(1);
851
+ expect(offenses[0].message).to.equal(
852
+ 'Block type "image" is not allowed in "group" blocks. Allowed types are: text.',
853
+ );
854
+ });
855
+
856
+ describe(`Static Blocks used in a ${path} file`, () => {
857
+ const textSetting: Setting.Text = {
858
+ type: 'text' as Setting.Type.Text,
859
+ id: 'text',
860
+ label: 'Text',
861
+ };
862
+
863
+ describe('When presets are defined as a hash', () => {
864
+ describe('When the static block is used in the same file', () => {
865
+ const makeTheme = (
866
+ preset: Preset.PresetBlockHash,
867
+ blocks_order: string[] = [],
868
+ ): MockTheme => {
869
+ return {
870
+ [`${path}/slideshow.liquid`]: `
871
+ # Static block is defined in the body of the file
872
+ {% content_for "block", type: "static", id: "static_id" %}
873
+
874
+ {% schema %}
875
+ {
876
+ "name": "Slideshow",
877
+ "presets": [
878
+ {
879
+ "name": "Default",
880
+ "blocks": ${JSON.stringify(preset, null, 2)},
881
+ "block_order": ${JSON.stringify(blocks_order)}
882
+ }
883
+ ]
884
+ }
885
+ {% endschema %}
886
+ `,
887
+ 'blocks/static.liquid': `
888
+ {% schema %}
889
+ {
890
+ "name": "some static block",
891
+ "settings": [${JSON.stringify(textSetting)}]
892
+ }
893
+ {% endschema %}
894
+ `,
895
+ };
896
+ };
897
+
898
+ it(`is silent for valid static blocks references`, async () => {
899
+ const theme: MockTheme = makeTheme({
900
+ static_id: {
901
+ type: 'static',
902
+ static: true,
903
+ settings: {
904
+ text: 'some text',
905
+ },
906
+ },
907
+ });
908
+ const offenses = await check(theme, [ValidBlockTarget]);
909
+ expect(offenses).to.be.empty;
910
+ });
911
+
912
+ it(`reports a warning for missing (or mismatching) static blocks references`, async () => {
913
+ const theme: MockTheme = makeTheme({
914
+ mismatching_id: {
915
+ type: 'static',
916
+ static: true,
917
+ settings: {
918
+ text: 'some text',
919
+ },
920
+ },
921
+ });
922
+
923
+ const offenses = await check(theme, [ValidBlockTarget]);
924
+ expect(offenses).not.to.be.empty;
925
+ expect(offenses).to.containOffense(
926
+ 'Could not find a static block of type "static" with id "mismatching_id" in this file.',
927
+ );
928
+ });
929
+ });
930
+
931
+ describe('When the static block preset is defined in a nested block', () => {
932
+ const makeTheme = (
933
+ preset: Preset.PresetBlockHash,
934
+ blocks_order: string[] = [],
935
+ ): MockTheme => {
936
+ return {
937
+ [`${path}/slideshow-container.liquid`]: `
938
+ # This file demonstrates how a static block can be used inside a nested block's preset
939
+ {% content_for "blocks" %}
940
+
941
+ {% schema %}
942
+ {
943
+ "name": "Slideshow container",
944
+ "blocks": [{ "type": "slideshow" }],
945
+ "presets": [{
946
+ "name": "default",
947
+ "block_order": ["slideshow1"],
948
+ "blocks": {
949
+ "slideshow1": {
950
+ "type": "slideshow",
951
+ "blocks": ${JSON.stringify(preset, null, 2)},
952
+ "block_order": ${JSON.stringify(blocks_order)}
953
+ }
954
+ }
955
+ }]
956
+ }
957
+ {% endschema %}
958
+ `,
959
+ [`blocks/slideshow.liquid`]: `
960
+ # Static block is defined in the body of the file
961
+ {% content_for "block", type: "static", id: "static_id" %}
962
+ # ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
963
+
964
+ {% schema %}
965
+ { "name": "Slideshow" }
966
+ {% endschema %}
967
+ `,
968
+ 'blocks/static.liquid': `
969
+ {% schema %}
970
+ {
971
+ "name": "some static block",
972
+ "settings": [${JSON.stringify(textSetting)}]
973
+ }
974
+ {% endschema %}
975
+ `,
976
+ };
977
+ };
978
+
979
+ it('is silent for valid static blocks references', async () => {
980
+ const theme = makeTheme({
981
+ static_id: {
982
+ type: 'static',
983
+ static: true,
984
+ },
985
+ });
986
+ const offenses = await check(theme, [ValidBlockTarget]);
987
+ expect(offenses).to.be.empty;
988
+ });
989
+
990
+ it('reports warnings when using a mismatching (or nonexisting) static block', async () => {
991
+ const theme = makeTheme({
992
+ mismatching_id: {
993
+ type: 'static',
994
+ static: true,
995
+ },
996
+ });
997
+ const offenses = await check(theme, [ValidBlockTarget]);
998
+ expect(offenses).not.to.be.empty;
999
+ expect(offenses).to.containOffense(
1000
+ 'Could not find a static block of type "static" with id "mismatching_id" in "blocks/slideshow.liquid".',
1001
+ );
1002
+ });
1003
+ });
1004
+ });
1005
+
1006
+ describe('When preset are defined as an array', () => {
1007
+ describe('When the static block is used in the same file', () => {
1008
+ const makeTheme = (preset: Preset.PresetBlockForArray[]): MockTheme => {
1009
+ return {
1010
+ 'blocks/static.liquid': `
1011
+ {% schema %}
1012
+ {
1013
+ "name": "some static block",
1014
+ "settings": [{ "label": "some setting", "type": "text", "id": "text" }],
1015
+ }
1016
+ {% endschema %}
1017
+ `,
1018
+ [`${path}/slideshow.liquid`]: `
1019
+
1020
+ # Static block is defined in the body of the file
1021
+ {% content_for "block", type: "static", id: "static_id" %}
1022
+ # ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1023
+
1024
+ {% schema %}
1025
+ {
1026
+ "name": "Slideshow",
1027
+ "presets": [
1028
+ {
1029
+ "name": "Default",
1030
+ "blocks": ${JSON.stringify(preset, null, 2)}
1031
+ }
1032
+ ]
1033
+ }
1034
+ {% endschema %}
1035
+ `,
1036
+ };
1037
+ };
1038
+
1039
+ it(`is silent for valid static blocks references (${path} bucket)`, async () => {
1040
+ const theme: MockTheme = makeTheme([
1041
+ {
1042
+ type: 'static',
1043
+ id: 'static_id',
1044
+ static: true,
1045
+ settings: {
1046
+ text: 'some text',
1047
+ },
1048
+ },
1049
+ ]);
1050
+ const offenses = await check(theme, [ValidBlockTarget]);
1051
+ expect(offenses).to.be.empty;
1052
+ });
1053
+
1054
+ it(`reports a warning for missing (or mismatching) static blocks references (${path} bucket)`, async () => {
1055
+ const theme: MockTheme = makeTheme([
1056
+ {
1057
+ type: 'static',
1058
+ id: 'mismatching_id',
1059
+ static: true,
1060
+ settings: {
1061
+ text: 'some text',
1062
+ },
1063
+ },
1064
+ ]);
1065
+
1066
+ const offenses = await check(theme, [ValidBlockTarget]);
1067
+ expect(offenses).not.to.be.empty;
1068
+ expect(offenses).to.containOffense(
1069
+ 'Could not find a static block of type "static" with id "mismatching_id" in this file.',
1070
+ );
1071
+ });
1072
+ });
1073
+ });
1074
+
1075
+ describe('When the static block preset is defined in a nested block', () => {
1076
+ const makeTheme = (
1077
+ preset: Preset.PresetBlockForArray[],
1078
+ blocks_order: string[] = [],
1079
+ ): MockTheme => {
1080
+ return {
1081
+ [`${path}/slideshow-container.liquid`]: `
1082
+ # This file demonstrates how a static block can be used inside a nested block's preset
1083
+ {% content_for "blocks" %}
1084
+
1085
+ {% schema %}
1086
+ {
1087
+ "name": "Slideshow container",
1088
+ "blocks": [{ "type": "slideshow" }],
1089
+ "presets": [{
1090
+ "name": "default",
1091
+ "blocks": [
1092
+ {
1093
+ "type": "slideshow",
1094
+ "id": "slideshow1",
1095
+ "blocks": ${JSON.stringify(preset, null, 2)},
1096
+ }
1097
+ ]
1098
+ }]
1099
+ }
1100
+ {% endschema %}
1101
+ `,
1102
+ [`blocks/slideshow.liquid`]: `
1103
+ # Static block is defined in the body of the file
1104
+ {% content_for "block", type: "static", id: "static_id" %}
1105
+ # ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
1106
+
1107
+ {% schema %}
1108
+ { "name": "Slideshow" }
1109
+ {% endschema %}
1110
+ `,
1111
+ 'blocks/static.liquid': `
1112
+ {% schema %}
1113
+ {
1114
+ "name": "some static block",
1115
+ "settings": [${JSON.stringify(textSetting)}]
1116
+ }
1117
+ {% endschema %}
1118
+ `,
1119
+ };
1120
+ };
1121
+
1122
+ it('is silent for valid static blocks references', async () => {
1123
+ const theme = makeTheme([
1124
+ {
1125
+ id: 'static_id',
1126
+ type: 'static',
1127
+ static: true,
1128
+ },
1129
+ ]);
1130
+ const offenses = await check(theme, [ValidBlockTarget]);
1131
+ expect(offenses).to.be.empty;
1132
+ });
1133
+
1134
+ it('reports warnings when using a mismatching (or nonexisting) static block', async () => {
1135
+ const theme = makeTheme([
1136
+ {
1137
+ id: 'mismatching_id',
1138
+ type: 'static',
1139
+ static: true,
1140
+ },
1141
+ ]);
1142
+ const offenses = await check(theme, [ValidBlockTarget]);
1143
+ expect(offenses).not.to.be.empty;
1144
+ expect(offenses).to.containOffense(
1145
+ 'Could not find a static block of type "static" with id "mismatching_id" in "blocks/slideshow.liquid".',
1146
+ );
1147
+ });
1148
+ });
1149
+ });
1150
+
1151
+ it(`should report errors with correct indices for nested blocks when they are not allowed (${path} bucket)`, async () => {
1152
+ const theme: MockTheme = {
1153
+ 'blocks/image.liquid': '',
1154
+ 'blocks/group.liquid': '',
1155
+ 'blocks/text.liquid': '',
1156
+ 'blocks/slide.liquid': `
1157
+ {% schema %}
1158
+ {
1159
+ "name": "Slide",
1160
+ "blocks": [
1161
+ {
1162
+ "type": "text"
1163
+ },
1164
+ {
1165
+ "type": "image"
1166
+ }
1167
+ ]
1168
+ }
1169
+ {% endschema %}
1170
+ `,
1171
+ [`${path}/slideshow.liquid`]: `
1172
+ {% schema %}
1173
+ {
1174
+ "name": "Slideshow",
1175
+ "blocks": [
1176
+ {
1177
+ "type": "slide"
1178
+ }
1179
+ ],
1180
+ "presets": [
1181
+ {
1182
+ "name": "Default",
1183
+ "blocks": [
1184
+ {
1185
+ "type": "slide",
1186
+ "blocks": [
1187
+ {
1188
+ "type": "group"
1189
+ }
1190
+ ]
1191
+ }
1192
+ ]
1193
+ }
1194
+ ]
1195
+ }
1196
+ {% endschema %}
1197
+ `,
1198
+ };
1199
+
1200
+ const offenses = await check(theme, [ValidBlockTarget]);
1201
+ expect(offenses).to.have.length(1);
1202
+ const content = theme[`${path}/slideshow.liquid`];
1203
+ const erroredContent = content.slice(offenses[0].start.index, offenses[0].end.index);
1204
+ expect(erroredContent).to.equal('"group"');
1205
+ });
1206
+
1207
+ it(`should not report errors for nested blocks when they are allowed (${path} bucket)`, async () => {
1208
+ const theme: MockTheme = {
1209
+ 'blocks/image.liquid': '',
1210
+ 'blocks/text.liquid': '',
1211
+ 'blocks/slide.liquid': `
1212
+ {% schema %}
1213
+ {
1214
+ "name": "Slide",
1215
+ "blocks": [
1216
+ {
1217
+ "type": "text"
1218
+ },
1219
+ {
1220
+ "type": "image"
1221
+ }
1222
+ ]
1223
+ }
1224
+ {% endschema %}
1225
+ `,
1226
+ [`${path}/slideshow.liquid`]: `
1227
+ {% schema %}
1228
+ {
1229
+ "name": "Slideshow",
1230
+ "blocks": [
1231
+ {
1232
+ "type": "slide"
1233
+ }
1234
+ ],
1235
+ "presets": [
1236
+ {
1237
+ "name": "Default",
1238
+ "blocks": [
1239
+ {
1240
+ "type": "slide",
1241
+ "blocks": [
1242
+ {
1243
+ "type": "image"
1244
+ }
1245
+ ]
1246
+ }
1247
+ ]
1248
+ }
1249
+ ]
1250
+ }
1251
+ {% endschema %}
1252
+ `,
1253
+ };
1254
+
1255
+ const offenses = await check(theme, [ValidBlockTarget]);
1256
+ expect(offenses).to.be.empty;
1257
+ });
1258
+
1259
+ it(`should report errors on the correct file for nested blocks when they are not allowed (${path} bucket)`, async () => {
1260
+ const theme: MockTheme = {
1261
+ 'blocks/image.liquid': '',
1262
+ 'blocks/group.liquid': '',
1263
+ 'blocks/text.liquid': '',
1264
+ 'blocks/slide.liquid': `
1265
+ {% schema %}
1266
+ {
1267
+ "name": "Slide",
1268
+ "blocks": [
1269
+ {
1270
+ "type": "text"
1271
+ },
1272
+ {
1273
+ "type": "image"
1274
+ }
1275
+ ]
1276
+ }
1277
+ {% endschema %}
1278
+ `,
1279
+ [`${path}/slideshow.liquid`]: `
1280
+ {% schema %}
1281
+ {
1282
+ "name": "Slideshow",
1283
+ "blocks": [
1284
+ {
1285
+ "type": "slide"
1286
+ }
1287
+ ],
1288
+ "presets": [
1289
+ {
1290
+ "name": "Default",
1291
+ "blocks": [
1292
+ {
1293
+ "type": "slide",
1294
+ "blocks": [
1295
+ {
1296
+ "type": "group"
1297
+ }
1298
+ ]
1299
+ }
1300
+ ]
1301
+ }
1302
+ ]
1303
+ }
1304
+ {% endschema %}
1305
+ `,
1306
+ };
1307
+
1308
+ const offenses = await check(theme, [ValidBlockTarget]);
1309
+ expect(offenses).to.have.lengthOf(1);
1310
+ expect(offenses[0].uri).to.equal(`file:///${path}/slideshow.liquid`);
1311
+ });
1312
+
1313
+ it('should not crash or timeout with cyclical nested block relationships', async () => {
1314
+ const theme: MockTheme = {
1315
+ 'blocks/block-b.liquid': `
1316
+ {% schema %}
1317
+ {
1318
+ "name": "Block B",
1319
+ "blocks": [
1320
+ {
1321
+ "type": "block-c"
1322
+ }
1323
+ ]
1324
+ }
1325
+ {% endschema %}
1326
+ `,
1327
+ 'blocks/block-a.liquid': `
1328
+ {% schema %}
1329
+ {
1330
+ "name": "Block A",
1331
+ "blocks": [
1332
+ {
1333
+ "type": "block-b"
1334
+ }
1335
+ ],
1336
+ "presets": [
1337
+ {
1338
+ "name": "Default",
1339
+ "blocks": [
1340
+ {
1341
+ "type": "block-b",
1342
+ "blocks": [
1343
+ {
1344
+ "type": "block-c"
1345
+ }
1346
+ ]
1347
+ }
1348
+ ]
1349
+ }
1350
+ ]
1351
+ }
1352
+ {% endschema %}
1353
+ `,
1354
+ 'blocks/block-c.liquid': `
1355
+ {% schema %}
1356
+ {
1357
+ "name": "Block C",
1358
+ "blocks": [
1359
+ {
1360
+ "type": "block-a"
1361
+ }
1362
+ ],
1363
+ "presets": [
1364
+ {
1365
+ "name": "Default",
1366
+ "blocks": [
1367
+ {
1368
+ "type": "block-a",
1369
+ "blocks": [
1370
+ {
1371
+ "type": "block-b"
1372
+ }
1373
+ ]
1374
+ }
1375
+ ]
1376
+ }
1377
+ ]
1378
+ }
1379
+ {% endschema %}
1380
+ `,
1381
+ };
1382
+
1383
+ const timeout = new Promise((_, reject) =>
1384
+ setTimeout(() => reject(new Error('Test exceeded 500 ms')), 500),
1385
+ );
1386
+
1387
+ const testPromise = (async () => {
1388
+ const offenses = await check(theme, [ValidBlockTarget]);
1389
+ expect(offenses).to.be.empty;
1390
+ })();
1391
+
1392
+ await Promise.race([testPromise, timeout]);
1393
+ });
1394
+ });
1395
+ });
1396
+ });