2016-03-29 16:41:24 +08:00
|
|
|
import React from 'react';
|
|
|
|
import ReactDOM from 'react-dom';
|
|
|
|
import ReactTestUtils from 'react-addons-test-utils';
|
|
|
|
|
2016-02-10 05:27:41 +08:00
|
|
|
import {renderIntoDocument} from '../../../spec/nylas-test-utils';
|
|
|
|
import Contenteditable from '../../../src/components/contenteditable/contenteditable';
|
2016-03-16 04:37:31 +08:00
|
|
|
import EmojiComposerExtension from '../lib/emoji-composer-extension';
|
2016-02-10 05:27:41 +08:00
|
|
|
|
2016-03-16 04:37:31 +08:00
|
|
|
describe('EmojiComposerExtension', ()=> {
|
2016-02-10 05:27:41 +08:00
|
|
|
beforeEach(()=> {
|
2016-03-16 04:37:31 +08:00
|
|
|
spyOn(EmojiComposerExtension, 'onContentChanged').andCallThrough()
|
|
|
|
spyOn(EmojiComposerExtension, '_onSelectEmoji').andCallThrough()
|
2016-02-10 05:27:41 +08:00
|
|
|
this.component = renderIntoDocument(
|
2016-04-13 01:27:24 +08:00
|
|
|
<Contenteditable
|
|
|
|
html={''}
|
|
|
|
onChange={jasmine.createSpy('onChange')}
|
|
|
|
extensions={[EmojiComposerExtension]} />
|
2016-02-10 05:27:41 +08:00
|
|
|
)
|
2016-03-29 16:41:24 +08:00
|
|
|
this.editableNode = ReactDOM.findDOMNode(this.component).querySelector('[contenteditable]');
|
2016-02-10 05:27:41 +08:00
|
|
|
})
|
|
|
|
|
|
|
|
describe('when emoji trigger is typed', ()=> {
|
|
|
|
beforeEach(()=> {
|
|
|
|
this._performEdit = (newHTML) => {
|
|
|
|
this.editableNode.innerHTML = newHTML;
|
|
|
|
const sel = document.getSelection()
|
|
|
|
const textNode = this.editableNode.childNodes[0];
|
|
|
|
sel.setBaseAndExtent(textNode, textNode.nodeValue.length, textNode, textNode.nodeValue.length);
|
|
|
|
}
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should show the emoji picker', ()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
this._performEdit('Testing! :h');
|
2016-02-10 05:27:41 +08:00
|
|
|
waitsFor(()=> {
|
|
|
|
return ReactTestUtils.scryRenderedDOMComponentsWithClass(this.component, 'emoji-picker').length > 0
|
|
|
|
});
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should be focused on the first emoji in the list', ()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
this._performEdit('Testing! :h');
|
2016-02-10 05:27:41 +08:00
|
|
|
waitsFor(()=> {
|
|
|
|
return ReactTestUtils.scryRenderedDOMComponentsWithClass(this.component, 'emoji-option').length > 0
|
|
|
|
});
|
|
|
|
runs(()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
expect(ReactDOM.findDOMNode(ReactTestUtils.findRenderedDOMComponentWithClass(this.component, 'emoji-option')).textContent.indexOf(":haircut:") !== -1).toBe(true);
|
2016-02-10 05:27:41 +08:00
|
|
|
});
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should insert an emoji on enter', ()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
this._performEdit('Testing! :h');
|
2016-02-10 05:27:41 +08:00
|
|
|
waitsFor(()=> {
|
|
|
|
return ReactTestUtils.scryRenderedDOMComponentsWithClass(this.component, 'emoji-picker').length > 0
|
|
|
|
});
|
|
|
|
runs(()=> {
|
|
|
|
ReactTestUtils.Simulate.keyDown(this.editableNode, {key: "Enter", keyCode: 13, which: 13});
|
|
|
|
});
|
|
|
|
waitsFor(()=> {
|
2016-03-16 04:37:31 +08:00
|
|
|
return EmojiComposerExtension._onSelectEmoji.calls.length > 0
|
2016-02-10 05:27:41 +08:00
|
|
|
})
|
|
|
|
runs(()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
expect(this.editableNode.innerHTML).toEqual(`Testing! <img class="emoji haircut" src="images/composer-emoji/apple/1f487.png" width="14" height="14" style="margin-top: -5px;">`);
|
2016-02-10 05:27:41 +08:00
|
|
|
});
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should insert an emoji on click', ()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
this._performEdit('Testing! :h');
|
2016-02-10 05:27:41 +08:00
|
|
|
waitsFor(()=> {
|
|
|
|
return ReactTestUtils.scryRenderedDOMComponentsWithClass(this.component, 'emoji-picker').length > 0
|
|
|
|
});
|
|
|
|
runs(()=> {
|
2016-03-29 16:41:24 +08:00
|
|
|
const button = ReactDOM.findDOMNode(ReactTestUtils.findRenderedDOMComponentWithClass(this.component, 'emoji-option'))
|
2016-02-10 05:27:41 +08:00
|
|
|
ReactTestUtils.Simulate.mouseDown(button);
|
2016-03-16 04:37:31 +08:00
|
|
|
expect(EmojiComposerExtension._onSelectEmoji).toHaveBeenCalled()
|
2016-02-10 05:27:41 +08:00
|
|
|
});
|
|
|
|
waitsFor(()=> {
|
2016-03-16 04:37:31 +08:00
|
|
|
return EmojiComposerExtension._onSelectEmoji.calls.length > 0
|
2016-02-10 05:27:41 +08:00
|
|
|
})
|
|
|
|
runs(()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
expect(this.editableNode.innerHTML).toEqual(`Testing! <img class="emoji haircut" src="images/composer-emoji/apple/1f487.png" width="14" height="14" style="margin-top: -5px;">`);
|
2016-02-10 05:27:41 +08:00
|
|
|
});
|
|
|
|
})
|
|
|
|
|
|
|
|
it('should move to the next emoji on arrow down', ()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
this._performEdit('Testing! :h');
|
2016-02-10 05:27:41 +08:00
|
|
|
waitsFor(()=> {
|
|
|
|
return ReactTestUtils.scryRenderedDOMComponentsWithClass(this.component, 'emoji-option').length > 0
|
|
|
|
});
|
|
|
|
runs(()=> {
|
|
|
|
ReactTestUtils.Simulate.keyDown(this.editableNode, {key: "ArrowDown", keyCode: 40, which: 40});
|
|
|
|
});
|
|
|
|
waitsFor(()=> {
|
2016-03-16 04:37:31 +08:00
|
|
|
return EmojiComposerExtension.onContentChanged.calls.length > 1
|
2016-02-10 05:27:41 +08:00
|
|
|
});
|
|
|
|
runs(()=> {
|
2016-04-13 01:27:24 +08:00
|
|
|
expect(ReactDOM.findDOMNode(ReactTestUtils.findRenderedDOMComponentWithClass(this.component, 'emoji-option')).textContent.indexOf(":hamburger:") !== -1).toBe(true);
|
2016-02-10 05:27:41 +08:00
|
|
|
});
|
|
|
|
})
|
|
|
|
})
|
|
|
|
})
|