1
0

custom-directives.spec.js 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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 evaluate = evaluateLater('foo')
  27. let incCount = evaluateLater('count++')
  28. cleanup(() => {
  29. incCount()
  30. incCount()
  31. })
  32. effect(() => {
  33. incCount()
  34. evaluate(value => el.textContent = value)
  35. })
  36. })
  37. `],
  38. ({ get }) => {
  39. get('h1').should(haveText('1'))
  40. get('#change').click()
  41. get('h1').should(haveText('3'))
  42. get('#remove').click()
  43. get('#change').click()
  44. get('h1').should(haveText('6'))
  45. get('#change').click()
  46. get('h1').should(haveText('7'))
  47. }
  48. )