no-deprecated-v-on-native-modifier.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. /**
  2. * @author Yosuke Ota
  3. * See LICENSE file in root directory for full license.
  4. */
  5. 'use strict'
  6. // ------------------------------------------------------------------------------
  7. // Requirements
  8. // ------------------------------------------------------------------------------
  9. const utils = require('../utils')
  10. // ------------------------------------------------------------------------------
  11. // Rule Definition
  12. // ------------------------------------------------------------------------------
  13. module.exports = {
  14. meta: {
  15. type: 'problem',
  16. docs: {
  17. description:
  18. 'disallow using deprecated `.native` modifiers (in Vue.js 3.0.0+)',
  19. categories: ['vue3-essential'],
  20. url:
  21. 'https://eslint.vuejs.org/rules/no-deprecated-v-on-native-modifier.html'
  22. },
  23. fixable: null,
  24. schema: [],
  25. messages: {
  26. deprecated: "'.native' modifier on 'v-on' directive is deprecated."
  27. }
  28. },
  29. /** @param {RuleContext} context */
  30. create(context) {
  31. return utils.defineTemplateBodyVisitor(context, {
  32. /** @param {VIdentifier & {parent:VDirectiveKey} } node */
  33. "VAttribute[directive=true][key.name.name='on'] > VDirectiveKey > VIdentifier[name='native']"(
  34. node
  35. ) {
  36. const key = node.parent
  37. if (!key.modifiers.includes(node)) return
  38. context.report({
  39. node,
  40. messageId: 'deprecated'
  41. })
  42. }
  43. })
  44. }
  45. }