treeSelect.test.js 44 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798991001011021031041051061071081091101111121131141151161171181191201211221231241251261271281291301311321331341351361371381391401411421431441451461471481491501511521531541551561571581591601611621631641651661671681691701711721731741751761771781791801811821831841851861871881891901911921931941951961971981992002012022032042052062072082092102112122132142152162172182192202212222232242252262272282292302312322332342352362372382392402412422432442452462472482492502512522532542552562572582592602612622632642652662672682692702712722732742752762772782792802812822832842852862872882892902912922932942952962972982993003013023033043053063073083093103113123133143153163173183193203213223233243253263273283293303313323333343353363373383393403413423433443453463473483493503513523533543553563573583593603613623633643653663673683693703713723733743753763773783793803813823833843853863873883893903913923933943953963973983994004014024034044054064074084094104114124134144154164174184194204214224234244254264274284294304314324334344354364374384394404414424434444454464474484494504514524534544554564574584594604614624634644654664674684694704714724734744754764774784794804814824834844854864874884894904914924934944954964974984995005015025035045055065075085095105115125135145155165175185195205215225235245255265275285295305315325335345355365375385395405415425435445455465475485495505515525535545555565575585595605615625635645655665675685695705715725735745755765775785795805815825835845855865875885895905915925935945955965975985996006016026036046056066076086096106116126136146156166176186196206216226236246256266276286296306316326336346356366376386396406416426436446456466476486496506516526536546556566576586596606616626636646656666676686696706716726736746756766776786796806816826836846856866876886896906916926936946956966976986997007017027037047057067077087097107117127137147157167177187197207217227237247257267277287297307317327337347357367377387397407417427437447457467477487497507517527537547557567577587597607617627637647657667677687697707717727737747757767777787797807817827837847857867877887897907917927937947957967977987998008018028038048058068078088098108118128138148158168178188198208218228238248258268278288298308318328338348358368378388398408418428438448458468478488498508518528538548558568578588598608618628638648658668678688698708718728738748758768778788798808818828838848858868878888898908918928938948958968978988999009019029039049059069079089099109119129139149159169179189199209219229239249259269279289299309319329339349359369379389399409419429439449459469479489499509519529539549559569579589599609619629639649659669679689699709719729739749759769779789799809819829839849859869879889899909919929939949959969979989991000100110021003100410051006100710081009101010111012101310141015101610171018101910201021102210231024102510261027102810291030103110321033103410351036103710381039104010411042104310441045104610471048104910501051105210531054105510561057105810591060106110621063106410651066106710681069107010711072107310741075107610771078107910801081108210831084108510861087
  1. import { TreeSelect, Icon } from '../../index';
  2. import { BASE_CLASS_PREFIX } from '../../../semi-foundation/base/constants';
  3. const treeChildren = [
  4. {
  5. label: '北京',
  6. value: 'Beijing',
  7. key: 'beijing',
  8. },
  9. {
  10. label: '上海',
  11. value: 'Shanghai',
  12. key: 'shanghai',
  13. },
  14. ];
  15. const treeData = [
  16. {
  17. label: '亚洲',
  18. value: 'Yazhou',
  19. key: 'yazhou',
  20. children: [
  21. {
  22. label: '中国',
  23. value: 'Zhongguo',
  24. key: 'zhongguo',
  25. children: treeChildren,
  26. },
  27. {
  28. label: '日本',
  29. value: 'Riben',
  30. key: 'riben',
  31. children: [
  32. {
  33. label: '东京',
  34. value: 'Dongjing',
  35. key: 'dongjing'
  36. },
  37. {
  38. label: '大阪',
  39. value: 'Daban',
  40. key: 'daban'
  41. }
  42. ]
  43. },
  44. ],
  45. },
  46. {
  47. label: '北美洲',
  48. value: 'Beimeizhou',
  49. key: 'beimeizhou',
  50. children: [
  51. {
  52. label: '美国',
  53. value: 'Meiguo',
  54. key: 'meiguo'
  55. },
  56. {
  57. label: '加拿大',
  58. value: 'Jianada',
  59. key: 'jianada'
  60. }
  61. ]
  62. },
  63. ];
  64. const treeData2 = [
  65. {
  66. label: '亚洲',
  67. value: 'Asia',
  68. key: '0',
  69. children: [
  70. {
  71. label: '中国',
  72. value: 'China',
  73. key: '0-0',
  74. children: [
  75. {
  76. label: '北京',
  77. value: 'Beijing',
  78. key: '0-0-0',
  79. },
  80. {
  81. label: '上海',
  82. value: 'Shanghai',
  83. key: '0-0-1',
  84. },
  85. ],
  86. },
  87. ],
  88. },
  89. {
  90. label: '北美洲',
  91. value: 'North America',
  92. key: '1',
  93. }
  94. ];
  95. const treeData3 = [
  96. {
  97. label: '亚洲',
  98. value: 'Asia',
  99. key: '0',
  100. children: [
  101. {
  102. label: '中国',
  103. value: 'China',
  104. key: '0-0',
  105. },
  106. ],
  107. },
  108. {
  109. label: '北美洲',
  110. value: 'North America',
  111. key: '1',
  112. }
  113. ];
  114. const treeChildrenWithoutValue = [
  115. {
  116. label: '北京',
  117. key: 'beijing',
  118. },
  119. {
  120. label: '上海',
  121. key: 'shanghai',
  122. },
  123. ];
  124. const treeDataWithoutValue = [
  125. {
  126. label: '亚洲',
  127. key: 'yazhou',
  128. children: [
  129. {
  130. label: '中国',
  131. key: 'zhongguo',
  132. children: treeChildrenWithoutValue,
  133. },
  134. {
  135. label: '日本',
  136. key: 'riben',
  137. children: [
  138. {
  139. label: '东京',
  140. key: 'dongjing'
  141. },
  142. {
  143. label: '大阪',
  144. key: 'daban'
  145. }
  146. ]
  147. },
  148. ],
  149. },
  150. {
  151. label: '北美洲',
  152. key: 'beimeizhou',
  153. children: [
  154. {
  155. label: '美国',
  156. key: 'meiguo'
  157. },
  158. {
  159. label: '加拿大',
  160. key: 'jianada'
  161. }
  162. ]
  163. },
  164. ];
  165. let commonProps = {
  166. motion: false,
  167. motionExpand: false,
  168. mouseEnterDelay: 0,
  169. mouseLeaveDelay: 0,
  170. };
  171. function getTreeSelect(props) {
  172. props = { treeData: treeData, ...props }
  173. return mount(
  174. <TreeSelect
  175. {...commonProps}
  176. defaultOpen={true}
  177. {...props}
  178. />,
  179. {
  180. attachTo: document.getElementById('container')
  181. }
  182. );
  183. }
  184. describe('TreeSelect', () => {
  185. beforeEach(() => {
  186. // Avoid `attachTo: document.body` Warning
  187. const div = document.createElement('div');
  188. div.setAttribute('id', 'container');
  189. document.body.appendChild(div);
  190. });
  191. afterEach(() => {
  192. const div = document.getElementById('container');
  193. if (div) {
  194. document.body.removeChild(div);
  195. }
  196. document.body.innerHTML = '';
  197. });
  198. it('className / style', () => {
  199. let props = {
  200. className: 'test',
  201. style: { height: 420 },
  202. };
  203. let treeSelect = getTreeSelect(props);
  204. expect(treeSelect.hasClass('test')).toEqual(true);
  205. expect(treeSelect.find('div.test')).toHaveStyle('height', 420);
  206. });
  207. it('placeholder', () => {
  208. const props = {
  209. placeholder: 'semi'
  210. };
  211. const treeSelect = getTreeSelect(props);
  212. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection-placeholder`).instance().textContent).toEqual('semi');
  213. });
  214. it('validateStatus', () => {
  215. const props = {};
  216. const treeSelect = getTreeSelect(props);
  217. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-error`)).toEqual(false);
  218. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-warning`)).toEqual(false);
  219. treeSelect.setProps({ validateStatus: 'error' });
  220. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-error`)).toEqual(true);
  221. treeSelect.setProps({ validateStatus: 'warning' });
  222. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-warning`)).toEqual(true);
  223. });
  224. it('outerBottomSlot', () => {
  225. let outerBottomSlot = <div class="outer-slot">outer</div>;
  226. let props = {
  227. outerBottomSlot: outerBottomSlot,
  228. };
  229. const treeSelect = getTreeSelect(props);
  230. expect(treeSelect.contains(outerBottomSlot)).toEqual(true);
  231. });
  232. it('size', () => {
  233. const props = {};
  234. const treeSelect = getTreeSelect(props);
  235. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-large`)).toEqual(false);
  236. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-small`)).toEqual(false);
  237. treeSelect.setProps({ size: 'large' });
  238. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-large`)).toEqual(true);
  239. treeSelect.setProps({ size: 'small' });
  240. expect(treeSelect.exists(`.${BASE_CLASS_PREFIX}-tree-select-small`)).toEqual(true);
  241. });
  242. it('custom dropdownClassName / dropdownStyle / zIndex', () => {
  243. let props = {
  244. dropdownClassName: 'test',
  245. dropdownStyle: {
  246. color: 'red',
  247. },
  248. zIndex: 2000,
  249. };
  250. let treeSelect = getTreeSelect(props);
  251. expect(treeSelect.exists('.test')).toEqual(true);
  252. expect(treeSelect.find('.test')).toHaveStyle('color', 'red');
  253. expect(document.querySelector(`.${BASE_CLASS_PREFIX}-portal`).style.zIndex).toEqual("2000");
  254. });
  255. it('dropdownMatchSelectWidth = true', () => {
  256. // dropdownMatchSelectWidth default is true
  257. let props = {
  258. style: { width: 90 },
  259. defaultValue: 'abc',
  260. };
  261. let treeSelect = getTreeSelect(props);
  262. // cause jsdom doesn't support layout engine like browser, so you can't access offsetWidth/scrollWidth or use getBoundingRect(), it will always return 0;
  263. // just use getComputedStyle to avoid this problem.
  264. let selector = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select`).getDOMNode();
  265. let selectorWidth = window.getComputedStyle(selector).width; // expect 90px
  266. let list = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-popover`).getDOMNode();
  267. let listWidth = window.getComputedStyle(list).minWidth;
  268. expect(selectorWidth).toEqual(listWidth);
  269. treeSelect.unmount();
  270. });
  271. it('dropdownMatchSelectWidth = false', () => {
  272. let props = {
  273. style: { width: 90 },
  274. defaultValue: 'abc',
  275. dropdownMatchSelectWidth: false,
  276. };
  277. let treeSelect = getTreeSelect(props);
  278. let selector = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select`).getDOMNode();
  279. let selectorWidth = window.getComputedStyle(selector).width; // expect 90px
  280. let list = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-popover`).getDOMNode();
  281. let listWidth = window.getComputedStyle(list).minWidth;
  282. expect(selectorWidth).not.toEqual(listWidth);
  283. treeSelect.unmount();
  284. });
  285. it('getPopupContainer', () => {
  286. let treeSelect = getTreeSelect({
  287. getPopupContainer: () => document.querySelector(`.${BASE_CLASS_PREFIX}-tree-select`),
  288. });
  289. let dom = document.querySelector(`.${BASE_CLASS_PREFIX}-tree-select`);
  290. expect(dom.querySelectorAll(`.${BASE_CLASS_PREFIX}-tree-select-popover`).length).toEqual(1);
  291. });
  292. it('custom prefix / suffix / insetLabel', () => {
  293. let prefix = <div className="prefix">prefix content</div>;
  294. let suffix = <div className="suffix">suffix content</div>;
  295. let insetLabel = 'semi';
  296. const props = {
  297. prefix: prefix,
  298. suffix: suffix,
  299. };
  300. let treeSelect = getTreeSelect(props);
  301. expect(treeSelect.contains(prefix)).toEqual(true);
  302. expect(treeSelect.contains(suffix)).toEqual(true);
  303. treeSelect.unmount();
  304. let ntreeSelect = getTreeSelect({ insetLabel: insetLabel });
  305. expect(ntreeSelect.contains(insetLabel)).toEqual(true);
  306. ntreeSelect.unmount();
  307. });
  308. it('empty data', () => {
  309. let treeSelect = getTreeSelect({
  310. treeData: [],
  311. emptyContent: 'empty'
  312. });
  313. let node = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  314. expect(node.length).toEqual(1);
  315. expect(node.hasClass(`${BASE_CLASS_PREFIX}-tree-option-empty`)).toEqual(true);
  316. expect(node.instance().textContent).toEqual('empty');
  317. });
  318. it('defaultOpen', () => {
  319. let props = {
  320. defaultOpen: false,
  321. };
  322. let treeSelect = getTreeSelect(props);
  323. expect(treeSelect.state().isOpen).toEqual(false);
  324. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-popover`).exists()).toEqual(false);
  325. treeSelect.unmount();
  326. let ntreeSelect = getTreeSelect({ defaultOpen: true, });
  327. expect(ntreeSelect.state().isOpen).toEqual(true);
  328. expect(ntreeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-popover`).exists()).toEqual(true);
  329. let options = ntreeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  330. expect(ntreeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`).length).toEqual(2);
  331. expect(options.at(0).getDOMNode().textContent).toEqual('亚洲');
  332. expect(options.at(1).getDOMNode().textContent).toEqual('北美洲');
  333. });
  334. it('defaultValue', () => {
  335. // auto expand parent, if node exist means parent is open
  336. let treeSelect = getTreeSelect({
  337. defaultValue: 'Beijing'
  338. });
  339. let selectedNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-selected`);
  340. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('北京');
  341. expect(selectedNode.instance().textContent).toEqual('北京');
  342. treeSelect.unmount();
  343. // array case only select first item
  344. let tree2 = getTreeSelect({
  345. defaultValue: ['Riben', 'Beijing']
  346. });
  347. let selectedNode2 = tree2.find(`.${BASE_CLASS_PREFIX}-tree-option-selected`);
  348. expect(selectedNode2.instance().textContent).toEqual('日本');
  349. expect(tree2.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('日本');
  350. expect(tree2.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-2`).at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  351. })
  352. it('defaultExpandedKeys', () => {
  353. // auto expand parent
  354. let treeSelect = getTreeSelect({
  355. defaultExpandedKeys: ['zhongguo', 'beimeizhou']
  356. });
  357. // yazhou beimeizhou
  358. let topNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`);
  359. expect(topNode.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(false);
  360. expect(topNode.at(1).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(false);
  361. // zhongguo riben
  362. let children = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-2`);
  363. expect(children.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(false);
  364. expect(children.at(1).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  365. })
  366. it('defaultExpandAll', () => {
  367. let treeSelect = getTreeSelect({
  368. defaultExpandAll: true
  369. });
  370. let nodes = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  371. let collapsed = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-collapsed`);
  372. expect(nodes.length).toEqual(10);
  373. expect(collapsed.length).toEqual(0);
  374. treeSelect.setProps({ treeData: treeData2});
  375. treeSelect.update();
  376. const nodes2 = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  377. const collapsed2 = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-collapsed`);
  378. expect(nodes2.length).toEqual(2);
  379. expect(collapsed2.length).toEqual(2);
  380. })
  381. it('expandAll', () => {
  382. const treeSelect = getTreeSelect({
  383. expandAll: true
  384. });
  385. const nodes = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  386. const collapsed = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-collapsed`);
  387. expect(nodes.length).toEqual(10);
  388. expect(collapsed.length).toEqual(0);
  389. treeSelect.setProps({ treeData: treeData2});
  390. treeSelect.update();
  391. const nodes2 = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  392. const collapsed2 = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-collapsed`);
  393. expect(nodes2.length).toEqual(5);
  394. expect(collapsed2.length).toEqual(0);
  395. })
  396. it('if expandedKeys values work', () => {
  397. // auto expand parent
  398. let treeSelect = getTreeSelect({
  399. expandedKeys: ['beimeizhou']
  400. });
  401. // yazhou beimeizhou
  402. let topNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`);
  403. expect(topNode.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  404. expect(topNode.at(1).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(false);
  405. treeSelect.setProps({ expandedKeys: ['yazhou', 'zhongguo', 'beimeizhou'] });
  406. treeSelect.update();
  407. // zhongguo riben
  408. let children = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-2`);
  409. expect(children.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(false);
  410. expect(children.at(1).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  411. });
  412. it('if expand behavior works / onExpand', () => {
  413. const nativeEvent = { nativeEvent: { stopImmediatePropagation: () => { } } }
  414. let spyOnExpand = sinon.spy(() => { });
  415. let treeSelect = getTreeSelect({
  416. onExpand: spyOnExpand,
  417. });
  418. // yazhou
  419. let topNodeAsia = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`).at(0);
  420. let expandIcon = topNodeAsia.find(`.${BASE_CLASS_PREFIX}-tree-option-expand-icon`).at(0);
  421. // expand yazhou
  422. expandIcon.simulate('click', nativeEvent);
  423. expect(spyOnExpand.calledOnce).toBe(true);
  424. expect(spyOnExpand.calledWithMatch(["yazhou"], { expanded: true, node: { key: 'yazhou' } })).toEqual(true);
  425. // zhongguo riben
  426. let topNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`);
  427. expect(topNode.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(false);
  428. expect(topNode.at(1).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  429. // collapse yazhou
  430. expandIcon.simulate('click', nativeEvent);
  431. expect(spyOnExpand.calledWithMatch([], { expanded: false, node: { key: 'yazhou' } })).toEqual(true);
  432. topNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`);
  433. expect(topNode.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  434. });
  435. it('if expandedKeys controlled work / onExpand', () => {
  436. const nativeEvent = { nativeEvent: { stopImmediatePropagation: () => { } } }
  437. let spyOnExpand = sinon.spy(() => { });
  438. let treeSelect = getTreeSelect({
  439. expandedKeys: ['beimeizhou'],
  440. onExpand: spyOnExpand,
  441. });
  442. // yazhou
  443. let topNodeAsia = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`).at(0);
  444. let expandIcon = topNodeAsia.find(`.${BASE_CLASS_PREFIX}-tree-option-expand-icon`).at(0);
  445. // expand yazhou
  446. expandIcon.simulate('click', nativeEvent);
  447. expect(spyOnExpand.calledWithMatch(["beimeizhou", "yazhou"], { expanded: true, node: { key: 'yazhou' } })).toEqual(true);
  448. // zhongguo riben
  449. let topNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`);
  450. expect(topNode.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  451. });
  452. it('select item / onSelect / onChange', () => {
  453. let spyOnSelect = sinon.spy(() => { });
  454. let spyOnChange = sinon.spy(() => { });
  455. let treeSelect = getTreeSelect({
  456. defaultExpandAll: true,
  457. onSelect: spyOnSelect,
  458. onChange: spyOnChange,
  459. });
  460. let nodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  461. // select beijing
  462. nodeBeijing.simulate('click');
  463. // onSelect & onChange
  464. expect(spyOnSelect.calledOnce).toBe(true);
  465. expect(spyOnChange.calledOnce).toBe(true);
  466. expect(spyOnSelect.calledWithMatch('beijing', true, { key: "beijing" })).toEqual(true);
  467. expect(spyOnChange.calledWithMatch('Beijing', { key: "beijing" })).toEqual(true);
  468. let selectBox = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select`).at(0);
  469. selectBox.simulate('click');
  470. // classname
  471. nodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  472. expect(nodeBeijing.hasClass(`${BASE_CLASS_PREFIX}-tree-option-selected`)).toEqual(true);
  473. // render in input box
  474. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('北京');
  475. // change
  476. let nodeAsia = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`).at(0);
  477. // select asia
  478. nodeAsia.simulate('click');
  479. // onSelect & onChange
  480. expect(spyOnSelect.calledWithMatch('yazhou', true, { key: "yazhou" })).toEqual(true);
  481. expect(spyOnChange.calledWithMatch('Yazhou', { key: "yazhou" })).toEqual(true);
  482. selectBox.simulate('click');
  483. // classname
  484. nodeAsia = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`).at(0);
  485. expect(nodeAsia.hasClass(`${BASE_CLASS_PREFIX}-tree-option-selected`)).toEqual(true);
  486. // render in input box
  487. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('亚洲');
  488. });
  489. it('onChange + value not changed', () => {
  490. let spyOnSelect = sinon.spy(() => { });
  491. let spyOnChange = sinon.spy(() => { });
  492. let treeSelect = getTreeSelect({
  493. defaultExpandAll: true,
  494. onSelect: spyOnSelect,
  495. onChange: spyOnChange,
  496. defaultValue: 'Beijing'
  497. });
  498. let nodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  499. // select beijing
  500. nodeBeijing.simulate('click');
  501. // onSelect & onChange
  502. expect(spyOnSelect.calledOnce).toBe(true);
  503. expect(spyOnChange.notCalled).toBe(true);
  504. });
  505. it('onChange + onChangeWithObject', () => {
  506. let spyOnChange = sinon.spy(() => { });
  507. let treeSelect = getTreeSelect({
  508. defaultExpandAll: true,
  509. onChangeWithObject: true,
  510. onChange: spyOnChange,
  511. });
  512. let nodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  513. // select beijing
  514. nodeBeijing.simulate('click');
  515. // onSelect & onChange
  516. expect(spyOnChange.calledOnce).toBe(true);
  517. expect(spyOnChange.calledWithMatch({ key: "beijing" })).toEqual(true);
  518. });
  519. it('treeNodeLabelProp', () => {
  520. // auto expand parent, if node exist means parent is open
  521. let treeSelect = getTreeSelect({
  522. defaultValue: 'Beijing',
  523. treeNodeLabelProp: 'value'
  524. });
  525. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('Beijing');
  526. // select asia
  527. let nodeAsia = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`).at(0);
  528. nodeAsia.simulate('click');
  529. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('Yazhou');
  530. })
  531. it('filterTreeNode = true shows input box', () => {
  532. let treeSelect = getTreeSelect({});
  533. let searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`)
  534. expect(searchWrapper.exists()).toEqual(false);
  535. treeSelect.setProps({
  536. filterTreeNode: true
  537. });
  538. treeSelect.update();
  539. searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`)
  540. expect(searchWrapper.exists()).toEqual(true);
  541. });
  542. it('searchPlaceholder', () => {
  543. let treeSelect = getTreeSelect({
  544. filterTreeNode: true,
  545. searchPlaceholder: 'test',
  546. });
  547. let searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`)
  548. expect(searchWrapper.find('input').instance().getAttribute('placeholder')).toEqual('test');
  549. });
  550. it('onSearch', () => {
  551. let onSearch = value => { };
  552. let spyOnSearch = sinon.spy(onSearch);
  553. let treeSelect = getTreeSelect({
  554. filterTreeNode: true,
  555. onSearch: spyOnSearch,
  556. });
  557. const searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  558. let searchValue = 'semi';
  559. let event = { target: { value: searchValue } };
  560. searchWrapper.find('input').simulate('change', event);
  561. expect(spyOnSearch.calledOnce).toBe(true);
  562. expect(spyOnSearch.calledWithMatch(searchValue)).toBe(true);
  563. /* Check the input parameters of onSearch */
  564. searchValue = '北京';
  565. event = { target: { value: searchValue } };
  566. searchWrapper.find('input').simulate('change', event);
  567. expect(spyOnSearch.callCount).toBe(2);
  568. const firstCall = spyOnSearch.getCall(1);
  569. const args = firstCall.args;
  570. expect(args[0]).toEqual('北京');
  571. expect(args[1].includes('yazhou')).toEqual(true);
  572. expect(args[1].includes('zhongguo')).toEqual(true);
  573. });
  574. it('filterTreeNode shows correct result', () => {
  575. let treeSelect1 = getTreeSelect({
  576. filterTreeNode: true,
  577. });
  578. const searchWrapper = treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  579. let searchValue = '北';
  580. let event = { target: { value: searchValue } };
  581. searchWrapper.find('input').simulate('change', event);
  582. expect(treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-option`).length).toEqual(6);
  583. expect(treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).length).toEqual(2);
  584. expect(treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).at(0).instance().textContent).toEqual('北');
  585. expect(treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).at(1).instance().textContent).toEqual('北');
  586. treeSelect1.unmount();
  587. let treeSelect2 = getTreeSelect({
  588. filterTreeNode: true,
  589. treeNodeFilterProp: 'value',
  590. });
  591. const searchWrapper2 = treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  592. let searchValue2 = 'an';
  593. let event2 = { target: { value: searchValue2 } };
  594. searchWrapper2.find('input').simulate('change', event2);
  595. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option`).length).toEqual(10);
  596. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).length).toEqual(3);
  597. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).at(0).instance().textContent).toEqual('上海');
  598. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).at(1).instance().textContent).toEqual('大阪');
  599. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).at(2).instance().textContent).toEqual('加拿大');
  600. });
  601. it('filterTreeNode + no result', () => {
  602. let treeSelect1 = getTreeSelect({
  603. filterTreeNode: true,
  604. });
  605. const searchWrapper = treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  606. let searchValue = 'Bei';
  607. let event = { target: { value: searchValue } };
  608. searchWrapper.find('input').simulate('change', event);
  609. expect(treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-option`).length).toEqual(2);
  610. expect(treeSelect1.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).length).toEqual(0);
  611. treeSelect1.unmount();
  612. let treeSelect2 = getTreeSelect({
  613. filterTreeNode: true,
  614. treeNodeFilterProp: 'value',
  615. });
  616. const searchWrapper2 = treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  617. let searchValue2 = '北';
  618. let event2 = { target: { value: searchValue2 } };
  619. searchWrapper2.find('input').simulate('change', event2);
  620. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option`).length).toEqual(2);
  621. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).length).toEqual(0);
  622. });
  623. it('async load data', () => {
  624. const nativeEvent = { nativeEvent: { stopImmediatePropagation: () => { } } }
  625. const then = jest.fn(() => Promise.resolve());
  626. const loadData = jest.fn(() => ({ then }));
  627. const data = {
  628. label: '亚洲',
  629. value: 'Asia',
  630. key: 'asia',
  631. };
  632. const treeSelect = getTreeSelect({
  633. loadData,
  634. loadedKeys: ['0-1'],
  635. treeData: [data]
  636. });
  637. const topNodeAsia = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`).at(0);
  638. const expandIcon = topNodeAsia.find(`.${BASE_CLASS_PREFIX}-tree-option-expand-icon`).at(0);
  639. expandIcon.simulate('click', nativeEvent);
  640. expect(loadData).toHaveBeenCalledWith(data);
  641. expect(then).toHaveBeenCalled();
  642. });
  643. it('filterTreeNode + treeNodeFilterProp', () => {
  644. let treeSelect = getTreeSelect({
  645. filterTreeNode: true,
  646. treeNodeFilterProp: 'value',
  647. });
  648. const searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  649. let searchValue = 'Bei';
  650. let event = { target: { value: searchValue } };
  651. searchWrapper.find('input').simulate('change', event);
  652. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`).length).toEqual(6);
  653. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).length).toEqual(2);
  654. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).at(0).instance().textContent).toEqual('北京');
  655. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-filtered`).at(1).instance().textContent).toEqual('北美洲');
  656. });
  657. it('filterTreeNode + showFilteredOnly + no result', () => {
  658. let treeSelect = getTreeSelect({
  659. filterTreeNode: true,
  660. showFilteredOnly: true,
  661. });
  662. const searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  663. let searchValue = 'Bei';
  664. let event = { target: { value: searchValue } };
  665. searchWrapper.find('input').simulate('change', event);
  666. let node = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  667. expect(node.length).toEqual(1);
  668. expect(node.hasClass(`${BASE_CLASS_PREFIX}-tree-option-empty`)).toEqual(true);
  669. });
  670. it('filterTreeNode + showFilteredOnly shows correct result', () => {
  671. let treeSelect = getTreeSelect({
  672. filterTreeNode: true,
  673. showFilteredOnly: true,
  674. });
  675. const searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  676. let searchValue = '北';
  677. let event = { target: { value: searchValue } };
  678. searchWrapper.find('input').simulate('change', event);
  679. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`).length).toEqual(4);
  680. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).length).toEqual(2);
  681. });
  682. it('filterTreeNode as a func', () => {
  683. let treeSelect = getTreeSelect({
  684. filterTreeNode: (inputValue, treeNode) => treeNode === inputValue,
  685. });
  686. const searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  687. searchWrapper.find('input').simulate('change', { target: { value: '北' } });
  688. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).length).toEqual(0);
  689. // update
  690. searchWrapper.find('input').simulate('change', { target: { value: '北京' } });
  691. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).length).toEqual(1);
  692. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-highlight`).instance().textContent).toEqual('北京');
  693. });
  694. it('controlled: value shows correct', () => {
  695. let treeSelect = getTreeSelect({
  696. value: 'Beijing'
  697. });
  698. let selectedNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-selected`);
  699. expect(selectedNode.instance().textContent).toEqual('北京');
  700. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('北京');
  701. treeSelect.unmount();
  702. // array case only select first item
  703. let treeSelect2 = getTreeSelect({
  704. value: ['Riben', 'Beijing']
  705. });
  706. let selectedNode2 = treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option-selected`);
  707. expect(selectedNode2.instance().textContent).toEqual('日本');
  708. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('日本');
  709. expect(treeSelect2.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-2`).at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  710. });
  711. it('controlled: fire onChange and ui not update', () => {
  712. let spyOnChange = sinon.spy(() => { });
  713. let treeSelect = getTreeSelect({
  714. value: '',
  715. defaultExpandAll: true,
  716. onChange: spyOnChange,
  717. });
  718. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-selected`).exists()).toEqual(false);
  719. let nodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  720. // select beijing
  721. nodeBeijing.simulate('click');
  722. // onSelect & onChange
  723. expect(spyOnChange.calledOnce).toBe(true);
  724. expect(spyOnChange.calledWithMatch("Beijing")).toEqual(true);
  725. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-selected`).exists()).toEqual(false);
  726. });
  727. it('controlled: value + onChangeWithObject', () => {
  728. let spyOnChange = sinon.spy(() => { });
  729. let treeSelect = getTreeSelect({
  730. value: {
  731. label: '北京',
  732. value: 'Beijing',
  733. key: 'beijing',
  734. },
  735. defaultExpandAll: true,
  736. onChange: spyOnChange,
  737. onChangeWithObject: true,
  738. });
  739. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option-selected`).exists()).toEqual(true);
  740. });
  741. it('virtualized: fixed height', () => {
  742. let treeSelect = getTreeSelect({
  743. defaultExpandAll: true,
  744. virtualize: {
  745. itemSize: 28,
  746. height: 84,
  747. },
  748. });
  749. // virtual list
  750. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-virtual-list`).exists()).toEqual(true);
  751. // fewer nodes
  752. let nodes = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option`);
  753. expect(nodes.length).toBeLessThan(10);
  754. });
  755. it('disabled', () => {
  756. let treeSelect = getTreeSelect({
  757. disabled: true,
  758. });
  759. let inputBox = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-disabled`);
  760. expect(inputBox.exists()).toEqual(true);
  761. expect(treeSelect.state().isOpen).toEqual(false);
  762. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-wrapper`).exists()).toEqual(false);
  763. inputBox.simulate('click');
  764. expect(treeSelect.state().isOpen).toEqual(false);
  765. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-wrapper`).exists()).toEqual(false);
  766. });
  767. it('renderSelectedItem', () => {
  768. let spyOnSelect = sinon.spy(() => { });
  769. let spyOnChange = sinon.spy(() => { });
  770. let treeSelect = getTreeSelect({
  771. renderSelectedItem: treeNode => treeNode.value,
  772. defaultExpandAll: true,
  773. onSelect: spyOnSelect,
  774. onChange: spyOnChange,
  775. });
  776. const yaZhouKey = 'yazhou';
  777. const yaZhouValue = 'Yazhou';
  778. let nodeYaZhou = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`).at(0);
  779. nodeYaZhou.simulate('click');
  780. // 判断回调,这里其实没有更新,不是很重要
  781. expect(spyOnSelect.calledOnce).toBe(true);
  782. expect(spyOnChange.calledOnce).toBe(true);
  783. expect(spyOnSelect.getCall(0).args[0]).toEqual(yaZhouKey);
  784. expect(spyOnChange.getCall(0).args[0]).toEqual(yaZhouValue);
  785. // 判断已选项的渲染
  786. const innerHTML = document.querySelector('.semi-tree-select-selection span').textContent;
  787. expect(innerHTML).toEqual(yaZhouValue);
  788. });
  789. it('search autofocus', () => {
  790. let treeSelect = getTreeSelect({
  791. filterTreeNode: true,
  792. searchAutoFocus: true,
  793. });
  794. let selectEle = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select`)
  795. selectEle.simulate('click');
  796. setTimeout(() => {
  797. let searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`)
  798. const searchInput = searchWrapper.find(`input`)
  799. expect(searchInput.matchesElement(document.activeElement)).toEqual(true);
  800. done();
  801. }, 100);
  802. });
  803. it('treeData is updated should not clear value when uncontrolled mode and single selection', () => {
  804. const nativeEvent = { nativeEvent: { stopImmediatePropagation: () => { } } }
  805. const treeSelect = getTreeSelect({
  806. defaultExpandAll: true
  807. });
  808. treeSelect
  809. .find(`.${BASE_CLASS_PREFIX}-tree-option-list .${BASE_CLASS_PREFIX}-tree-option`)
  810. .at(2)
  811. .simulate('click', nativeEvent);
  812. expect(
  813. treeSelect
  814. .find(`.${BASE_CLASS_PREFIX}-tree-select .${BASE_CLASS_PREFIX}-tree-select-selection span`)
  815. .getDOMNode()
  816. .textContent
  817. ).toEqual('北京');
  818. treeSelect.setProps({ treeData: treeChildren});
  819. treeSelect.update();
  820. expect(
  821. treeSelect
  822. .find(`.${BASE_CLASS_PREFIX}-tree-select .${BASE_CLASS_PREFIX}-tree-select-selection span`)
  823. .getDOMNode()
  824. .textContent
  825. ).toEqual('北京');
  826. treeSelect.setProps({ treeData: treeData2});
  827. treeSelect.update();
  828. expect(
  829. treeSelect
  830. .find(`.${BASE_CLASS_PREFIX}-tree-select .${BASE_CLASS_PREFIX}-tree-select-selection span`)
  831. .getDOMNode()
  832. .textContent
  833. ).toEqual('');
  834. });
  835. it('treeData is updated should not clear value when uncontrolled mode and multiple selection', () => {
  836. const nativeEvent = { nativeEvent: { stopImmediatePropagation: () => { } } }
  837. const treeSelect = getTreeSelect({
  838. defaultExpandAll: true,
  839. multiple: true,
  840. });
  841. treeSelect
  842. .find(`.${BASE_CLASS_PREFIX}-tree-option-list .${BASE_CLASS_PREFIX}-tree-option`)
  843. .at(2)
  844. .simulate('click', nativeEvent);
  845. expect(
  846. treeSelect
  847. .find(`.${BASE_CLASS_PREFIX}-tree-select-selection .${BASE_CLASS_PREFIX}-tag-group .${BASE_CLASS_PREFIX}-tag`)
  848. .at(0)
  849. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  850. .getDOMNode()
  851. .textContent
  852. ).toEqual('北京');
  853. treeSelect.setProps({ treeData: treeChildren});
  854. treeSelect.update();
  855. expect(
  856. treeSelect
  857. .find(`.${BASE_CLASS_PREFIX}-tree-select-selection .${BASE_CLASS_PREFIX}-tag-group .${BASE_CLASS_PREFIX}-tag`)
  858. .at(0)
  859. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  860. .getDOMNode()
  861. .textContent
  862. ).toEqual('北京');
  863. treeSelect.setProps({ treeData: treeData2});
  864. treeSelect.update();
  865. expect(
  866. treeSelect
  867. .find(`.${BASE_CLASS_PREFIX}-tree-select-selection .${BASE_CLASS_PREFIX}-tag-group .${BASE_CLASS_PREFIX}-tag`)
  868. .at(0)
  869. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  870. .length
  871. ).toEqual(0);
  872. });
  873. it('treeData is updated should not clear value when controlled mode and single selection', () => {
  874. const treeSelect = getTreeSelect({
  875. defaultExpandAll: true,
  876. value: 'Beijing'
  877. });
  878. expect(
  879. treeSelect
  880. .find(`.${BASE_CLASS_PREFIX}-tree-select .${BASE_CLASS_PREFIX}-tree-select-selection span`)
  881. .getDOMNode()
  882. .textContent
  883. ).toEqual('北京');
  884. treeSelect.setProps({ treeData: treeChildren});
  885. treeSelect.update();
  886. expect(
  887. treeSelect
  888. .find(`.${BASE_CLASS_PREFIX}-tree-select .${BASE_CLASS_PREFIX}-tree-select-selection span`)
  889. .getDOMNode()
  890. .textContent
  891. ).toEqual('北京');
  892. treeSelect.setProps({ treeData: treeData3});
  893. treeSelect.update();
  894. // If the value exists, but not in the treeData, the value will be displayed in the trigger
  895. expect(
  896. treeSelect
  897. .find(`.${BASE_CLASS_PREFIX}-tree-select .${BASE_CLASS_PREFIX}-tree-select-selection span`)
  898. .getDOMNode()
  899. .textContent
  900. ).toEqual('Beijing');
  901. });
  902. it('treeData is updated should not clear value when controlled mode and multiple selection', () => {
  903. const treeSelect = getTreeSelect({
  904. defaultExpandAll: true,
  905. multiple: true,
  906. value: 'Beijing'
  907. });
  908. expect(
  909. treeSelect
  910. .find(`.${BASE_CLASS_PREFIX}-tree-select-selection .${BASE_CLASS_PREFIX}-tag-group .${BASE_CLASS_PREFIX}-tag`)
  911. .at(0)
  912. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  913. .getDOMNode()
  914. .textContent
  915. ).toEqual('北京');
  916. treeSelect.setProps({ treeData: treeChildren});
  917. treeSelect.update();
  918. expect(
  919. treeSelect
  920. .find(`.${BASE_CLASS_PREFIX}-tree-select-selection .${BASE_CLASS_PREFIX}-tag-group .${BASE_CLASS_PREFIX}-tag`)
  921. .at(0)
  922. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  923. .getDOMNode()
  924. .textContent
  925. ).toEqual('北京');
  926. treeSelect.setProps({ treeData: treeData3});
  927. treeSelect.update();
  928. expect(
  929. treeSelect
  930. .find(`.${BASE_CLASS_PREFIX}-tree-select-selection .${BASE_CLASS_PREFIX}-tag-group .${BASE_CLASS_PREFIX}-tag`)
  931. .at(0)
  932. .find(`.${BASE_CLASS_PREFIX}-tag-content`)
  933. .length
  934. ).toEqual(1);
  935. });
  936. it('expandedKeys controlled + filterTreeNode', () => {
  937. const spyOnExpand = sinon.spy(() => { });
  938. const treeSelect = getTreeSelect({
  939. expandedKeys: [],
  940. onExpand: spyOnExpand,
  941. filterTreeNode: true,
  942. });
  943. const searchWrapper = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-search-wrapper`);
  944. const searchValue = '北京';
  945. const event = { target: { value: searchValue } };
  946. searchWrapper.find('input').simulate('change', event);
  947. expect(spyOnExpand.callCount).toBe(0);
  948. /* filter won't impact on the expansion of node when expandedKeys is controlled */
  949. const topNode = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-1`);
  950. expect(topNode.at(0).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  951. expect(topNode.at(1).hasClass(`${BASE_CLASS_PREFIX}-tree-option-collapsed`)).toEqual(true);
  952. });
  953. it('option not in treeData + treeData item with value', () => {
  954. const spyOnSelect = sinon.spy(() => { });
  955. const spyOnChange = sinon.spy(() => { });
  956. let treeSelect = getTreeSelect({
  957. defaultValue: 'fish',
  958. defaultExpandAll: true,
  959. onSelect: spyOnSelect,
  960. onChange: spyOnChange,
  961. });
  962. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('fish');
  963. // beijing
  964. let topNodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  965. topNodeBeijing.simulate('click');
  966. expect(spyOnChange.calledWithMatch("Beijing")).toEqual(true);
  967. treeSelect.unmount();
  968. // onChangeWithObject
  969. treeSelect = getTreeSelect({
  970. defaultValue: { label: '鱼', value: 'Fish', key: 'fish' },
  971. onChangeWithObject: true,
  972. defaultExpandAll: true,
  973. onSelect: spyOnSelect,
  974. onChange: spyOnChange,
  975. });
  976. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('鱼');
  977. // beijing
  978. topNodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  979. topNodeBeijing.simulate('click');
  980. expect(spyOnChange.calledWithMatch({ label: '北京', value: 'Beijing', key: 'beijing' })).toEqual(true);
  981. treeSelect.unmount();
  982. })
  983. it('option not in treeData + treeData item without value', () => {
  984. const spyOnSelect = sinon.spy(() => { });
  985. const spyOnChange = sinon.spy(() => { });
  986. let treeSelect = getTreeSelect({
  987. treeData: treeDataWithoutValue,
  988. defaultValue: 'fish',
  989. defaultExpandAll: true,
  990. onSelect: spyOnSelect,
  991. onChange: spyOnChange,
  992. });
  993. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('fish');
  994. // beijing
  995. let topNodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  996. topNodeBeijing.simulate('click');
  997. expect(spyOnChange.calledWithMatch("beijing")).toEqual(true);
  998. treeSelect.unmount();
  999. // onChangeWithObject
  1000. treeSelect = getTreeSelect({
  1001. defaultValue: { label: '鱼', key: 'fish' },
  1002. onChangeWithObject: true,
  1003. defaultExpandAll: true,
  1004. onSelect: spyOnSelect,
  1005. onChange: spyOnChange,
  1006. });
  1007. expect(treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-select-selection`).getDOMNode().textContent).toEqual('鱼');
  1008. // beijing
  1009. topNodeBeijing = treeSelect.find(`.${BASE_CLASS_PREFIX}-tree-option.${BASE_CLASS_PREFIX}-tree-option-level-3`).at(0);
  1010. topNodeBeijing.simulate('click');
  1011. expect(spyOnChange.calledWithMatch({ label: '北京', key: 'beijing' })).toEqual(true);
  1012. treeSelect.unmount();
  1013. })
  1014. })