index.js 8.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310
  1. import React from 'react';
  2. import {Table, Tag, Tooltip} from '../../../index';
  3. const {Column} = Table;
  4. function getRandomNumber(end = 100, start = 0) {
  5. const number = Math.ceil(Math.random() * (end - start)) + start;
  6. return number;
  7. }
  8. function getData(total = 25) {
  9. const _data = [];
  10. for (let i = 0; i < total; i++) {
  11. let age = (i * 1000) % 149;
  12. let name = `Edward King ${i}`;
  13. _data.push({
  14. key: String(i),
  15. name,
  16. age,
  17. address: `London, Park Lane no. ${i} Lake Park`,
  18. description: `My name is ${name}, I am ${age} years old, living in New York No. ${i + 1} Lake Park.`,
  19. });
  20. }
  21. return _data;
  22. }
  23. function getGroupData() {
  24. const data = [
  25. {city: 'Beijing', job: 'FE', department: 'IES'},
  26. {city: 'Beijing', job: 'BE', department: 'IES'},
  27. {city: 'Shanghai', job: 'Android', department: 'IES'},
  28. {city: 'Tokyo', job: 'Android', department: 'IES'},
  29. {city: 'Shanghai', job: 'IOS', department: 'EE'},
  30. {city: 'LA', job: 'SE', department: 'EE'},
  31. {city: 'Beijing', job: 'Android', department: 'EE'},
  32. {city: 'Tokyo', job: 'IOS', department: 'EE'},
  33. {city: 'Tokyo', job: 'SE', department: 'DATA'},
  34. {city: 'Shanghai', job: 'BE', department: 'DATA'},
  35. {city: 'LA', job: 'Android', department: 'DATA'},
  36. {city: 'LA', job: 'IOS', department: 'DATA'},
  37. ];
  38. return data;
  39. }
  40. function getColumns() {
  41. const columns = [
  42. {
  43. title: 'Name',
  44. dataIndex: 'name',
  45. width: 150,
  46. fixed: 'left',
  47. },
  48. {
  49. title: 'Age',
  50. dataIndex: 'age',
  51. width: 150,
  52. },
  53. {
  54. title: 'Description',
  55. dataIndex: 'description',
  56. },
  57. {
  58. title: 'Address',
  59. dataIndex: 'address',
  60. },
  61. {
  62. render: (text, record) => (
  63. <Tooltip content={record.description}>
  64. <Tag color="green">Show Info</Tag>
  65. </Tooltip>
  66. ),
  67. width: 150,
  68. fixed: 'right',
  69. },
  70. ];
  71. return columns;
  72. }
  73. function getJSXColumns() {
  74. const jsxColumns = (
  75. <>
  76. <Column title={'Name'} dataIndex={'name'} width={150}/>
  77. <Column title={'Age'} dataIndex={'age'} width={150}/>
  78. <Column title={'Address'} dataIndex={'address'}/>
  79. <Column
  80. render={(text, record) => (
  81. <Tooltip content={record.description}>
  82. <Tag color="green">Show Info</Tag>
  83. </Tooltip>
  84. )}
  85. width={150}
  86. />
  87. </>
  88. );
  89. return jsxColumns;
  90. }
  91. function getGroupColumns() {
  92. const columns = [
  93. {dataIndex: 'city', title: 'City', width: 400, sorter: (a, b) => (a.city > b.city ? 1 : -1)},
  94. {
  95. dataIndex: 'job',
  96. title: 'Job',
  97. width: 200,
  98. filters: [
  99. {text: 'IOS', value: 'IOS'},
  100. {text: 'Android', value: 'Android'},
  101. ],
  102. onFilter: (value, record) => record.job && record.job.indexOf(value) === 0,
  103. },
  104. {dataIndex: 'department', title: 'Department'},
  105. ];
  106. return columns;
  107. }
  108. function getNestColumns() {
  109. const nestColumns = ([
  110. {
  111. title: 'Base Information',
  112. fixed: 'left',
  113. children: [
  114. {
  115. title: 'Name',
  116. dataIndex: 'name',
  117. fixed: 'left',
  118. width: 200,
  119. filters: [
  120. {
  121. text: 'Code 45',
  122. value: '45',
  123. },
  124. {
  125. text: 'King 4',
  126. value: 'King 4',
  127. },
  128. ],
  129. onFilter: (value, record) => record.name.includes(value),
  130. },
  131. {
  132. title: 'Age',
  133. dataIndex: 'age',
  134. fixed: 'left',
  135. width: 100,
  136. sorter: (a, b) => (a.age - b.age > 0 ? 1 : -1),
  137. },
  138. ],
  139. },
  140. {
  141. title: 'Company Information',
  142. children: [
  143. {
  144. title: 'Company Name',
  145. dataIndex: 'company.name',
  146. },
  147. {
  148. title: 'Company Address',
  149. dataIndex: 'company.address',
  150. },
  151. ],
  152. },
  153. {
  154. title: 'Address',
  155. width: 250,
  156. dataIndex: 'address',
  157. fixed: 'right',
  158. },
  159. ]);
  160. return nestColumns;
  161. }
  162. function getNestData(total = 25) {
  163. const data = [];
  164. for (let i = 0; i < total; i++) {
  165. let age = (i * 1000) % 149;
  166. let name = `Edward King ${i}`;
  167. data.push({
  168. key: String(i),
  169. company: {
  170. name: 'ByteDance',
  171. address: 'No. 48, Zhichun Road',
  172. },
  173. name,
  174. age,
  175. address: `No ${i + 1}, Zhongguancun Street`,
  176. description: `My name is ${name}, I am ${age} years old, living in No ${i + 1}, Zhongguancun Street`,
  177. });
  178. }
  179. return data;
  180. }
  181. function getTreeData() {
  182. const childrenData = [
  183. {
  184. key: 1,
  185. name: 'ZhangSan',
  186. age: 30,
  187. address: 'bytedance 1',
  188. children: [
  189. {
  190. key: 11,
  191. name: 'LiSi',
  192. age: 40,
  193. address: 'bytedance 2',
  194. },
  195. {
  196. key: 12,
  197. name: 'WangWu',
  198. age: 30,
  199. address: 'bytedance 2',
  200. children: [
  201. {
  202. key: 121,
  203. name: 'XiaoMing',
  204. age: 50,
  205. address: 'bytedance 3',
  206. },
  207. ],
  208. },
  209. {
  210. key: 13,
  211. name: 'XiaoZhang',
  212. age: 60,
  213. address: 'bytedance 4',
  214. children: [
  215. {
  216. key: 131,
  217. name: 'XiaoLi',
  218. age: 50,
  219. address: 'bytedance 5',
  220. children: [
  221. {
  222. key: 1311,
  223. name: 'XiaoGuo',
  224. age: 40,
  225. address: 'bytedance 6',
  226. },
  227. {
  228. key: 1312,
  229. name: 'XiaoHong',
  230. age: 30,
  231. address: 'bytedance 7',
  232. },
  233. ],
  234. },
  235. ],
  236. },
  237. ],
  238. },
  239. {
  240. key: 2,
  241. name: 'XiaoGang',
  242. age: 80,
  243. address: 'bytedance 8',
  244. },
  245. ];
  246. return childrenData;
  247. }
  248. function getJSXNestColumns() {
  249. const filters = [
  250. {
  251. text: 'Code 45',
  252. value: '45',
  253. },
  254. {
  255. text: 'King 4',
  256. value: 'King 4',
  257. },
  258. ];
  259. const jsxNestColumns = (
  260. <>
  261. <Column title={'Base Information'} dataIndex={'base'} fixed="left">
  262. <Column
  263. title={'Name'}
  264. dataIndex={'name'}
  265. fixed="left"
  266. width={200}
  267. filters={filters}
  268. onFilter={(value, record) => record.name.includes(value)}
  269. />
  270. <Column
  271. title={'Age'}
  272. dataIndex={'age'}
  273. width={100}
  274. fixed="left"
  275. sorter={(a, b) => (a.age - b.age > 0 ? 1 : -1)}
  276. />
  277. </Column>
  278. <Column title={'Company Information'} dataIndex={'company'}>
  279. <Column title={'Company Name'} dataIndex={'company.name'}/>
  280. <Column title={'Company Address'} dataIndex={'company.address'}/>
  281. </Column>
  282. <Column title={'Address'} dataIndex={'address'} width={250} fixed="right"/>
  283. </>
  284. );
  285. return jsxNestColumns;
  286. }
  287. export {
  288. getRandomNumber,
  289. getData,
  290. getGroupData,
  291. getNestData,
  292. getTreeData,
  293. getColumns,
  294. getJSXColumns,
  295. getGroupColumns,
  296. getJSXNestColumns,
  297. getNestColumns
  298. };