cascader.test.js 47 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589590591592593594595596597598599600601602603604605606607608609610611612613614615616617618619620621622623624625626627628629630631632633634635636637638639640641642643644645646647648649650651652653654655656657658659660661662663664665666667668669670671672673674675676677678679680681682683684685686687688689690691692693694695696697698699700701702703704705706707708709710711712713714715716717718719720721722723724725726727728729730731732733734735736737738739740741742743744745746747748749750751752753754755756757758759760761762763764765766767768769770771772773774775776777778779780781782783784785786787788789790791792793794795796797798799800801802803804805806807808809810811812813814815816817818819820821822823824825826827828829830831832833834835836837838839840841842843844845846847848849850851852853854855856857858859860861862863864865866867868869870871872873874875876877878879880881882883884885886887888889890891892893894895896897898899900901902903904905906907908909910911912913914915916917918919920921922923924925926927928929930931932933934935936937938939940941942943944945946947948949950951952953954955956957958959960961962963964965966967968969970971972973974975976977978979980981982983984985986987988989990991992993994995996997998999100010011002100310041005100610071008100910101011101210131014101510161017101810191020102110221023102410251026102710281029103010311032103310341035103610371038103910401041104210431044104510461047104810491050105110521053105410551056105710581059106010611062106310641065106610671068106910701071107210731074107510761077107810791080108110821083108410851086108710881089109010911092109310941095109610971098109911001101110211031104110511061107110811091110111111121113111411151116111711181119112011211122112311241125112611271128112911301131113211331134113511361137113811391140114111421143114411451146114711481149115011511152115311541155115611571158115911601161116211631164116511661167116811691170117111721173117411751176117711781179118011811182118311841185118611871188118911901191119211931194119511961197119811991200120112021203120412051206120712081209121012111212121312141215121612171218121912201221122212231224122512261227122812291230123112321233123412351236123712381239124012411242124312441245124612471248124912501251125212531254125512561257125812591260126112621263126412651266126712681269127012711272127312741275
  1. import { Cascader, Icon } from '../../index';
  2. import { clear } from 'jest-date-mock';
  3. import { BASE_CLASS_PREFIX } from '../../../semi-foundation/base/constants';
  4. const animationMs = 200;
  5. const sleep = (ms = animationMs) =>
  6. new Promise((resolve, reject) =>
  7. setTimeout(() => {
  8. resolve(ms);
  9. }, ms)
  10. );
  11. const getPopupContainer = () => document.querySelector(`.${BASE_CLASS_PREFIX}-cascader`);
  12. const treeData = [
  13. {
  14. label: '亚洲',
  15. value: 'Yazhou',
  16. key: 'yazhou',
  17. children: [
  18. {
  19. label: '中国',
  20. value: 'Zhongguo',
  21. key: 'zhongguo',
  22. children: [
  23. {
  24. label: '北京',
  25. value: 'Beijing',
  26. key: 'beijing',
  27. },
  28. {
  29. label: '上海',
  30. value: 'Shanghai',
  31. key: 'shanghai',
  32. },
  33. ],
  34. },
  35. ],
  36. },
  37. {
  38. label: '北美洲',
  39. value: 'Beimeizhou',
  40. key: 'beimeizhou',
  41. children: [
  42. {
  43. label: '美国',
  44. value: 'Meiguo',
  45. key: 'meiguo',
  46. },
  47. {
  48. label: '加拿大',
  49. value: 'Jianada',
  50. key: 'jianada',
  51. },
  52. ],
  53. },
  54. ];
  55. const treeDataWithDisabled = [
  56. {
  57. label: '亚洲',
  58. value: 'Yazhou',
  59. key: 'yazhou',
  60. children: [
  61. {
  62. label: '中国',
  63. value: 'Zhongguo',
  64. key: 'zhongguo',
  65. disabled: true,
  66. children: [
  67. {
  68. label: '北京',
  69. value: 'Beijing',
  70. key: 'beijing',
  71. },
  72. {
  73. label: '上海',
  74. value: 'Shanghai',
  75. key: 'shanghai',
  76. },
  77. ],
  78. },
  79. {
  80. label: '韩国',
  81. value: 'Hanguo',
  82. key: 'hanguo',
  83. }
  84. ],
  85. }
  86. ];
  87. let commonProps = {
  88. // Cascader use Popup Layer to show candidate option,
  89. // but all Popup Layer which extends from Tooltip (eg Popover, Dropdown) have animation and delay.
  90. // Turn off animation and delay during testing, to avoid wating (something like setTimeOut/balabala...) in the test code
  91. motion: false,
  92. mouseEnterDelay: 0,
  93. mouseLeaveDelay: 0,
  94. };
  95. function render(props) {
  96. props = { treeData: treeData, ...commonProps, ...props };
  97. return mount(<Cascader {...props} />, {
  98. attachTo: document.getElementById('container'),
  99. });
  100. }
  101. describe('Cascader', () => {
  102. beforeEach(() => {
  103. // Avoid `attachTo: document.body` Warning
  104. // clear();
  105. const div = document.createElement('div');
  106. div.setAttribute('id', 'container');
  107. document.body.appendChild(div);
  108. });
  109. afterEach(() => {
  110. const div = document.getElementById('container');
  111. if (div) {
  112. document.body.removeChild(div);
  113. }
  114. document.body.innerHTML = '';
  115. });
  116. it('className / style', () => {
  117. let props = {
  118. className: 'test',
  119. style: { height: 420 },
  120. };
  121. let cascader = render(props);
  122. expect(cascader.hasClass('test')).toEqual(true);
  123. expect(cascader.find('div.test')).toHaveStyle('height', 420);
  124. });
  125. it('with placeholder', () => {
  126. const props = { placeholder: 'semi' };
  127. const cascader = render(props);
  128. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection-placeholder`).instance().textContent).toEqual(
  129. 'semi'
  130. );
  131. });
  132. it('with validateStatus', () => {
  133. const props = {};
  134. const cascader = render(props);
  135. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-error`)).toEqual(false);
  136. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-warning`)).toEqual(false);
  137. cascader.setProps({ validateStatus: `error` });
  138. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-error`)).toEqual(true);
  139. cascader.setProps({ validateStatus: `warning` });
  140. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-warning`)).toEqual(true);
  141. });
  142. it('different size', () => {
  143. const props = {};
  144. const cascader = render(props);
  145. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-large`)).toEqual(false);
  146. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-small`)).toEqual(false);
  147. cascader.setProps({ size: 'large' });
  148. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-large`)).toEqual(true);
  149. cascader.setProps({ size: 'small' });
  150. expect(cascader.exists(`.${BASE_CLASS_PREFIX}-cascader-small`)).toEqual(true);
  151. });
  152. it('custom prefix / suffix / insetLabel', () => {
  153. let prefix = <div className="prefix">prefix content</div>;
  154. let suffix = <div className="suffix">suffix content</div>;
  155. let insetLabel = 'semi';
  156. const props = {
  157. prefix: prefix,
  158. suffix: suffix,
  159. };
  160. let cascader = render(props);
  161. expect(cascader.contains(prefix)).toEqual(true);
  162. expect(cascader.contains(suffix)).toEqual(true);
  163. cascader.unmount();
  164. let cascader2 = render({ insetLabel: insetLabel });
  165. expect(cascader2.contains(insetLabel)).toEqual(true);
  166. cascader2.unmount();
  167. });
  168. it('empty data / empty content', () => {
  169. let cascader = render({
  170. treeData: [],
  171. defaultOpen: true,
  172. });
  173. // await sleep();
  174. let opt = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`);
  175. expect(opt.length).toEqual(1);
  176. expect(opt[0].className.includes(`${BASE_CLASS_PREFIX}-cascader-option-empty`)).toEqual(true);
  177. cascader.setProps({ emptyContent: 'test' });
  178. cascader.update();
  179. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0].textContent).toEqual('test');
  180. // done();
  181. });
  182. it('dynamic treeData in multiple and uncontrolled mode', () => {
  183. const cascader = render({
  184. defaultValue: 'Yazhou',
  185. multiple: true,
  186. });
  187. const opt = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-selection-multiple .${BASE_CLASS_PREFIX}-tag`);
  188. expect(opt.length).toEqual(1);
  189. cascader.setProps({ treeData: treeDataWithDisabled });
  190. cascader.update();
  191. expect(opt.length).toEqual(1);
  192. });
  193. it('dynamic treeData in multiple and controlled mode', () => {
  194. const cascader = render({
  195. value: 'Yazhou',
  196. multiple: true,
  197. });
  198. const opt = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-selection-multiple .${BASE_CLASS_PREFIX}-tag`);
  199. expect(opt.length).toEqual(1);
  200. cascader.setProps({ treeData: treeDataWithDisabled });
  201. cascader.update();
  202. expect(opt.length).toEqual(1);
  203. });
  204. it('getPopupContainer', () => {
  205. let cascader = render({
  206. getPopupContainer: getPopupContainer,
  207. defaultOpen: true,
  208. });
  209. // await sleep();
  210. let dom = document.querySelector(`.${BASE_CLASS_PREFIX}-cascader`);
  211. expect(dom.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-lists`).length).toEqual(1);
  212. // done();
  213. });
  214. it('defaultOpen', () => {
  215. let cascader = render({
  216. defaultOpen: true,
  217. });
  218. // await sleep();
  219. expect(cascader.state().isOpen).toEqual(true);
  220. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-lists`).length).toEqual(1);
  221. // done();
  222. });
  223. it('custom dropdownClassNam/dropdownStyle/zIndex', () => {
  224. let props = {
  225. dropdownClassName: 'test',
  226. dropdownStyle: {
  227. color: 'red',
  228. },
  229. defaultOpen: true,
  230. zIndex: 2000,
  231. };
  232. let cascader = render(props);
  233. // await sleep();
  234. const dropdown = document.querySelector(`.${BASE_CLASS_PREFIX}-cascader-popover`);
  235. expect(document.querySelector(`.${BASE_CLASS_PREFIX}-portal`).style.zIndex).toEqual('2000');
  236. expect(dropdown.className.includes('test')).toEqual(true);
  237. expect(dropdown.style.color).toEqual('red');
  238. // done();
  239. });
  240. it('defaultValue', () => {
  241. let cascader = render({
  242. defaultValue: ['Yazhou', 'Zhongguo', 'Beijing'],
  243. defaultOpen: true,
  244. });
  245. // await sleep();
  246. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  247. '亚洲 / 中国 / 北京'
  248. );
  249. let lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  250. expect(lists.length).toEqual(3);
  251. let activeItems = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-active`);
  252. expect(activeItems.length).toEqual(2);
  253. expect(activeItems[0].textContent).toEqual('亚洲');
  254. expect(activeItems[1].textContent).toEqual('中国');
  255. let selectItem = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-select`);
  256. expect(selectItem.length).toEqual(1);
  257. expect(selectItem[0].textContent).toEqual('北京');
  258. expect(selectItem[0].querySelectorAll(`.${BASE_CLASS_PREFIX}-icon`).length).toEqual(1);
  259. // done();
  260. });
  261. it('displayProp', () => {
  262. let cascader = render({
  263. defaultValue: ['Yazhou', 'Zhongguo', 'Beijing'],
  264. displayProp: 'value',
  265. });
  266. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  267. 'Yazhou / Zhongguo / Beijing'
  268. );
  269. });
  270. it('displayRender', () => {
  271. let spyOnRender = sinon.spy(() => {});
  272. let cascader = render({
  273. defaultValue: ['Yazhou', 'Zhongguo', 'Beijing'],
  274. displayRender: spyOnRender,
  275. });
  276. expect(spyOnRender.calledWithMatch(['亚洲', '中国', '北京'])).toEqual(true);
  277. cascader.unmount();
  278. let cusRender = render({
  279. defaultValue: ['Yazhou', 'Zhongguo', 'Beijing'],
  280. displayRender: list => '已选择:' + list.join(' -> '),
  281. });
  282. expect(cusRender.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  283. '已选择:亚洲 -> 中国 -> 北京'
  284. );
  285. });
  286. it('disabled', () => {
  287. let cascader = render({
  288. disabled: true,
  289. });
  290. expect(
  291. document
  292. .querySelector(`.${BASE_CLASS_PREFIX}-cascader`)
  293. .className.includes(`${BASE_CLASS_PREFIX}-cascader-disabled`)
  294. ).toEqual(true);
  295. // cannot select
  296. let selectBox = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  297. selectBox.simulate('click');
  298. // await sleep();
  299. expect(cascader.state().isOpen).toEqual(false);
  300. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-lists`).length).toEqual(0);
  301. // done();
  302. });
  303. it('disabled + defaultValue', () => {
  304. const cascaderWithSingle = render({
  305. treeData: treeDataWithDisabled,
  306. changeOnSelect: true,
  307. defaultValue:['Yazhou', 'Zhongguo']
  308. });
  309. expect(
  310. cascaderWithSingle
  311. .find(`.${BASE_CLASS_PREFIX}-cascader-selection span`)
  312. .at(0)
  313. .getDOMNode()
  314. .textContent
  315. ).toEqual('亚洲 / 中国');
  316. cascaderWithSingle.unmount();
  317. const cascaderWithSingleFilter = render({
  318. treeData: treeDataWithDisabled,
  319. changeOnSelect: true,
  320. filterTreeNode: true,
  321. defaultValue:['Yazhou', 'Zhongguo']
  322. });
  323. expect(
  324. cascaderWithSingleFilter
  325. .find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper .${BASE_CLASS_PREFIX}-input`)
  326. .getDOMNode()
  327. .getAttribute('value')
  328. ).toEqual('亚洲 / 中国');
  329. cascaderWithSingleFilter.unmount();
  330. const cascaderWithSingleControlled = render({
  331. treeData: treeDataWithDisabled,
  332. changeOnSelect: true,
  333. value: ['Yazhou', 'Zhongguo'],
  334. });
  335. expect(cascaderWithSingleControlled.find(`.${BASE_CLASS_PREFIX}-cascader-selection span`).getDOMNode().textContent).toEqual(
  336. '亚洲 / 中国'
  337. );
  338. cascaderWithSingleControlled.unmount();
  339. const cascaderWithMultiple = render({
  340. treeData: treeDataWithDisabled,
  341. multiple: true,
  342. defaultValue:['Yazhou', 'Zhongguo']
  343. });
  344. expect(
  345. cascaderWithMultiple
  346. .find(`.${BASE_CLASS_PREFIX}-tag .${BASE_CLASS_PREFIX}-tag-content`)
  347. .at(0)
  348. .getDOMNode()
  349. .textContent
  350. ).toEqual('中国');
  351. cascaderWithMultiple.unmount();
  352. const cascaderWithMultipleFilter = render({
  353. treeData: treeDataWithDisabled,
  354. multiple: true,
  355. filterTreeNode: true,
  356. defaultValue:['Yazhou', 'Zhongguo']
  357. });
  358. expect(
  359. cascaderWithMultipleFilter
  360. .find(`.${BASE_CLASS_PREFIX}-tag .${BASE_CLASS_PREFIX}-tag-content`)
  361. .at(0)
  362. .getDOMNode()
  363. .textContent
  364. ).toEqual('中国');
  365. cascaderWithMultipleFilter.unmount();
  366. const cascaderWithMultipleControlled = render({
  367. treeData: treeDataWithDisabled,
  368. multiple: true,
  369. value:['Yazhou', 'Zhongguo']
  370. });
  371. expect(
  372. cascaderWithMultipleControlled
  373. .find(`.${BASE_CLASS_PREFIX}-tag .${BASE_CLASS_PREFIX}-tag-content`)
  374. .at(0)
  375. .getDOMNode()
  376. .textContent
  377. ).toEqual('中国');
  378. cascaderWithMultipleControlled.unmount();
  379. });
  380. it('select item / onSelect / onChange', () => {
  381. let spyOnSelect = sinon.spy(() => {});
  382. let spyOnChange = sinon.spy(() => {});
  383. let cascader = render({
  384. defaultOpen: true,
  385. onSelect: spyOnSelect,
  386. onChange: spyOnChange,
  387. });
  388. // let selectBox = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  389. // selectBox.simulate('click');
  390. // await sleep();
  391. let lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  392. expect(lists.length).toEqual(1);
  393. lists[0].querySelectorAll('li')[0].click();
  394. lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  395. expect(lists.length).toEqual(2);
  396. expect(spyOnSelect.notCalled).toBe(true);
  397. expect(spyOnChange.notCalled).toBe(true);
  398. expect(
  399. lists[0]
  400. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  401. .className.includes(`${BASE_CLASS_PREFIX}-cascader-option-active`)
  402. ).toEqual(true);
  403. lists[1].querySelectorAll('li')[0].click();
  404. lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  405. expect(lists.length).toEqual(3);
  406. expect(spyOnSelect.notCalled).toBe(true);
  407. expect(spyOnChange.notCalled).toBe(true);
  408. expect(
  409. lists[1]
  410. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  411. .className.includes(`${BASE_CLASS_PREFIX}-cascader-option-active`)
  412. ).toEqual(true);
  413. lists[2].querySelectorAll('li')[0].click();
  414. expect(spyOnSelect.calledOnce).toBe(true);
  415. expect(spyOnChange.calledOnce).toBe(true);
  416. expect(spyOnSelect.calledWithMatch('Beijing')).toEqual(true);
  417. expect(spyOnChange.calledWithMatch(['Yazhou', 'Zhongguo', 'Beijing'])).toEqual(true);
  418. expect(
  419. lists[2]
  420. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  421. .querySelectorAll(`.${BASE_CLASS_PREFIX}-icon-tick`).length
  422. ).toEqual(1);
  423. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  424. '亚洲 / 中国 / 北京'
  425. );
  426. // done();
  427. });
  428. it('filterTreeNode = true shows input box', () => {
  429. let cascader = render({
  430. filterTreeNode: true,
  431. searchPlaceholder: 'placeholder',
  432. });
  433. let searchWrapper = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper`);
  434. expect(searchWrapper.exists()).toEqual(true);
  435. expect(
  436. searchWrapper
  437. .find('input')
  438. .instance()
  439. .getAttribute('placeholder')
  440. ).toEqual('placeholder');
  441. });
  442. it('onSearch', () => {
  443. let onSearch = value => {};
  444. let spyOnSearch = sinon.spy(onSearch);
  445. let cascader = render({
  446. filterTreeNode: true,
  447. onSearch: spyOnSearch,
  448. });
  449. const searchWrapper = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper`);
  450. let searchValue = '${BASE_CLASS_PREFIX}';
  451. let event = { target: { value: searchValue } };
  452. searchWrapper.find('input').simulate('change', event);
  453. expect(spyOnSearch.calledOnce).toBe(true);
  454. expect(spyOnSearch.calledWithMatch(searchValue)).toBe(true);
  455. });
  456. it('onSelect + changeOnSelect', async () => {
  457. let spyOnSelect = sinon.spy(() => {});
  458. let spyOnChange = sinon.spy(() => {});
  459. let cascader = render({
  460. defaultOpen: true,
  461. onSelect: spyOnSelect,
  462. onChange: spyOnChange,
  463. changeOnSelect: true,
  464. });
  465. // await sleep();
  466. let lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  467. lists[0].querySelectorAll('li')[0].click();
  468. expect(spyOnSelect.calledOnce).toBe(true);
  469. expect(spyOnChange.calledOnce).toBe(true);
  470. expect(spyOnSelect.calledWithMatch('Yazhou')).toEqual(true);
  471. expect(spyOnChange.calledWithMatch(['Yazhou'])).toEqual(true);
  472. expect(
  473. lists[0]
  474. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  475. .className.includes(`${BASE_CLASS_PREFIX}-cascader-option-select`)
  476. ).toEqual(true);
  477. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual('亚洲');
  478. lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  479. lists[1].querySelectorAll('li')[0].click();
  480. expect(spyOnSelect.calledWithMatch('Zhongguo')).toEqual(true);
  481. expect(spyOnChange.calledWithMatch(['Yazhou', 'Zhongguo'])).toEqual(true);
  482. expect(
  483. lists[0]
  484. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  485. .className.includes(`${BASE_CLASS_PREFIX}-cascader-option-active`)
  486. ).toEqual(true);
  487. expect(
  488. lists[1]
  489. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  490. .className.includes(`${BASE_CLASS_PREFIX}-cascader-option-select`)
  491. ).toEqual(true);
  492. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  493. '亚洲 / 中国'
  494. );
  495. });
  496. // display none not working properly
  497. it('filterTreeNode shows correct result', () => {
  498. let cascader = render({
  499. filterTreeNode: true,
  500. defaultOpen: true,
  501. });
  502. // let selectBox = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  503. // selectBox.simulate('click');
  504. // await sleep();
  505. const searchWrapper = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper`);
  506. let searchValue = '北';
  507. let event = { target: { value: searchValue } };
  508. searchWrapper.find('input').simulate('change', event);
  509. // await sleep();
  510. let resList = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-label-highlight`);
  511. expect(resList.length).toEqual(3);
  512. // debugger
  513. // expect(resList[0].textContent).toEqual('亚洲/中国/北京');
  514. // done();
  515. });
  516. // display none not working properly
  517. it('filterTreeNode + treeNodeFilterProp', () => {
  518. let cascader = render({
  519. filterTreeNode: true,
  520. treeNodeFilterProp: 'value',
  521. defaultOpen: true,
  522. });
  523. // let selectBox = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  524. // selectBox.simulate('click');
  525. // await sleep();
  526. const searchWrapper = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper`);
  527. let searchValue = 'Bei';
  528. let event = { target: { value: searchValue } };
  529. searchWrapper.find('input').simulate('change', event);
  530. // await sleep();
  531. let resList = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-label-highlight`);
  532. expect(resList.length).toEqual(3);
  533. // debugger
  534. // expect(resList[0].textContent).toEqual('亚洲/中国/北京');
  535. // done();
  536. });
  537. it('filterTreeNode + no result', () => {
  538. let cascader = render({
  539. filterTreeNode: true,
  540. defaultOpen: true,
  541. emptyContent: 'test',
  542. });
  543. // await sleep();
  544. const searchWrapper = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper`);
  545. let searchValue = 'Bei';
  546. let event = { target: { value: searchValue } };
  547. searchWrapper.find('input').simulate('change', event);
  548. // await sleep();
  549. let opt = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`);
  550. expect(opt.length).toEqual(1);
  551. expect(opt[0].className.includes(`${BASE_CLASS_PREFIX}-cascader-option-empty`)).toEqual(true);
  552. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0].textContent).toEqual('test');
  553. // done();
  554. });
  555. it('filterTreeNode as a func', () => {
  556. let cascader = render({
  557. filterTreeNode: (inputValue, cascaderNode) => cascaderNode === inputValue,
  558. defaultOpen: true,
  559. });
  560. const searchWrapper = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper`);
  561. searchWrapper.find('input').simulate('change', { target: { value: '北' } });
  562. // await sleep();
  563. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-option-label-highlight`).length).toEqual(0);
  564. // done();
  565. });
  566. it('controlled: value shows correct', () => {
  567. let cascader = render({
  568. value: ['Yazhou', 'Zhongguo', 'Beijing'],
  569. });
  570. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  571. '亚洲 / 中国 / 北京'
  572. );
  573. });
  574. it('controlled: fire onChange and ui not update', () => {
  575. let spyOnChange = sinon.spy(() => {});
  576. let cascader = render({
  577. value: ['Yazhou', 'Zhongguo', 'Beijing'],
  578. defaultOpen: true,
  579. onChange: spyOnChange,
  580. changeOnSelect: true,
  581. });
  582. // await sleep();
  583. let lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  584. lists[0].querySelectorAll('li')[0].click();
  585. expect(spyOnChange.calledOnce).toBe(true);
  586. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  587. '亚洲 / 中国 / 北京'
  588. );
  589. // done();
  590. });
  591. it('async load data', () => {
  592. const nativeEvent = { nativeEvent: { stopImmediatePropagation: () => {} } };
  593. const then = jest.fn(() => Promise.resolve());
  594. const loadData = jest.fn(() => ({ then }));
  595. const data = {
  596. label: '亚洲',
  597. value: 'Asia',
  598. };
  599. let cascader = render({
  600. loadData,
  601. defaultOpen: true,
  602. treeData: [data],
  603. });
  604. let topNodeAsia = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-option`).at(0);
  605. topNodeAsia.simulate('click', nativeEvent);
  606. expect(loadData).toHaveBeenCalledWith([data]);
  607. expect(then).toHaveBeenCalled();
  608. });
  609. it('select item + onChange + onChangeWithObject', () => {
  610. let spyOnChange = sinon.spy(() => {});
  611. let cascader = render({
  612. defaultOpen: true,
  613. onChange: spyOnChange,
  614. onChangeWithObject: true,
  615. });
  616. // let selectBox = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  617. // selectBox.simulate('click');
  618. // await sleep();
  619. let lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  620. lists[0].querySelectorAll('li')[0].click();
  621. lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  622. lists[1].querySelectorAll('li')[0].click();
  623. lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  624. lists[2].querySelectorAll('li')[0].click();
  625. expect(spyOnChange.calledOnce).toBe(true);
  626. expect(
  627. spyOnChange.calledWithMatch([
  628. {
  629. label: '亚洲',
  630. value: 'Yazhou',
  631. key: 'yazhou',
  632. children: [
  633. {
  634. label: '中国',
  635. value: 'Zhongguo',
  636. key: 'zhongguo',
  637. children: [
  638. {
  639. label: '北京',
  640. value: 'Beijing',
  641. key: 'beijing',
  642. },
  643. {
  644. label: '上海',
  645. value: 'Shanghai',
  646. key: 'shanghai',
  647. },
  648. ],
  649. },
  650. ],
  651. },
  652. {
  653. label: '中国',
  654. value: 'Zhongguo',
  655. key: 'zhongguo',
  656. children: [
  657. {
  658. label: '北京',
  659. value: 'Beijing',
  660. key: 'beijing',
  661. },
  662. {
  663. label: '上海',
  664. value: 'Shanghai',
  665. key: 'shanghai',
  666. },
  667. ],
  668. },
  669. {
  670. label: '北京',
  671. value: 'Beijing',
  672. key: 'beijing',
  673. },
  674. ])
  675. ).toEqual(true);
  676. expect(
  677. lists[2]
  678. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  679. .querySelectorAll(`.${BASE_CLASS_PREFIX}-icon-tick`).length
  680. ).toEqual(1);
  681. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  682. '亚洲 / 中国 / 北京'
  683. );
  684. // done();
  685. });
  686. it('select item + onChange + onChangeWithObject + changeOnSelect', () => {
  687. let spyOnChange = sinon.spy(() => {});
  688. let cascader = render({
  689. defaultOpen: true,
  690. onChange: spyOnChange,
  691. onChangeWithObject: true,
  692. changeOnSelect: true,
  693. });
  694. let lists = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`);
  695. lists[0].querySelectorAll('li')[0].click();
  696. expect(spyOnChange.calledOnce).toBe(true);
  697. expect(
  698. spyOnChange.calledWithMatch([
  699. {
  700. label: '亚洲',
  701. value: 'Yazhou',
  702. key: 'yazhou',
  703. children: [
  704. {
  705. label: '中国',
  706. value: 'Zhongguo',
  707. key: 'zhongguo',
  708. children: [
  709. {
  710. label: '北京',
  711. value: 'Beijing',
  712. key: 'beijing',
  713. },
  714. {
  715. label: '上海',
  716. value: 'Shanghai',
  717. key: 'shanghai',
  718. },
  719. ],
  720. },
  721. ],
  722. },
  723. ])
  724. ).toEqual(true);
  725. expect(
  726. lists[0]
  727. .querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option`)[0]
  728. .className.includes(`${BASE_CLASS_PREFIX}-cascader-option-select`)
  729. ).toEqual(true);
  730. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual('亚洲');
  731. });
  732. it('controlled: value shows correct', () => {
  733. let cascader = render({
  734. value: [
  735. {
  736. label: '亚洲',
  737. value: 'Yazhou',
  738. key: 'yazhou',
  739. children: [
  740. {
  741. label: '中国',
  742. value: 'Zhongguo',
  743. key: 'zhongguo',
  744. children: [
  745. {
  746. label: '北京',
  747. value: 'Beijing',
  748. key: 'beijing',
  749. },
  750. {
  751. label: '上海',
  752. value: 'Shanghai',
  753. key: 'shanghai',
  754. },
  755. ],
  756. },
  757. ],
  758. },
  759. {
  760. label: '中国',
  761. value: 'Zhongguo',
  762. key: 'zhongguo',
  763. children: [
  764. {
  765. label: '北京',
  766. value: 'Beijing',
  767. key: 'beijing',
  768. },
  769. {
  770. label: '上海',
  771. value: 'Shanghai',
  772. key: 'shanghai',
  773. },
  774. ],
  775. },
  776. {
  777. label: '北京',
  778. value: 'Beijing',
  779. key: 'beijing',
  780. },
  781. ],
  782. onChangeWithObject: true,
  783. });
  784. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  785. '亚洲 / 中国 / 北京'
  786. );
  787. });
  788. it('onClear and showClear', () => {
  789. const spyOnClear = sinon.spy(() => { });
  790. const cascader = render({
  791. defaultValue: ['Yazhou', 'Zhongguo', 'Beijing'],
  792. showClear: true,
  793. onClear: spyOnClear,
  794. placeholder: "请选择所在地区"
  795. });
  796. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  797. '亚洲 / 中国 / 北京'
  798. );
  799. cascader.simulate('mouseEnter', {}).find(`.${BASE_CLASS_PREFIX}-cascader-clearbtn`).simulate('click');
  800. expect(spyOnClear.calledOnce).toBe(true);
  801. expect(cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).getDOMNode().textContent).toEqual(
  802. '请选择所在地区'
  803. );
  804. cascader.unmount();
  805. });
  806. it('filterLeafOnly = false', () => {
  807. let cascader = render({
  808. filterTreeNode: true,
  809. defaultOpen: true,
  810. filterLeafOnly: false
  811. });
  812. // let selectBox = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  813. // selectBox.simulate('click');
  814. // await sleep();
  815. const searchWrapper = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-search-wrapper`);
  816. let searchValue = '亚';
  817. let event = { target: { value: searchValue } };
  818. searchWrapper.find('input').simulate('change', event);
  819. // await sleep();
  820. let resList = document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-label-highlight`);
  821. expect(resList.length).toEqual(4);
  822. // debugger
  823. // expect(resList[0].textContent).toEqual('亚洲/中国/北京');
  824. // done();
  825. });
  826. it('showNext',()=>{
  827. // expand next menu by hover
  828. // 通过 hover 展开 Dropdown 的子菜单
  829. const cascaderWithHover = render({
  830. showNext: 'hover',
  831. });
  832. const selectBox = cascaderWithHover.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  833. selectBox.simulate('click');
  834. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`).length).toEqual(1);
  835. cascaderWithHover
  836. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  837. .at(0)
  838. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  839. .at(0)
  840. .simulate('mouseEnter');
  841. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`).length).toEqual(2);
  842. cascaderWithHover.unmount();
  843. // expand next menu by click
  844. // 通过 click 展开 Dropdown 的子菜单
  845. const cascaderWithClick = render({
  846. showNext: 'click',
  847. });
  848. const selectBox2 = cascaderWithClick.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  849. selectBox2.simulate('click');
  850. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`).length).toEqual(1);
  851. cascaderWithClick
  852. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  853. .at(0)
  854. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  855. .at(0)
  856. .simulate('mouseEnter');
  857. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`).length).toEqual(1);
  858. cascaderWithClick
  859. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  860. .at(0)
  861. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  862. .at(0)
  863. .simulate('click');
  864. expect(document.querySelectorAll(`.${BASE_CLASS_PREFIX}-cascader-option-list`).length).toEqual(2);
  865. cascaderWithClick.unmount();
  866. })
  867. it('disableStrictly', ()=>{
  868. // disable strictly
  869. const cascaderWithDisableStrictly = render({
  870. showNext: 'hover',
  871. treeData:treeDataWithDisabled,
  872. disableStrictly: true,
  873. multiple: true,
  874. });
  875. expect(cascaderWithDisableStrictly.state().checkedKeys.size).toEqual(0);
  876. expect(cascaderWithDisableStrictly.state().disabledKeys.size).toEqual(3);
  877. // open dropdown
  878. const selectBoxWithDisableStrictly = cascaderWithDisableStrictly.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  879. selectBoxWithDisableStrictly.simulate('click');
  880. // click checkbox
  881. cascaderWithDisableStrictly
  882. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  883. .at(0)
  884. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  885. .at(0)
  886. .find(`.${BASE_CLASS_PREFIX}-cascader-option-label`)
  887. .at(0)
  888. .find(`.${BASE_CLASS_PREFIX}-checkbox`)
  889. .at(0)
  890. .simulate('click');
  891. // check checkedKeys
  892. expect(cascaderWithDisableStrictly.state().checkedKeys.size).toEqual(1);
  893. cascaderWithDisableStrictly.unmount();
  894. // default disable
  895. const cascaderWithDisable = render({
  896. showNext: 'hover',
  897. treeData:treeDataWithDisabled,
  898. multiple: true,
  899. });
  900. expect(cascaderWithDisable.state().checkedKeys.size).toEqual(0);
  901. expect(cascaderWithDisable.state().disabledKeys.size).toEqual(0);
  902. // open dropdown
  903. const selectBoxWithDisable = cascaderWithDisable.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  904. selectBoxWithDisable.simulate('click');
  905. // click checkbox
  906. cascaderWithDisable
  907. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  908. .at(0)
  909. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  910. .at(0)
  911. .find(`.${BASE_CLASS_PREFIX}-cascader-option-label`)
  912. .at(0)
  913. .find(`.${BASE_CLASS_PREFIX}-checkbox`)
  914. .at(0)
  915. .simulate('click');
  916. // check checkedKeys
  917. expect(cascaderWithDisable.state().checkedKeys.size).toEqual(5);
  918. cascaderWithDisable.unmount();
  919. });
  920. it('multiple + onChangeWithObject', () => {
  921. const cascader = render({
  922. multiple: true,
  923. onChangeWithObject: true,
  924. defaultValue: [
  925. {
  926. label: '北美洲',
  927. value: 'Beimeizhou',
  928. key: 'beimeizhou',
  929. children: [
  930. {
  931. label: '美国',
  932. value: 'Meiguo',
  933. key: 'meiguo',
  934. },
  935. {
  936. label: '加拿大',
  937. value: 'Jianada',
  938. key: 'jianada',
  939. },
  940. ],
  941. },
  942. {
  943. label: '美国',
  944. value: 'Meiguo',
  945. key: 'meiguo',
  946. }
  947. ]
  948. });
  949. const tags = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection .${BASE_CLASS_PREFIX}-tag`)
  950. expect(tags.length).toEqual(1);
  951. expect(
  952. tags
  953. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  954. .getDOMNode()
  955. .textContent
  956. ).toEqual('美国');
  957. });
  958. it('multiple select enableLeafClick', () => {
  959. const cascaderWithMultiple = render({
  960. multiple: true,
  961. enableLeafClick: true,
  962. treeData: [
  963. {
  964. label: '北美洲',
  965. value: 'Beimeizhou',
  966. key: 'beimeizhou',
  967. children: [
  968. {
  969. label: '美国',
  970. value: 'Meiguo',
  971. key: 'meiguo',
  972. },
  973. {
  974. label: '加拿大',
  975. value: 'Jianada',
  976. key: 'jianada',
  977. },
  978. ],
  979. },
  980. {
  981. label: '南美洲',
  982. value: 'Nanmeiguo',
  983. key: 'Nanmeiguo',
  984. }
  985. ]
  986. })
  987. const selectBox = cascaderWithMultiple.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  988. selectBox.simulate('click');
  989. // click checkbox
  990. cascaderWithMultiple
  991. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  992. .at(0)
  993. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  994. .at(1)
  995. .find(`.${BASE_CLASS_PREFIX}-cascader-option-label`)
  996. .at(0)
  997. .find(`.${BASE_CLASS_PREFIX}-checkbox`)
  998. .at(0)
  999. .simulate('click');
  1000. expect(cascaderWithMultiple.state().checkedKeys.size).toEqual(1);
  1001. // click option cancel checked
  1002. cascaderWithMultiple
  1003. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  1004. .at(0)
  1005. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  1006. .at(1)
  1007. .simulate('click')
  1008. expect(cascaderWithMultiple.state().checkedKeys.size).toEqual(0);
  1009. // click option select
  1010. cascaderWithMultiple
  1011. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  1012. .at(0)
  1013. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  1014. .at(0)
  1015. .simulate('click')
  1016. cascaderWithMultiple
  1017. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  1018. .at(1)
  1019. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  1020. .at(0)
  1021. .simulate('click')
  1022. expect(cascaderWithMultiple.state().checkedKeys.size).toEqual(1);
  1023. const states = cascaderWithMultiple.state()
  1024. cascaderWithMultiple.unmount();
  1025. })
  1026. it('multiple select disable enableLeafClick', () => {
  1027. const cascaderWithMultiple = render({
  1028. multiple: true,
  1029. treeData: [
  1030. {
  1031. label: '北美洲',
  1032. value: 'Beimeizhou',
  1033. key: 'beimeizhou',
  1034. children: [
  1035. {
  1036. label: '美国',
  1037. value: 'Meiguo',
  1038. key: 'meiguo',
  1039. },
  1040. {
  1041. label: '加拿大',
  1042. value: 'Jianada',
  1043. key: 'jianada',
  1044. },
  1045. ],
  1046. },
  1047. {
  1048. label: '南美洲',
  1049. value: 'Nanmeiguo',
  1050. key: 'Nanmeiguo',
  1051. }
  1052. ]
  1053. })
  1054. const selectBox = cascaderWithMultiple.find(`.${BASE_CLASS_PREFIX}-cascader-selection`).at(0);
  1055. selectBox.simulate('click');
  1056. // click checkbox
  1057. cascaderWithMultiple
  1058. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  1059. .at(0)
  1060. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  1061. .at(1)
  1062. .find(`.${BASE_CLASS_PREFIX}-cascader-option-label`)
  1063. .at(0)
  1064. .find(`.${BASE_CLASS_PREFIX}-checkbox`)
  1065. .at(0)
  1066. .simulate('click');
  1067. expect(cascaderWithMultiple.state().checkedKeys.size).toEqual(1);
  1068. // click option can't cancel checked
  1069. cascaderWithMultiple
  1070. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list`)
  1071. .at(0)
  1072. .find(`.${BASE_CLASS_PREFIX}-cascader-option`)
  1073. .at(1)
  1074. .simulate('click')
  1075. expect(cascaderWithMultiple.state().checkedKeys.size).toEqual(1);
  1076. cascaderWithMultiple.unmount();
  1077. })
  1078. it('separator', () => {
  1079. const cascader = render({
  1080. filterTreeNode: true,
  1081. defaultValue: ['Yazhou', 'Zhongguo', 'Beijing'],
  1082. separator: ' > ',
  1083. defaultOpen: true,
  1084. });
  1085. const input = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection input`);
  1086. expect(input.props().placeholder).toEqual('亚洲 > 中国 > 北京');
  1087. const event = { target: { value: '中国' } };
  1088. input.simulate('change', event);
  1089. expect(
  1090. cascader
  1091. .find(`.${BASE_CLASS_PREFIX}-cascader-option-list li`)
  1092. .at(0)
  1093. .getDOMNode()
  1094. .textContent
  1095. ).toEqual('亚洲 > 中国 > 北京');
  1096. cascader.unmount();
  1097. });
  1098. it('triggerRender', () => {
  1099. const spyTriggerRender = sinon.spy(() => <span>123</span>);
  1100. const cascaderAutoMerge = render({
  1101. multiple: true,
  1102. triggerRender: spyTriggerRender,
  1103. defaultValue: 'Yazhou'
  1104. });
  1105. cascaderAutoMerge.simulate('click');
  1106. const firstCall = spyTriggerRender.getCall(0);
  1107. const args = firstCall.args[0];
  1108. /* check arguments of triggerRender */
  1109. expect(args.value.size).toEqual(1);
  1110. expect(args.value).toEqual(new Set('0'));
  1111. cascaderAutoMerge.unmount();
  1112. const spyTriggerRender2 = sinon.spy(() => <span>123</span>);
  1113. const cascaderNoAutoMerge = render({
  1114. multiple: true,
  1115. triggerRender: spyTriggerRender2,
  1116. defaultValue: 'Yazhou',
  1117. autoMergeValue: false,
  1118. });
  1119. cascaderNoAutoMerge.simulate('click');
  1120. const firstCall2 = spyTriggerRender2.getCall(0);
  1121. const args2 = firstCall2.args[0];
  1122. /* check arguments of triggerRender */
  1123. expect(args2.value.size).toEqual(4);
  1124. expect(args2.value).toEqual(new Set(['0','0-0','0-0-1','0-0-0']));
  1125. cascaderNoAutoMerge.unmount();
  1126. });
  1127. it('autoMergeValue', () => {
  1128. const cascader = render({
  1129. multiple: true,
  1130. autoMergeValue: false,
  1131. defaultValue: 'Yazhou',
  1132. });
  1133. const tags = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection .${BASE_CLASS_PREFIX}-tag`)
  1134. expect(tags.length).toEqual(4);
  1135. cascader.unmount();
  1136. const cascaderAutoMerge = render({
  1137. multiple: true,
  1138. autoMergeValue: true,
  1139. defaultValue: 'Yazhou',
  1140. });
  1141. const tags2 = cascaderAutoMerge.find(`.${BASE_CLASS_PREFIX}-cascader-selection .${BASE_CLASS_PREFIX}-tag`)
  1142. expect(tags2.length).toEqual(1);
  1143. expect(
  1144. tags2
  1145. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  1146. .getDOMNode()
  1147. .textContent
  1148. ).toEqual('亚洲');
  1149. cascaderAutoMerge.unmount();
  1150. });
  1151. it('leafOnly', () => {
  1152. /* autoMergeValue and leafOnly are both false */
  1153. const cascader = render({
  1154. multiple: true,
  1155. autoMergeValue: false,
  1156. leafOnly: false,
  1157. defaultValue: 'Yazhou',
  1158. });
  1159. const tags = cascader.find(`.${BASE_CLASS_PREFIX}-cascader-selection .${BASE_CLASS_PREFIX}-tag`)
  1160. expect(tags.length).toEqual(4);
  1161. cascader.unmount();
  1162. /* autoMergeValue and leafOnly are both true */
  1163. const cascader2 = render({
  1164. multiple: true,
  1165. autoMergeValue: true,
  1166. leafOnly: true,
  1167. defaultValue: 'Yazhou',
  1168. });
  1169. const tags2 = cascader2.find(`.${BASE_CLASS_PREFIX}-cascader-selection .${BASE_CLASS_PREFIX}-tag`)
  1170. expect(tags2.length).toEqual(2);
  1171. cascader2.unmount();
  1172. /* autoMergeValue is false, leafOnly is true */
  1173. const cascader3 = render({
  1174. multiple: true,
  1175. autoMergeValue: false,
  1176. leafOnly: true,
  1177. defaultValue: 'Yazhou',
  1178. });
  1179. const tags3 = cascader3.find(`.${BASE_CLASS_PREFIX}-cascader-selection .${BASE_CLASS_PREFIX}-tag`)
  1180. expect(tags3.length).toEqual(2);
  1181. cascader3.unmount();
  1182. /* autoMergeValue is true, leafOnly is false */
  1183. const cascader4 = render({
  1184. multiple: true,
  1185. autoMergeValue: true,
  1186. leafOnly: false,
  1187. defaultValue: 'Yazhou',
  1188. });
  1189. const tags4 = cascader4.find(`.${BASE_CLASS_PREFIX}-cascader-selection .${BASE_CLASS_PREFIX}-tag`)
  1190. expect(tags4.length).toEqual(1);
  1191. expect(
  1192. tags4
  1193. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  1194. .getDOMNode()
  1195. .textContent
  1196. ).toEqual('亚洲');
  1197. cascader4.unmount();
  1198. });
  1199. });