sideSheet.test.js 14 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319
  1. import { Icon, SideSheet, Modal } from '../../index';
  2. import { BASE_CLASS_PREFIX } from '../../../semi-foundation/base/constants';
  3. // import toJson from 'enzyme-to-json';
  4. function getSideSheet(SideSheetProps, children) {
  5. let props = SideSheetProps ? SideSheetProps : {};
  6. return (
  7. <SideSheet
  8. {...props}
  9. >
  10. {children ? children : <p>This is content of basic sideSheet</p>}
  11. </SideSheet>
  12. );
  13. }
  14. function mountToBody(component) {
  15. return mount(component, { attachTo: document.getElementById('container') });
  16. }
  17. describe('SideSheet', () => {
  18. beforeEach(() => {
  19. // Avoid `attachTo: document.body` Warning
  20. const div = document.createElement('div');
  21. div.setAttribute('id', 'container');
  22. document.body.appendChild(div);
  23. });
  24. afterEach(() => {
  25. const div = document.getElementById('container');
  26. if (div) {
  27. document.body.removeChild(div);
  28. }
  29. });
  30. it('className / style / maskStyle / bodyStyle / headerStyle / zIndex', () => {
  31. debugger
  32. let component = getSideSheet({
  33. className: 'test',
  34. style: { color: 'red' },
  35. visible: true,
  36. maskStyle: { color: 'grey' },
  37. headerStyle: { color: 'green' },
  38. bodyStyle: { color: 'pink' },
  39. zIndex: 500,
  40. });
  41. let sideSheet = mount(component, { attachTo: document.getElementById('container') });
  42. // let sideSheet = mount(component, { attachTo: document.body });
  43. // test className
  44. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet.test`)).toEqual(true);
  45. // test style
  46. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle('color', 'red')
  47. // test bodyStyle
  48. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-body`)).toHaveStyle('color', 'pink');
  49. // test headerStyle
  50. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-header`)).toHaveStyle('color', 'green');
  51. // test maskStyle
  52. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-mask`)).toHaveStyle('color', 'grey');
  53. // test zIndex
  54. expect(document.querySelector(`.${BASE_CLASS_PREFIX}-portal`).style.zIndex).toEqual("500");
  55. sideSheet.unmount();
  56. });
  57. it('visible', () => {
  58. let component = getSideSheet();
  59. // let sideSheet = mount(component, { attachTo: document.body }); // 如果用body的话,第一个测试用例可以过,但第二个就不行
  60. let sideSheet = mount(component, { attachTo: document.getElementById('container') });
  61. expect(sideSheet.exists(`div.${BASE_CLASS_PREFIX}-sidesheet`)).toEqual(false);
  62. sideSheet.setProps({ visible: true });
  63. sideSheet.update(); // 必须调用一次update
  64. expect(sideSheet.exists(`div.${BASE_CLASS_PREFIX}-sidesheet`)).toEqual(true);
  65. sideSheet.unmount();
  66. });
  67. it('test', () => {
  68. let bottomCom = getSideSheet({ placement: 'bottom', visible: true });
  69. let bottomSideSheet = mount(bottomCom, { attachTo: document.getElementById('container') });
  70. expect(bottomSideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-bottom`)).toEqual(true);
  71. bottomSideSheet.unmount();
  72. })
  73. it('different position', () => {
  74. let topCom = getSideSheet({ placement: 'top', visible: true });
  75. let sideSheet = mount(topCom, { attachTo: document.getElementById('container') });
  76. // top
  77. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-top`)).toEqual(true);
  78. // expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ transform: 'translateY(-100%)', width: '100%' });
  79. // bottom
  80. sideSheet.setProps({ placement: 'bottom' });
  81. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-bottom`)).toEqual(true);
  82. // expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ transform: 'translateY(100%)', width: '100%' });
  83. // left
  84. sideSheet.setProps({ placement: 'left' });
  85. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-left`)).toEqual(true);
  86. // expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ transform: 'translateX(-0%)', height: '100%' });
  87. // right
  88. sideSheet.setProps({ placement: 'right' });
  89. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-right`)).toEqual(true);
  90. // expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ transform: 'translateX(0%)', height: '100%' });
  91. sideSheet.unmount();
  92. });
  93. // it('onCancel', () => {
  94. // });
  95. it('render basiclly', () => {
  96. let com = getSideSheet({ title: 'SemiTitle', visible: true })
  97. let sideSheet = mount(com, { attachTo: document.getElementById('container') });
  98. // test title
  99. let sheetTitle = document.querySelector(`.${BASE_CLASS_PREFIX}-sidesheet-title`);
  100. expect(sheetTitle.textContent).toEqual('SemiTitle');
  101. // test content
  102. let sheetContent = document.querySelector(`.${BASE_CLASS_PREFIX}-sidesheet-body`);
  103. // the content in getSideSheet could not be overwritten
  104. expect(sheetContent.textContent).toEqual('This is content of basic sideSheet');
  105. sideSheet.unmount();
  106. });
  107. it('size', () => {
  108. let com = getSideSheet({ size: 'small', visible: true })
  109. let sideSheet = mount(com, { attachTo: document.getElementById('container') });
  110. // test small size
  111. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveClassName("semi-sidesheet-size-small");
  112. // test medium size
  113. sideSheet.setProps({ size: 'medium' });
  114. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveClassName("semi-sidesheet-size-medium");
  115. // test large size
  116. sideSheet.setProps({ size: 'large' });
  117. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveClassName("semi-sidesheet-size-large");
  118. sideSheet.unmount();
  119. });
  120. it('height / width', () => {
  121. let com = getSideSheet({ width: '413px', visible: true })
  122. let sideSheet = mount(com, { attachTo: document.getElementById('container') });
  123. // test width on left
  124. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ width: '413px' });
  125. // test height on left
  126. sideSheet.setProps({ height: '413px' });
  127. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ height: '100%' });
  128. // test width on right
  129. sideSheet.setProps({ placement: 'right' });
  130. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ width: '413px' });
  131. // test height on right
  132. sideSheet.setProps({ height: '413px' });
  133. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ height: '100%' });
  134. // test height on top
  135. sideSheet.setProps({ height: '413px', placement: 'top' });
  136. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ height: '413px' });
  137. // test width on top
  138. sideSheet.setProps({ width: '413px' });
  139. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ width: '100%' });
  140. // test height on bottom
  141. sideSheet.setProps({ height: '413px', placement: 'bottom' });
  142. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ height: '413px' });
  143. // test width on bottom
  144. sideSheet.setProps({ width: '413px' });
  145. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).toHaveStyle({ width: '100%' });
  146. sideSheet.unmount();
  147. });
  148. it('disableScroll', () => {
  149. let com = getSideSheet({ visible: true })
  150. let sideSheet = mount(com, { attachTo: document.getElementById('container') });
  151. // test default
  152. expect(document.body.style.overflow).toEqual('hidden');
  153. sideSheet.setProps({ visible: false });
  154. expect(document.body.style.overflow).not.toEqual('hidden');
  155. // test disableScroll
  156. sideSheet.setProps({ disableScroll: false, visible: true });
  157. expect(document.body.style.overflow).not.toEqual('hidden');
  158. sideSheet.unmount();
  159. });
  160. it('closable', () => {
  161. let closeCom = getSideSheet({ closable: true, visible: true });
  162. let nocloseCom = getSideSheet({ closable: false, visible: true });
  163. let sideSheet = mount(closeCom, { attachTo: document.getElementById('container') });
  164. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-close`)).toEqual(true);
  165. sideSheet.unmount();
  166. let notClosableSideSheet = mount(nocloseCom, { attachTo: document.getElementById('container') });
  167. expect(notClosableSideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-close`)).toEqual(false);
  168. notClosableSideSheet.unmount();
  169. });
  170. it('maskClosable', () => {
  171. let onCancel = () => { };
  172. let spyOnCancel = sinon.spy(onCancel);
  173. let spyOnCancel2 = sinon.spy(onCancel);
  174. let closeCom = getSideSheet({
  175. maskClosable: true,
  176. visible: true,
  177. onCancel: spyOnCancel
  178. });
  179. let sideSheet = mount(closeCom, { attachTo: document.getElementById('container') });
  180. // maskClosable
  181. sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-mask`).simulate('click');
  182. expect(spyOnCancel.calledOnce).toBe(true);
  183. sideSheet.unmount();
  184. // mask not closable
  185. let notMaskClosableSideSheet = mount(getSideSheet({
  186. maskClosable: false,
  187. visible: true,
  188. onCancel: spyOnCancel2
  189. }), { attachTo: document.getElementById('container') });
  190. notMaskClosableSideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-mask`).simulate('click');
  191. expect(spyOnCancel2.calledOnce).toBe(false);
  192. notMaskClosableSideSheet.unmount();
  193. });
  194. it('onCancel', () => {
  195. // onCancel on mask tested in [maskClosable]
  196. // onCancel on close btn
  197. // debugger
  198. let onCancel = () => { };
  199. let spyOnCancel = sinon.spy(onCancel);
  200. let closeCom = getSideSheet({
  201. visible: true,
  202. onCancel: spyOnCancel
  203. });
  204. let sideSheet = mount(closeCom, { attachTo: document.getElementById('container') });
  205. // let dom = sideSheet.find('div.${BASE_CLASS_PREFIX}-sidesheet-close').getDOMNode();
  206. sideSheet.find(`button.${BASE_CLASS_PREFIX}-sidesheet-close`).simulate('click');
  207. expect(spyOnCancel.calledOnce).toBe(true);
  208. sideSheet.unmount();
  209. });
  210. it('no mask', () => {
  211. let com = getSideSheet({
  212. mask: false
  213. });
  214. let sideSheet = mount(com, { attachTo: document.getElementById('container') });
  215. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-modal-mask`)).toEqual(false);
  216. // TODO: add a button to see if could be clicked
  217. sideSheet.unmount();
  218. });
  219. it('getPopupContainer', () => {
  220. debugger
  221. let containedcom = (
  222. <div
  223. style={{
  224. height: 320,
  225. overflow: 'hidden',
  226. position: 'relative',
  227. }}
  228. className='sidesheet-container'
  229. >
  230. <SideSheet
  231. visible={true}
  232. getPopupContainer={() => document.querySelector('.sidesheet-container')}
  233. />
  234. </div>
  235. )
  236. let wrapper1 = mount(containedcom, { attachTo: document.getElementById('container') });
  237. let container1 = document.querySelector('.sidesheet-container').querySelector(`.${BASE_CLASS_PREFIX}-sidesheet`);
  238. expect(wrapper1.find(`div.${BASE_CLASS_PREFIX}-sidesheet`).html()).toEqual(container1.outerHTML);
  239. // get popup container no body overflow
  240. debugger
  241. expect(document.body.style.overflow).not.toEqual('hidden');
  242. wrapper1.unmount();
  243. // no getPopupContainer
  244. let com = (
  245. <div
  246. style={{
  247. height: 320,
  248. overflow: 'hidden',
  249. position: 'relative',
  250. }}
  251. className='sidesheet-container'
  252. >
  253. <SideSheet
  254. visible={true}
  255. />
  256. </div>
  257. )
  258. let wrapper2 = mount(com, { attachTo: document.getElementById('container') });
  259. let container2 = document.querySelector('.sidesheet-container').querySelector(`.${BASE_CLASS_PREFIX}-sidesheet`);
  260. expect(container2).toEqual(null);
  261. wrapper2.unmount();
  262. });
  263. it('motion false', () => {
  264. let topCom = getSideSheet({ placement: 'top', visible: true, motion: false });
  265. let sideSheet = mount(topCom, { attachTo: document.getElementById('container') });
  266. // top
  267. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-top`)).toEqual(true);
  268. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).not.toHaveStyle({ transform: 'translateY(-100%)' });
  269. // bottom
  270. sideSheet.setProps({ placement: 'bottom' });
  271. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-bottom`)).toEqual(true);
  272. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).not.toHaveStyle({ transform: 'translateY(100%)' });
  273. // left
  274. sideSheet.setProps({ placement: 'left' });
  275. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-left`)).toEqual(true);
  276. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).not.toHaveStyle({ transform: 'translateX(-0%)' });
  277. // right
  278. sideSheet.setProps({ placement: 'right' });
  279. expect(sideSheet.exists(`.${BASE_CLASS_PREFIX}-sidesheet-right`)).toEqual(true);
  280. expect(sideSheet.find(`.${BASE_CLASS_PREFIX}-sidesheet-inner`)).not.toHaveStyle({ transform: 'translateX(0%)' });
  281. // visible false
  282. sideSheet.setProps({ visible: false });
  283. sideSheet.update(); // 必须调用一次update
  284. expect(sideSheet.exists(`div.${BASE_CLASS_PREFIX}-sidesheet`)).toEqual(false);
  285. sideSheet.unmount();
  286. });
  287. })