@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.
- package/CHANGELOG.md +9 -0
- package/README.md +92 -0
- package/dist/AugmentedThemeDocset.d.ts +12 -0
- package/dist/AugmentedThemeDocset.js +126 -0
- package/dist/AugmentedThemeDocset.js.map +1 -0
- package/dist/JSONValidator.d.ts +20 -0
- package/dist/JSONValidator.js +76 -0
- package/dist/JSONValidator.js.map +1 -0
- package/dist/checks/app-block-missing-schema/index.d.ts +2 -0
- package/dist/checks/app-block-missing-schema/index.js +46 -0
- package/dist/checks/app-block-missing-schema/index.js.map +1 -0
- package/dist/checks/app-block-valid-tags/index.d.ts +10 -0
- package/dist/checks/app-block-valid-tags/index.js +49 -0
- package/dist/checks/app-block-valid-tags/index.js.map +1 -0
- package/dist/checks/asset-preload/index.d.ts +2 -0
- package/dist/checks/asset-preload/index.js +56 -0
- package/dist/checks/asset-preload/index.js.map +1 -0
- package/dist/checks/asset-size-app-block-css/index.d.ts +6 -0
- package/dist/checks/asset-size-app-block-css/index.js +64 -0
- package/dist/checks/asset-size-app-block-css/index.js.map +1 -0
- package/dist/checks/asset-size-app-block-javascript/index.d.ts +6 -0
- package/dist/checks/asset-size-app-block-javascript/index.js +64 -0
- package/dist/checks/asset-size-app-block-javascript/index.js.map +1 -0
- package/dist/checks/asset-size-css/index.d.ts +6 -0
- package/dist/checks/asset-size-css/index.js +125 -0
- package/dist/checks/asset-size-css/index.js.map +1 -0
- package/dist/checks/asset-size-javascript/index.d.ts +6 -0
- package/dist/checks/asset-size-javascript/index.js +110 -0
- package/dist/checks/asset-size-javascript/index.js.map +1 -0
- package/dist/checks/block-id-usage/index.d.ts +2 -0
- package/dist/checks/block-id-usage/index.js +60 -0
- package/dist/checks/block-id-usage/index.js.map +1 -0
- package/dist/checks/cdn-preconnect/index.d.ts +2 -0
- package/dist/checks/cdn-preconnect/index.js +44 -0
- package/dist/checks/cdn-preconnect/index.js.map +1 -0
- package/dist/checks/content-for-header-modification/index.d.ts +2 -0
- package/dist/checks/content-for-header-modification/index.js +66 -0
- package/dist/checks/content-for-header-modification/index.js.map +1 -0
- package/dist/checks/deprecate-bgsizes/index.d.ts +2 -0
- package/dist/checks/deprecate-bgsizes/index.js +46 -0
- package/dist/checks/deprecate-bgsizes/index.js.map +1 -0
- package/dist/checks/deprecate-lazysizes/index.d.ts +2 -0
- package/dist/checks/deprecate-lazysizes/index.js +52 -0
- package/dist/checks/deprecate-lazysizes/index.js.map +1 -0
- package/dist/checks/deprecated-filter/fixes.d.ts +8 -0
- package/dist/checks/deprecated-filter/fixes.js +205 -0
- package/dist/checks/deprecated-filter/fixes.js.map +1 -0
- package/dist/checks/deprecated-filter/index.d.ts +2 -0
- package/dist/checks/deprecated-filter/index.js +93 -0
- package/dist/checks/deprecated-filter/index.js.map +1 -0
- package/dist/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.d.ts +1 -0
- package/dist/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.js +1347 -0
- package/dist/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.js.map +1 -0
- package/dist/checks/deprecated-fonts-on-sections-and-blocks/index.d.ts +2 -0
- package/dist/checks/deprecated-fonts-on-sections-and-blocks/index.js +156 -0
- package/dist/checks/deprecated-fonts-on-sections-and-blocks/index.js.map +1 -0
- package/dist/checks/deprecated-fonts-on-settings-schema/index.d.ts +2 -0
- package/dist/checks/deprecated-fonts-on-settings-schema/index.js +56 -0
- package/dist/checks/deprecated-fonts-on-settings-schema/index.js.map +1 -0
- package/dist/checks/deprecated-tag/index.d.ts +2 -0
- package/dist/checks/deprecated-tag/index.js +48 -0
- package/dist/checks/deprecated-tag/index.js.map +1 -0
- package/dist/checks/duplicate-content-for-arguments/index.d.ts +2 -0
- package/dist/checks/duplicate-content-for-arguments/index.js +39 -0
- package/dist/checks/duplicate-content-for-arguments/index.js.map +1 -0
- package/dist/checks/duplicate-function-arguments/index.d.ts +2 -0
- package/dist/checks/duplicate-function-arguments/index.js +40 -0
- package/dist/checks/duplicate-function-arguments/index.js.map +1 -0
- package/dist/checks/duplicate-render-partial-arguments/index.d.ts +2 -0
- package/dist/checks/duplicate-render-partial-arguments/index.js +43 -0
- package/dist/checks/duplicate-render-partial-arguments/index.js.map +1 -0
- package/dist/checks/empty-block-content/index.d.ts +2 -0
- package/dist/checks/empty-block-content/index.js +60 -0
- package/dist/checks/empty-block-content/index.js.map +1 -0
- package/dist/checks/graphql/index.d.ts +2 -0
- package/dist/checks/graphql/index.js +58 -0
- package/dist/checks/graphql/index.js.map +1 -0
- package/dist/checks/graphql-variables/index.d.ts +8 -0
- package/dist/checks/graphql-variables/index.js +91 -0
- package/dist/checks/graphql-variables/index.js.map +1 -0
- package/dist/checks/hardcoded-routes/index.d.ts +2 -0
- package/dist/checks/hardcoded-routes/index.js +89 -0
- package/dist/checks/hardcoded-routes/index.js.map +1 -0
- package/dist/checks/img-width-and-height/index.d.ts +2 -0
- package/dist/checks/img-width-and-height/index.js +46 -0
- package/dist/checks/img-width-and-height/index.js.map +1 -0
- package/dist/checks/index.d.ts +8 -0
- package/dist/checks/index.js +154 -0
- package/dist/checks/index.js.map +1 -0
- package/dist/checks/invalid-hash-assign-target/index.d.ts +2 -0
- package/dist/checks/invalid-hash-assign-target/index.js +252 -0
- package/dist/checks/invalid-hash-assign-target/index.js.map +1 -0
- package/dist/checks/json-missing-block/index.d.ts +2 -0
- package/dist/checks/json-missing-block/index.js +48 -0
- package/dist/checks/json-missing-block/index.js.map +1 -0
- package/dist/checks/json-missing-block/missing-block-utils.d.ts +4 -0
- package/dist/checks/json-missing-block/missing-block-utils.js +87 -0
- package/dist/checks/json-missing-block/missing-block-utils.js.map +1 -0
- package/dist/checks/json-syntax-error/index.d.ts +2 -0
- package/dist/checks/json-syntax-error/index.js +92 -0
- package/dist/checks/json-syntax-error/index.js.map +1 -0
- package/dist/checks/liquid-free-settings/index.d.ts +2 -0
- package/dist/checks/liquid-free-settings/index.js +64 -0
- package/dist/checks/liquid-free-settings/index.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.js +23 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.js +136 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.js +26 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidEchoValue.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidEchoValue.js +59 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidEchoValue.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidFilterName.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidFilterName.js +66 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidFilterName.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.js +73 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopRange.d.ts +4 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopRange.js +54 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidLoopRange.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.js +71 -0
- package/dist/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/MultipleAssignValues.d.ts +3 -0
- package/dist/checks/liquid-html-syntax-error/checks/MultipleAssignValues.js +69 -0
- package/dist/checks/liquid-html-syntax-error/checks/MultipleAssignValues.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/checks/utils.d.ts +15 -0
- package/dist/checks/liquid-html-syntax-error/checks/utils.js +58 -0
- package/dist/checks/liquid-html-syntax-error/checks/utils.js.map +1 -0
- package/dist/checks/liquid-html-syntax-error/index.d.ts +2 -0
- package/dist/checks/liquid-html-syntax-error/index.js +131 -0
- package/dist/checks/liquid-html-syntax-error/index.js.map +1 -0
- package/dist/checks/matching-translations/index.d.ts +2 -0
- package/dist/checks/matching-translations/index.js +146 -0
- package/dist/checks/matching-translations/index.js.map +1 -0
- package/dist/checks/metadata-params/index.d.ts +2 -0
- package/dist/checks/metadata-params/index.js +96 -0
- package/dist/checks/metadata-params/index.js.map +1 -0
- package/dist/checks/missing-asset/index.d.ts +2 -0
- package/dist/checks/missing-asset/index.js +44 -0
- package/dist/checks/missing-asset/index.js.map +1 -0
- package/dist/checks/missing-content-for-arguments/index.d.ts +2 -0
- package/dist/checks/missing-content-for-arguments/index.js +36 -0
- package/dist/checks/missing-content-for-arguments/index.js.map +1 -0
- package/dist/checks/missing-template/index.d.ts +6 -0
- package/dist/checks/missing-template/index.js +70 -0
- package/dist/checks/missing-template/index.js.map +1 -0
- package/dist/checks/orphaned-partial/index.d.ts +2 -0
- package/dist/checks/orphaned-partial/index.js +42 -0
- package/dist/checks/orphaned-partial/index.js.map +1 -0
- package/dist/checks/pagination-size/index.d.ts +7 -0
- package/dist/checks/pagination-size/index.js +89 -0
- package/dist/checks/pagination-size/index.js.map +1 -0
- package/dist/checks/parser-blocking-script/index.d.ts +2 -0
- package/dist/checks/parser-blocking-script/index.js +81 -0
- package/dist/checks/parser-blocking-script/index.js.map +1 -0
- package/dist/checks/parser-blocking-script/suggestions.d.ts +4 -0
- package/dist/checks/parser-blocking-script/suggestions.js +22 -0
- package/dist/checks/parser-blocking-script/suggestions.js.map +1 -0
- package/dist/checks/remote-asset/index.d.ts +6 -0
- package/dist/checks/remote-asset/index.js +189 -0
- package/dist/checks/remote-asset/index.js.map +1 -0
- package/dist/checks/reserved-doc-param-names/index.d.ts +2 -0
- package/dist/checks/reserved-doc-param-names/index.js +46 -0
- package/dist/checks/reserved-doc-param-names/index.js.map +1 -0
- package/dist/checks/schema-presets-block-order/index.d.ts +2 -0
- package/dist/checks/schema-presets-block-order/index.js +108 -0
- package/dist/checks/schema-presets-block-order/index.js.map +1 -0
- package/dist/checks/schema-presets-static-blocks/index.d.ts +2 -0
- package/dist/checks/schema-presets-static-blocks/index.js +109 -0
- package/dist/checks/schema-presets-static-blocks/index.js.map +1 -0
- package/dist/checks/static-stylesheet-and-javascript-tags/index.d.ts +2 -0
- package/dist/checks/static-stylesheet-and-javascript-tags/index.js +42 -0
- package/dist/checks/static-stylesheet-and-javascript-tags/index.js.map +1 -0
- package/dist/checks/translation-key-exists/index.d.ts +2 -0
- package/dist/checks/translation-key-exists/index.js +67 -0
- package/dist/checks/translation-key-exists/index.js.map +1 -0
- package/dist/checks/unclosed-html-element/index.d.ts +2 -0
- package/dist/checks/unclosed-html-element/index.js +252 -0
- package/dist/checks/unclosed-html-element/index.js.map +1 -0
- package/dist/checks/undefined-object/index.d.ts +2 -0
- package/dist/checks/undefined-object/index.js +255 -0
- package/dist/checks/undefined-object/index.js.map +1 -0
- package/dist/checks/unique-doc-param-names/index.d.ts +2 -0
- package/dist/checks/unique-doc-param-names/index.js +37 -0
- package/dist/checks/unique-doc-param-names/index.js.map +1 -0
- package/dist/checks/unique-settings-id/index.d.ts +2 -0
- package/dist/checks/unique-settings-id/index.js +69 -0
- package/dist/checks/unique-settings-id/index.js.map +1 -0
- package/dist/checks/unique-settings-id/test-data.d.ts +2 -0
- package/dist/checks/unique-settings-id/test-data.js +1194 -0
- package/dist/checks/unique-settings-id/test-data.js.map +1 -0
- package/dist/checks/unique-static-block-id/index.d.ts +2 -0
- package/dist/checks/unique-static-block-id/index.js +56 -0
- package/dist/checks/unique-static-block-id/index.js.map +1 -0
- package/dist/checks/unknown-filter/index.d.ts +2 -0
- package/dist/checks/unknown-filter/index.js +38 -0
- package/dist/checks/unknown-filter/index.js.map +1 -0
- package/dist/checks/unknown-property/index.d.ts +2 -0
- package/dist/checks/unknown-property/index.js +361 -0
- package/dist/checks/unknown-property/index.js.map +1 -0
- package/dist/checks/unknown-property/property-shape.d.ts +41 -0
- package/dist/checks/unknown-property/property-shape.js +267 -0
- package/dist/checks/unknown-property/property-shape.js.map +1 -0
- package/dist/checks/unrecognized-content-for-arguments/index.d.ts +2 -0
- package/dist/checks/unrecognized-content-for-arguments/index.js +43 -0
- package/dist/checks/unrecognized-content-for-arguments/index.js.map +1 -0
- package/dist/checks/unrecognized-render-partial-arguments/index.d.ts +2 -0
- package/dist/checks/unrecognized-render-partial-arguments/index.js +59 -0
- package/dist/checks/unrecognized-render-partial-arguments/index.js.map +1 -0
- package/dist/checks/unused-assign/index.d.ts +2 -0
- package/dist/checks/unused-assign/index.js +77 -0
- package/dist/checks/unused-assign/index.js.map +1 -0
- package/dist/checks/unused-doc-param/index.d.ts +2 -0
- package/dist/checks/unused-doc-param/index.js +55 -0
- package/dist/checks/unused-doc-param/index.js.map +1 -0
- package/dist/checks/utils.d.ts +22 -0
- package/dist/checks/utils.js +74 -0
- package/dist/checks/utils.js.map +1 -0
- package/dist/checks/valid-block-target/index.d.ts +2 -0
- package/dist/checks/valid-block-target/index.js +99 -0
- package/dist/checks/valid-block-target/index.js.map +1 -0
- package/dist/checks/valid-content-for-argument-types/index.d.ts +2 -0
- package/dist/checks/valid-content-for-argument-types/index.js +35 -0
- package/dist/checks/valid-content-for-argument-types/index.js.map +1 -0
- package/dist/checks/valid-content-for-arguments/index.d.ts +2 -0
- package/dist/checks/valid-content-for-arguments/index.js +82 -0
- package/dist/checks/valid-content-for-arguments/index.js.map +1 -0
- package/dist/checks/valid-doc-param-types/index.d.ts +2 -0
- package/dist/checks/valid-doc-param-types/index.js +61 -0
- package/dist/checks/valid-doc-param-types/index.js.map +1 -0
- package/dist/checks/valid-html-translation/index.d.ts +2 -0
- package/dist/checks/valid-html-translation/index.js +46 -0
- package/dist/checks/valid-html-translation/index.js.map +1 -0
- package/dist/checks/valid-json/index.d.ts +2 -0
- package/dist/checks/valid-json/index.js +36 -0
- package/dist/checks/valid-json/index.js.map +1 -0
- package/dist/checks/valid-local-blocks/index.d.ts +2 -0
- package/dist/checks/valid-local-blocks/index.js +66 -0
- package/dist/checks/valid-local-blocks/index.js.map +1 -0
- package/dist/checks/valid-local-blocks/valid-block-utils.d.ts +13 -0
- package/dist/checks/valid-local-blocks/valid-block-utils.js +74 -0
- package/dist/checks/valid-local-blocks/valid-block-utils.js.map +1 -0
- package/dist/checks/valid-render-partial-argument-types/index.d.ts +2 -0
- package/dist/checks/valid-render-partial-argument-types/index.js +66 -0
- package/dist/checks/valid-render-partial-argument-types/index.js.map +1 -0
- package/dist/checks/valid-schema/index.d.ts +2 -0
- package/dist/checks/valid-schema/index.js +40 -0
- package/dist/checks/valid-schema/index.js.map +1 -0
- package/dist/checks/valid-schema-name/index.d.ts +2 -0
- package/dist/checks/valid-schema-name/index.js +74 -0
- package/dist/checks/valid-schema-name/index.js.map +1 -0
- package/dist/checks/valid-settings-key/index.d.ts +2 -0
- package/dist/checks/valid-settings-key/index.js +90 -0
- package/dist/checks/valid-settings-key/index.js.map +1 -0
- package/dist/checks/valid-static-block-type/index.d.ts +2 -0
- package/dist/checks/valid-static-block-type/index.js +54 -0
- package/dist/checks/valid-static-block-type/index.js.map +1 -0
- package/dist/checks/valid-visible-if/index.d.ts +3 -0
- package/dist/checks/valid-visible-if/index.js +146 -0
- package/dist/checks/valid-visible-if/index.js.map +1 -0
- package/dist/checks/valid-visible-if/visible-if-utils.d.ts +14 -0
- package/dist/checks/valid-visible-if/visible-if-utils.js +125 -0
- package/dist/checks/valid-visible-if/visible-if-utils.js.map +1 -0
- package/dist/checks/variable-name/index.d.ts +6 -0
- package/dist/checks/variable-name/index.js +93 -0
- package/dist/checks/variable-name/index.js.map +1 -0
- package/dist/context-utils.d.ts +15 -0
- package/dist/context-utils.js +185 -0
- package/dist/context-utils.js.map +1 -0
- package/dist/create-safe-check.d.ts +2 -0
- package/dist/create-safe-check.js +15 -0
- package/dist/create-safe-check.js.map +1 -0
- package/dist/disabled-checks/index.d.ts +7 -0
- package/dist/disabled-checks/index.js +145 -0
- package/dist/disabled-checks/index.js.map +1 -0
- package/dist/disabled-checks/test-checks.d.ts +3 -0
- package/dist/disabled-checks/test-checks.js +59 -0
- package/dist/disabled-checks/test-checks.js.map +1 -0
- package/dist/doc-generator/DocBlockGenerator.d.ts +16 -0
- package/dist/doc-generator/DocBlockGenerator.js +464 -0
- package/dist/doc-generator/DocBlockGenerator.js.map +1 -0
- package/dist/doc-generator/index.d.ts +1 -0
- package/dist/doc-generator/index.js +6 -0
- package/dist/doc-generator/index.js.map +1 -0
- package/dist/find-root.d.ts +18 -0
- package/dist/find-root.js +81 -0
- package/dist/find-root.js.map +1 -0
- package/dist/fixes/apply-fix-to-string.d.ts +2 -0
- package/dist/fixes/apply-fix-to-string.js +50 -0
- package/dist/fixes/apply-fix-to-string.js.map +1 -0
- package/dist/fixes/autofix.d.ts +9 -0
- package/dist/fixes/autofix.js +30 -0
- package/dist/fixes/autofix.js.map +1 -0
- package/dist/fixes/corrector.d.ts +0 -0
- package/dist/fixes/corrector.js +2 -0
- package/dist/fixes/corrector.js.map +1 -0
- package/dist/fixes/correctors/base-corrector.d.ts +4 -0
- package/dist/fixes/correctors/base-corrector.js +3 -0
- package/dist/fixes/correctors/base-corrector.js.map +1 -0
- package/dist/fixes/correctors/graphql-corrector.d.ts +56 -0
- package/dist/fixes/correctors/graphql-corrector.js +78 -0
- package/dist/fixes/correctors/graphql-corrector.js.map +1 -0
- package/dist/fixes/correctors/index.d.ts +6 -0
- package/dist/fixes/correctors/index.js +30 -0
- package/dist/fixes/correctors/index.js.map +1 -0
- package/dist/fixes/correctors/json-corrector.d.ts +39 -0
- package/dist/fixes/correctors/json-corrector.js +86 -0
- package/dist/fixes/correctors/json-corrector.js.map +1 -0
- package/dist/fixes/correctors/string-corrector.d.ts +56 -0
- package/dist/fixes/correctors/string-corrector.js +78 -0
- package/dist/fixes/correctors/string-corrector.js.map +1 -0
- package/dist/fixes/index.d.ts +4 -0
- package/dist/fixes/index.js +14 -0
- package/dist/fixes/index.js.map +1 -0
- package/dist/fixes/utils.d.ts +2 -0
- package/dist/fixes/utils.js +9 -0
- package/dist/fixes/utils.js.map +1 -0
- package/dist/ignore.d.ts +2 -0
- package/dist/ignore.js +20 -0
- package/dist/ignore.js.map +1 -0
- package/dist/index.d.ts +23 -0
- package/dist/index.js +211 -0
- package/dist/index.js.map +1 -0
- package/dist/json.d.ts +17 -0
- package/dist/json.js +79 -0
- package/dist/json.js.map +1 -0
- package/dist/jsonc/parse.d.ts +25 -0
- package/dist/jsonc/parse.js +101 -0
- package/dist/jsonc/parse.js.map +1 -0
- package/dist/jsonc/types.d.ts +37 -0
- package/dist/jsonc/types.js +3 -0
- package/dist/jsonc/types.js.map +1 -0
- package/dist/liquid-doc/arguments.d.ts +36 -0
- package/dist/liquid-doc/arguments.js +239 -0
- package/dist/liquid-doc/arguments.js.map +1 -0
- package/dist/liquid-doc/liquidDoc.d.ts +33 -0
- package/dist/liquid-doc/liquidDoc.js +94 -0
- package/dist/liquid-doc/liquidDoc.js.map +1 -0
- package/dist/liquid-doc/utils.d.ts +49 -0
- package/dist/liquid-doc/utils.js +119 -0
- package/dist/liquid-doc/utils.js.map +1 -0
- package/dist/path.d.ts +10 -0
- package/dist/path.js +47 -0
- package/dist/path.js.map +1 -0
- package/dist/tags/content-for.d.ts +3 -0
- package/dist/tags/content-for.js +27 -0
- package/dist/tags/content-for.js.map +1 -0
- package/dist/test/MockFileSystem.d.ts +12 -0
- package/dist/test/MockFileSystem.js +109 -0
- package/dist/test/MockFileSystem.js.map +1 -0
- package/dist/test/MockTheme.d.ts +16 -0
- package/dist/test/MockTheme.js +16 -0
- package/dist/test/MockTheme.js.map +1 -0
- package/dist/test/chai-offer-fix-assertion.d.ts +22 -0
- package/dist/test/chai-offer-fix-assertion.js +20 -0
- package/dist/test/chai-offer-fix-assertion.js.map +1 -0
- package/dist/test/chai-suggest-assertion.d.ts +22 -0
- package/dist/test/chai-suggest-assertion.js +29 -0
- package/dist/test/chai-suggest-assertion.js.map +1 -0
- package/dist/test/contain-offense.d.ts +12 -0
- package/dist/test/contain-offense.js +36 -0
- package/dist/test/contain-offense.js.map +1 -0
- package/dist/test/index.d.ts +3 -0
- package/dist/test/index.js +20 -0
- package/dist/test/index.js.map +1 -0
- package/dist/test/test-helper.d.ts +14 -0
- package/dist/test/test-helper.js +289 -0
- package/dist/test/test-helper.js.map +1 -0
- package/dist/test/test-setup.d.ts +9 -0
- package/dist/test/test-setup.js +26 -0
- package/dist/test/test-setup.js.map +1 -0
- package/dist/to-schema.d.ts +16 -0
- package/dist/to-schema.js +218 -0
- package/dist/to-schema.js.map +1 -0
- package/dist/to-source-code.d.ts +5 -0
- package/dist/to-source-code.js +103 -0
- package/dist/to-source-code.js.map +1 -0
- package/dist/tsconfig.tsbuildinfo +1 -0
- package/dist/types/schema-prop-factory.d.ts +76 -0
- package/dist/types/schema-prop-factory.js +84 -0
- package/dist/types/schema-prop-factory.js.map +1 -0
- package/dist/types/schemas/index.d.ts +5 -0
- package/dist/types/schemas/index.js +6 -0
- package/dist/types/schemas/index.js.map +1 -0
- package/dist/types/schemas/preset.d.ts +38 -0
- package/dist/types/schemas/preset.js +3 -0
- package/dist/types/schemas/preset.js.map +1 -0
- package/dist/types/schemas/section.d.ts +49 -0
- package/dist/types/schemas/section.js +3 -0
- package/dist/types/schemas/section.js.map +1 -0
- package/dist/types/schemas/setting.d.ts +216 -0
- package/dist/types/schemas/setting.js +3 -0
- package/dist/types/schemas/setting.js.map +1 -0
- package/dist/types/schemas/template.d.ts +30 -0
- package/dist/types/schemas/template.js +3 -0
- package/dist/types/schemas/template.js.map +1 -0
- package/dist/types/schemas/theme-block.d.ts +24 -0
- package/dist/types/schemas/theme-block.js +3 -0
- package/dist/types/schemas/theme-block.js.map +1 -0
- package/dist/types/theme-liquid-docs.d.ts +131 -0
- package/dist/types/theme-liquid-docs.js +3 -0
- package/dist/types/theme-liquid-docs.js.map +1 -0
- package/dist/types/theme-schemas.d.ts +70 -0
- package/dist/types/theme-schemas.js +25 -0
- package/dist/types/theme-schemas.js.map +1 -0
- package/dist/types.d.ts +469 -0
- package/dist/types.js +55 -0
- package/dist/types.js.map +1 -0
- package/dist/utils/array.d.ts +5 -0
- package/dist/utils/array.js +28 -0
- package/dist/utils/array.js.map +1 -0
- package/dist/utils/block.d.ts +22 -0
- package/dist/utils/block.js +179 -0
- package/dist/utils/block.js.map +1 -0
- package/dist/utils/error.d.ts +2 -0
- package/dist/utils/error.js +44 -0
- package/dist/utils/error.js.map +1 -0
- package/dist/utils/file-utils.d.ts +6 -0
- package/dist/utils/file-utils.js +46 -0
- package/dist/utils/file-utils.js.map +1 -0
- package/dist/utils/index.d.ts +8 -0
- package/dist/utils/index.js +25 -0
- package/dist/utils/index.js.map +1 -0
- package/dist/utils/indexBy.d.ts +5 -0
- package/dist/utils/indexBy.js +15 -0
- package/dist/utils/indexBy.js.map +1 -0
- package/dist/utils/markup.d.ts +2 -0
- package/dist/utils/markup.js +10 -0
- package/dist/utils/markup.js.map +1 -0
- package/dist/utils/memo.d.ts +34 -0
- package/dist/utils/memo.js +61 -0
- package/dist/utils/memo.js.map +1 -0
- package/dist/utils/object.d.ts +1 -0
- package/dist/utils/object.js +7 -0
- package/dist/utils/object.js.map +1 -0
- package/dist/utils/position.d.ts +3 -0
- package/dist/utils/position.js +20 -0
- package/dist/utils/position.js.map +1 -0
- package/dist/utils/types.d.ts +52 -0
- package/dist/utils/types.js +23 -0
- package/dist/utils/types.js.map +1 -0
- package/dist/visitor.d.ts +24 -0
- package/dist/visitor.js +119 -0
- package/dist/visitor.js.map +1 -0
- package/dist/visitors/index.d.ts +2 -0
- package/dist/visitors/index.js +8 -0
- package/dist/visitors/index.js.map +1 -0
- package/dist/visitors/json.d.ts +2 -0
- package/dist/visitors/json.js +39 -0
- package/dist/visitors/json.js.map +1 -0
- package/dist/visitors/liquid.d.ts +2 -0
- package/dist/visitors/liquid.js +39 -0
- package/dist/visitors/liquid.js.map +1 -0
- package/package.json +45 -0
- package/src/AugmentedThemeDocset.spec.ts +148 -0
- package/src/AugmentedThemeDocset.ts +148 -0
- package/src/JSONValidator.ts +82 -0
- package/src/checks/app-block-missing-schema/index.spec.ts +121 -0
- package/src/checks/app-block-missing-schema/index.ts +46 -0
- package/src/checks/app-block-valid-tags/index.spec.ts +96 -0
- package/src/checks/app-block-valid-tags/index.ts +54 -0
- package/src/checks/asset-preload/index.spec.ts +78 -0
- package/src/checks/asset-preload/index.ts +65 -0
- package/src/checks/asset-size-app-block-css/index.spec.ts +88 -0
- package/src/checks/asset-size-app-block-css/index.ts +78 -0
- package/src/checks/asset-size-app-block-javascript/index.spec.ts +66 -0
- package/src/checks/asset-size-app-block-javascript/index.ts +78 -0
- package/src/checks/asset-size-css/index.spec.ts +166 -0
- package/src/checks/asset-size-css/index.ts +160 -0
- package/src/checks/asset-size-javascript/index.spec.ts +184 -0
- package/src/checks/asset-size-javascript/index.ts +144 -0
- package/src/checks/block-id-usage/index.spec.ts +76 -0
- package/src/checks/block-id-usage/index.ts +72 -0
- package/src/checks/cdn-preconnect/index.spec.ts +40 -0
- package/src/checks/cdn-preconnect/index.ts +43 -0
- package/src/checks/content-for-header-modification/index.spec.ts +65 -0
- package/src/checks/content-for-header-modification/index.ts +72 -0
- package/src/checks/deprecate-bgsizes/index.spec.ts +41 -0
- package/src/checks/deprecate-bgsizes/index.ts +49 -0
- package/src/checks/deprecate-lazysizes/index.spec.ts +26 -0
- package/src/checks/deprecate-lazysizes/index.ts +58 -0
- package/src/checks/deprecated-filter/fixes.ts +264 -0
- package/src/checks/deprecated-filter/index.spec.ts +274 -0
- package/src/checks/deprecated-filter/index.ts +113 -0
- package/src/checks/deprecated-fonts-on-sections-and-blocks/deprecated-fonts-data.ts +1343 -0
- package/src/checks/deprecated-fonts-on-sections-and-blocks/index.spec.ts +613 -0
- package/src/checks/deprecated-fonts-on-sections-and-blocks/index.ts +284 -0
- package/src/checks/deprecated-fonts-on-settings-schema/index.spec.ts +102 -0
- package/src/checks/deprecated-fonts-on-settings-schema/index.ts +66 -0
- package/src/checks/deprecated-tag/index.spec.ts +68 -0
- package/src/checks/deprecated-tag/index.ts +46 -0
- package/src/checks/duplicate-content-for-arguments/index.spec.ts +98 -0
- package/src/checks/duplicate-content-for-arguments/index.ts +43 -0
- package/src/checks/duplicate-function-arguments/index.spec.ts +98 -0
- package/src/checks/duplicate-function-arguments/index.ts +44 -0
- package/src/checks/duplicate-render-partial-arguments/index.spec.ts +120 -0
- package/src/checks/duplicate-render-partial-arguments/index.ts +48 -0
- package/src/checks/empty-block-content/index.spec.ts +117 -0
- package/src/checks/empty-block-content/index.ts +60 -0
- package/src/checks/graphql/index.ts +64 -0
- package/src/checks/graphql-variables/index.ts +113 -0
- package/src/checks/hardcoded-routes/index.spec.ts +58 -0
- package/src/checks/hardcoded-routes/index.ts +100 -0
- package/src/checks/img-width-and-height/index.spec.ts +79 -0
- package/src/checks/img-width-and-height/index.ts +52 -0
- package/src/checks/index.ts +160 -0
- package/src/checks/invalid-hash-assign-target/index.spec.ts +176 -0
- package/src/checks/invalid-hash-assign-target/index.ts +306 -0
- package/src/checks/json-missing-block/index.spec.ts +435 -0
- package/src/checks/json-missing-block/index.ts +56 -0
- package/src/checks/json-missing-block/missing-block-utils.ts +147 -0
- package/src/checks/json-syntax-error/index.spec.ts +64 -0
- package/src/checks/json-syntax-error/index.ts +92 -0
- package/src/checks/liquid-free-settings/index.spec.ts +180 -0
- package/src/checks/liquid-free-settings/index.ts +79 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidBooleanExpression.spec.ts +43 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidBooleanExpressions.ts +29 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.spec.ts +385 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNode.ts +165 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.spec.ts +52 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidConditionalNodeParenthesis.ts +39 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidEchoValue.spec.ts +108 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidEchoValue.ts +74 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidFilterName.spec.ts +223 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidFilterName.ts +92 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.spec.ts +145 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidLoopArguments.ts +116 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidLoopRange.spec.ts +84 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidLoopRange.ts +79 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.spec.ts +184 -0
- package/src/checks/liquid-html-syntax-error/checks/InvalidPipeSyntax.ts +91 -0
- package/src/checks/liquid-html-syntax-error/checks/MultipleAssignValues.spec.ts +82 -0
- package/src/checks/liquid-html-syntax-error/checks/MultipleAssignValues.ts +86 -0
- package/src/checks/liquid-html-syntax-error/checks/utils.spec.ts +82 -0
- package/src/checks/liquid-html-syntax-error/checks/utils.ts +66 -0
- package/src/checks/liquid-html-syntax-error/index.spec.ts +129 -0
- package/src/checks/liquid-html-syntax-error/index.ts +152 -0
- package/src/checks/matching-translations/index.spec.ts +400 -0
- package/src/checks/matching-translations/index.ts +175 -0
- package/src/checks/metadata-params/index.spec.ts +103 -0
- package/src/checks/metadata-params/index.ts +119 -0
- package/src/checks/missing-asset/index.spec.ts +59 -0
- package/src/checks/missing-asset/index.ts +48 -0
- package/src/checks/missing-content-for-arguments/index.spec.ts +144 -0
- package/src/checks/missing-content-for-arguments/index.ts +46 -0
- package/src/checks/missing-template/index.spec.ts +61 -0
- package/src/checks/missing-template/index.ts +101 -0
- package/src/checks/orphaned-partial/index.spec.ts +58 -0
- package/src/checks/orphaned-partial/index.ts +43 -0
- package/src/checks/pagination-size/index.spec.ts +158 -0
- package/src/checks/pagination-size/index.ts +104 -0
- package/src/checks/parser-blocking-script/index.spec.ts +225 -0
- package/src/checks/parser-blocking-script/index.ts +91 -0
- package/src/checks/parser-blocking-script/suggestions.ts +42 -0
- package/src/checks/remote-asset/index.spec.ts +280 -0
- package/src/checks/remote-asset/index.ts +238 -0
- package/src/checks/reserved-doc-param-names/index.spec.ts +62 -0
- package/src/checks/reserved-doc-param-names/index.ts +57 -0
- package/src/checks/schema-presets-block-order/index.spec.ts +344 -0
- package/src/checks/schema-presets-block-order/index.ts +154 -0
- package/src/checks/schema-presets-static-blocks/index.spec.ts +145 -0
- package/src/checks/schema-presets-static-blocks/index.ts +126 -0
- package/src/checks/static-stylesheet-and-javascript-tags/index.spec.ts +257 -0
- package/src/checks/static-stylesheet-and-javascript-tags/index.ts +48 -0
- package/src/checks/translation-key-exists/index.spec.ts +44 -0
- package/src/checks/translation-key-exists/index.ts +78 -0
- package/src/checks/unclosed-html-element/index.spec.ts +260 -0
- package/src/checks/unclosed-html-element/index.ts +296 -0
- package/src/checks/undefined-object/index.spec.ts +519 -0
- package/src/checks/undefined-object/index.ts +336 -0
- package/src/checks/unique-doc-param-names/index.spec.ts +35 -0
- package/src/checks/unique-doc-param-names/index.ts +39 -0
- package/src/checks/unique-settings-id/index.spec.ts +24 -0
- package/src/checks/unique-settings-id/index.ts +84 -0
- package/src/checks/unique-settings-id/test-data.ts +1191 -0
- package/src/checks/unique-static-block-id/index.spec.ts +55 -0
- package/src/checks/unique-static-block-id/index.ts +60 -0
- package/src/checks/unknown-filter/index.spec.ts +59 -0
- package/src/checks/unknown-filter/index.ts +38 -0
- package/src/checks/unknown-property/index.spec.ts +234 -0
- package/src/checks/unknown-property/index.ts +468 -0
- package/src/checks/unknown-property/property-shape.ts +315 -0
- package/src/checks/unrecognized-content-for-arguments/index.spec.ts +145 -0
- package/src/checks/unrecognized-content-for-arguments/index.ts +55 -0
- package/src/checks/unrecognized-render-partial-arguments/index.spec.ts +184 -0
- package/src/checks/unrecognized-render-partial-arguments/index.ts +76 -0
- package/src/checks/unused-assign/index.spec.ts +160 -0
- package/src/checks/unused-assign/index.ts +87 -0
- package/src/checks/unused-doc-param/index.spec.ts +89 -0
- package/src/checks/unused-doc-param/index.ts +59 -0
- package/src/checks/utils.ts +117 -0
- package/src/checks/valid-block-target/index.spec.ts +1396 -0
- package/src/checks/valid-block-target/index.ts +142 -0
- package/src/checks/valid-content-for-argument-types/index.spec.ts +382 -0
- package/src/checks/valid-content-for-argument-types/index.ts +42 -0
- package/src/checks/valid-content-for-arguments/index.spec.ts +107 -0
- package/src/checks/valid-content-for-arguments/index.ts +98 -0
- package/src/checks/valid-doc-param-types/index.spec.ts +75 -0
- package/src/checks/valid-doc-param-types/index.ts +71 -0
- package/src/checks/valid-html-translation/index.spec.ts +74 -0
- package/src/checks/valid-html-translation/index.ts +45 -0
- package/src/checks/valid-json/index.spec.ts +102 -0
- package/src/checks/valid-json/index.ts +34 -0
- package/src/checks/valid-local-blocks/index.spec.ts +286 -0
- package/src/checks/valid-local-blocks/index.ts +100 -0
- package/src/checks/valid-local-blocks/valid-block-utils.ts +97 -0
- package/src/checks/valid-render-partial-argument-types/index.spec.ts +468 -0
- package/src/checks/valid-render-partial-argument-types/index.ts +89 -0
- package/src/checks/valid-schema/index.spec.ts +174 -0
- package/src/checks/valid-schema/index.ts +41 -0
- package/src/checks/valid-schema-name/index.spec.ts +112 -0
- package/src/checks/valid-schema-name/index.ts +75 -0
- package/src/checks/valid-settings-key/index.spec.ts +321 -0
- package/src/checks/valid-settings-key/index.ts +144 -0
- package/src/checks/valid-static-block-type/index.spec.ts +38 -0
- package/src/checks/valid-static-block-type/index.ts +58 -0
- package/src/checks/valid-visible-if/index.spec.ts +619 -0
- package/src/checks/valid-visible-if/index.ts +184 -0
- package/src/checks/valid-visible-if/visible-if-utils.ts +158 -0
- package/src/checks/variable-name/index.spec.ts +62 -0
- package/src/checks/variable-name/index.ts +115 -0
- package/src/context-utils.spec.ts +103 -0
- package/src/context-utils.ts +220 -0
- package/src/create-safe-check.ts +13 -0
- package/src/disabled-checks/index.spec.ts +262 -0
- package/src/disabled-checks/index.ts +189 -0
- package/src/disabled-checks/test-checks.ts +60 -0
- package/src/find-root.ts +60 -0
- package/src/fixes/apply-fix-to-string.spec.ts +52 -0
- package/src/fixes/apply-fix-to-string.ts +59 -0
- package/src/fixes/autofix.spec.ts +85 -0
- package/src/fixes/autofix.ts +41 -0
- package/src/fixes/corrector.ts +0 -0
- package/src/fixes/correctors/base-corrector.ts +5 -0
- package/src/fixes/correctors/graphql-corrector.ts +78 -0
- package/src/fixes/correctors/index.ts +29 -0
- package/src/fixes/correctors/json-corrector.spec.ts +111 -0
- package/src/fixes/correctors/json-corrector.ts +106 -0
- package/src/fixes/correctors/string-corrector.ts +78 -0
- package/src/fixes/index.ts +4 -0
- package/src/fixes/utils.ts +6 -0
- package/src/ignore.spec.ts +202 -0
- package/src/ignore.ts +23 -0
- package/src/index.spec.ts +8 -0
- package/src/index.ts +234 -0
- package/src/json.spec.ts +140 -0
- package/src/json.ts +81 -0
- package/src/jsonc/parse.spec.ts +118 -0
- package/src/jsonc/parse.ts +121 -0
- package/src/jsonc/types.ts +47 -0
- package/src/liquid-doc/arguments.spec.ts +146 -0
- package/src/liquid-doc/arguments.ts +315 -0
- package/src/liquid-doc/liquidDoc.spec.ts +296 -0
- package/src/liquid-doc/liquidDoc.ts +147 -0
- package/src/liquid-doc/utils.spec.ts +23 -0
- package/src/liquid-doc/utils.ts +125 -0
- package/src/path.ts +45 -0
- package/src/tags/content-for.ts +25 -0
- package/src/test/MockFileSystem.spec.ts +71 -0
- package/src/test/MockFileSystem.ts +87 -0
- package/src/test/MockTheme.ts +17 -0
- package/src/test/chai-offer-fix-assertion.spec.ts +53 -0
- package/src/test/chai-offer-fix-assertion.ts +45 -0
- package/src/test/chai-suggest-assertion.spec.ts +53 -0
- package/src/test/chai-suggest-assertion.ts +62 -0
- package/src/test/contain-offense.spec.ts +74 -0
- package/src/test/contain-offense.ts +54 -0
- package/src/test/index.ts +3 -0
- package/src/test/test-helper.ts +327 -0
- package/src/test/test-setup.ts +36 -0
- package/src/to-schema.ts +231 -0
- package/src/to-source-code.ts +75 -0
- package/src/types/schema-prop-factory.ts +112 -0
- package/src/types/schemas/index.ts +5 -0
- package/src/types/schemas/preset.ts +52 -0
- package/src/types/schemas/section.ts +86 -0
- package/src/types/schemas/setting.ts +320 -0
- package/src/types/schemas/template.ts +34 -0
- package/src/types/schemas/theme-block.ts +34 -0
- package/src/types/theme-liquid-docs.ts +184 -0
- package/src/types/theme-schemas.ts +80 -0
- package/src/types.ts +617 -0
- package/src/utils/array.ts +31 -0
- package/src/utils/block.ts +300 -0
- package/src/utils/error.spec.ts +71 -0
- package/src/utils/error.ts +48 -0
- package/src/utils/file-utils.ts +58 -0
- package/src/utils/index.ts +8 -0
- package/src/utils/indexBy.ts +14 -0
- package/src/utils/markup.ts +10 -0
- package/src/utils/memo.spec.ts +83 -0
- package/src/utils/memo.ts +80 -0
- package/src/utils/object.ts +3 -0
- package/src/utils/position.ts +16 -0
- package/src/utils/types.ts +57 -0
- package/src/visitor.spec.ts +163 -0
- package/src/visitor.ts +161 -0
- package/src/visitors/index.ts +2 -0
- package/src/visitors/json.ts +41 -0
- package/src/visitors/liquid.ts +40 -0
- package/tsconfig.build.json +8 -0
- package/tsconfig.json +31 -0
|
@@ -0,0 +1,66 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidRenderPartialArgumentTypes = void 0;
|
|
4
|
+
const types_1 = require("../../types");
|
|
5
|
+
const liquid_html_parser_1 = require("@platformos/liquid-html-parser");
|
|
6
|
+
const utils_1 = require("../../liquid-doc/utils");
|
|
7
|
+
const arguments_1 = require("../../liquid-doc/arguments");
|
|
8
|
+
exports.ValidRenderPartialArgumentTypes = {
|
|
9
|
+
meta: {
|
|
10
|
+
code: 'ValidRenderPartialArgumentTypes',
|
|
11
|
+
name: 'Valid Render Partial Argument Types',
|
|
12
|
+
aliases: ['ValidRenderPartialParamTypes'],
|
|
13
|
+
docs: {
|
|
14
|
+
description: 'This check ensures that arguments passed to partial match the expected types defined in the liquidDoc header if present.',
|
|
15
|
+
recommended: true,
|
|
16
|
+
url: 'https://shopify.dev/docs/storefronts/themes/tools/theme-check/checks/valid-render-partial-argument-types',
|
|
17
|
+
},
|
|
18
|
+
type: types_1.SourceCodeType.LiquidHtml,
|
|
19
|
+
severity: types_1.Severity.WARNING,
|
|
20
|
+
schema: {},
|
|
21
|
+
targets: [],
|
|
22
|
+
},
|
|
23
|
+
create(context) {
|
|
24
|
+
/**
|
|
25
|
+
* Checks for type mismatches when alias is used with `for` or `with` syntax.
|
|
26
|
+
* This can be refactored at a later date to share more code with regular named arguments as they are both backed by LiquidExpression nodes.
|
|
27
|
+
*
|
|
28
|
+
* E.g. {% render 'card' with 123 as title %}
|
|
29
|
+
*/
|
|
30
|
+
function findAndReportAliasType(node, liquidDocParameters) {
|
|
31
|
+
if (node.alias &&
|
|
32
|
+
node.variable?.name &&
|
|
33
|
+
node.variable.name.type !== liquid_html_parser_1.NodeTypes.VariableLookup) {
|
|
34
|
+
const paramIsDefinedWithType = liquidDocParameters
|
|
35
|
+
.get(node.alias.value)
|
|
36
|
+
?.type?.toLowerCase();
|
|
37
|
+
if (paramIsDefinedWithType) {
|
|
38
|
+
const providedParamType = (0, utils_1.inferArgumentType)(node.variable.name);
|
|
39
|
+
if (!(0, utils_1.isTypeCompatible)(paramIsDefinedWithType, providedParamType)) {
|
|
40
|
+
const suggestions = (0, arguments_1.generateTypeMismatchSuggestions)(paramIsDefinedWithType, node.variable.name.position.start, node.variable.name.position.end);
|
|
41
|
+
context.report({
|
|
42
|
+
message: `Type mismatch for argument '${node.alias.value}': expected ${paramIsDefinedWithType}, got ${providedParamType}`,
|
|
43
|
+
startIndex: node.variable.name.position.start,
|
|
44
|
+
endIndex: node.variable.name.position.end,
|
|
45
|
+
suggest: suggestions,
|
|
46
|
+
});
|
|
47
|
+
}
|
|
48
|
+
}
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
return {
|
|
52
|
+
async RenderMarkup(node) {
|
|
53
|
+
const partialName = (0, arguments_1.getPartialName)(node);
|
|
54
|
+
if (!partialName)
|
|
55
|
+
return;
|
|
56
|
+
const liquidDocParameters = await (0, arguments_1.getLiquidDocParams)(context, `app/views/partials/${partialName}.liquid`);
|
|
57
|
+
if (!liquidDocParameters)
|
|
58
|
+
return;
|
|
59
|
+
findAndReportAliasType(node, liquidDocParameters);
|
|
60
|
+
const typeMismatchParams = (0, arguments_1.findTypeMismatchParams)(liquidDocParameters, node.args);
|
|
61
|
+
(0, arguments_1.reportTypeMismatches)(context, typeMismatchParams, liquidDocParameters);
|
|
62
|
+
},
|
|
63
|
+
};
|
|
64
|
+
},
|
|
65
|
+
};
|
|
66
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/checks/valid-render-partial-argument-types/index.ts"],"names":[],"mappings":";;;AAAA,uCAA8E;AAC9E,uEAAyE;AAEzE,kDAA6E;AAC7E,0DAMoC;AAEvB,QAAA,+BAA+B,GAA0B;IACpE,IAAI,EAAE;QACJ,IAAI,EAAE,iCAAiC;QACvC,IAAI,EAAE,qCAAqC;QAC3C,OAAO,EAAE,CAAC,8BAA8B,CAAC;QACzC,IAAI,EAAE;YACJ,WAAW,EACT,0HAA0H;YAC5H,WAAW,EAAE,IAAI;YACjB,GAAG,EAAE,0GAA0G;SAChH;QACD,IAAI,EAAE,sBAAc,CAAC,UAAU;QAC/B,QAAQ,EAAE,gBAAQ,CAAC,OAAO;QAC1B,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,EAAE;KACZ;IAED,MAAM,CAAC,OAAO;QACZ;;;;;WAKG;QACH,SAAS,sBAAsB,CAC7B,IAAkB,EAClB,mBAAoD;YAEpD,IACE,IAAI,CAAC,KAAK;gBACV,IAAI,CAAC,QAAQ,EAAE,IAAI;gBACnB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,KAAK,8BAAS,CAAC,cAAc,EACpD,CAAC;gBACD,MAAM,sBAAsB,GAAG,mBAAmB;qBAC/C,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,KAAK,CAAC;oBACtB,EAAE,IAAI,EAAE,WAAW,EAAE,CAAC;gBACxB,IAAI,sBAAsB,EAAE,CAAC;oBAC3B,MAAM,iBAAiB,GAAG,IAAA,yBAAiB,EAAC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC;oBAChE,IAAI,CAAC,IAAA,wBAAgB,EAAC,sBAAsB,EAAE,iBAAiB,CAAC,EAAE,CAAC;wBACjE,MAAM,WAAW,GAAG,IAAA,2CAA+B,EACjD,sBAAsB,EACtB,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK,EACjC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAChC,CAAC;wBAEF,OAAO,CAAC,MAAM,CAAC;4BACb,OAAO,EAAE,+BAA+B,IAAI,CAAC,KAAK,CAAC,KAAK,eAAe,sBAAsB,SAAS,iBAAiB,EAAE;4BACzH,UAAU,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,KAAK;4BAC7C,QAAQ,EAAE,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG;4BACzC,OAAO,EAAE,WAAW;yBACrB,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC;YACH,CAAC;QACH,CAAC;QAED,OAAO;YACL,KAAK,CAAC,YAAY,CAAC,IAAkB;gBACnC,MAAM,WAAW,GAAG,IAAA,0BAAc,EAAC,IAAI,CAAC,CAAC;gBAEzC,IAAI,CAAC,WAAW;oBAAE,OAAO;gBAEzB,MAAM,mBAAmB,GAAG,MAAM,IAAA,8BAAkB,EAClD,OAAO,EACP,sBAAsB,WAAW,SAAS,CAC3C,CAAC;gBAEF,IAAI,CAAC,mBAAmB;oBAAE,OAAO;gBAEjC,sBAAsB,CAAC,IAAI,EAAE,mBAAmB,CAAC,CAAC;gBAElD,MAAM,kBAAkB,GAAG,IAAA,kCAAsB,EAAC,mBAAmB,EAAE,IAAI,CAAC,IAAI,CAAC,CAAC;gBAClF,IAAA,gCAAoB,EAAC,OAAO,EAAE,kBAAkB,EAAE,mBAAmB,CAAC,CAAC;YACzE,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,40 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidSchema = void 0;
|
|
4
|
+
const types_1 = require("../../types");
|
|
5
|
+
exports.ValidSchema = {
|
|
6
|
+
meta: {
|
|
7
|
+
code: 'ValidSchema',
|
|
8
|
+
name: 'Prevent invalid JSON in {% schema %} tags',
|
|
9
|
+
docs: {
|
|
10
|
+
description: 'This check is aimed at eliminating JSON errors in schema tags.',
|
|
11
|
+
recommended: true,
|
|
12
|
+
url: 'https://shopify.dev/docs/storefronts/themes/tools/theme-check/checks/valid-schema',
|
|
13
|
+
},
|
|
14
|
+
type: types_1.SourceCodeType.LiquidHtml,
|
|
15
|
+
severity: types_1.Severity.ERROR,
|
|
16
|
+
schema: {},
|
|
17
|
+
targets: [],
|
|
18
|
+
},
|
|
19
|
+
create(context) {
|
|
20
|
+
return {
|
|
21
|
+
async LiquidRawTag(node) {
|
|
22
|
+
if (node.name !== 'schema' || node.body.kind !== 'json' || !context.validateJSON) {
|
|
23
|
+
return;
|
|
24
|
+
}
|
|
25
|
+
const jsonString = node.source.slice(node.blockStartPosition.end, node.blockEndPosition.start);
|
|
26
|
+
const problems = await context.validateJSON(context.file.uri, jsonString);
|
|
27
|
+
if (!problems)
|
|
28
|
+
return;
|
|
29
|
+
for (const problem of problems) {
|
|
30
|
+
context.report({
|
|
31
|
+
message: problem.message,
|
|
32
|
+
startIndex: node.blockStartPosition.end + problem.startIndex,
|
|
33
|
+
endIndex: node.blockStartPosition.end + problem.endIndex,
|
|
34
|
+
});
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
};
|
|
38
|
+
},
|
|
39
|
+
};
|
|
40
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/checks/valid-schema/index.ts"],"names":[],"mappings":";;;AAAA,uCAA8E;AAEjE,QAAA,WAAW,GAA0B;IAChD,IAAI,EAAE;QACJ,IAAI,EAAE,aAAa;QACnB,IAAI,EAAE,2CAA2C;QACjD,IAAI,EAAE;YACJ,WAAW,EAAE,gEAAgE;YAC7E,WAAW,EAAE,IAAI;YACjB,GAAG,EAAE,mFAAmF;SACzF;QACD,IAAI,EAAE,sBAAc,CAAC,UAAU;QAC/B,QAAQ,EAAE,gBAAQ,CAAC,KAAK;QACxB,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,EAAE;KACZ;IAED,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,KAAK,CAAC,YAAY,CAAC,IAAI;gBACrB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,MAAM,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE,CAAC;oBACjF,OAAO;gBACT,CAAC;gBACD,MAAM,UAAU,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAClC,IAAI,CAAC,kBAAkB,CAAC,GAAG,EAC3B,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAC5B,CAAC;gBACF,MAAM,QAAQ,GAAG,MAAM,OAAO,CAAC,YAAY,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,EAAE,UAAU,CAAC,CAAC;gBAC1E,IAAI,CAAC,QAAQ;oBAAE,OAAO;gBAEtB,KAAK,MAAM,OAAO,IAAI,QAAQ,EAAE,CAAC;oBAC/B,OAAO,CAAC,MAAM,CAAC;wBACb,OAAO,EAAE,OAAO,CAAC,OAAO;wBACxB,UAAU,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,GAAG,OAAO,CAAC,UAAU;wBAC5D,QAAQ,EAAE,IAAI,CAAC,kBAAkB,CAAC,GAAG,GAAG,OAAO,CAAC,QAAQ;qBACzD,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidSchemaName = void 0;
|
|
4
|
+
const json_1 = require("../../json");
|
|
5
|
+
const to_schema_1 = require("../../to-schema");
|
|
6
|
+
const types_1 = require("../../types");
|
|
7
|
+
const utils_1 = require("../../utils");
|
|
8
|
+
const MAX_SCHEMA_NAME_LENGTH = 25;
|
|
9
|
+
exports.ValidSchemaName = {
|
|
10
|
+
meta: {
|
|
11
|
+
code: 'ValidSchemaName',
|
|
12
|
+
name: 'Enforce valid schema name',
|
|
13
|
+
docs: {
|
|
14
|
+
description: 'This check is aimed at ensuring a valid schema name.',
|
|
15
|
+
recommended: true,
|
|
16
|
+
url: 'https://shopify.dev/docs/storefronts/themes/tools/theme-check/checks/valid-schema-name',
|
|
17
|
+
},
|
|
18
|
+
type: types_1.SourceCodeType.LiquidHtml,
|
|
19
|
+
severity: types_1.Severity.ERROR,
|
|
20
|
+
schema: {},
|
|
21
|
+
targets: [],
|
|
22
|
+
},
|
|
23
|
+
create(context) {
|
|
24
|
+
return {
|
|
25
|
+
async LiquidRawTag(node) {
|
|
26
|
+
if (node.name !== 'schema' || node.body.kind !== 'json') {
|
|
27
|
+
return;
|
|
28
|
+
}
|
|
29
|
+
const offset = node.blockStartPosition.end;
|
|
30
|
+
const schema = await (0, to_schema_1.getSchema)(context);
|
|
31
|
+
const { validSchema, ast } = schema ?? {};
|
|
32
|
+
if (!validSchema || validSchema instanceof Error)
|
|
33
|
+
return;
|
|
34
|
+
if (!ast || ast instanceof Error)
|
|
35
|
+
return;
|
|
36
|
+
const name = validSchema.name;
|
|
37
|
+
if (!name)
|
|
38
|
+
return;
|
|
39
|
+
// We can make this type assertion because we know the schema is valid
|
|
40
|
+
const nameNode = (0, json_1.nodeAtPath)(ast, ['name']);
|
|
41
|
+
const startIndex = offset + (0, json_1.getLocStart)(nameNode);
|
|
42
|
+
const endIndex = offset + (0, json_1.getLocEnd)(nameNode);
|
|
43
|
+
if (name.startsWith('t:')) {
|
|
44
|
+
const defaultLocale = await context.getDefaultLocale();
|
|
45
|
+
const key = name.replace('t:', '');
|
|
46
|
+
const defaultTranslations = await context.getDefaultSchemaTranslations();
|
|
47
|
+
const translation = (0, utils_1.deepGet)(defaultTranslations, key.split('.'));
|
|
48
|
+
if (translation === undefined) {
|
|
49
|
+
context.report({
|
|
50
|
+
message: `'${name}' does not have a matching entry in 'locales/${defaultLocale}.default.schema.json'`,
|
|
51
|
+
startIndex,
|
|
52
|
+
endIndex,
|
|
53
|
+
});
|
|
54
|
+
}
|
|
55
|
+
if (translation !== undefined && translation.length > MAX_SCHEMA_NAME_LENGTH) {
|
|
56
|
+
context.report({
|
|
57
|
+
message: `Schema name '${translation}' from 'locales/${defaultLocale}.default.schema.json' is too long (max 25 characters)`,
|
|
58
|
+
startIndex,
|
|
59
|
+
endIndex,
|
|
60
|
+
});
|
|
61
|
+
}
|
|
62
|
+
}
|
|
63
|
+
else if (name.length > MAX_SCHEMA_NAME_LENGTH) {
|
|
64
|
+
context.report({
|
|
65
|
+
message: `Schema name '${name}' is too long (max 25 characters)`,
|
|
66
|
+
startIndex,
|
|
67
|
+
endIndex,
|
|
68
|
+
});
|
|
69
|
+
}
|
|
70
|
+
},
|
|
71
|
+
};
|
|
72
|
+
},
|
|
73
|
+
};
|
|
74
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/checks/valid-schema-name/index.ts"],"names":[],"mappings":";;;AAAA,qCAAgE;AAChE,+CAA4C;AAC5C,uCAA2F;AAC3F,uCAAsC;AAEtC,MAAM,sBAAsB,GAAG,EAAE,CAAC;AAErB,QAAA,eAAe,GAA0B;IACpD,IAAI,EAAE;QACJ,IAAI,EAAE,iBAAiB;QACvB,IAAI,EAAE,2BAA2B;QACjC,IAAI,EAAE;YACJ,WAAW,EAAE,sDAAsD;YACnE,WAAW,EAAE,IAAI;YACjB,GAAG,EAAE,wFAAwF;SAC9F;QACD,IAAI,EAAE,sBAAc,CAAC,UAAU;QAC/B,QAAQ,EAAE,gBAAQ,CAAC,KAAK;QACxB,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,EAAE;KACZ;IAED,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,KAAK,CAAC,YAAY,CAAC,IAAI;gBACrB,IAAI,IAAI,CAAC,IAAI,KAAK,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,IAAI,KAAK,MAAM,EAAE,CAAC;oBACxD,OAAO;gBACT,CAAC;gBAED,MAAM,MAAM,GAAG,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC;gBAC3C,MAAM,MAAM,GAAG,MAAM,IAAA,qBAAS,EAAC,OAAO,CAAC,CAAC;gBACxC,MAAM,EAAE,WAAW,EAAE,GAAG,EAAE,GAAG,MAAM,IAAI,EAAE,CAAC;gBAC1C,IAAI,CAAC,WAAW,IAAI,WAAW,YAAY,KAAK;oBAAE,OAAO;gBACzD,IAAI,CAAC,GAAG,IAAI,GAAG,YAAY,KAAK;oBAAE,OAAO;gBAEzC,MAAM,IAAI,GAAG,WAAW,CAAC,IAAI,CAAC;gBAC9B,IAAI,CAAC,IAAI;oBAAE,OAAO;gBAElB,sEAAsE;gBACtE,MAAM,QAAQ,GAAG,IAAA,iBAAU,EAAC,GAAG,EAAE,CAAC,MAAM,CAAC,CAAiB,CAAC;gBAC3D,MAAM,UAAU,GAAG,MAAM,GAAG,IAAA,kBAAW,EAAC,QAAQ,CAAC,CAAC;gBAClD,MAAM,QAAQ,GAAG,MAAM,GAAG,IAAA,gBAAS,EAAC,QAAQ,CAAC,CAAC;gBAE9C,IAAI,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;oBAC1B,MAAM,aAAa,GAAG,MAAM,OAAO,CAAC,gBAAgB,EAAE,CAAC;oBACvD,MAAM,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC;oBACnC,MAAM,mBAAmB,GAAG,MAAM,OAAO,CAAC,4BAA4B,EAAE,CAAC;oBACzE,MAAM,WAAW,GAAG,IAAA,eAAO,EAAC,mBAAmB,EAAE,GAAG,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC,CAAC;oBAEjE,IAAI,WAAW,KAAK,SAAS,EAAE,CAAC;wBAC9B,OAAO,CAAC,MAAM,CAAC;4BACb,OAAO,EAAE,IAAI,IAAI,gDAAgD,aAAa,uBAAuB;4BACrG,UAAU;4BACV,QAAQ;yBACT,CAAC,CAAC;oBACL,CAAC;oBAED,IAAI,WAAW,KAAK,SAAS,IAAI,WAAW,CAAC,MAAM,GAAG,sBAAsB,EAAE,CAAC;wBAC7E,OAAO,CAAC,MAAM,CAAC;4BACb,OAAO,EAAE,gBAAgB,WAAW,mBAAmB,aAAa,uDAAuD;4BAC3H,UAAU;4BACV,QAAQ;yBACT,CAAC,CAAC;oBACL,CAAC;gBACH,CAAC;qBAAM,IAAI,IAAI,CAAC,MAAM,GAAG,sBAAsB,EAAE,CAAC;oBAChD,OAAO,CAAC,MAAM,CAAC;wBACb,OAAO,EAAE,gBAAgB,IAAI,mCAAmC;wBAChE,UAAU;wBACV,QAAQ;qBACT,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,90 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidSettingsKey = void 0;
|
|
4
|
+
const types_1 = require("../../types");
|
|
5
|
+
const json_1 = require("../../json");
|
|
6
|
+
const to_schema_1 = require("../../to-schema");
|
|
7
|
+
const utils_1 = require("../../utils");
|
|
8
|
+
exports.ValidSettingsKey = {
|
|
9
|
+
meta: {
|
|
10
|
+
code: 'ValidSettingsKey',
|
|
11
|
+
name: 'Validate settings key in presets',
|
|
12
|
+
docs: {
|
|
13
|
+
description: 'Ensures settings key only references valid settings defined in its respective schema',
|
|
14
|
+
recommended: true,
|
|
15
|
+
url: 'https://shopify.dev/docs/storefronts/themes/tools/theme-check/checks/valid-settings-key',
|
|
16
|
+
},
|
|
17
|
+
type: types_1.SourceCodeType.LiquidHtml,
|
|
18
|
+
severity: types_1.Severity.ERROR,
|
|
19
|
+
schema: {},
|
|
20
|
+
targets: [],
|
|
21
|
+
},
|
|
22
|
+
create(context) {
|
|
23
|
+
return {
|
|
24
|
+
async LiquidRawTag(node) {
|
|
25
|
+
if (node.name !== 'schema' || node.body.kind !== 'json')
|
|
26
|
+
return;
|
|
27
|
+
const offset = node.blockStartPosition.end;
|
|
28
|
+
const schema = await (0, to_schema_1.getSchema)(context);
|
|
29
|
+
const { validSchema, ast } = schema ?? {};
|
|
30
|
+
if (!validSchema || validSchema instanceof Error)
|
|
31
|
+
return;
|
|
32
|
+
if (!ast || ast instanceof Error)
|
|
33
|
+
return;
|
|
34
|
+
const { rootLevelLocalBlocks, presetLevelBlocks } = (0, utils_1.getBlocks)(validSchema);
|
|
35
|
+
// Check if presets settings match schema-level settings
|
|
36
|
+
if (validSchema.presets) {
|
|
37
|
+
for (let i = 0; i < validSchema.presets.length; i++) {
|
|
38
|
+
const settingsNode = (0, json_1.nodeAtPath)(ast, ['presets', i, 'settings']);
|
|
39
|
+
validateSettingsKey(context, offset, settingsNode, validSchema.settings);
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
if ((0, to_schema_1.isSectionSchema)(schema) && 'default' in validSchema && validSchema.default) {
|
|
43
|
+
// Check if default settings match schema-level settings
|
|
44
|
+
const settingsNode = (0, json_1.nodeAtPath)(ast, ['default', 'settings']);
|
|
45
|
+
validateSettingsKey(context, offset, settingsNode, validSchema.settings);
|
|
46
|
+
// Check if default block settings match the settings defined in the block file's schema
|
|
47
|
+
await Promise.all(validSchema.default.blocks?.map((block, i) => {
|
|
48
|
+
const settingsNode = (0, json_1.nodeAtPath)(ast, ['default', 'blocks', i, 'settings']);
|
|
49
|
+
return validateReferencedBlock(context, offset, settingsNode, rootLevelLocalBlocks, block);
|
|
50
|
+
}) || []);
|
|
51
|
+
}
|
|
52
|
+
// Check if preset block settings match the settings defined in the block file's schema
|
|
53
|
+
await Promise.all(Object.entries(presetLevelBlocks).flatMap(([_depthStr, blocks]) => blocks.map(({ node: blockNode, path }) => {
|
|
54
|
+
const settingsNode = (0, json_1.nodeAtPath)(ast, path.slice(0, -1).concat('settings'));
|
|
55
|
+
return validateReferencedBlock(context, offset, settingsNode, rootLevelLocalBlocks, blockNode);
|
|
56
|
+
})));
|
|
57
|
+
},
|
|
58
|
+
};
|
|
59
|
+
},
|
|
60
|
+
};
|
|
61
|
+
async function validateReferencedBlock(context, offset, settingsNode, localBlocks, referencedBlock) {
|
|
62
|
+
if (localBlocks.length > 0) {
|
|
63
|
+
const localBlock = localBlocks.find((localBlock) => localBlock.node.type === referencedBlock.type);
|
|
64
|
+
if (!localBlock)
|
|
65
|
+
return;
|
|
66
|
+
const localBlockNode = localBlock.node;
|
|
67
|
+
validateSettingsKey(context, offset, settingsNode, localBlockNode.settings);
|
|
68
|
+
}
|
|
69
|
+
else {
|
|
70
|
+
const blockSchema = await context.getBlockSchema?.(referencedBlock.type);
|
|
71
|
+
const { validSchema: validBlockSchema } = blockSchema ?? {};
|
|
72
|
+
if (!validBlockSchema || validBlockSchema instanceof Error)
|
|
73
|
+
return;
|
|
74
|
+
validateSettingsKey(context, offset, settingsNode, validBlockSchema.settings, referencedBlock);
|
|
75
|
+
}
|
|
76
|
+
}
|
|
77
|
+
function validateSettingsKey(context, offset, settingsNode, validSettings, blockNode) {
|
|
78
|
+
if (!settingsNode || settingsNode.type !== 'Object')
|
|
79
|
+
return;
|
|
80
|
+
for (const setting of settingsNode.children) {
|
|
81
|
+
const settingExists = validSettings?.find((validSetting) => validSetting?.id === setting.key.value);
|
|
82
|
+
if (!settingExists) {
|
|
83
|
+
const errorMessage = blockNode
|
|
84
|
+
? `Setting '${setting.key.value}' does not exist in 'blocks/${blockNode.type}.liquid'.`
|
|
85
|
+
: `Setting '${setting.key.value}' does not exist in schema.`;
|
|
86
|
+
(0, utils_1.reportWarning)(errorMessage, offset, setting.key, context);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/checks/valid-settings-key/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidStaticBlockType = void 0;
|
|
4
|
+
const liquid_html_parser_1 = require("@platformos/liquid-html-parser");
|
|
5
|
+
const types_1 = require("../../types");
|
|
6
|
+
const file_utils_1 = require("../../utils/file-utils");
|
|
7
|
+
const markup_1 = require("../../utils/markup");
|
|
8
|
+
exports.ValidStaticBlockType = {
|
|
9
|
+
meta: {
|
|
10
|
+
code: 'ValidStaticBlockType',
|
|
11
|
+
name: 'Prevent use of type that is not valid for static blocks',
|
|
12
|
+
docs: {
|
|
13
|
+
description: 'This check is aimed at preventing the use of an invalid type for blocks rendered statically.',
|
|
14
|
+
url: 'https://shopify.dev/docs/storefronts/themes/tools/theme-check/checks/valid-static-block-type',
|
|
15
|
+
recommended: true,
|
|
16
|
+
},
|
|
17
|
+
type: types_1.SourceCodeType.LiquidHtml,
|
|
18
|
+
severity: types_1.Severity.ERROR,
|
|
19
|
+
schema: {},
|
|
20
|
+
targets: [],
|
|
21
|
+
},
|
|
22
|
+
create(context) {
|
|
23
|
+
return {
|
|
24
|
+
async LiquidTag(node) {
|
|
25
|
+
if (node.name !== 'content_for') {
|
|
26
|
+
return;
|
|
27
|
+
}
|
|
28
|
+
if (!(0, markup_1.isContentForBlock)(node.markup)) {
|
|
29
|
+
return;
|
|
30
|
+
}
|
|
31
|
+
const typeArg = node.markup.args.find((arg) => arg.name === 'type');
|
|
32
|
+
if (!typeArg) {
|
|
33
|
+
return; // covered by VariableContentForArguments
|
|
34
|
+
}
|
|
35
|
+
const typeArgValueNode = typeArg.value;
|
|
36
|
+
if (typeArgValueNode.type !== liquid_html_parser_1.NodeTypes.String) {
|
|
37
|
+
return; // covered by VariableContentForArguments
|
|
38
|
+
}
|
|
39
|
+
const blockName = typeArgValueNode.value;
|
|
40
|
+
const relativePath = `blocks/${blockName}.liquid`;
|
|
41
|
+
const fileExists = await (0, file_utils_1.doesFileExist)(context, relativePath);
|
|
42
|
+
if (!fileExists) {
|
|
43
|
+
context.report({
|
|
44
|
+
message: `'blocks/${blockName}.liquid' does not exist`,
|
|
45
|
+
startIndex: typeArgValueNode.position.start,
|
|
46
|
+
endIndex: typeArgValueNode.position.end,
|
|
47
|
+
suggest: [],
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
},
|
|
51
|
+
};
|
|
52
|
+
},
|
|
53
|
+
};
|
|
54
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/checks/valid-static-block-type/index.ts"],"names":[],"mappings":";;;AAAA,uEAA2D;AAC3D,uCAA8E;AAC9E,uDAAuD;AACvD,+CAAuD;AAE1C,QAAA,oBAAoB,GAA0B;IACzD,IAAI,EAAE;QACJ,IAAI,EAAE,sBAAsB;QAC5B,IAAI,EAAE,yDAAyD;QAC/D,IAAI,EAAE;YACJ,WAAW,EACT,8FAA8F;YAChG,GAAG,EAAE,8FAA8F;YACnG,WAAW,EAAE,IAAI;SAClB;QACD,IAAI,EAAE,sBAAc,CAAC,UAAU;QAC/B,QAAQ,EAAE,gBAAQ,CAAC,KAAK;QACxB,MAAM,EAAE,EAAE;QACV,OAAO,EAAE,EAAE;KACZ;IAED,MAAM,CAAC,OAAO;QACZ,OAAO;YACL,KAAK,CAAC,SAAS,CAAC,IAAI;gBAClB,IAAI,IAAI,CAAC,IAAI,KAAK,aAAa,EAAE,CAAC;oBAChC,OAAO;gBACT,CAAC;gBAED,IAAI,CAAC,IAAA,0BAAiB,EAAC,IAAI,CAAC,MAAM,CAAC,EAAE,CAAC;oBACpC,OAAO;gBACT,CAAC;gBAED,MAAM,OAAO,GAAG,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE,CAAC,GAAG,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC;gBACpE,IAAI,CAAC,OAAO,EAAE,CAAC;oBACb,OAAO,CAAC,yCAAyC;gBACnD,CAAC;gBAED,MAAM,gBAAgB,GAAG,OAAO,CAAC,KAAK,CAAC;gBACvC,IAAI,gBAAgB,CAAC,IAAI,KAAK,8BAAS,CAAC,MAAM,EAAE,CAAC;oBAC/C,OAAO,CAAC,yCAAyC;gBACnD,CAAC;gBAED,MAAM,SAAS,GAAG,gBAAgB,CAAC,KAAK,CAAC;gBACzC,MAAM,YAAY,GAAG,UAAU,SAAS,SAAS,CAAC;gBAClD,MAAM,UAAU,GAAG,MAAM,IAAA,0BAAa,EAAC,OAAO,EAAE,YAAY,CAAC,CAAC;gBAE9D,IAAI,CAAC,UAAU,EAAE,CAAC;oBAChB,OAAO,CAAC,MAAM,CAAC;wBACb,OAAO,EAAE,WAAW,SAAS,yBAAyB;wBACtD,UAAU,EAAE,gBAAgB,CAAC,QAAQ,CAAC,KAAK;wBAC3C,QAAQ,EAAE,gBAAgB,CAAC,QAAQ,CAAC,GAAG;wBACvC,OAAO,EAAE,EAAE;qBACZ,CAAC,CAAC;gBACL,CAAC;YACH,CAAC;SACF,CAAC;IACJ,CAAC;CACF,CAAC"}
|
|
@@ -0,0 +1,146 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
+
exports.ValidVisibleIfSettingsSchema = exports.ValidVisibleIf = void 0;
|
|
4
|
+
const types_1 = require("../../types");
|
|
5
|
+
const json_1 = require("../../json");
|
|
6
|
+
const to_schema_1 = require("../../to-schema");
|
|
7
|
+
const utils_1 = require("../../utils");
|
|
8
|
+
const visible_if_utils_1 = require("./visible-if-utils");
|
|
9
|
+
// Note that unlike most other files in the `checks` directory, this exports two
|
|
10
|
+
// checks: one for Liquid files and one for 'config/settings_schema.json'. They
|
|
11
|
+
// perform the same check using the same logic (modulo differences extracting
|
|
12
|
+
// the schema and determining warning start and end indices).
|
|
13
|
+
const meta = {
|
|
14
|
+
code: 'ValidVisibleIf',
|
|
15
|
+
name: 'Validate visible_if expressions',
|
|
16
|
+
docs: {
|
|
17
|
+
description: 'Ensures visible_if expressions are well-formed and only reference settings keys that are defined',
|
|
18
|
+
recommended: true,
|
|
19
|
+
url: 'https://shopify.dev/docs/storefronts/themes/tools/theme-check/checks/valid-visible-if',
|
|
20
|
+
},
|
|
21
|
+
severity: types_1.Severity.ERROR,
|
|
22
|
+
schema: {},
|
|
23
|
+
targets: [],
|
|
24
|
+
};
|
|
25
|
+
exports.ValidVisibleIf = {
|
|
26
|
+
meta: { ...meta, type: types_1.SourceCodeType.LiquidHtml },
|
|
27
|
+
create(context) {
|
|
28
|
+
return {
|
|
29
|
+
async LiquidRawTag(node) {
|
|
30
|
+
if (node.name !== 'schema' || node.body.kind !== 'json')
|
|
31
|
+
return;
|
|
32
|
+
const schema = await (0, to_schema_1.getSchema)(context);
|
|
33
|
+
const { validSchema, ast } = schema ?? {};
|
|
34
|
+
if (!validSchema ||
|
|
35
|
+
validSchema instanceof Error ||
|
|
36
|
+
!validSchema.settings?.some((setting) => 'visible_if' in setting) ||
|
|
37
|
+
!ast ||
|
|
38
|
+
ast instanceof Error) {
|
|
39
|
+
return;
|
|
40
|
+
}
|
|
41
|
+
const offset = node.blockStartPosition.end;
|
|
42
|
+
const settings = Object.fromEntries((await (0, visible_if_utils_1.getGlobalSettings)(context)).map((s) => [s, true]));
|
|
43
|
+
const currentFileSettings = Object.fromEntries(validSchema.settings.map((setting) => [setting.id, true]));
|
|
44
|
+
const vars = { settings };
|
|
45
|
+
if ((0, to_schema_1.isSectionSchema)(schema)) {
|
|
46
|
+
vars.section = { settings: currentFileSettings };
|
|
47
|
+
}
|
|
48
|
+
else if ((0, to_schema_1.isBlockSchema)(schema)) {
|
|
49
|
+
vars.block = { settings: currentFileSettings };
|
|
50
|
+
}
|
|
51
|
+
for (const [i, setting] of validSchema.settings.entries()) {
|
|
52
|
+
if (!('visible_if' in setting) || typeof setting.visible_if !== 'string')
|
|
53
|
+
continue;
|
|
54
|
+
const visibleIfNode = (0, json_1.nodeAtPath)(ast, ['settings', i, 'visible_if']);
|
|
55
|
+
const varLookupsOrWarning = await (0, visible_if_utils_1.getVariableLookupsInExpression)(setting.visible_if);
|
|
56
|
+
if (varLookupsOrWarning === null)
|
|
57
|
+
continue;
|
|
58
|
+
if ('warning' in varLookupsOrWarning) {
|
|
59
|
+
(0, utils_1.reportWarning)(varLookupsOrWarning.warning, offset, visibleIfNode, context);
|
|
60
|
+
continue;
|
|
61
|
+
}
|
|
62
|
+
const report = (message, lookup) => {
|
|
63
|
+
if (typeof message === 'string') {
|
|
64
|
+
context.report({
|
|
65
|
+
message,
|
|
66
|
+
// the JSONNode start location returned by `getLocStart`
|
|
67
|
+
// includes the opening quotation mark — whereas when we parse
|
|
68
|
+
// the inner expression, 0 is the location _inside_ the quotes.
|
|
69
|
+
// we add 1 to the offsets to compensate.
|
|
70
|
+
startIndex: offset + (0, json_1.getLocStart)(visibleIfNode) + lookup.position.start + visible_if_utils_1.offsetAdjust + 1,
|
|
71
|
+
endIndex: offset + (0, json_1.getLocStart)(visibleIfNode) + lookup.position.end + visible_if_utils_1.offsetAdjust + 1,
|
|
72
|
+
});
|
|
73
|
+
}
|
|
74
|
+
};
|
|
75
|
+
for (const lookup of varLookupsOrWarning) {
|
|
76
|
+
if (lookup.name === 'section' && (0, to_schema_1.isBlockSchema)(schema)) {
|
|
77
|
+
//no-op, we don't know what section this block will be used in, so we can't validate that the setting exists
|
|
78
|
+
}
|
|
79
|
+
else if (lookup.name === 'section' && !(0, to_schema_1.isSectionSchema)(schema)) {
|
|
80
|
+
report(`Invalid visible_if: can't refer to "section" when not in a section or block file.`, lookup);
|
|
81
|
+
}
|
|
82
|
+
else if (lookup.name === 'block' && !(0, to_schema_1.isBlockSchema)(schema)) {
|
|
83
|
+
report(`Invalid visible_if: can't refer to "block" when not in a block file.`, lookup);
|
|
84
|
+
}
|
|
85
|
+
else {
|
|
86
|
+
report((0, visible_if_utils_1.validateLookup)(lookup, vars), lookup);
|
|
87
|
+
}
|
|
88
|
+
}
|
|
89
|
+
}
|
|
90
|
+
},
|
|
91
|
+
};
|
|
92
|
+
},
|
|
93
|
+
};
|
|
94
|
+
exports.ValidVisibleIfSettingsSchema = {
|
|
95
|
+
meta: { ...meta, type: types_1.SourceCodeType.JSON },
|
|
96
|
+
create(context) {
|
|
97
|
+
const relativePath = context.toRelativePath(context.file.uri);
|
|
98
|
+
if (relativePath !== 'config/settings_schema.json')
|
|
99
|
+
return {};
|
|
100
|
+
return {
|
|
101
|
+
async Property(node) {
|
|
102
|
+
if (node.key.value !== 'visible_if' || node.value.type !== 'Literal')
|
|
103
|
+
return;
|
|
104
|
+
const visibleIfExpression = node.value.value;
|
|
105
|
+
if (typeof visibleIfExpression !== 'string')
|
|
106
|
+
return;
|
|
107
|
+
const offset = node.value.loc.start.offset;
|
|
108
|
+
const varLookupsOrWarning = await (0, visible_if_utils_1.getVariableLookupsInExpression)(visibleIfExpression);
|
|
109
|
+
if (varLookupsOrWarning === null)
|
|
110
|
+
return;
|
|
111
|
+
if ('warning' in varLookupsOrWarning) {
|
|
112
|
+
context.report({
|
|
113
|
+
message: varLookupsOrWarning.warning,
|
|
114
|
+
startIndex: node.value.loc.start.offset,
|
|
115
|
+
endIndex: node.value.loc.end.offset,
|
|
116
|
+
});
|
|
117
|
+
return;
|
|
118
|
+
}
|
|
119
|
+
const settings = Object.fromEntries((await (0, visible_if_utils_1.getGlobalSettings)(context)).map((s) => [s, true]));
|
|
120
|
+
const vars = { settings };
|
|
121
|
+
const report = (message, lookup) => {
|
|
122
|
+
if (typeof message === 'string') {
|
|
123
|
+
context.report({
|
|
124
|
+
message,
|
|
125
|
+
startIndex: offset + lookup.position.start + visible_if_utils_1.offsetAdjust + 1,
|
|
126
|
+
endIndex: offset + lookup.position.end + visible_if_utils_1.offsetAdjust + 1,
|
|
127
|
+
});
|
|
128
|
+
}
|
|
129
|
+
};
|
|
130
|
+
for (const lookup of varLookupsOrWarning) {
|
|
131
|
+
// settings_schema.json can't reference `section` or `block`.
|
|
132
|
+
if (lookup.name === 'section') {
|
|
133
|
+
report(`Invalid visible_if: can't refer to "section" when not in a section file.`, lookup);
|
|
134
|
+
}
|
|
135
|
+
else if (lookup.name === 'block') {
|
|
136
|
+
report(`Invalid visible_if: can't refer to "block" when not in a block file.`, lookup);
|
|
137
|
+
}
|
|
138
|
+
else {
|
|
139
|
+
report((0, visible_if_utils_1.validateLookup)(lookup, vars), lookup);
|
|
140
|
+
}
|
|
141
|
+
}
|
|
142
|
+
},
|
|
143
|
+
};
|
|
144
|
+
},
|
|
145
|
+
};
|
|
146
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/checks/valid-visible-if/index.ts"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
import { type LiquidVariableLookup } from '@platformos/liquid-html-parser';
|
|
2
|
+
import { Context, SourceCodeType } from '../..';
|
|
3
|
+
export type Vars = {
|
|
4
|
+
[key: string]: Vars | true;
|
|
5
|
+
};
|
|
6
|
+
export declare const variableExpressionMatcher: RegExp;
|
|
7
|
+
export declare const adjustedPrefix = "{% if ";
|
|
8
|
+
export declare const adjustedSuffix = " %}{% endif %}";
|
|
9
|
+
export declare const offsetAdjust: number;
|
|
10
|
+
export declare function getVariableLookupsInExpression(expression: string): Promise<LiquidVariableLookup[] | {
|
|
11
|
+
warning: string;
|
|
12
|
+
} | null>;
|
|
13
|
+
export declare function validateLookup(lookup: LiquidVariableLookup, vars: Vars): string | null;
|
|
14
|
+
export declare function getGlobalSettings(context: Context<SourceCodeType>): Promise<string[]>;
|