@atlaskit/eslint-plugin-design-system 14.2.0 → 14.3.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/CHANGELOG.md +8 -0
- package/README.md +79 -79
- package/configs/deprecated.json +9 -0
- package/dist/cjs/ast-nodes/jsx-element-helper.js +90 -0
- package/dist/cjs/common/token-maps.partial.js +2 -1
- package/dist/cjs/rules/consistent-css-prop-usage/index.js +2 -2
- package/dist/cjs/rules/enforce-inline-styles-in-select/index.js +2 -2
- package/dist/cjs/rules/ensure-avatar-tag-avatar-props/index.js +2 -2
- package/dist/cjs/rules/ensure-design-token-usage/em-to-pixels.js +21 -0
- package/dist/cjs/rules/ensure-design-token-usage/find-token-name-by-property-value.js +23 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-domains-for-property.js +34 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-font-size-value-in-scope.js +31 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-property-node-from-parent.js +19 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-token-node-for-value.js +34 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-token-replacement.js +23 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-token-suggestion.js +27 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-value-for-property-node.js +13 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-value-from-shorthand.js +19 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-value-from-template-literal-raw.js +35 -0
- package/dist/cjs/rules/ensure-design-token-usage/get-value.js +141 -0
- package/dist/cjs/rules/ensure-design-token-usage/index.js +41 -27
- package/dist/cjs/rules/ensure-design-token-usage/is-border-size-property.js +10 -0
- package/dist/cjs/rules/ensure-design-token-usage/is-calc.js +15 -0
- package/dist/cjs/rules/ensure-design-token-usage/is-radius-property.js +10 -0
- package/dist/cjs/rules/ensure-design-token-usage/is-shape-property.js +11 -0
- package/dist/cjs/rules/ensure-design-token-usage/is-spacing-property.js +10 -0
- package/dist/cjs/rules/ensure-design-token-usage/is-valid-spacing-value.js +26 -0
- package/dist/cjs/rules/ensure-design-token-usage/lint-jsx-identifier-for-color.js +29 -0
- package/dist/cjs/rules/ensure-design-token-usage/lint-jsx-literal-for-color.js +152 -0
- package/dist/cjs/rules/ensure-design-token-usage/lint-jsx-member-for-color.js +28 -0
- package/dist/cjs/rules/ensure-design-token-usage/lint-object-for-color.js +94 -0
- package/dist/cjs/rules/ensure-design-token-usage/lint-template-identifier-for-color.js +53 -0
- package/dist/cjs/rules/ensure-design-token-usage/process-css-node.js +39 -0
- package/dist/cjs/rules/ensure-design-token-usage/remove-pixel-suffix.js +14 -0
- package/dist/cjs/rules/ensure-design-token-usage/spacing.js +19 -13
- package/dist/cjs/rules/ensure-design-token-usage-preview/index.js +2 -2
- package/dist/cjs/rules/ensure-icon-color/index.js +2 -2
- package/dist/cjs/rules/ensure-proper-xcss-usage/index.js +2 -2
- package/dist/cjs/rules/icon-label/index.js +2 -2
- package/dist/cjs/rules/lozenge-badge-tag-labelling-system-migration/index.js +2 -2
- package/dist/cjs/rules/no-banned-imports/index.js +2 -2
- package/dist/cjs/rules/no-boolean-autofocus-on-modal-dialog/index.js +4 -4
- package/dist/cjs/rules/no-css-tagged-template-expression/index.js +5 -4
- package/dist/cjs/rules/no-dark-theme-vr-tests/index.js +2 -2
- package/dist/cjs/rules/no-deprecated-apis/index.js +4 -4
- package/dist/cjs/rules/no-deprecated-design-token-usage/index.js +2 -2
- package/dist/cjs/rules/no-deprecated-imports/checks.js +2 -2
- package/dist/cjs/rules/no-deprecated-imports/index.js +2 -2
- package/dist/cjs/rules/no-direct-use-of-web-platform-drag-and-drop/index.js +2 -2
- package/dist/cjs/rules/no-emotion-primitives/index.js +2 -2
- package/dist/cjs/rules/no-empty-styled-expression/index.js +2 -2
- package/dist/cjs/rules/no-exported-css/index.js +2 -2
- package/dist/cjs/rules/no-exported-keyframes/index.js +2 -2
- package/dist/cjs/rules/no-html-anchor/index.js +2 -2
- package/dist/cjs/rules/no-html-anchor/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-anchor/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-button/index.js +2 -2
- package/dist/cjs/rules/no-html-button/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-button/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-checkbox/index.js +2 -2
- package/dist/cjs/rules/no-html-checkbox/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-checkbox/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-code/index.js +2 -2
- package/dist/cjs/rules/no-html-code/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-code/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-heading/index.js +2 -2
- package/dist/cjs/rules/no-html-heading/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-heading/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-image/index.js +2 -2
- package/dist/cjs/rules/no-html-image/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-image/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-radio/index.js +2 -2
- package/dist/cjs/rules/no-html-radio/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-radio/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-range/index.js +2 -2
- package/dist/cjs/rules/no-html-range/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-range/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-select/index.js +2 -2
- package/dist/cjs/rules/no-html-select/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-select/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-text-input/index.js +2 -2
- package/dist/cjs/rules/no-html-text-input/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-text-input/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-html-textarea/index.js +2 -2
- package/dist/cjs/rules/no-html-textarea/node-types/jsx-element/index.js +2 -2
- package/dist/cjs/rules/no-html-textarea/node-types/supported.js +3 -3
- package/dist/cjs/rules/no-icon-spacing-prop/index.js +2 -2
- package/dist/cjs/rules/no-invalid-css-map/index.js +2 -2
- package/dist/cjs/rules/no-keyframes-tagged-template-expression/index.js +5 -4
- package/dist/cjs/rules/no-margin/index.js +2 -2
- package/dist/cjs/rules/no-nested-styles/index.js +2 -2
- package/dist/cjs/rules/no-physical-properties/index.js +2 -2
- package/dist/cjs/rules/no-placeholder/affected-atlaskit-packages.js +12 -0
- package/dist/cjs/rules/no-placeholder/affected-html-elements.js +7 -0
- package/dist/cjs/rules/no-placeholder/index.js +12 -17
- package/dist/cjs/rules/no-readonly-or-disabled-inputs/affected-atlaskit-packages.js +10 -0
- package/dist/cjs/rules/no-readonly-or-disabled-inputs/affected-html-elements.js +7 -0
- package/dist/cjs/rules/no-readonly-or-disabled-inputs/index.js +15 -18
- package/dist/cjs/rules/no-readonly-or-disabled-inputs/unwanted-atlaskit-attributes.js +7 -0
- package/dist/cjs/rules/no-readonly-or-disabled-inputs/unwanted-html-attributes.js +7 -0
- package/dist/cjs/rules/no-separator-with-list-elements/index.js +2 -2
- package/dist/cjs/rules/no-styled-tagged-template-expression/index.js +5 -4
- package/dist/cjs/rules/no-to-match-snapshot/index.js +2 -2
- package/dist/cjs/rules/no-unsafe-design-token-usage/index.js +4 -4
- package/dist/cjs/rules/no-unsafe-inline-snapshot/index.js +2 -2
- package/dist/cjs/rules/no-unsafe-style-overrides/index.js +2 -2
- package/dist/cjs/rules/no-unsupported-drag-and-drop-libraries/index.js +2 -2
- package/dist/cjs/rules/no-unused-css-map/get-css-map-object.js +18 -0
- package/dist/cjs/rules/no-unused-css-map/index.js +6 -5
- package/dist/cjs/rules/no-unused-css-map/unused-css-map-checker.js +150 -0
- package/dist/cjs/rules/prefer-primitives/index.js +2 -2
- package/dist/cjs/rules/use-button-group-label/index.js +2 -2
- package/dist/cjs/rules/use-character-counter-field/index.js +7 -5
- package/dist/cjs/rules/use-correct-field/index.js +2 -2
- package/dist/cjs/rules/use-cx-function-in-xcss/index.js +2 -2
- package/dist/cjs/rules/use-datetime-picker-calendar-button/index.js +5 -5
- package/dist/cjs/rules/use-drawer-label/index.js +2 -2
- package/dist/cjs/rules/use-field-message-wrapper/index.js +2 -2
- package/dist/cjs/rules/use-heading/index.js +2 -2
- package/dist/cjs/rules/use-heading/transformers/native-elements.js +7 -7
- package/dist/cjs/rules/use-heading/transformers/update-test-id-attribute-fix.js +2 -2
- package/dist/cjs/rules/use-heading-level-in-spotlight-card/index.js +2 -2
- package/dist/cjs/rules/use-href-in-link-item/index.js +2 -2
- package/dist/cjs/rules/use-latest-xcss-syntax/index.js +2 -2
- package/dist/cjs/rules/use-latest-xcss-syntax-typography/config/get-config.js +16 -0
- package/dist/cjs/rules/use-latest-xcss-syntax-typography/config/patterns.js +7 -0
- package/dist/cjs/rules/use-latest-xcss-syntax-typography/config/types.js +5 -0
- package/dist/cjs/rules/use-latest-xcss-syntax-typography/index.js +7 -6
- package/dist/cjs/rules/use-menu-section-title/index.js +2 -2
- package/dist/cjs/rules/use-modal-dialog-close-button/index.js +4 -4
- package/dist/cjs/rules/use-onboarding-spotlight-label/index.js +2 -2
- package/dist/cjs/rules/use-popup-label/index.js +2 -2
- package/dist/cjs/rules/{use-latest-xcss-syntax-typography/config/index.js → use-primitives/config/get-config.js} +2 -4
- package/dist/cjs/rules/use-primitives/config/types.js +5 -0
- package/dist/cjs/rules/use-primitives/config/valid-patterns.js +46 -0
- package/dist/cjs/rules/use-primitives/index.js +7 -6
- package/dist/cjs/rules/use-primitives/transformers/compiled-styled/convert-jsx-call-site.js +2 -2
- package/dist/cjs/rules/use-primitives/transformers/compiled-styled/convert-styled-component-call-to-jsx.js +2 -2
- package/dist/cjs/rules/use-primitives/transformers/compiled-styled/index.js +2 -2
- package/dist/cjs/rules/use-primitives/transformers/css-to-xcss-transformer.js +45 -0
- package/dist/cjs/rules/use-primitives/transformers/emotion-css/index.js +8 -8
- package/dist/cjs/rules/use-primitives/transformers/styled-object-to-xcss-tokens.js +39 -0
- package/dist/cjs/rules/use-primitives/transformers/supported-styles-map.js +37 -0
- package/dist/cjs/rules/use-primitives/utils/is-valid-css-properties-to-transform.js +4 -4
- package/dist/cjs/rules/use-primitives/utils/validate-styles.js +2 -2
- package/dist/cjs/rules/use-primitives-text/config/{index.js → get-config.js} +1 -10
- package/dist/cjs/rules/use-primitives-text/config/patterns.js +15 -0
- package/dist/cjs/rules/use-primitives-text/config/types.js +5 -0
- package/dist/cjs/rules/use-primitives-text/index.js +7 -6
- package/dist/cjs/rules/use-primitives-text/transformers/add-color-inherit-attribute-fix.js +2 -2
- package/dist/cjs/rules/use-primitives-text/transformers/emphasis-elements.js +5 -5
- package/dist/cjs/rules/use-primitives-text/transformers/has-text-children-only.js +2 -2
- package/dist/cjs/rules/use-primitives-text/transformers/paragraph-elements.js +10 -10
- package/dist/cjs/rules/use-primitives-text/transformers/span-elements.js +4 -4
- package/dist/cjs/rules/use-primitives-text/transformers/strong-elements.js +5 -5
- package/dist/cjs/rules/use-primitives-text/transformers/update-test-id-attribute-fix.js +2 -2
- package/dist/cjs/rules/use-should-render-to-parent/add-prop.js +9 -0
- package/dist/cjs/rules/use-should-render-to-parent/index.js +20 -7
- package/dist/cjs/rules/use-should-render-to-parent/set-prop-to-true.js +9 -0
- package/dist/cjs/rules/use-simple-field/index.js +2 -2
- package/dist/cjs/rules/use-simple-form/index.js +11 -5
- package/dist/cjs/rules/use-simple-form/top-level-attribute-names.js +7 -0
- package/dist/cjs/rules/use-spotlight-package/index.js +2 -2
- package/dist/cjs/rules/use-tag-group-label/index.js +2 -2
- package/dist/cjs/rules/use-textfield-autocomplete/index.js +7 -7
- package/dist/cjs/rules/use-tokens-shape/index.js +2 -2
- package/dist/cjs/rules/use-tokens-space/index.js +2 -2
- package/dist/cjs/rules/use-tokens-typography/config/get-config.js +16 -0
- package/dist/cjs/rules/use-tokens-typography/config/{index.js → rule-schema.js} +1 -9
- package/dist/cjs/rules/use-tokens-typography/config/types.js +1 -0
- package/dist/cjs/rules/use-tokens-typography/default-font-weight.js +8 -0
- package/dist/cjs/rules/use-tokens-typography/find-font-weight-token-for-value.js +21 -0
- package/dist/cjs/rules/use-tokens-typography/find-typography-token-for-values.js +21 -0
- package/dist/cjs/rules/use-tokens-typography/font-weight-map.js +12 -0
- package/dist/cjs/rules/use-tokens-typography/font-weight-tokens.js +18 -0
- package/dist/cjs/rules/use-tokens-typography/get-token-property.js +41 -0
- package/dist/cjs/rules/use-tokens-typography/index.js +6 -5
- package/dist/cjs/rules/use-tokens-typography/transformers/banned-properties.js +2 -2
- package/dist/cjs/rules/use-tokens-typography/transformers/font-family.js +2 -2
- package/dist/cjs/rules/use-tokens-typography/transformers/font-weight.js +4 -4
- package/dist/cjs/rules/use-tokens-typography/transformers/style-object.js +23 -19
- package/dist/cjs/rules/use-tokens-typography/transformers/untokenized-properties.js +2 -2
- package/dist/cjs/rules/use-tokens-typography/types.js +1 -0
- package/dist/cjs/rules/use-tokens-typography/typography-value-to-token.js +43 -0
- package/dist/cjs/rules/use-visually-hidden/count-matching-key-values.js +27 -0
- package/dist/cjs/rules/use-visually-hidden/get-object-likeness.js +33 -0
- package/dist/cjs/rules/use-visually-hidden/index.js +10 -9
- package/dist/cjs/rules/use-visually-hidden/reference-object.js +16 -0
- package/dist/cjs/rules/utils/create-lint-rule.js +14 -0
- package/dist/cjs/rules/utils/create-no-tagged-template-expression-rule/create-no-tagged-template-expression-rule.js +137 -0
- package/dist/cjs/rules/utils/create-no-tagged-template-expression-rule/no-tagged-template-expression-rule-schema.js +20 -0
- package/dist/cjs/rules/utils/create-rule.js +4 -15
- package/dist/cjs/rules/utils/get-rule-url.js +11 -0
- package/dist/cjs/rules/utils/includes-hard-coded-color.js +23 -0
- package/dist/cjs/rules/utils/is-color-css-property-name.js +15 -0
- package/dist/cjs/rules/utils/is-css-in-js-call-node.js +10 -0
- package/dist/cjs/rules/utils/is-css-in-js-object-node.js +10 -0
- package/dist/cjs/rules/utils/is-decendant-of-style-block.js +48 -0
- package/dist/cjs/rules/utils/is-deprecated-import-config.js +9 -0
- package/dist/cjs/rules/utils/is-deprecated-jsx-attribute-config.js +9 -0
- package/dist/cjs/rules/utils/is-hard-coded-color.js +27 -0
- package/dist/cjs/rules/utils/is-legacy-color.js +12 -0
- package/dist/cjs/rules/utils/is-legacy-named-color.js +10 -0
- package/dist/cjs/rules/utils/named-colors.js +7 -0
- package/dist/cjs/rules/utils/types.js +1 -17
- package/dist/configs/deprecated.json +9 -0
- package/dist/es2019/ast-nodes/jsx-element-helper.js +84 -0
- package/dist/es2019/common/token-maps.partial.js +2 -1
- package/dist/es2019/rules/consistent-css-prop-usage/index.js +1 -1
- package/dist/es2019/rules/enforce-inline-styles-in-select/index.js +1 -1
- package/dist/es2019/rules/ensure-avatar-tag-avatar-props/index.js +1 -1
- package/dist/es2019/rules/ensure-design-token-usage/em-to-pixels.js +15 -0
- package/dist/es2019/rules/ensure-design-token-usage/find-token-name-by-property-value.js +15 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-domains-for-property.js +28 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-font-size-value-in-scope.js +15 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-property-node-from-parent.js +13 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-token-node-for-value.js +29 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-token-replacement.js +18 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-token-suggestion.js +14 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-value-for-property-node.js +7 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-value-from-shorthand.js +13 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-value-from-template-literal-raw.js +30 -0
- package/dist/es2019/rules/ensure-design-token-usage/get-value.js +129 -0
- package/dist/es2019/rules/ensure-design-token-usage/index.js +21 -8
- package/dist/es2019/rules/ensure-design-token-usage/is-border-size-property.js +4 -0
- package/dist/es2019/rules/ensure-design-token-usage/is-calc.js +9 -0
- package/dist/es2019/rules/ensure-design-token-usage/is-radius-property.js +4 -0
- package/dist/es2019/rules/ensure-design-token-usage/is-shape-property.js +5 -0
- package/dist/es2019/rules/ensure-design-token-usage/is-spacing-property.js +4 -0
- package/dist/es2019/rules/ensure-design-token-usage/is-valid-spacing-value.js +20 -0
- package/dist/es2019/rules/ensure-design-token-usage/lint-jsx-identifier-for-color.js +23 -0
- package/dist/es2019/rules/ensure-design-token-usage/lint-jsx-literal-for-color.js +123 -0
- package/dist/es2019/rules/ensure-design-token-usage/lint-jsx-member-for-color.js +22 -0
- package/dist/es2019/rules/ensure-design-token-usage/lint-object-for-color.js +88 -0
- package/dist/es2019/rules/ensure-design-token-usage/lint-template-identifier-for-color.js +46 -0
- package/dist/es2019/rules/ensure-design-token-usage/process-css-node.js +31 -0
- package/dist/es2019/rules/ensure-design-token-usage/remove-pixel-suffix.js +8 -0
- package/dist/es2019/rules/ensure-design-token-usage/spacing.js +7 -1
- package/dist/es2019/rules/ensure-design-token-usage-preview/index.js +1 -1
- package/dist/es2019/rules/ensure-icon-color/index.js +1 -1
- package/dist/es2019/rules/ensure-proper-xcss-usage/index.js +1 -1
- package/dist/es2019/rules/icon-label/index.js +1 -1
- package/dist/es2019/rules/lozenge-badge-tag-labelling-system-migration/index.js +1 -1
- package/dist/es2019/rules/no-banned-imports/index.js +1 -1
- package/dist/es2019/rules/no-boolean-autofocus-on-modal-dialog/index.js +2 -2
- package/dist/es2019/rules/no-css-tagged-template-expression/index.js +3 -2
- package/dist/es2019/rules/no-dark-theme-vr-tests/index.js +1 -1
- package/dist/es2019/rules/no-deprecated-apis/index.js +2 -2
- package/dist/es2019/rules/no-deprecated-design-token-usage/index.js +1 -1
- package/dist/es2019/rules/no-deprecated-imports/checks.js +1 -1
- package/dist/es2019/rules/no-deprecated-imports/index.js +1 -1
- package/dist/es2019/rules/no-direct-use-of-web-platform-drag-and-drop/index.js +1 -1
- package/dist/es2019/rules/no-emotion-primitives/index.js +1 -1
- package/dist/es2019/rules/no-empty-styled-expression/index.js +1 -1
- package/dist/es2019/rules/no-exported-css/index.js +1 -1
- package/dist/es2019/rules/no-exported-keyframes/index.js +1 -1
- package/dist/es2019/rules/no-html-anchor/index.js +1 -1
- package/dist/es2019/rules/no-html-anchor/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-anchor/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-button/index.js +1 -1
- package/dist/es2019/rules/no-html-button/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-button/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-checkbox/index.js +1 -1
- package/dist/es2019/rules/no-html-checkbox/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-checkbox/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-code/index.js +1 -1
- package/dist/es2019/rules/no-html-code/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-code/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-heading/index.js +1 -1
- package/dist/es2019/rules/no-html-heading/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-heading/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-image/index.js +1 -1
- package/dist/es2019/rules/no-html-image/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-image/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-radio/index.js +1 -1
- package/dist/es2019/rules/no-html-radio/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-radio/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-range/index.js +1 -1
- package/dist/es2019/rules/no-html-range/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-range/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-select/index.js +1 -1
- package/dist/es2019/rules/no-html-select/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-select/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-text-input/index.js +1 -1
- package/dist/es2019/rules/no-html-text-input/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-text-input/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-html-textarea/index.js +1 -1
- package/dist/es2019/rules/no-html-textarea/node-types/jsx-element/index.js +1 -1
- package/dist/es2019/rules/no-html-textarea/node-types/supported.js +1 -1
- package/dist/es2019/rules/no-icon-spacing-prop/index.js +1 -1
- package/dist/es2019/rules/no-invalid-css-map/index.js +1 -1
- package/dist/es2019/rules/no-keyframes-tagged-template-expression/index.js +3 -2
- package/dist/es2019/rules/no-margin/index.js +1 -1
- package/dist/es2019/rules/no-nested-styles/index.js +1 -1
- package/dist/es2019/rules/no-physical-properties/index.js +1 -1
- package/dist/es2019/rules/no-placeholder/affected-atlaskit-packages.js +6 -0
- package/dist/es2019/rules/no-placeholder/affected-html-elements.js +1 -0
- package/dist/es2019/rules/no-placeholder/index.js +6 -11
- package/dist/es2019/rules/no-readonly-or-disabled-inputs/affected-atlaskit-packages.js +4 -0
- package/dist/es2019/rules/no-readonly-or-disabled-inputs/affected-html-elements.js +1 -0
- package/dist/es2019/rules/no-readonly-or-disabled-inputs/index.js +6 -9
- package/dist/es2019/rules/no-readonly-or-disabled-inputs/unwanted-atlaskit-attributes.js +1 -0
- package/dist/es2019/rules/no-readonly-or-disabled-inputs/unwanted-html-attributes.js +1 -0
- package/dist/es2019/rules/no-separator-with-list-elements/index.js +1 -1
- package/dist/es2019/rules/no-styled-tagged-template-expression/index.js +3 -2
- package/dist/es2019/rules/no-to-match-snapshot/index.js +1 -1
- package/dist/es2019/rules/no-unsafe-design-token-usage/index.js +2 -2
- package/dist/es2019/rules/no-unsafe-inline-snapshot/index.js +1 -1
- package/dist/es2019/rules/no-unsafe-style-overrides/index.js +1 -1
- package/dist/es2019/rules/no-unsupported-drag-and-drop-libraries/index.js +1 -1
- package/dist/es2019/rules/no-unused-css-map/get-css-map-object.js +12 -0
- package/dist/es2019/rules/no-unused-css-map/index.js +3 -2
- package/dist/es2019/rules/no-unused-css-map/unused-css-map-checker.js +89 -0
- package/dist/es2019/rules/prefer-primitives/index.js +1 -1
- package/dist/es2019/rules/use-button-group-label/index.js +1 -1
- package/dist/es2019/rules/use-character-counter-field/index.js +4 -2
- package/dist/es2019/rules/use-correct-field/index.js +1 -1
- package/dist/es2019/rules/use-cx-function-in-xcss/index.js +1 -1
- package/dist/es2019/rules/use-datetime-picker-calendar-button/index.js +2 -2
- package/dist/es2019/rules/use-drawer-label/index.js +1 -1
- package/dist/es2019/rules/use-field-message-wrapper/index.js +1 -1
- package/dist/es2019/rules/use-heading/index.js +1 -1
- package/dist/es2019/rules/use-heading/transformers/native-elements.js +1 -1
- package/dist/es2019/rules/use-heading/transformers/update-test-id-attribute-fix.js +1 -1
- package/dist/es2019/rules/use-heading-level-in-spotlight-card/index.js +1 -1
- package/dist/es2019/rules/use-href-in-link-item/index.js +1 -1
- package/dist/es2019/rules/use-latest-xcss-syntax/index.js +1 -1
- package/dist/es2019/rules/use-latest-xcss-syntax-typography/config/{index.js → get-config.js} +1 -1
- package/dist/es2019/rules/use-latest-xcss-syntax-typography/config/patterns.js +1 -0
- package/dist/es2019/rules/use-latest-xcss-syntax-typography/config/types.js +1 -0
- package/dist/es2019/rules/use-latest-xcss-syntax-typography/index.js +3 -2
- package/dist/es2019/rules/use-menu-section-title/index.js +1 -1
- package/dist/es2019/rules/use-modal-dialog-close-button/index.js +2 -2
- package/dist/es2019/rules/use-onboarding-spotlight-label/index.js +1 -1
- package/dist/es2019/rules/use-popup-label/index.js +1 -1
- package/dist/es2019/rules/use-primitives/config/get-config.js +6 -0
- package/dist/es2019/rules/use-primitives/config/types.js +1 -0
- package/dist/es2019/rules/use-primitives/config/valid-patterns.js +40 -0
- package/dist/es2019/rules/use-primitives/index.js +3 -2
- package/dist/es2019/rules/use-primitives/transformers/compiled-styled/convert-jsx-call-site.js +1 -1
- package/dist/es2019/rules/use-primitives/transformers/compiled-styled/convert-styled-component-call-to-jsx.js +1 -1
- package/dist/es2019/rules/use-primitives/transformers/compiled-styled/index.js +1 -1
- package/dist/es2019/rules/use-primitives/transformers/css-to-xcss-transformer.js +37 -0
- package/dist/es2019/rules/use-primitives/transformers/emotion-css/index.js +2 -2
- package/dist/es2019/rules/use-primitives/transformers/styled-object-to-xcss-tokens.js +34 -0
- package/dist/es2019/rules/use-primitives/transformers/supported-styles-map.js +28 -0
- package/dist/es2019/rules/use-primitives/utils/is-valid-css-properties-to-transform.js +1 -1
- package/dist/es2019/rules/use-primitives/utils/validate-styles.js +1 -1
- package/dist/es2019/rules/use-primitives-text/config/{index.js → get-config.js} +0 -9
- package/dist/es2019/rules/use-primitives-text/config/patterns.js +9 -0
- package/dist/es2019/rules/use-primitives-text/config/types.js +1 -0
- package/dist/es2019/rules/use-primitives-text/index.js +3 -2
- package/dist/es2019/rules/use-primitives-text/transformers/add-color-inherit-attribute-fix.js +1 -1
- package/dist/es2019/rules/use-primitives-text/transformers/emphasis-elements.js +1 -1
- package/dist/es2019/rules/use-primitives-text/transformers/has-text-children-only.js +1 -1
- package/dist/es2019/rules/use-primitives-text/transformers/paragraph-elements.js +1 -1
- package/dist/es2019/rules/use-primitives-text/transformers/span-elements.js +1 -1
- package/dist/es2019/rules/use-primitives-text/transformers/strong-elements.js +1 -1
- package/dist/es2019/rules/use-primitives-text/transformers/update-test-id-attribute-fix.js +1 -1
- package/dist/es2019/rules/use-should-render-to-parent/add-prop.js +3 -0
- package/dist/es2019/rules/use-should-render-to-parent/index.js +6 -4
- package/dist/es2019/rules/use-should-render-to-parent/set-prop-to-true.js +3 -0
- package/dist/es2019/rules/use-simple-field/index.js +1 -1
- package/dist/es2019/rules/use-simple-form/index.js +4 -3
- package/dist/es2019/rules/use-simple-form/top-level-attribute-names.js +1 -0
- package/dist/es2019/rules/use-spotlight-package/index.js +1 -1
- package/dist/es2019/rules/use-tag-group-label/index.js +1 -1
- package/dist/es2019/rules/use-textfield-autocomplete/index.js +2 -2
- package/dist/es2019/rules/use-tokens-shape/index.js +1 -1
- package/dist/es2019/rules/use-tokens-space/index.js +1 -1
- package/dist/es2019/rules/use-tokens-typography/config/get-config.js +10 -0
- package/dist/es2019/rules/use-tokens-typography/config/{index.js → rule-schema.js} +0 -8
- package/dist/es2019/rules/use-tokens-typography/config/types.js +0 -0
- package/dist/es2019/rules/use-tokens-typography/default-font-weight.js +2 -0
- package/dist/es2019/rules/use-tokens-typography/find-font-weight-token-for-value.js +12 -0
- package/dist/es2019/rules/use-tokens-typography/find-typography-token-for-values.js +11 -0
- package/dist/es2019/rules/use-tokens-typography/font-weight-map.js +6 -0
- package/dist/es2019/rules/use-tokens-typography/font-weight-tokens.js +10 -0
- package/dist/es2019/rules/use-tokens-typography/get-token-property.js +33 -0
- package/dist/es2019/rules/use-tokens-typography/index.js +3 -2
- package/dist/es2019/rules/use-tokens-typography/transformers/banned-properties.js +1 -1
- package/dist/es2019/rules/use-tokens-typography/transformers/font-family.js +1 -1
- package/dist/es2019/rules/use-tokens-typography/transformers/font-weight.js +2 -2
- package/dist/es2019/rules/use-tokens-typography/transformers/style-object.js +7 -3
- package/dist/es2019/rules/use-tokens-typography/transformers/untokenized-properties.js +1 -1
- package/dist/es2019/rules/use-tokens-typography/types.js +0 -0
- package/dist/es2019/rules/use-tokens-typography/typography-value-to-token.js +25 -0
- package/dist/es2019/rules/use-visually-hidden/count-matching-key-values.js +19 -0
- package/dist/es2019/rules/use-visually-hidden/get-object-likeness.js +24 -0
- package/dist/es2019/rules/use-visually-hidden/index.js +4 -3
- package/dist/es2019/rules/use-visually-hidden/reference-object.js +10 -0
- package/dist/es2019/rules/utils/create-lint-rule.js +9 -0
- package/dist/es2019/rules/utils/create-no-tagged-template-expression-rule/create-no-tagged-template-expression-rule.js +145 -0
- package/dist/es2019/rules/utils/create-no-tagged-template-expression-rule/no-tagged-template-expression-rule-schema.js +14 -0
- package/dist/es2019/rules/utils/create-rule.js +2 -13
- package/dist/es2019/rules/utils/get-rule-url.js +5 -0
- package/dist/es2019/rules/utils/includes-hard-coded-color.js +15 -0
- package/dist/es2019/rules/utils/is-color-css-property-name.js +3 -0
- package/dist/es2019/rules/utils/is-css-in-js-call-node.js +2 -0
- package/dist/es2019/rules/utils/is-css-in-js-object-node.js +2 -0
- package/dist/es2019/rules/utils/is-decendant-of-style-block.js +38 -0
- package/dist/es2019/rules/utils/is-deprecated-import-config.js +3 -0
- package/dist/es2019/rules/utils/is-deprecated-jsx-attribute-config.js +3 -0
- package/dist/es2019/rules/utils/is-hard-coded-color.js +19 -0
- package/dist/es2019/rules/utils/is-legacy-color.js +4 -0
- package/dist/es2019/rules/utils/is-legacy-named-color.js +2 -0
- package/dist/es2019/rules/utils/named-colors.js +1 -0
- package/dist/es2019/rules/utils/types.js +0 -11
- package/dist/esm/ast-nodes/jsx-element-helper.js +84 -0
- package/dist/esm/common/token-maps.partial.js +2 -1
- package/dist/esm/rules/consistent-css-prop-usage/index.js +1 -1
- package/dist/esm/rules/enforce-inline-styles-in-select/index.js +1 -1
- package/dist/esm/rules/ensure-avatar-tag-avatar-props/index.js +1 -1
- package/dist/esm/rules/ensure-design-token-usage/em-to-pixels.js +15 -0
- package/dist/esm/rules/ensure-design-token-usage/find-token-name-by-property-value.js +17 -0
- package/dist/esm/rules/ensure-design-token-usage/get-domains-for-property.js +28 -0
- package/dist/esm/rules/ensure-design-token-usage/get-font-size-value-in-scope.js +24 -0
- package/dist/esm/rules/ensure-design-token-usage/get-property-node-from-parent.js +13 -0
- package/dist/esm/rules/ensure-design-token-usage/get-token-node-for-value.js +29 -0
- package/dist/esm/rules/ensure-design-token-usage/get-token-replacement.js +18 -0
- package/dist/esm/rules/ensure-design-token-usage/get-token-suggestion.js +21 -0
- package/dist/esm/rules/ensure-design-token-usage/get-value-for-property-node.js +7 -0
- package/dist/esm/rules/ensure-design-token-usage/get-value-from-shorthand.js +13 -0
- package/dist/esm/rules/ensure-design-token-usage/get-value-from-template-literal-raw.js +30 -0
- package/dist/esm/rules/ensure-design-token-usage/get-value.js +135 -0
- package/dist/esm/rules/ensure-design-token-usage/index.js +21 -8
- package/dist/esm/rules/ensure-design-token-usage/is-border-size-property.js +4 -0
- package/dist/esm/rules/ensure-design-token-usage/is-calc.js +9 -0
- package/dist/esm/rules/ensure-design-token-usage/is-radius-property.js +4 -0
- package/dist/esm/rules/ensure-design-token-usage/is-shape-property.js +5 -0
- package/dist/esm/rules/ensure-design-token-usage/is-spacing-property.js +4 -0
- package/dist/esm/rules/ensure-design-token-usage/is-valid-spacing-value.js +20 -0
- package/dist/esm/rules/ensure-design-token-usage/lint-jsx-identifier-for-color.js +23 -0
- package/dist/esm/rules/ensure-design-token-usage/lint-jsx-literal-for-color.js +146 -0
- package/dist/esm/rules/ensure-design-token-usage/lint-jsx-member-for-color.js +22 -0
- package/dist/esm/rules/ensure-design-token-usage/lint-object-for-color.js +88 -0
- package/dist/esm/rules/ensure-design-token-usage/lint-template-identifier-for-color.js +47 -0
- package/dist/esm/rules/ensure-design-token-usage/process-css-node.js +33 -0
- package/dist/esm/rules/ensure-design-token-usage/remove-pixel-suffix.js +8 -0
- package/dist/esm/rules/ensure-design-token-usage/spacing.js +7 -1
- package/dist/esm/rules/ensure-design-token-usage-preview/index.js +1 -1
- package/dist/esm/rules/ensure-icon-color/index.js +1 -1
- package/dist/esm/rules/ensure-proper-xcss-usage/index.js +1 -1
- package/dist/esm/rules/icon-label/index.js +1 -1
- package/dist/esm/rules/lozenge-badge-tag-labelling-system-migration/index.js +1 -1
- package/dist/esm/rules/no-banned-imports/index.js +1 -1
- package/dist/esm/rules/no-boolean-autofocus-on-modal-dialog/index.js +2 -2
- package/dist/esm/rules/no-css-tagged-template-expression/index.js +3 -2
- package/dist/esm/rules/no-dark-theme-vr-tests/index.js +1 -1
- package/dist/esm/rules/no-deprecated-apis/index.js +2 -2
- package/dist/esm/rules/no-deprecated-design-token-usage/index.js +1 -1
- package/dist/esm/rules/no-deprecated-imports/checks.js +1 -1
- package/dist/esm/rules/no-deprecated-imports/index.js +1 -1
- package/dist/esm/rules/no-direct-use-of-web-platform-drag-and-drop/index.js +1 -1
- package/dist/esm/rules/no-emotion-primitives/index.js +1 -1
- package/dist/esm/rules/no-empty-styled-expression/index.js +1 -1
- package/dist/esm/rules/no-exported-css/index.js +1 -1
- package/dist/esm/rules/no-exported-keyframes/index.js +1 -1
- package/dist/esm/rules/no-html-anchor/index.js +1 -1
- package/dist/esm/rules/no-html-anchor/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-anchor/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-button/index.js +1 -1
- package/dist/esm/rules/no-html-button/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-button/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-checkbox/index.js +1 -1
- package/dist/esm/rules/no-html-checkbox/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-checkbox/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-code/index.js +1 -1
- package/dist/esm/rules/no-html-code/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-code/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-heading/index.js +1 -1
- package/dist/esm/rules/no-html-heading/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-heading/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-image/index.js +1 -1
- package/dist/esm/rules/no-html-image/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-image/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-radio/index.js +1 -1
- package/dist/esm/rules/no-html-radio/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-radio/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-range/index.js +1 -1
- package/dist/esm/rules/no-html-range/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-range/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-select/index.js +1 -1
- package/dist/esm/rules/no-html-select/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-select/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-text-input/index.js +1 -1
- package/dist/esm/rules/no-html-text-input/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-text-input/node-types/supported.js +1 -1
- package/dist/esm/rules/no-html-textarea/index.js +1 -1
- package/dist/esm/rules/no-html-textarea/node-types/jsx-element/index.js +1 -1
- package/dist/esm/rules/no-html-textarea/node-types/supported.js +1 -1
- package/dist/esm/rules/no-icon-spacing-prop/index.js +1 -1
- package/dist/esm/rules/no-invalid-css-map/index.js +1 -1
- package/dist/esm/rules/no-keyframes-tagged-template-expression/index.js +3 -2
- package/dist/esm/rules/no-margin/index.js +1 -1
- package/dist/esm/rules/no-nested-styles/index.js +1 -1
- package/dist/esm/rules/no-physical-properties/index.js +1 -1
- package/dist/esm/rules/no-placeholder/affected-atlaskit-packages.js +6 -0
- package/dist/esm/rules/no-placeholder/affected-html-elements.js +1 -0
- package/dist/esm/rules/no-placeholder/index.js +6 -11
- package/dist/esm/rules/no-readonly-or-disabled-inputs/affected-atlaskit-packages.js +4 -0
- package/dist/esm/rules/no-readonly-or-disabled-inputs/affected-html-elements.js +1 -0
- package/dist/esm/rules/no-readonly-or-disabled-inputs/index.js +6 -9
- package/dist/esm/rules/no-readonly-or-disabled-inputs/unwanted-atlaskit-attributes.js +1 -0
- package/dist/esm/rules/no-readonly-or-disabled-inputs/unwanted-html-attributes.js +1 -0
- package/dist/esm/rules/no-separator-with-list-elements/index.js +1 -1
- package/dist/esm/rules/no-styled-tagged-template-expression/index.js +3 -2
- package/dist/esm/rules/no-to-match-snapshot/index.js +1 -1
- package/dist/esm/rules/no-unsafe-design-token-usage/index.js +2 -2
- package/dist/esm/rules/no-unsafe-inline-snapshot/index.js +1 -1
- package/dist/esm/rules/no-unsafe-style-overrides/index.js +1 -1
- package/dist/esm/rules/no-unsupported-drag-and-drop-libraries/index.js +1 -1
- package/dist/esm/rules/no-unused-css-map/get-css-map-object.js +12 -0
- package/dist/esm/rules/no-unused-css-map/index.js +3 -2
- package/dist/esm/rules/no-unused-css-map/unused-css-map-checker.js +143 -0
- package/dist/esm/rules/prefer-primitives/index.js +1 -1
- package/dist/esm/rules/use-button-group-label/index.js +1 -1
- package/dist/esm/rules/use-character-counter-field/index.js +4 -2
- package/dist/esm/rules/use-correct-field/index.js +1 -1
- package/dist/esm/rules/use-cx-function-in-xcss/index.js +1 -1
- package/dist/esm/rules/use-datetime-picker-calendar-button/index.js +2 -2
- package/dist/esm/rules/use-drawer-label/index.js +1 -1
- package/dist/esm/rules/use-field-message-wrapper/index.js +1 -1
- package/dist/esm/rules/use-heading/index.js +1 -1
- package/dist/esm/rules/use-heading/transformers/native-elements.js +1 -1
- package/dist/esm/rules/use-heading/transformers/update-test-id-attribute-fix.js +1 -1
- package/dist/esm/rules/use-heading-level-in-spotlight-card/index.js +1 -1
- package/dist/esm/rules/use-href-in-link-item/index.js +1 -1
- package/dist/esm/rules/use-latest-xcss-syntax/index.js +1 -1
- package/dist/esm/rules/use-latest-xcss-syntax-typography/config/get-config.js +9 -0
- package/dist/esm/rules/use-latest-xcss-syntax-typography/config/patterns.js +1 -0
- package/dist/esm/rules/use-latest-xcss-syntax-typography/config/types.js +1 -0
- package/dist/esm/rules/use-latest-xcss-syntax-typography/index.js +3 -2
- package/dist/esm/rules/use-menu-section-title/index.js +1 -1
- package/dist/esm/rules/use-modal-dialog-close-button/index.js +2 -2
- package/dist/esm/rules/use-onboarding-spotlight-label/index.js +1 -1
- package/dist/esm/rules/use-popup-label/index.js +1 -1
- package/dist/esm/rules/use-primitives/config/get-config.js +6 -0
- package/dist/esm/rules/use-primitives/config/types.js +1 -0
- package/dist/esm/rules/use-primitives/config/valid-patterns.js +40 -0
- package/dist/esm/rules/use-primitives/index.js +3 -2
- package/dist/esm/rules/use-primitives/transformers/compiled-styled/convert-jsx-call-site.js +1 -1
- package/dist/esm/rules/use-primitives/transformers/compiled-styled/convert-styled-component-call-to-jsx.js +1 -1
- package/dist/esm/rules/use-primitives/transformers/compiled-styled/index.js +1 -1
- package/dist/esm/rules/use-primitives/transformers/css-to-xcss-transformer.js +38 -0
- package/dist/esm/rules/use-primitives/transformers/emotion-css/index.js +2 -2
- package/dist/esm/rules/use-primitives/transformers/styled-object-to-xcss-tokens.js +34 -0
- package/dist/esm/rules/use-primitives/transformers/supported-styles-map.js +30 -0
- package/dist/esm/rules/use-primitives/utils/is-valid-css-properties-to-transform.js +1 -1
- package/dist/esm/rules/use-primitives/utils/validate-styles.js +1 -1
- package/dist/esm/rules/use-primitives-text/config/{index.js → get-config.js} +0 -9
- package/dist/esm/rules/use-primitives-text/config/patterns.js +9 -0
- package/dist/esm/rules/use-primitives-text/config/types.js +1 -0
- package/dist/esm/rules/use-primitives-text/index.js +3 -2
- package/dist/esm/rules/use-primitives-text/transformers/add-color-inherit-attribute-fix.js +1 -1
- package/dist/esm/rules/use-primitives-text/transformers/emphasis-elements.js +1 -1
- package/dist/esm/rules/use-primitives-text/transformers/has-text-children-only.js +1 -1
- package/dist/esm/rules/use-primitives-text/transformers/paragraph-elements.js +1 -1
- package/dist/esm/rules/use-primitives-text/transformers/span-elements.js +1 -1
- package/dist/esm/rules/use-primitives-text/transformers/strong-elements.js +1 -1
- package/dist/esm/rules/use-primitives-text/transformers/update-test-id-attribute-fix.js +1 -1
- package/dist/esm/rules/use-should-render-to-parent/add-prop.js +3 -0
- package/dist/esm/rules/use-should-render-to-parent/index.js +6 -4
- package/dist/esm/rules/use-should-render-to-parent/set-prop-to-true.js +3 -0
- package/dist/esm/rules/use-simple-field/index.js +1 -1
- package/dist/esm/rules/use-simple-form/index.js +4 -3
- package/dist/esm/rules/use-simple-form/top-level-attribute-names.js +1 -0
- package/dist/esm/rules/use-spotlight-package/index.js +1 -1
- package/dist/esm/rules/use-tag-group-label/index.js +1 -1
- package/dist/esm/rules/use-textfield-autocomplete/index.js +2 -2
- package/dist/esm/rules/use-tokens-shape/index.js +1 -1
- package/dist/esm/rules/use-tokens-space/index.js +1 -1
- package/dist/esm/rules/use-tokens-typography/config/get-config.js +10 -0
- package/dist/esm/rules/use-tokens-typography/config/{index.js → rule-schema.js} +0 -8
- package/dist/esm/rules/use-tokens-typography/config/types.js +0 -0
- package/dist/esm/rules/use-tokens-typography/default-font-weight.js +2 -0
- package/dist/esm/rules/use-tokens-typography/find-font-weight-token-for-value.js +15 -0
- package/dist/esm/rules/use-tokens-typography/find-typography-token-for-values.js +15 -0
- package/dist/esm/rules/use-tokens-typography/font-weight-map.js +6 -0
- package/dist/esm/rules/use-tokens-typography/font-weight-tokens.js +12 -0
- package/dist/esm/rules/use-tokens-typography/get-token-property.js +35 -0
- package/dist/esm/rules/use-tokens-typography/index.js +3 -2
- package/dist/esm/rules/use-tokens-typography/transformers/banned-properties.js +1 -1
- package/dist/esm/rules/use-tokens-typography/transformers/font-family.js +1 -1
- package/dist/esm/rules/use-tokens-typography/transformers/font-weight.js +2 -2
- package/dist/esm/rules/use-tokens-typography/transformers/style-object.js +7 -3
- package/dist/esm/rules/use-tokens-typography/transformers/untokenized-properties.js +1 -1
- package/dist/esm/rules/use-tokens-typography/types.js +0 -0
- package/dist/esm/rules/use-tokens-typography/typography-value-to-token.js +37 -0
- package/dist/esm/rules/use-visually-hidden/count-matching-key-values.js +21 -0
- package/dist/esm/rules/use-visually-hidden/get-object-likeness.js +27 -0
- package/dist/esm/rules/use-visually-hidden/index.js +4 -3
- package/dist/esm/rules/use-visually-hidden/reference-object.js +10 -0
- package/dist/esm/rules/utils/create-lint-rule.js +9 -0
- package/dist/esm/rules/utils/create-no-tagged-template-expression-rule/create-no-tagged-template-expression-rule.js +130 -0
- package/dist/esm/rules/utils/create-no-tagged-template-expression-rule/no-tagged-template-expression-rule-schema.js +14 -0
- package/dist/esm/rules/utils/create-rule.js +2 -13
- package/dist/esm/rules/utils/get-rule-url.js +5 -0
- package/dist/esm/rules/utils/includes-hard-coded-color.js +17 -0
- package/dist/esm/rules/utils/is-color-css-property-name.js +9 -0
- package/dist/esm/rules/utils/is-css-in-js-call-node.js +4 -0
- package/dist/esm/rules/utils/is-css-in-js-object-node.js +4 -0
- package/dist/esm/rules/utils/is-decendant-of-style-block.js +43 -0
- package/dist/esm/rules/utils/is-deprecated-import-config.js +3 -0
- package/dist/esm/rules/utils/is-deprecated-jsx-attribute-config.js +3 -0
- package/dist/esm/rules/utils/is-hard-coded-color.js +21 -0
- package/dist/esm/rules/utils/is-legacy-color.js +6 -0
- package/dist/esm/rules/utils/is-legacy-named-color.js +4 -0
- package/dist/esm/rules/utils/named-colors.js +1 -0
- package/dist/esm/rules/utils/types.js +0 -11
- package/dist/types/ast-nodes/jsx-element-helper.d.ts +23 -0
- package/dist/types/common/token-maps.partial.d.ts +1 -1
- package/dist/types/rules/ensure-design-token-usage/em-to-pixels.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/find-token-name-by-property-value.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/get-domains-for-property.d.ts +13 -0
- package/dist/types/rules/ensure-design-token-usage/get-font-size-value-in-scope.d.ts +2 -0
- package/dist/types/rules/ensure-design-token-usage/get-property-node-from-parent.d.ts +3 -0
- package/dist/types/rules/ensure-design-token-usage/get-token-node-for-value.d.ts +12 -0
- package/dist/types/rules/ensure-design-token-usage/get-token-replacement.d.ts +8 -0
- package/dist/types/rules/ensure-design-token-usage/get-token-suggestion.d.ts +7 -0
- package/dist/types/rules/ensure-design-token-usage/get-value-for-property-node.d.ts +3 -0
- package/dist/types/rules/ensure-design-token-usage/get-value-from-shorthand.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/get-value-from-template-literal-raw.d.ts +17 -0
- package/dist/types/rules/ensure-design-token-usage/get-value.d.ts +3 -0
- package/dist/types/rules/ensure-design-token-usage/index.d.ts +1 -2
- package/dist/types/rules/ensure-design-token-usage/is-border-size-property.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/is-calc.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/is-radius-property.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/is-shape-property.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/is-spacing-property.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/is-valid-spacing-value.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/lint-jsx-identifier-for-color.d.ts +3 -0
- package/dist/types/rules/ensure-design-token-usage/lint-jsx-literal-for-color.d.ts +3 -0
- package/dist/types/rules/ensure-design-token-usage/lint-jsx-member-for-color.d.ts +3 -0
- package/dist/types/rules/ensure-design-token-usage/lint-object-for-color.d.ts +4 -0
- package/dist/types/rules/ensure-design-token-usage/lint-template-identifier-for-color.d.ts +3 -0
- package/dist/types/rules/ensure-design-token-usage/process-css-node.d.ts +16 -0
- package/dist/types/rules/ensure-design-token-usage/remove-pixel-suffix.d.ts +1 -0
- package/dist/types/rules/ensure-design-token-usage/types.d.ts +1 -0
- package/dist/types/rules/no-deprecated-apis/helpers/validate-deprecated-apis-config.d.ts +1 -1
- package/dist/types/rules/no-placeholder/affected-atlaskit-packages.d.ts +1 -0
- package/dist/types/rules/no-placeholder/affected-html-elements.d.ts +1 -0
- package/dist/types/rules/no-placeholder/index.d.ts +0 -4
- package/dist/types/rules/no-readonly-or-disabled-inputs/affected-atlaskit-packages.d.ts +1 -0
- package/dist/types/rules/no-readonly-or-disabled-inputs/affected-html-elements.d.ts +1 -0
- package/dist/types/rules/no-readonly-or-disabled-inputs/index.d.ts +0 -4
- package/dist/types/rules/no-readonly-or-disabled-inputs/unwanted-atlaskit-attributes.d.ts +1 -0
- package/dist/types/rules/no-readonly-or-disabled-inputs/unwanted-html-attributes.d.ts +1 -0
- package/dist/types/rules/no-unused-css-map/get-css-map-object.d.ts +5 -0
- package/dist/types/rules/no-unused-css-map/unused-css-map-checker.d.ts +14 -0
- package/dist/types/rules/use-latest-xcss-syntax-typography/config/get-config.d.ts +2 -0
- package/dist/types/rules/use-latest-xcss-syntax-typography/config/patterns.d.ts +2 -0
- package/dist/types/rules/use-latest-xcss-syntax-typography/config/types.d.ts +5 -0
- package/dist/types/rules/use-latest-xcss-syntax-typography/linters/common.d.ts +1 -1
- package/dist/types/rules/use-primitives/config/get-config.d.ts +2 -0
- package/dist/types/rules/use-primitives/config/types.d.ts +4 -0
- package/dist/types/rules/use-primitives/config/valid-patterns.d.ts +2 -0
- package/dist/types/rules/use-primitives/transformers/compiled-styled/index.d.ts +1 -1
- package/dist/types/rules/use-primitives/transformers/css-to-xcss-transformer.d.ts +3 -0
- package/dist/types/rules/use-primitives/transformers/emotion-css/index.d.ts +1 -1
- package/dist/types/rules/use-primitives/transformers/styled-object-to-xcss-tokens.d.ts +3 -0
- package/dist/types/rules/use-primitives/transformers/supported-styles-map.d.ts +4 -0
- package/dist/types/rules/use-primitives/utils/is-valid-css-properties-to-transform.d.ts +1 -1
- package/dist/types/rules/use-primitives/utils/validate-styles.d.ts +1 -1
- package/dist/types/rules/use-primitives-text/config/get-config.d.ts +2 -0
- package/dist/types/rules/use-primitives-text/config/patterns.d.ts +2 -0
- package/dist/types/rules/use-primitives-text/config/{index.d.ts → types.d.ts} +1 -4
- package/dist/types/rules/use-primitives-text/transformers/add-color-inherit-attribute-fix.d.ts +1 -1
- package/dist/types/rules/use-primitives-text/transformers/common.d.ts +1 -1
- package/dist/types/rules/use-should-render-to-parent/add-prop.d.ts +1 -0
- package/dist/types/rules/use-should-render-to-parent/index.d.ts +2 -2
- package/dist/types/rules/use-should-render-to-parent/set-prop-to-true.d.ts +1 -0
- package/dist/types/rules/use-simple-form/index.d.ts +1 -1
- package/dist/types/rules/use-simple-form/top-level-attribute-names.d.ts +1 -0
- package/dist/types/rules/use-tokens-typography/config/get-config.d.ts +2 -0
- package/dist/types/rules/use-tokens-typography/config/rule-schema.d.ts +2 -0
- package/dist/{types-ts4.5/rules/use-tokens-typography/config/index.d.ts → types/rules/use-tokens-typography/config/types.d.ts} +0 -3
- package/dist/types/rules/use-tokens-typography/default-font-weight.d.ts +1 -0
- package/dist/types/rules/use-tokens-typography/find-font-weight-token-for-value.d.ts +2 -0
- package/dist/types/rules/use-tokens-typography/find-typography-token-for-values.d.ts +2 -0
- package/dist/types/rules/use-tokens-typography/font-weight-map.d.ts +2 -0
- package/dist/types/rules/use-tokens-typography/font-weight-tokens.d.ts +2 -0
- package/dist/types/rules/use-tokens-typography/get-token-property.d.ts +2 -0
- package/dist/types/rules/use-tokens-typography/transformers/banned-properties.d.ts +1 -1
- package/dist/types/rules/use-tokens-typography/transformers/font-family.d.ts +1 -1
- package/dist/types/rules/use-tokens-typography/transformers/font-weight.d.ts +1 -1
- package/dist/types/rules/use-tokens-typography/transformers/restricted-capitalisation.d.ts +1 -1
- package/dist/types/rules/use-tokens-typography/transformers/style-object.d.ts +2 -2
- package/dist/types/rules/use-tokens-typography/transformers/untokenized-properties.d.ts +1 -1
- package/dist/types/rules/use-tokens-typography/types.d.ts +15 -0
- package/dist/types/rules/use-tokens-typography/typography-value-to-token.d.ts +2 -0
- package/dist/types/rules/use-visually-hidden/count-matching-key-values.d.ts +6 -0
- package/dist/types/rules/use-visually-hidden/get-object-likeness.d.ts +9 -0
- package/dist/types/rules/use-visually-hidden/reference-object.d.ts +11 -0
- package/dist/types/rules/utils/create-lint-rule.d.ts +8 -0
- package/dist/types/rules/utils/create-no-tagged-template-expression-rule/create-no-tagged-template-expression-rule.d.ts +5 -0
- package/dist/types/rules/utils/create-no-tagged-template-expression-rule/no-tagged-template-expression-rule-schema.d.ts +2 -0
- package/dist/types/rules/utils/create-rule.d.ts +0 -8
- package/dist/types/rules/utils/get-rule-url.d.ts +1 -0
- package/dist/types/rules/utils/includes-hard-coded-color.d.ts +1 -0
- package/dist/types/rules/utils/is-color-css-property-name.d.ts +1 -0
- package/dist/types/rules/utils/is-css-in-js-call-node.d.ts +2 -0
- package/dist/types/rules/utils/is-css-in-js-object-node.d.ts +2 -0
- package/dist/types/rules/utils/is-decendant-of-style-block.d.ts +2 -0
- package/dist/types/rules/utils/is-deprecated-import-config.d.ts +2 -0
- package/dist/types/rules/utils/is-deprecated-jsx-attribute-config.d.ts +2 -0
- package/dist/types/rules/utils/is-hard-coded-color.d.ts +1 -0
- package/dist/types/rules/utils/is-legacy-color.d.ts +1 -0
- package/dist/types/rules/utils/is-legacy-named-color.d.ts +1 -0
- package/dist/types/rules/utils/named-colors.d.ts +1 -0
- package/dist/types/rules/utils/types.d.ts +0 -2
- package/dist/types-ts4.5/ast-nodes/jsx-element-helper.d.ts +23 -0
- package/dist/types-ts4.5/common/token-maps.partial.d.ts +1 -1
- package/dist/types-ts4.5/rules/ensure-design-token-usage/em-to-pixels.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/find-token-name-by-property-value.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-domains-for-property.d.ts +13 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-font-size-value-in-scope.d.ts +2 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-property-node-from-parent.d.ts +3 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-token-node-for-value.d.ts +12 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-token-replacement.d.ts +8 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-token-suggestion.d.ts +7 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-value-for-property-node.d.ts +3 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-value-from-shorthand.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-value-from-template-literal-raw.d.ts +17 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/get-value.d.ts +3 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/index.d.ts +1 -2
- package/dist/types-ts4.5/rules/ensure-design-token-usage/is-border-size-property.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/is-calc.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/is-radius-property.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/is-shape-property.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/is-spacing-property.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/is-valid-spacing-value.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/lint-jsx-identifier-for-color.d.ts +3 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/lint-jsx-literal-for-color.d.ts +3 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/lint-jsx-member-for-color.d.ts +3 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/lint-object-for-color.d.ts +4 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/lint-template-identifier-for-color.d.ts +3 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/process-css-node.d.ts +16 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/remove-pixel-suffix.d.ts +1 -0
- package/dist/types-ts4.5/rules/ensure-design-token-usage/types.d.ts +4 -0
- package/dist/types-ts4.5/rules/no-deprecated-apis/helpers/validate-deprecated-apis-config.d.ts +1 -1
- package/dist/types-ts4.5/rules/no-placeholder/affected-atlaskit-packages.d.ts +1 -0
- package/dist/types-ts4.5/rules/no-placeholder/affected-html-elements.d.ts +1 -0
- package/dist/types-ts4.5/rules/no-placeholder/index.d.ts +0 -4
- package/dist/types-ts4.5/rules/no-readonly-or-disabled-inputs/affected-atlaskit-packages.d.ts +1 -0
- package/dist/types-ts4.5/rules/no-readonly-or-disabled-inputs/affected-html-elements.d.ts +1 -0
- package/dist/types-ts4.5/rules/no-readonly-or-disabled-inputs/index.d.ts +0 -10
- package/dist/types-ts4.5/rules/no-readonly-or-disabled-inputs/unwanted-atlaskit-attributes.d.ts +4 -0
- package/dist/types-ts4.5/rules/no-readonly-or-disabled-inputs/unwanted-html-attributes.d.ts +4 -0
- package/dist/types-ts4.5/rules/no-unused-css-map/get-css-map-object.d.ts +5 -0
- package/dist/types-ts4.5/rules/no-unused-css-map/unused-css-map-checker.d.ts +14 -0
- package/dist/types-ts4.5/rules/use-latest-xcss-syntax-typography/config/get-config.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-latest-xcss-syntax-typography/config/patterns.d.ts +6 -0
- package/dist/types-ts4.5/rules/use-latest-xcss-syntax-typography/config/types.d.ts +5 -0
- package/dist/types-ts4.5/rules/use-latest-xcss-syntax-typography/linters/common.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-primitives/config/get-config.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-primitives/config/types.d.ts +4 -0
- package/dist/types-ts4.5/rules/use-primitives/config/valid-patterns.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-primitives/transformers/compiled-styled/index.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-primitives/transformers/css-to-xcss-transformer.d.ts +3 -0
- package/dist/types-ts4.5/rules/use-primitives/transformers/emotion-css/index.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-primitives/transformers/styled-object-to-xcss-tokens.d.ts +3 -0
- package/dist/types-ts4.5/rules/use-primitives/transformers/supported-styles-map.d.ts +4 -0
- package/dist/types-ts4.5/rules/use-primitives/utils/is-valid-css-properties-to-transform.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-primitives/utils/validate-styles.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-primitives-text/config/get-config.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-primitives-text/config/patterns.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-primitives-text/config/{index.d.ts → types.d.ts} +1 -4
- package/dist/types-ts4.5/rules/use-primitives-text/transformers/add-color-inherit-attribute-fix.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-primitives-text/transformers/common.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-should-render-to-parent/add-prop.d.ts +1 -0
- package/dist/types-ts4.5/rules/use-should-render-to-parent/index.d.ts +2 -2
- package/dist/types-ts4.5/rules/use-should-render-to-parent/set-prop-to-true.d.ts +1 -0
- package/dist/types-ts4.5/rules/use-simple-form/index.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-simple-form/top-level-attribute-names.d.ts +1 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/config/get-config.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/config/rule-schema.d.ts +2 -0
- package/dist/{types/rules/use-tokens-typography/config/index.d.ts → types-ts4.5/rules/use-tokens-typography/config/types.d.ts} +0 -3
- package/dist/types-ts4.5/rules/use-tokens-typography/default-font-weight.d.ts +1 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/find-font-weight-token-for-value.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/find-typography-token-for-values.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/font-weight-map.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/font-weight-tokens.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/get-token-property.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/transformers/banned-properties.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-tokens-typography/transformers/font-family.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-tokens-typography/transformers/font-weight.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-tokens-typography/transformers/restricted-capitalisation.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-tokens-typography/transformers/style-object.d.ts +2 -2
- package/dist/types-ts4.5/rules/use-tokens-typography/transformers/untokenized-properties.d.ts +1 -1
- package/dist/types-ts4.5/rules/use-tokens-typography/types.d.ts +15 -0
- package/dist/types-ts4.5/rules/use-tokens-typography/typography-value-to-token.d.ts +2 -0
- package/dist/types-ts4.5/rules/use-visually-hidden/count-matching-key-values.d.ts +6 -0
- package/dist/types-ts4.5/rules/use-visually-hidden/get-object-likeness.d.ts +9 -0
- package/dist/types-ts4.5/rules/use-visually-hidden/reference-object.d.ts +11 -0
- package/dist/types-ts4.5/rules/utils/create-lint-rule.d.ts +8 -0
- package/dist/types-ts4.5/rules/utils/create-no-tagged-template-expression-rule/create-no-tagged-template-expression-rule.d.ts +5 -0
- package/dist/types-ts4.5/rules/utils/create-no-tagged-template-expression-rule/no-tagged-template-expression-rule-schema.d.ts +2 -0
- package/dist/types-ts4.5/rules/utils/create-rule.d.ts +0 -8
- package/dist/types-ts4.5/rules/utils/get-rule-url.d.ts +1 -0
- package/dist/types-ts4.5/rules/utils/includes-hard-coded-color.d.ts +1 -0
- package/dist/types-ts4.5/rules/utils/is-color-css-property-name.d.ts +1 -0
- package/dist/types-ts4.5/rules/utils/is-css-in-js-call-node.d.ts +2 -0
- package/dist/types-ts4.5/rules/utils/is-css-in-js-object-node.d.ts +2 -0
- package/dist/types-ts4.5/rules/utils/is-decendant-of-style-block.d.ts +2 -0
- package/dist/types-ts4.5/rules/utils/is-deprecated-import-config.d.ts +2 -0
- package/dist/types-ts4.5/rules/utils/is-deprecated-jsx-attribute-config.d.ts +2 -0
- package/dist/types-ts4.5/rules/utils/is-hard-coded-color.d.ts +1 -0
- package/dist/types-ts4.5/rules/utils/is-legacy-color.d.ts +1 -0
- package/dist/types-ts4.5/rules/utils/is-legacy-named-color.d.ts +1 -0
- package/dist/types-ts4.5/rules/utils/named-colors.d.ts +1 -0
- package/dist/types-ts4.5/rules/utils/types.d.ts +0 -2
- package/package.json +3 -3
- package/dist/cjs/rules/ensure-design-token-usage/color.js +0 -333
- package/dist/cjs/rules/ensure-design-token-usage/shape.js +0 -19
- package/dist/cjs/rules/ensure-design-token-usage/utils.js +0 -404
- package/dist/cjs/rules/use-primitives/transformers/css-to-xcss.js +0 -108
- package/dist/cjs/rules/use-tokens-typography/utils.js +0 -136
- package/dist/cjs/rules/utils/is-color.js +0 -56
- package/dist/es2019/rules/ensure-design-token-usage/color.js +0 -296
- package/dist/es2019/rules/ensure-design-token-usage/shape.js +0 -11
- package/dist/es2019/rules/ensure-design-token-usage/utils.js +0 -366
- package/dist/es2019/rules/use-primitives/transformers/css-to-xcss.js +0 -98
- package/dist/es2019/rules/use-tokens-typography/utils.js +0 -96
- package/dist/es2019/rules/utils/is-color.js +0 -38
- package/dist/esm/rules/ensure-design-token-usage/color.js +0 -327
- package/dist/esm/rules/ensure-design-token-usage/shape.js +0 -11
- package/dist/esm/rules/ensure-design-token-usage/utils.js +0 -385
- package/dist/esm/rules/use-latest-xcss-syntax-typography/config/index.js +0 -8
- package/dist/esm/rules/use-primitives/transformers/css-to-xcss.js +0 -101
- package/dist/esm/rules/use-tokens-typography/utils.js +0 -119
- package/dist/esm/rules/utils/is-color.js +0 -50
- package/dist/types/rules/ensure-design-token-usage/color.d.ts +0 -13
- package/dist/types/rules/ensure-design-token-usage/shape.d.ts +0 -3
- package/dist/types/rules/ensure-design-token-usage/utils.d.ts +0 -73
- package/dist/types/rules/use-latest-xcss-syntax-typography/config/index.d.ts +0 -8
- package/dist/types/rules/use-primitives/transformers/css-to-xcss.d.ts +0 -8
- package/dist/types/rules/use-tokens-typography/utils.d.ts +0 -24
- package/dist/types/rules/utils/is-color.d.ts +0 -5
- package/dist/types-ts4.5/rules/ensure-design-token-usage/color.d.ts +0 -13
- package/dist/types-ts4.5/rules/ensure-design-token-usage/shape.d.ts +0 -3
- package/dist/types-ts4.5/rules/ensure-design-token-usage/utils.d.ts +0 -76
- package/dist/types-ts4.5/rules/use-latest-xcss-syntax-typography/config/index.d.ts +0 -12
- package/dist/types-ts4.5/rules/use-primitives/transformers/css-to-xcss.d.ts +0 -8
- package/dist/types-ts4.5/rules/use-tokens-typography/utils.d.ts +0 -24
- package/dist/types-ts4.5/rules/utils/is-color.d.ts +0 -5
|
@@ -4,9 +4,10 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
4
4
|
value: true
|
|
5
5
|
});
|
|
6
6
|
exports.default = void 0;
|
|
7
|
-
var
|
|
7
|
+
var _createLintRule = require("../utils/create-lint-rule");
|
|
8
8
|
var _errorBoundary = require("../utils/error-boundary");
|
|
9
|
-
var
|
|
9
|
+
var _getConfig = require("./config/get-config");
|
|
10
|
+
var _ruleSchema = require("./config/rule-schema");
|
|
10
11
|
var _bannedProperties = require("./transformers/banned-properties");
|
|
11
12
|
var _fontFamily = require("./transformers/font-family");
|
|
12
13
|
var _fontWeight = require("./transformers/font-weight");
|
|
@@ -15,7 +16,7 @@ var _styleObject = require("./transformers/style-object");
|
|
|
15
16
|
var _untokenizedProperties = require("./transformers/untokenized-properties");
|
|
16
17
|
var create = function create(context) {
|
|
17
18
|
// TODO: JFP-2823 - this type cast was added due to Jira's ESLint v9 migration
|
|
18
|
-
var config = (0,
|
|
19
|
+
var config = (0, _getConfig.getConfig)(context.options[0]);
|
|
19
20
|
return (0, _errorBoundary.errorBoundary)({
|
|
20
21
|
// const styles = css({ fontSize: '14px', ... }), styled.div({ fontSize: 14, ... })
|
|
21
22
|
ObjectExpression: function ObjectExpression(node) {
|
|
@@ -61,7 +62,7 @@ var create = function create(context) {
|
|
|
61
62
|
}
|
|
62
63
|
}, config);
|
|
63
64
|
};
|
|
64
|
-
var rule = (0,
|
|
65
|
+
var rule = (0, _createLintRule.createLintRule)({
|
|
65
66
|
meta: {
|
|
66
67
|
name: 'use-tokens-typography',
|
|
67
68
|
type: 'suggestion',
|
|
@@ -81,7 +82,7 @@ var rule = (0, _createRule.createLintRule)({
|
|
|
81
82
|
noBannedProperties: 'Do not use `{{property}}`. Typography tokens automatically specify `{{property}}` alongside font size and font weight.',
|
|
82
83
|
noRestrictedCapitalisation: "Avoid using ALL CAPS as it reduces readability and is bad for accessibility."
|
|
83
84
|
},
|
|
84
|
-
schema:
|
|
85
|
+
schema: _ruleSchema.ruleSchema
|
|
85
86
|
},
|
|
86
87
|
create: create
|
|
87
88
|
});
|
|
@@ -5,8 +5,8 @@ Object.defineProperty(exports, "__esModule", {
|
|
|
5
5
|
});
|
|
6
6
|
exports.BannedProperties = void 0;
|
|
7
7
|
var _eslintCodemodUtils = require("eslint-codemod-utils");
|
|
8
|
+
var _isDecendantOfStyleBlock = require("../../utils/is-decendant-of-style-block");
|
|
8
9
|
var _isDecendantOfType = require("../../utils/is-decendant-of-type");
|
|
9
|
-
var _isNode = require("../../utils/is-node");
|
|
10
10
|
/* eslint-disable @repo/internal/react/require-jsdoc */
|
|
11
11
|
|
|
12
12
|
var BannedProperties = exports.BannedProperties = {
|
|
@@ -36,7 +36,7 @@ var BannedProperties = exports.BannedProperties = {
|
|
|
36
36
|
if (!(0, _eslintCodemodUtils.isNodeOfType)(node, 'Property')) {
|
|
37
37
|
return false;
|
|
38
38
|
}
|
|
39
|
-
if (!(0,
|
|
39
|
+
if (!(0, _isDecendantOfStyleBlock.isDecendantOfStyleBlock)(node) && !(0, _isDecendantOfType.isDecendantOfType)(node, 'JSXExpressionContainer')) {
|
|
40
40
|
return false;
|
|
41
41
|
}
|
|
42
42
|
return true;
|
|
@@ -8,8 +8,8 @@ var _eslintCodemodUtils = require("eslint-codemod-utils");
|
|
|
8
8
|
var _contextCompat = require("@atlaskit/eslint-utils/context-compat");
|
|
9
9
|
var _root = require("../../../ast-nodes/root");
|
|
10
10
|
var _getNodeSource = require("../../utils/get-node-source");
|
|
11
|
+
var _isDecendantOfStyleBlock = require("../../utils/is-decendant-of-style-block");
|
|
11
12
|
var _isDecendantOfType = require("../../utils/is-decendant-of-type");
|
|
12
|
-
var _isNode = require("../../utils/is-node");
|
|
13
13
|
var _findFontFamilyTokenForValue = require("../find-font-family-token-for-value");
|
|
14
14
|
var _insertTokensImport = require("../insert-tokens-import");
|
|
15
15
|
/* eslint-disable @repo/internal/react/require-jsdoc */
|
|
@@ -40,7 +40,7 @@ var FontFamily = exports.FontFamily = {
|
|
|
40
40
|
if (!(0, _eslintCodemodUtils.isNodeOfType)(node, 'Property')) {
|
|
41
41
|
return false;
|
|
42
42
|
}
|
|
43
|
-
if (!(0,
|
|
43
|
+
if (!(0, _isDecendantOfStyleBlock.isDecendantOfStyleBlock)(node) && !(0, _isDecendantOfType.isDecendantOfType)(node, 'JSXExpressionContainer')) {
|
|
44
44
|
return false;
|
|
45
45
|
}
|
|
46
46
|
var isFontFamilyProperty = (0, _eslintCodemodUtils.isNodeOfType)(node.key, 'Identifier') && node.key.name === 'fontFamily';
|
|
@@ -8,10 +8,10 @@ var _eslintCodemodUtils = require("eslint-codemod-utils");
|
|
|
8
8
|
var _contextCompat = require("@atlaskit/eslint-utils/context-compat");
|
|
9
9
|
var _root = require("../../../ast-nodes/root");
|
|
10
10
|
var _getNodeSource = require("../../utils/get-node-source");
|
|
11
|
+
var _isDecendantOfStyleBlock = require("../../utils/is-decendant-of-style-block");
|
|
11
12
|
var _isDecendantOfType = require("../../utils/is-decendant-of-type");
|
|
12
|
-
var
|
|
13
|
+
var _findFontWeightTokenForValue = require("../find-font-weight-token-for-value");
|
|
13
14
|
var _insertTokensImport = require("../insert-tokens-import");
|
|
14
|
-
var _utils = require("../utils");
|
|
15
15
|
/* eslint-disable @repo/internal/react/require-jsdoc */
|
|
16
16
|
|
|
17
17
|
var FontWeight = exports.FontWeight = {
|
|
@@ -40,7 +40,7 @@ var FontWeight = exports.FontWeight = {
|
|
|
40
40
|
if (!(0, _eslintCodemodUtils.isNodeOfType)(node, 'Property')) {
|
|
41
41
|
return false;
|
|
42
42
|
}
|
|
43
|
-
if (!(0,
|
|
43
|
+
if (!(0, _isDecendantOfStyleBlock.isDecendantOfStyleBlock)(node) && !(0, _isDecendantOfType.isDecendantOfType)(node, 'JSXExpressionContainer')) {
|
|
44
44
|
return false;
|
|
45
45
|
}
|
|
46
46
|
var isFontWeightProperty = (0, _eslintCodemodUtils.isNodeOfType)(node.key, 'Identifier') && node.key.name === 'fontWeight';
|
|
@@ -64,7 +64,7 @@ var FontWeight = exports.FontWeight = {
|
|
|
64
64
|
}
|
|
65
65
|
|
|
66
66
|
// Replace raw value with token if there is a token match
|
|
67
|
-
var matchingToken = (_findFontWeightTokenF = (0,
|
|
67
|
+
var matchingToken = (_findFontWeightTokenF = (0, _findFontWeightTokenForValue.findFontWeightTokenForValue)(String(node.value.value))) === null || _findFontWeightTokenF === void 0 ? void 0 : _findFontWeightTokenF.tokenName;
|
|
68
68
|
if (!matchingToken) {
|
|
69
69
|
return fixes;
|
|
70
70
|
}
|
|
@@ -11,18 +11,22 @@ var _contextCompat = require("@atlaskit/eslint-utils/context-compat");
|
|
|
11
11
|
var _object = require("../../../ast-nodes/object");
|
|
12
12
|
var _objectEntry = require("../../../ast-nodes/object-entry");
|
|
13
13
|
var _root = require("../../../ast-nodes/root");
|
|
14
|
+
var _getValueForPropertyNode = require("../../ensure-design-token-usage/get-value-for-property-node");
|
|
14
15
|
var _normaliseValue = require("../../ensure-design-token-usage/normalise-value");
|
|
15
|
-
var _utils = require("../../ensure-design-token-usage/utils");
|
|
16
16
|
var _isDecendantOfGlobalToken = require("../../utils/is-decendant-of-global-token");
|
|
17
|
+
var _isDecendantOfStyleBlock = require("../../utils/is-decendant-of-style-block");
|
|
17
18
|
var _isDecendantOfType = require("../../utils/is-decendant-of-type");
|
|
18
|
-
var _isNode = require("../../utils/is-node");
|
|
19
19
|
var _convertPropertyNodeToStringableNode = require("../convert-property-node-to-stringable-node");
|
|
20
|
+
var _defaultFontWeight = require("../default-font-weight");
|
|
21
|
+
var _findFontWeightTokenForValue = require("../find-font-weight-token-for-value");
|
|
22
|
+
var _findTypographyTokenForValues = require("../find-typography-token-for-values");
|
|
23
|
+
var _fontWeightMap = require("../font-weight-map");
|
|
20
24
|
var _getLiteralProperty = require("../get-literal-property");
|
|
25
|
+
var _getTokenProperty = require("../get-token-property");
|
|
21
26
|
var _insertTokensImport = require("../insert-tokens-import");
|
|
22
27
|
var _isValidPropertyNode = require("../is-valid-property-node");
|
|
23
28
|
var _isValidTypographyToken = require("../is-valid-typography-token");
|
|
24
29
|
var _notUndefined = require("../not-undefined");
|
|
25
|
-
var _utils2 = require("../utils");
|
|
26
30
|
function ownKeys(e, r) { var t = Object.keys(e); if (Object.getOwnPropertySymbols) { var o = Object.getOwnPropertySymbols(e); r && (o = o.filter(function (r) { return Object.getOwnPropertyDescriptor(e, r).enumerable; })), t.push.apply(t, o); } return t; }
|
|
27
31
|
function _objectSpread(e) { for (var r = 1; r < arguments.length; r++) { var t = null != arguments[r] ? arguments[r] : {}; r % 2 ? ownKeys(Object(t), !0).forEach(function (r) { (0, _defineProperty2.default)(e, r, t[r]); }) : Object.getOwnPropertyDescriptors ? Object.defineProperties(e, Object.getOwnPropertyDescriptors(t)) : ownKeys(Object(t)).forEach(function (r) { Object.defineProperty(e, r, Object.getOwnPropertyDescriptor(t, r)); }); } return e; } /* eslint-disable @repo/internal/react/require-jsdoc */
|
|
28
32
|
var StyleObject = exports.StyleObject = {
|
|
@@ -53,7 +57,7 @@ var StyleObject = exports.StyleObject = {
|
|
|
53
57
|
|
|
54
58
|
// -- Font weight --
|
|
55
59
|
var fontWeightNode = _object.Object.getEntryByPropertyName(node, 'fontWeight');
|
|
56
|
-
var fontWeightRaw = fontWeightNode && (0,
|
|
60
|
+
var fontWeightRaw = fontWeightNode && (0, _getValueForPropertyNode.getValueForPropertyNode)(fontWeightNode, context);
|
|
57
61
|
|
|
58
62
|
// If fontWeightRaw is a token we find the token name and treat it like a raw value for simplicity.
|
|
59
63
|
// e.g. token('font.weight.bold', '700') ends up as '700' after this if-block.
|
|
@@ -61,18 +65,18 @@ var StyleObject = exports.StyleObject = {
|
|
|
61
65
|
if (fontWeightRaw && typeof fontWeightRaw === 'string' && fontWeightRaw.includes('font.weight.')) {
|
|
62
66
|
var _fontWeightRaw$match;
|
|
63
67
|
var fontWeightTokenSuffix = ((_fontWeightRaw$match = fontWeightRaw.match(/font\.weight\.(\w*)/)) === null || _fontWeightRaw$match === void 0 ? void 0 : _fontWeightRaw$match[1]) || 'regular'; // ${token('font.weight.bold', '700')} -> 'bold'
|
|
64
|
-
if (Object.keys(
|
|
65
|
-
fontWeightRaw =
|
|
68
|
+
if (Object.keys(_fontWeightMap.fontWeightMap).includes(fontWeightTokenSuffix)) {
|
|
69
|
+
fontWeightRaw = _fontWeightMap.fontWeightMap[fontWeightTokenSuffix];
|
|
66
70
|
}
|
|
67
71
|
}
|
|
68
72
|
|
|
69
73
|
// If no fontWeight value exists, default to 400 to avoid matching with a bolder token resulting in a visual change
|
|
70
|
-
var fontWeightValue = fontWeightRaw && (0, _normaliseValue.normaliseValue)('fontWeight', fontWeightRaw) ||
|
|
71
|
-
fontWeightValue = fontWeightValue.length === 3 ? fontWeightValue :
|
|
74
|
+
var fontWeightValue = fontWeightRaw && (0, _normaliseValue.normaliseValue)('fontWeight', fontWeightRaw) || _defaultFontWeight.defaultFontWeight;
|
|
75
|
+
fontWeightValue = fontWeightValue.length === 3 ? fontWeightValue : _fontWeightMap.fontWeightMap[fontWeightValue] || _defaultFontWeight.defaultFontWeight;
|
|
72
76
|
|
|
73
77
|
// -- Line height --
|
|
74
78
|
var lineHeightNode = _object.Object.getEntryByPropertyName(node, 'lineHeight');
|
|
75
|
-
var lineHeightRaw = lineHeightNode && (0,
|
|
79
|
+
var lineHeightRaw = lineHeightNode && (0, _getValueForPropertyNode.getValueForPropertyNode)(lineHeightNode, context);
|
|
76
80
|
var shouldAddFontWeight = false;
|
|
77
81
|
var lineHeightValue = lineHeightRaw && (0, _normaliseValue.normaliseValue)('lineHeight', lineHeightRaw) || undefined;
|
|
78
82
|
if (lineHeightValue === fontSizeValue) {
|
|
@@ -100,10 +104,10 @@ var StyleObject = exports.StyleObject = {
|
|
|
100
104
|
}
|
|
101
105
|
} else {
|
|
102
106
|
// Standard matching against fontSize/lineHeight values
|
|
103
|
-
matchingTokens = (0,
|
|
107
|
+
matchingTokens = (0, _findTypographyTokenForValues.findTypographyTokenForValues)(fontSizeValue, lineHeightValue);
|
|
104
108
|
if (matchingTokens.length) {
|
|
105
109
|
// If we have multiple matching tokens, try matching fontWeight
|
|
106
|
-
var matchingTokenWithWeight = (0,
|
|
110
|
+
var matchingTokenWithWeight = (0, _findFontWeightTokenForValue.findFontWeightTokenForValue)(fontWeightValue, matchingTokens);
|
|
107
111
|
if (matchingTokenWithWeight) {
|
|
108
112
|
// Possibly narrowed down tokens
|
|
109
113
|
matchingTokens = [matchingTokenWithWeight];
|
|
@@ -123,7 +127,7 @@ var StyleObject = exports.StyleObject = {
|
|
|
123
127
|
|
|
124
128
|
// -- Font family --
|
|
125
129
|
var fontFamilyNode = _object.Object.getEntryByPropertyName(node, 'fontFamily');
|
|
126
|
-
var fontFamilyRaw = fontFamilyNode && (0,
|
|
130
|
+
var fontFamilyRaw = fontFamilyNode && (0, _getValueForPropertyNode.getValueForPropertyNode)(fontFamilyNode, context);
|
|
127
131
|
var fontFamilyValue = fontFamilyRaw && (0, _normaliseValue.normaliseValue)('fontFamily', fontFamilyRaw) || undefined;
|
|
128
132
|
|
|
129
133
|
// If font family is already a token, we remove and re-add it
|
|
@@ -147,7 +151,7 @@ var StyleObject = exports.StyleObject = {
|
|
|
147
151
|
|
|
148
152
|
// -- Font style --
|
|
149
153
|
var fontStyleNode = _object.Object.getEntryByPropertyName(node, 'fontStyle');
|
|
150
|
-
var fontStyleRaw = fontStyleNode && (0,
|
|
154
|
+
var fontStyleRaw = fontStyleNode && (0, _getValueForPropertyNode.getValueForPropertyNode)(fontStyleNode, context);
|
|
151
155
|
var fontStyleValue = fontStyleRaw && (0, _normaliseValue.normaliseValue)('fontStyle', fontStyleRaw) || undefined;
|
|
152
156
|
var fontStyleToAdd;
|
|
153
157
|
if (fontStyleValue === 'italic') {
|
|
@@ -165,11 +169,11 @@ var StyleObject = exports.StyleObject = {
|
|
|
165
169
|
// fontSize node is always first
|
|
166
170
|
var nodesToReplace = [fontSizeNode, fontWeightNode, lineHeightNode, fontFamilyNode, fontStyleNode, letterSpacingNode].filter(_notUndefined.notUndefined);
|
|
167
171
|
var fontFamilyTokenName = fontFamilyToAdd ? "font.family.brand.".concat(fontFamilyToAdd) : '';
|
|
168
|
-
var fontWeightReplacementToken = shouldAddFontWeight ? (0,
|
|
169
|
-
var fontWeightReplacement = fontWeightReplacementToken && (0,
|
|
172
|
+
var fontWeightReplacementToken = shouldAddFontWeight ? (0, _findFontWeightTokenForValue.findFontWeightTokenForValue)(fontWeightValue) : undefined;
|
|
173
|
+
var fontWeightReplacement = fontWeightReplacementToken && (0, _getTokenProperty.getTokenProperty)('fontWeight', fontWeightReplacementToken.tokenName);
|
|
170
174
|
var fontFamilyReplacement = fontFamilyToAdd && (fontFamilyToAdd === 'original' ? (0, _convertPropertyNodeToStringableNode.convertPropertyNodeToStringableNode)(
|
|
171
175
|
// This will always exist if fontFamilyToAdd === 'original', TS can't figure that out.
|
|
172
|
-
fontFamilyNode) : (0,
|
|
176
|
+
fontFamilyNode) : (0, _getTokenProperty.getTokenProperty)('fontFamily', fontFamilyTokenName));
|
|
173
177
|
var fontStyleReplacement = fontStyleToAdd && (0, _getLiteralProperty.getLiteralProperty)('fontStyle', fontStyleToAdd);
|
|
174
178
|
var fixerRefs = {
|
|
175
179
|
matchingToken: matchingToken,
|
|
@@ -207,7 +211,7 @@ var StyleObject = exports.StyleObject = {
|
|
|
207
211
|
success: false
|
|
208
212
|
};
|
|
209
213
|
}
|
|
210
|
-
if (!(0,
|
|
214
|
+
if (!(0, _isDecendantOfStyleBlock.isDecendantOfStyleBlock)(node) && !(0, _isDecendantOfType.isDecendantOfType)(node, 'JSXExpressionContainer')) {
|
|
211
215
|
return {
|
|
212
216
|
success: false
|
|
213
217
|
};
|
|
@@ -220,7 +224,7 @@ var StyleObject = exports.StyleObject = {
|
|
|
220
224
|
success: false
|
|
221
225
|
};
|
|
222
226
|
}
|
|
223
|
-
var fontSizeRaw = (0,
|
|
227
|
+
var fontSizeRaw = (0, _getValueForPropertyNode.getValueForPropertyNode)(fontSizeNode, context);
|
|
224
228
|
|
|
225
229
|
// Without a valid fontSize value we can't be certain what token should be used; exit
|
|
226
230
|
if (fontSizeRaw === undefined || fontSizeRaw === null) {
|
|
@@ -258,7 +262,7 @@ var StyleObject = exports.StyleObject = {
|
|
|
258
262
|
return (!tokensImportNode ? [(0, _insertTokensImport.insertTokensImport)(root, fixer)] : []).concat(nodesToReplace.map(function (node, index) {
|
|
259
263
|
// Replace first node with token, delete remaining nodes. Guaranteed to be fontSize
|
|
260
264
|
if (index === 0) {
|
|
261
|
-
return fixer.replaceText(node, "".concat((0,
|
|
265
|
+
return fixer.replaceText(node, "".concat((0, _getTokenProperty.getTokenProperty)('font', matchingToken.tokenName, undefined, true)));
|
|
262
266
|
}
|
|
263
267
|
|
|
264
268
|
// We don't replace fontWeight/fontFamily/fontStyle here in case it occurs before the font property.
|
|
@@ -7,8 +7,8 @@ exports.UntokenizedProperties = void 0;
|
|
|
7
7
|
var _eslintCodemodUtils = require("eslint-codemod-utils");
|
|
8
8
|
var _contextCompat = require("@atlaskit/eslint-utils/context-compat");
|
|
9
9
|
var _getNodeSource = require("../../utils/get-node-source");
|
|
10
|
+
var _isDecendantOfStyleBlock = require("../../utils/is-decendant-of-style-block");
|
|
10
11
|
var _isDecendantOfType = require("../../utils/is-decendant-of-type");
|
|
11
|
-
var _isNode = require("../../utils/is-node");
|
|
12
12
|
/* eslint-disable @repo/internal/react/require-jsdoc */
|
|
13
13
|
|
|
14
14
|
var UntokenizedProperties = exports.UntokenizedProperties = {
|
|
@@ -39,7 +39,7 @@ var UntokenizedProperties = exports.UntokenizedProperties = {
|
|
|
39
39
|
if (!(0, _eslintCodemodUtils.isNodeOfType)(node, 'Property')) {
|
|
40
40
|
return false;
|
|
41
41
|
}
|
|
42
|
-
if (!(0,
|
|
42
|
+
if (!(0, _isDecendantOfStyleBlock.isDecendantOfStyleBlock)(node) && !(0, _isDecendantOfType.isDecendantOfType)(node, 'JSXExpressionContainer')) {
|
|
43
43
|
return false;
|
|
44
44
|
}
|
|
45
45
|
var isFontProperty = (0, _eslintCodemodUtils.isNodeOfType)(node.key, 'Identifier') && node.key.name === 'font';
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
"use strict";
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.typographyValueToToken = void 0;
|
|
7
|
+
var _palettesRaw = require("@atlaskit/tokens/palettes-raw");
|
|
8
|
+
var _tokensRaw = require("@atlaskit/tokens/tokens-raw");
|
|
9
|
+
var typographyValueToToken = exports.typographyValueToToken = _tokensRaw.typography
|
|
10
|
+
// we're filtering here to remove the `font` tokens.
|
|
11
|
+
.filter(function (t) {
|
|
12
|
+
return t.attributes.group === 'typography';
|
|
13
|
+
}).filter(function (t) {
|
|
14
|
+
return t.cleanName.includes('font.heading') || t.cleanName.includes('font.body');
|
|
15
|
+
})
|
|
16
|
+
// Filtering out UNSAFE tokens that were meant for migrations, these tokens are deprecated and will be removed in the future
|
|
17
|
+
.filter(function (t) {
|
|
18
|
+
return !t.cleanName.includes('UNSAFE');
|
|
19
|
+
}).map(function (currentToken) {
|
|
20
|
+
var _typographyPalette$fi, _typographyPalette$fi2, _typographyPalette$fi3;
|
|
21
|
+
var individualValues = {
|
|
22
|
+
fontSize: (_typographyPalette$fi = _palettesRaw.typographyPalette.find(function (baseToken) {
|
|
23
|
+
return baseToken.path.slice(-1)[0] ===
|
|
24
|
+
// @ts-expect-error token.original.value can be a string, due to the typographyTokens export including deprecated tokens
|
|
25
|
+
currentToken.original.value.fontSize;
|
|
26
|
+
})) === null || _typographyPalette$fi === void 0 ? void 0 : _typographyPalette$fi.value,
|
|
27
|
+
fontWeight: (_typographyPalette$fi2 = _palettesRaw.typographyPalette.find(function (baseToken) {
|
|
28
|
+
return baseToken.path.slice(-1)[0] ===
|
|
29
|
+
// @ts-expect-error token.original.value can be a string, due to the typographyTokens export including deprecated tokens
|
|
30
|
+
currentToken.original.value.fontWeight;
|
|
31
|
+
})) === null || _typographyPalette$fi2 === void 0 ? void 0 : _typographyPalette$fi2.value,
|
|
32
|
+
lineHeight: (_typographyPalette$fi3 = _palettesRaw.typographyPalette.find(function (baseToken) {
|
|
33
|
+
return baseToken.path.slice(-1)[0] ===
|
|
34
|
+
// @ts-expect-error token.original.value can be a string, due to the typographyTokens export including deprecated tokens
|
|
35
|
+
currentToken.original.value.lineHeight;
|
|
36
|
+
})) === null || _typographyPalette$fi3 === void 0 ? void 0 : _typographyPalette$fi3.value
|
|
37
|
+
};
|
|
38
|
+
return {
|
|
39
|
+
tokenName: currentToken.cleanName,
|
|
40
|
+
tokenValue: currentToken.value,
|
|
41
|
+
values: individualValues
|
|
42
|
+
};
|
|
43
|
+
});
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.countMatchingKeyValues = void 0;
|
|
7
|
+
var referenceObject = {
|
|
8
|
+
width: '1px',
|
|
9
|
+
height: '1px',
|
|
10
|
+
padding: '0',
|
|
11
|
+
position: 'absolute',
|
|
12
|
+
border: '0',
|
|
13
|
+
clip: 'rect(1px, 1px, 1px, 1px)',
|
|
14
|
+
overflow: 'hidden',
|
|
15
|
+
whiteSpace: 'nowrap'
|
|
16
|
+
};
|
|
17
|
+
var countMatchingKeyValues = exports.countMatchingKeyValues = function countMatchingKeyValues(styleEntries) {
|
|
18
|
+
var matchingStyleEntries = styleEntries.filter(function (entry) {
|
|
19
|
+
return entry.key in referenceObject;
|
|
20
|
+
});
|
|
21
|
+
if (styleEntries.length < 5) {
|
|
22
|
+
return 0;
|
|
23
|
+
}
|
|
24
|
+
return matchingStyleEntries.reduce(function (acc, curr) {
|
|
25
|
+
return acc + (referenceObject[curr === null || curr === void 0 ? void 0 : curr.key] === (curr === null || curr === void 0 ? void 0 : curr.value) ? 1.5 : 0.75);
|
|
26
|
+
}, 0) / styleEntries.length;
|
|
27
|
+
};
|
|
@@ -0,0 +1,33 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.getObjectLikeness = void 0;
|
|
7
|
+
var _eslintCodemodUtils = require("eslint-codemod-utils");
|
|
8
|
+
var _countMatchingKeyValues = require("./count-matching-key-values");
|
|
9
|
+
/**
|
|
10
|
+
* Given a node, translate the node into css key-value pairs and
|
|
11
|
+
* compare the output to the reference styles required to make a
|
|
12
|
+
* visually hidden element.
|
|
13
|
+
*
|
|
14
|
+
* @returns {number} A fraction between 0-1 depending on the object's likeness.
|
|
15
|
+
*/
|
|
16
|
+
var getObjectLikeness = exports.getObjectLikeness = function getObjectLikeness(node) {
|
|
17
|
+
var styleEntries = node.properties.filter(function (node) {
|
|
18
|
+
return (0, _eslintCodemodUtils.isNodeOfType)(node, 'Property');
|
|
19
|
+
}).map(function (_ref) {
|
|
20
|
+
var key = _ref.key,
|
|
21
|
+
value = _ref.value;
|
|
22
|
+
if (key.type === 'Identifier') {
|
|
23
|
+
return {
|
|
24
|
+
key: key.name,
|
|
25
|
+
value: value.type === 'Literal' && value.value
|
|
26
|
+
};
|
|
27
|
+
}
|
|
28
|
+
return null;
|
|
29
|
+
}).filter(function (node) {
|
|
30
|
+
return Boolean(node);
|
|
31
|
+
});
|
|
32
|
+
return (0, _countMatchingKeyValues.countMatchingKeyValues)(styleEntries);
|
|
33
|
+
};
|
|
@@ -8,15 +8,16 @@ exports.default = void 0;
|
|
|
8
8
|
var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
|
|
9
9
|
var _eslintCodemodUtils = require("eslint-codemod-utils");
|
|
10
10
|
var _contextCompat = require("@atlaskit/eslint-utils/context-compat");
|
|
11
|
-
var
|
|
11
|
+
var _createLintRule = require("../utils/create-lint-rule");
|
|
12
|
+
var _isCssInJsObjectNode = require("../utils/is-css-in-js-object-node");
|
|
12
13
|
var _isCssInJsTemplateNode = require("../utils/is-css-in-js-template-node");
|
|
13
|
-
var
|
|
14
|
+
var _countMatchingKeyValues = require("./count-matching-key-values");
|
|
14
15
|
var _fixJsx = _interopRequireDefault(require("./fix-jsx"));
|
|
15
16
|
var _fixVanilla = _interopRequireDefault(require("./fix-vanilla"));
|
|
17
|
+
var _getObjectLikeness = require("./get-object-likeness");
|
|
16
18
|
var _makeTemplateLiteralIntoEntries = require("./make-template-literal-into-entries");
|
|
17
|
-
var _utils = require("./utils");
|
|
18
19
|
var THEME_IMPORT_NAMES = ['visuallyHidden', 'assistive'];
|
|
19
|
-
var rule = (0,
|
|
20
|
+
var rule = (0, _createLintRule.createLintRule)({
|
|
20
21
|
meta: {
|
|
21
22
|
name: 'use-visually-hidden',
|
|
22
23
|
type: 'suggestion',
|
|
@@ -65,7 +66,7 @@ var rule = (0, _createRule.createLintRule)({
|
|
|
65
66
|
});
|
|
66
67
|
// this is either a styled usage OR mixin usage in a styled usage
|
|
67
68
|
} else if (idNode.parent.type === 'CallExpression') {
|
|
68
|
-
if ((0,
|
|
69
|
+
if ((0, _isCssInJsObjectNode.isCssInJsObjectNode)(idNode.parent) || (0, _isCssInJsTemplateNode.isCssInJsTemplateNode)(idNode.parent)) {
|
|
69
70
|
context.report({
|
|
70
71
|
node: idNode.parent,
|
|
71
72
|
messageId: 'noDeprecatedUsage',
|
|
@@ -107,7 +108,7 @@ var rule = (0, _createRule.createLintRule)({
|
|
|
107
108
|
if (!(node.callee.type === 'MemberExpression' || node.callee.type === 'Identifier')) {
|
|
108
109
|
return;
|
|
109
110
|
}
|
|
110
|
-
var isStyled = (0,
|
|
111
|
+
var isStyled = (0, _isCssInJsObjectNode.isCssInJsObjectNode)(node);
|
|
111
112
|
if (node.callee.type === 'MemberExpression' && node.callee.object.type === 'Identifier' && node.callee.object.name !== 'styled') {
|
|
112
113
|
return;
|
|
113
114
|
}
|
|
@@ -117,7 +118,7 @@ var rule = (0, _createRule.createLintRule)({
|
|
|
117
118
|
|
|
118
119
|
// This is an object style (probably)
|
|
119
120
|
if (node.arguments && ((_node$arguments$ = node.arguments[0]) === null || _node$arguments$ === void 0 ? void 0 : _node$arguments$.type) === 'ObjectExpression') {
|
|
120
|
-
var matchingScore = (0,
|
|
121
|
+
var matchingScore = (0, _getObjectLikeness.getObjectLikeness)(node.arguments[0]);
|
|
121
122
|
if (matchingScore > 0.8) {
|
|
122
123
|
return context.report({
|
|
123
124
|
node: node.parent,
|
|
@@ -132,7 +133,7 @@ var rule = (0, _createRule.createLintRule)({
|
|
|
132
133
|
if (node.parent.type === 'CallExpression') {
|
|
133
134
|
return;
|
|
134
135
|
}
|
|
135
|
-
var matchingScore = (0,
|
|
136
|
+
var matchingScore = (0, _getObjectLikeness.getObjectLikeness)(node);
|
|
136
137
|
if (matchingScore > 0.8) {
|
|
137
138
|
return context.report({
|
|
138
139
|
node: node,
|
|
@@ -151,7 +152,7 @@ var rule = (0, _createRule.createLintRule)({
|
|
|
151
152
|
if (!styleEntries) {
|
|
152
153
|
return;
|
|
153
154
|
}
|
|
154
|
-
var count = (0,
|
|
155
|
+
var count = (0, _countMatchingKeyValues.countMatchingKeyValues)(styleEntries.map(function (_ref) {
|
|
155
156
|
var _ref2 = (0, _slicedToArray2.default)(_ref, 2),
|
|
156
157
|
key = _ref2[0],
|
|
157
158
|
value = _ref2[1];
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.referenceObject = void 0;
|
|
7
|
+
var referenceObject = exports.referenceObject = {
|
|
8
|
+
width: '1px',
|
|
9
|
+
height: '1px',
|
|
10
|
+
padding: '0',
|
|
11
|
+
position: 'absolute',
|
|
12
|
+
border: '0',
|
|
13
|
+
clip: 'rect(1px, 1px, 1px, 1px)',
|
|
14
|
+
overflow: 'hidden',
|
|
15
|
+
whiteSpace: 'nowrap'
|
|
16
|
+
};
|
|
@@ -0,0 +1,14 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.createLintRule = void 0;
|
|
7
|
+
var _createRule = require("@atlaskit/eslint-utils/create-rule");
|
|
8
|
+
var _getRuleUrl = require("./get-rule-url");
|
|
9
|
+
/**
|
|
10
|
+
* Tiny wrapped over the ESLint rule module type that ensures
|
|
11
|
+
* there is a docs link to our ESLint plugin documentation page,
|
|
12
|
+
* as well as improving type support.
|
|
13
|
+
*/
|
|
14
|
+
var createLintRule = exports.createLintRule = (0, _createRule.getCreateLintRule)(_getRuleUrl.getRuleUrl);
|
|
@@ -0,0 +1,137 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
|
|
4
|
+
Object.defineProperty(exports, "__esModule", {
|
|
5
|
+
value: true
|
|
6
|
+
});
|
|
7
|
+
exports.createNoTaggedTemplateExpressionRule = void 0;
|
|
8
|
+
var _regenerator = _interopRequireDefault(require("@babel/runtime/regenerator"));
|
|
9
|
+
var _esquery = _interopRequireDefault(require("esquery"));
|
|
10
|
+
var _contextCompat = require("@atlaskit/eslint-utils/context-compat");
|
|
11
|
+
var _isSupportedImport = require("@atlaskit/eslint-utils/is-supported-import");
|
|
12
|
+
var _generate = require("./generate");
|
|
13
|
+
var _getTaggedTemplateExpressionOffset = require("./get-tagged-template-expression-offset");
|
|
14
|
+
var _toArguments = require("./to-arguments");
|
|
15
|
+
// Original source from Compiled https://github.com/atlassian-labs/compiled/blob/master/packages/eslint-plugin/src/utils/create-no-tagged-template-expression-rule/index.ts
|
|
16
|
+
|
|
17
|
+
var shouldSkipMultilineComments = false;
|
|
18
|
+
function hasNestedSelectorWithMultipleArguments(arg) {
|
|
19
|
+
if (arg.type === 'literal' || arg.type === 'expression' || arg.type === 'declaration') {
|
|
20
|
+
return false;
|
|
21
|
+
}
|
|
22
|
+
if (arg.type === 'rule' && arg.declarations.length > 1) {
|
|
23
|
+
return true;
|
|
24
|
+
}
|
|
25
|
+
if (arg.type === 'block') {
|
|
26
|
+
return arg.blocks.some(hasNestedSelectorWithMultipleArguments);
|
|
27
|
+
}
|
|
28
|
+
if (arg.type === 'rule') {
|
|
29
|
+
return arg.declarations.some(hasNestedSelectorWithMultipleArguments);
|
|
30
|
+
}
|
|
31
|
+
}
|
|
32
|
+
var createNoTaggedTemplateExpressionRule = exports.createNoTaggedTemplateExpressionRule = function createNoTaggedTemplateExpressionRule(isUsage, messageId) {
|
|
33
|
+
return function (context) {
|
|
34
|
+
var importSources = (0, _isSupportedImport.getImportSources)(context);
|
|
35
|
+
return {
|
|
36
|
+
TaggedTemplateExpression: function TaggedTemplateExpression(node) {
|
|
37
|
+
var _getScope = (0, _contextCompat.getScope)(context, node),
|
|
38
|
+
references = _getScope.references;
|
|
39
|
+
if (!isUsage(node.tag, references, importSources)) {
|
|
40
|
+
return;
|
|
41
|
+
}
|
|
42
|
+
context.report({
|
|
43
|
+
messageId: messageId,
|
|
44
|
+
node: node,
|
|
45
|
+
fix: /*#__PURE__*/_regenerator.default.mark(function fix(fixer) {
|
|
46
|
+
var quasi, source, matches, args, oldCode, withoutQuasi, newCode, usesEmotion;
|
|
47
|
+
return _regenerator.default.wrap(function fix$(_context) {
|
|
48
|
+
while (1) switch (_context.prev = _context.next) {
|
|
49
|
+
case 0:
|
|
50
|
+
quasi = node.quasi;
|
|
51
|
+
source = (0, _contextCompat.getSourceCode)(context); // TODO Eventually handle comments instead of skipping them
|
|
52
|
+
// Skip auto-fixing comments
|
|
53
|
+
if (!(shouldSkipMultilineComments && quasi.quasis.map(function (q) {
|
|
54
|
+
return q.value.raw;
|
|
55
|
+
}).join('').match(/\/\*[\s\S]*\*\//g))) {
|
|
56
|
+
_context.next = 4;
|
|
57
|
+
break;
|
|
58
|
+
}
|
|
59
|
+
return _context.abrupt("return");
|
|
60
|
+
case 4:
|
|
61
|
+
matches = (0, _esquery.default)(node, 'ArrowFunctionExpression > BlockStatement');
|
|
62
|
+
if (!matches.length) {
|
|
63
|
+
_context.next = 7;
|
|
64
|
+
break;
|
|
65
|
+
}
|
|
66
|
+
return _context.abrupt("return");
|
|
67
|
+
case 7:
|
|
68
|
+
if (!(!quasi.expressions.length && quasi.quasis.length === 1 && !quasi.quasis[0].value.raw.trim())) {
|
|
69
|
+
_context.next = 11;
|
|
70
|
+
break;
|
|
71
|
+
}
|
|
72
|
+
_context.next = 10;
|
|
73
|
+
return fixer.replaceText(quasi, '({})');
|
|
74
|
+
case 10:
|
|
75
|
+
return _context.abrupt("return");
|
|
76
|
+
case 11:
|
|
77
|
+
args = (0, _toArguments.toArguments)(source, quasi);
|
|
78
|
+
if (!args.some(hasNestedSelectorWithMultipleArguments)) {
|
|
79
|
+
_context.next = 14;
|
|
80
|
+
break;
|
|
81
|
+
}
|
|
82
|
+
return _context.abrupt("return");
|
|
83
|
+
case 14:
|
|
84
|
+
if (!(args.length < 1)) {
|
|
85
|
+
_context.next = 16;
|
|
86
|
+
break;
|
|
87
|
+
}
|
|
88
|
+
return _context.abrupt("return");
|
|
89
|
+
case 16:
|
|
90
|
+
oldCode = source.getText(node); // Remove quasi:
|
|
91
|
+
// styled.div<Props>`
|
|
92
|
+
// color: red;
|
|
93
|
+
// `
|
|
94
|
+
// becomes
|
|
95
|
+
// styled.div<Props>
|
|
96
|
+
withoutQuasi = oldCode.replace(source.getText(quasi), '');
|
|
97
|
+
newCode = withoutQuasi +
|
|
98
|
+
// Indent the arguments after the tagged template expression range
|
|
99
|
+
(0, _generate.generate)(args, (0, _getTaggedTemplateExpressionOffset.getTaggedTemplateExpressionOffset)(node));
|
|
100
|
+
if (!(oldCode === newCode)) {
|
|
101
|
+
_context.next = 21;
|
|
102
|
+
break;
|
|
103
|
+
}
|
|
104
|
+
return _context.abrupt("return");
|
|
105
|
+
case 21:
|
|
106
|
+
// For styles like `position: initial !important`,
|
|
107
|
+
// Emotion can give typechecking errors when using object syntax
|
|
108
|
+
// due to csstype being overly strict
|
|
109
|
+
usesEmotion = (0, _isSupportedImport.isEmotion)(node.tag, references, importSources);
|
|
110
|
+
if (!(usesEmotion && !!newCode.match(/!\s*important/gm))) {
|
|
111
|
+
_context.next = 24;
|
|
112
|
+
break;
|
|
113
|
+
}
|
|
114
|
+
return _context.abrupt("return");
|
|
115
|
+
case 24:
|
|
116
|
+
if (!/\$\{.*:/.test(newCode)) {
|
|
117
|
+
_context.next = 26;
|
|
118
|
+
break;
|
|
119
|
+
}
|
|
120
|
+
return _context.abrupt("return");
|
|
121
|
+
case 26:
|
|
122
|
+
_context.next = 28;
|
|
123
|
+
return fixer.insertTextBefore(node, newCode);
|
|
124
|
+
case 28:
|
|
125
|
+
_context.next = 30;
|
|
126
|
+
return fixer.remove(node);
|
|
127
|
+
case 30:
|
|
128
|
+
case "end":
|
|
129
|
+
return _context.stop();
|
|
130
|
+
}
|
|
131
|
+
}, fix);
|
|
132
|
+
})
|
|
133
|
+
});
|
|
134
|
+
}
|
|
135
|
+
};
|
|
136
|
+
};
|
|
137
|
+
};
|
|
@@ -0,0 +1,20 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.noTaggedTemplateExpressionRuleSchema = void 0;
|
|
7
|
+
// Original source from Compiled https://github.com/atlassian-labs/compiled/blob/master/packages/eslint-plugin/src/utils/create-no-tagged-template-expression-rule/index.ts
|
|
8
|
+
|
|
9
|
+
var noTaggedTemplateExpressionRuleSchema = exports.noTaggedTemplateExpressionRuleSchema = [{
|
|
10
|
+
type: 'object',
|
|
11
|
+
properties: {
|
|
12
|
+
importSources: {
|
|
13
|
+
type: 'array',
|
|
14
|
+
items: {
|
|
15
|
+
type: 'string'
|
|
16
|
+
},
|
|
17
|
+
uniqueItems: true
|
|
18
|
+
}
|
|
19
|
+
}
|
|
20
|
+
}];
|