Skip to content

Commit

Permalink
No raw text ignore nodes/pattern/text
Browse files Browse the repository at this point in the history
  • Loading branch information
stevelacey committed Oct 2, 2019
1 parent 0cdf776 commit a3e5d09
Show file tree
Hide file tree
Showing 4 changed files with 132 additions and 16 deletions.
19 changes: 19 additions & 0 deletions docs/rules/no-raw-text.md
Original file line number Diff line number Diff line change
Expand Up @@ -65,3 +65,22 @@ export default {
// ...
}
```

## :gear: Options

```json
{
"vue-i18n/no-raw-text": ["error", {
"ignoreNodes": ["md-icon", "v-icon"],
"ignorePattern": "^[-#:()&]+$",
"ignoreText": ["EUR", "HKD", USD"]
}]
}
```

- `src`: specify the source codes directory to be able to lint. If you don't set any options, it set to `process.cwd()` as default.
- `extensions`: an array to allow specified lintable target file extension. If you don't set any options, it set to `.js` and` .vue` as default.

- `ignoreNodes`: specify nodes to ignore such as icon components
- `ignorePattern`: specify a regexp pattern that matches strings to ignore
- `ignoreText`: specify an array of strings to ignore
2 changes: 1 addition & 1 deletion docs/rules/no-unused-keys.md
Original file line number Diff line number Diff line change
Expand Up @@ -76,7 +76,7 @@ const i18n = new VueI18n({
i18n.t('hi')
```

## Options
## :gear: Options

```json
{
Expand Down
44 changes: 41 additions & 3 deletions lib/rules/no-raw-text.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,8 @@
const { parse, AST } = require('vue-eslint-parser')
const { defineTemplateBodyVisitor } = require('../utils/index')

const hasOnlyLineBreak = value => /^[\r\n\t\f\v]+$/.test(value.replace(/ /g, ''))
const config = {}
const hasOnlyWhitespace = value => /^[\r\n\s\t\f\v]+$/.test(value)
const INNER_START_OFFSET = '<template>'.length

function calculateLoc (node, base = null) {
Expand Down Expand Up @@ -65,7 +66,11 @@ function checkVExpressionContainerText (context, node, baseNode = null) {
}

function checkRawText (context, value, loc) {
if (typeof value !== 'string' || hasOnlyLineBreak(value)) { return }
if (typeof value !== 'string' || hasOnlyWhitespace(value)) { return }

if (config.ignorePattern.test(value.trim())) { return }

if (config.ignoreText.includes(value.trim())) { return }

context.report({
loc,
Expand Down Expand Up @@ -107,12 +112,30 @@ function getComponentTemplateNode (value) {
}

function create (context) {
config.ignorePattern = /^$/
config.ignoreNodes = []
config.ignoreText = []

if (context.options[0] && context.options[0].ignorePattern) {
config.ignorePattern = new RegExp(context.options[0].ignorePattern, 'u')
}

if (context.options[0] && context.options[0].ignoreNodes) {
config.ignoreNodes = context.options[0].ignoreNodes
}

if (context.options[0] && context.options[0].ignoreText) {
config.ignoreText = context.options[0].ignoreText
}

return defineTemplateBodyVisitor(context, { // template block
VExpressionContainer (node) {
checkVExpressionContainerText(context, node)
},

VText (node) {
if (config.ignoreNodes.includes(node.parent.name)) { return }

checkRawText(context, node.value, node.loc)
}
}, { // script block or scripts
Expand Down Expand Up @@ -148,7 +171,22 @@ module.exports = {
recommended: true
},
fixable: null,
schema: []
schema: [
{
type: "object",
properties: {
ignoreNodes: {
type: "array"
},
ignorePattern: {
type: "string"
},
ignoreText: {
type: "array"
},
}
}
]
},
create
}
83 changes: 71 additions & 12 deletions tests/lib/rules/no-raw-text.js
Original file line number Diff line number Diff line change
Expand Up @@ -19,18 +19,20 @@ const tester = new RuleTester({

tester.run('no-raw-text', rule, {
valid: [{
code: `<template>
<div class="app">
<p class="a1">{{ $t('hello') }}</p>
<p class="inner">{{ $t('click') }}<a href="/foo">{{ $t('here') }}</a>{{ $t('terminal') }}</p>
</div>
</template>`
}, {
code: `
<template>
<comp :value="1" :msg="$t('foo.bar')"/>
<p>{{ hello }}</p>
</template>
code: `
<template>
<div class="app">
<p class="a1">{{ $t('hello') }}</p>
<p class="inner">{{ $t('click') }}<a href="/foo">{{ $t('here') }}</a>{{ $t('terminal') }}</p>
</div>
</template>
`
}, {
code: `
<template>
<comp :value="1" :msg="$t('foo.bar')"/>
<p>{{ hello }}</p>
</template>
`
}, {
filename: 'test.vue',
Expand All @@ -55,6 +57,29 @@ tester.run('no-raw-text', rule, {
}
}
`
}, {
code: `
<template>
<md-icon>person</md-icon>
<v-icon>menu</v-icon>
</template>
`,
options: [{ ignoreNodes: ['md-icon', 'v-icon'] }],
}, {
code: `
<template>
<p>{{ $t('foo') }}: {{ $t('bar') }}</p>
</template>
`,
options: [{ ignorePattern: '^[-.#:()&]+$' }],
}, {
code: `
<template>
<p>hello</p>
<p>world</p>
</template>
`,
options: [{ ignoreText: ['hello', 'world'] }],
}],

invalid: [{
Expand Down Expand Up @@ -191,5 +216,39 @@ tester.run('no-raw-text', rule, {
errors: [{
message: `raw text 'hello' is used`, line: 4
}]
}, {
code: `
<template>
<md-icon>person</md-icon>
<v-icon>menu</v-icon>
<p>hello</p>
</template>
`,
options: [{ ignoreNodes: ['md-icon', 'v-icon'] }],
errors: [{
message: `raw text 'hello' is used`, line: 5
}]
}, {
code: `
<template>
<p>{{ $t('foo') }}: {{ $t('bar') }}</p>
<p>hello</p>
</template>
`,
options: [{ ignorePattern: '^[-.#:()&]+$' }],
errors: [{
message: `raw text 'hello' is used`, line: 4
}]
}, {
code: `
<template>
<p>hello</p>
<p>world</p>
</template>
`,
options: [{ ignoreText: ['hello'] }],
errors: [{
message: `raw text 'world' is used`, line: 4
}]
}]
})

0 comments on commit a3e5d09

Please sign in to comment.