braces.test.ts 1.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647
  1. import Plain from 'slate-plain-serializer';
  2. import BracesPlugin from './braces';
  3. declare global {
  4. interface Window {
  5. KeyboardEvent: any;
  6. }
  7. }
  8. describe('braces', () => {
  9. const handler = BracesPlugin().onKeyDown;
  10. it('adds closing braces around empty value', () => {
  11. const change = Plain.deserialize('').change();
  12. const event = new window.KeyboardEvent('keydown', { key: '(' });
  13. handler(event, change);
  14. expect(Plain.serialize(change.value)).toEqual('()');
  15. });
  16. it('adds closing braces around a value', () => {
  17. const change = Plain.deserialize('foo').change();
  18. const event = new window.KeyboardEvent('keydown', { key: '(' });
  19. handler(event, change);
  20. expect(Plain.serialize(change.value)).toEqual('(foo)');
  21. });
  22. it('adds closing braces around the following value only', () => {
  23. const change = Plain.deserialize('foo bar ugh').change();
  24. let event;
  25. event = new window.KeyboardEvent('keydown', { key: '(' });
  26. handler(event, change);
  27. expect(Plain.serialize(change.value)).toEqual('(foo) bar ugh');
  28. // Wrap bar
  29. change.move(5);
  30. event = new window.KeyboardEvent('keydown', { key: '(' });
  31. handler(event, change);
  32. expect(Plain.serialize(change.value)).toEqual('(foo) (bar) ugh');
  33. // Create empty parens after (bar)
  34. change.move(4);
  35. event = new window.KeyboardEvent('keydown', { key: '(' });
  36. handler(event, change);
  37. expect(Plain.serialize(change.value)).toEqual('(foo) (bar)() ugh');
  38. });
  39. });