custom-directives.spec.js 1.3 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051
  1. import { haveText, html, test } from '../utils'
  2. test('can register custom directive',
  3. [html`
  4. <div x-data>
  5. <span x-foo:bar.baz="bob"></span>
  6. </div>
  7. `,
  8. `
  9. Alpine.directive('foo', (el, { value, modifiers, expression }) => {
  10. el.textContent = value+modifiers+expression
  11. })
  12. `],
  13. ({ get }) => get('span').should(haveText('barbazbob'))
  14. )
  15. test('directives are auto cleaned up',
  16. [html`
  17. <div x-data="{ count: 0 }">
  18. <span x-foo x-ref="foo"></span>
  19. <h1 x-text="count"></h1>
  20. <button @click="count++" id="change">change</button>
  21. <button @click="$refs.foo.remove()" id="remove">remove</button>
  22. </div>
  23. `,
  24. `
  25. Alpine.directive('foo', (el, {}, { effect, cleanup, evaluateLater }) => {
  26. let incCount = evaluateLater('count++')
  27. cleanup(() => {
  28. incCount()
  29. incCount()
  30. })
  31. effect(() => {
  32. incCount()
  33. })
  34. })
  35. `],
  36. ({ get }) => {
  37. get('h1').should(haveText('1'))
  38. get('#change').click()
  39. get('h1').should(haveText('3'))
  40. get('#remove').click()
  41. get('#change').click()
  42. get('h1').should(haveText('6'))
  43. get('#change').click()
  44. get('h1').should(haveText('7'))
  45. }
  46. )