page.js 10 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314
  1. import React from 'react';
  2. import './index.less';
  3. import { Icon, Checkbox } from 'antd';
  4. import Page from '@src/containers/Page';
  5. import { timeRange } from '@src/services/Tools';
  6. import UserLayout from '../../../layouts/User';
  7. import UserTable from '../../../components/UserTable';
  8. import UserAction from '../../../components/UserAction';
  9. import menu, { refreshQuestionType, refreshStruct } from '../index';
  10. import Tabs from '../../../components/Tabs';
  11. import Modal from '../../../components/Modal';
  12. import Select from '../../../components/Select';
  13. import GIcon from '../../../components/Icon';
  14. import { TimeRange } from '../../../../Constant';
  15. import { My } from '../../../stores/my';
  16. const columns = [
  17. { key: 'question_type', title: '题型', fixSort: true },
  18. { key: 'title', title: '题目ID', fixSort: true },
  19. { key: 'description', title: '内容' },
  20. { key: 'time', title: '耗时', sort: true },
  21. { key: 'correct', title: '错误率', sort: true },
  22. { key: 'latest_time', title: '最近做题' },
  23. {
  24. key: '',
  25. title: '',
  26. render() {
  27. return [<GIcon name="star" className="m-r-5" />, <GIcon name="note" />];
  28. },
  29. },
  30. ];
  31. const exportType = [
  32. { key: '1', title: '题目' },
  33. { key: '2', title: '官方解析' },
  34. { key: '3', title: '我的笔记' },
  35. { key: '4', title: '千行解析', auth: true },
  36. { key: '5', title: '题源联想', auth: true },
  37. { key: '6', title: '相关问答', auth: true },
  38. ];
  39. export default class extends Page {
  40. constructor(props) {
  41. props.size = 10;
  42. super(props);
  43. }
  44. initState() {
  45. return {
  46. tab: 'exercise',
  47. timerange: 'today',
  48. filterMap: {},
  49. sortMap: {},
  50. data: [{}, {}],
  51. selectList: [],
  52. allChecked: false,
  53. };
  54. }
  55. initData() {
  56. const data = Object.assign(this.state, this.state.search);
  57. data.filterMap = this.state.search;
  58. if (data.order) {
  59. data.sortMap = { [data.order]: data.direction };
  60. }
  61. if (data.timerange) {
  62. data.filterMap.timerange = data.timerange;
  63. }
  64. const [startTime, endTime] = timeRange(data.timerange);
  65. refreshQuestionType(this, data.subject, data.questionType, { all: true, needSentence: true, allSubject: true })
  66. .then(({ questionTypes }) => {
  67. return refreshStruct(this, data.tab, data.one, data.two, {
  68. all: true, needPreview: false, needTextbook: true,
  69. })
  70. .then(({ structIds, latest, year }) => {
  71. My.listQuestionAsk(Object.assign({ module: data.tab, questionTypes, structIds, latest, year, startTime, endTime }, this.state.search, {
  72. order: Object.keys(data.sortMap).map(key => {
  73. if (key === 'title') return 'pid desc, no desc';
  74. return `${key} ${data.sortMap[key]}`;
  75. }).join(','),
  76. })).then(result => {
  77. this.setState({ list: result.list, total: result.total });
  78. });
  79. });
  80. });
  81. }
  82. onTabChange(tab) {
  83. const data = { tab };
  84. this.refreshQuery(data);
  85. }
  86. onFilter(value) {
  87. this.search(value);
  88. }
  89. onSort(value) {
  90. const keys = Object.keys(value);
  91. // this.search({ order: keys.length ? keys.join('|') : null, direction: keys.length ? Object.values(value).join('|') : null });
  92. const { sortMap } = this.state;
  93. const index = keys.length > 1 && sortMap[keys[0]] ? 1 : 0;
  94. this.search({ order: keys.length ? keys[index] : null, direction: keys.length ? value[keys[index]] : null });
  95. }
  96. onChangePage(page) {
  97. this.search({ page });
  98. }
  99. onAll(checked) {
  100. if (checked) {
  101. const { data = [] } = this.state;
  102. const list = [];
  103. data.forEach(item => {
  104. list.push(item.key);
  105. });
  106. this.setState({ selectList: list, allChecked: true });
  107. } else {
  108. this.setState({ selectList: [], allChecked: false });
  109. }
  110. }
  111. onAction() { }
  112. onSelect(selectList) {
  113. this.setState({ selectList });
  114. }
  115. renderView() {
  116. const { config } = this.props;
  117. return <UserLayout active={config.key} menu={menu} center={this.renderTable()} />;
  118. }
  119. renderTable() {
  120. const { tab, questionSubjectSelect, questionSubjectMap = {}, oneSelect, twoSelectMap = {}, filterMap = {}, sortMap = {}, list = [] } = this.state;
  121. const { selectList = [], allChecked, page, total } = this.state;
  122. return (
  123. <div className="table-layout">
  124. <Tabs
  125. border
  126. type="division"
  127. theme="theme"
  128. size="small"
  129. space={2.5}
  130. width={100}
  131. active={tab}
  132. tabs={[{ key: 'exercise', title: '练习' }, { key: 'examination', title: '模考' }]}
  133. onChange={key => this.onTabChange(key)}
  134. />
  135. <UserAction
  136. search
  137. selectList={[{
  138. children: [{
  139. key: 'subject',
  140. placeholder: '学科',
  141. select: questionSubjectSelect,
  142. }, {
  143. placeholder: '题型',
  144. key: 'questionType',
  145. be: 'subject',
  146. selectMap: questionSubjectMap,
  147. }],
  148. }, {
  149. label: '范围',
  150. children: [{
  151. key: 'one',
  152. placeholder: '全部',
  153. select: oneSelect,
  154. }, {
  155. key: 'two',
  156. be: 'one',
  157. placeholder: '全部',
  158. selectMap: twoSelectMap,
  159. }],
  160. }, {
  161. right: true,
  162. key: 'timerange',
  163. select: TimeRange,
  164. }]}
  165. filterMap={filterMap}
  166. onFilter={value => this.onFilter(value)}
  167. />
  168. <UserAction
  169. allCheckbox
  170. allChecked={allChecked}
  171. help
  172. btnList={[
  173. { title: '移除', key: 'remove' },
  174. { title: '组卷', key: 'group', tag: 'vip' },
  175. { title: '导出', key: 'export', tag: 'vip', disabled: true },
  176. ]}
  177. right={
  178. <div className="tip">
  179. 2019-06-03 15:30 组卷50题,做对30题。<span>移除正确题目</span>
  180. <Icon type="close-circle" theme="filled" />
  181. </div>
  182. }
  183. onAll={checked => this.onAll(checked)}
  184. onAction={key => this.onAction(key)}
  185. />
  186. <UserTable
  187. select
  188. columns={columns}
  189. sortMap={sortMap}
  190. data={list}
  191. current={page}
  192. total={total}
  193. selectList={selectList}
  194. onSelect={l => this.onSelect(l)}
  195. onSort={v => this.onSort(v)}
  196. onChange={p => this.onChangePage(p)}
  197. />
  198. {this.renderModal()}
  199. </div>
  200. );
  201. }
  202. renderModal() {
  203. return [
  204. <Modal title="操作提示" confirmText="好的,知道了" btnAlign="center" onConfirm={() => { }}>
  205. <div className="flex-layout m-b-2">
  206. <div className="flex-block">
  207. <div className="t-1 t-s-18">组卷功能</div>
  208. <div className="t-2">操作数量:10-50;</div>
  209. <div className="t-2">注意事项:可跨题型、不可跨学科。</div>
  210. </div>
  211. <div className="flex-block">
  212. <div className="t-1 t-s-18">导出功能</div>
  213. <div className="t-2">操作数量:1-100;</div>
  214. <div className="t-2">注意事项:“综合推理IR”暂时无法导出。</div>
  215. </div>
  216. </div>
  217. <div className="t-3">
  218. *您可点击
  219. <Icon type="question-circle" theme="filled" />
  220. 查阅以上信息。
  221. </div>
  222. </Modal>,
  223. <Modal title="组卷练习" confirmText="好的,知道了" btnAlign="center" onConfirm={() => { }}>
  224. <div className="t-2 t-s-18">不可同时选中语文题和数学题,请重新选择。</div>
  225. </Modal>,
  226. <Modal title="组卷练习" confirmText="开始练习" onConfirm={() => { }} onCancel={() => { }}>
  227. <div className="t-2 t-s-18">
  228. 您共选择了 <span className="t-4">50</span> 道题目,是否开始练习?
  229. </div>
  230. <div className="t-2 t-s-16">
  231. <Checkbox checked className="m-r-5" />
  232. 剔除已组卷练习 <Select
  233. theme="white"
  234. value="1"
  235. list={[{ key: '1', title: '2' }, { key: '2', title: '3' }]}
  236. />{' '}
  237. 次以上的错题
  238. </div>
  239. </Modal>,
  240. <Modal title="移出" onConfirm={() => { }} onCancel={() => { }}>
  241. <div className="t-2 t-s-18">
  242. 当前选中的 <span className="t-4">50</span> 道题即将被移出错题本,移出后无法恢复,是否继续?
  243. </div>
  244. </Modal>,
  245. <Modal title="导出" confirmText="好的,知道了" btnAlign="center" onConfirm={() => { }}>
  246. <div className="t-2 t-s-18">正在下载中,请不要关闭当前页面!</div>
  247. </Modal>,
  248. <Modal title="导出" confirmText="导出" onConfirm={() => { }} onCancel={() => { }}>
  249. <div className="t-2 t-s-18 m-b-5">
  250. 当前共选中 <span className="t-4">50</span> 道题,请确认需要导出的内容:
  251. </div>
  252. <div className="t-2 t-s-16">
  253. {exportType.map(item => {
  254. return (
  255. <div className="d-i-b m-b-5" style={{ width: 135 }}>
  256. <Checkbox checked className="m-r-5" />
  257. {item.title}
  258. </div>
  259. );
  260. })}
  261. </div>
  262. </Modal>,
  263. <Modal title="导出" confirmText="导出" onConfirm={() => { }} onCancel={() => { }}>
  264. <div className="t-2 t-s-18 m-b-5">
  265. 当前共选中 <span className="t-4">50</span> 道题,请确认需要导出的内容:
  266. </div>
  267. <div className="t-2 t-s-16 m-b-2">
  268. {exportType
  269. .filter(item => !item.auth)
  270. .map(item => {
  271. return (
  272. <div className="d-i-b m-b-2" style={{ width: 135 }}>
  273. <Checkbox checked className="m-r-5" />
  274. {item.title}
  275. </div>
  276. );
  277. })}
  278. </div>
  279. <div className="b-b m-b-2 m-t-2" />
  280. <div className="t-3 m-b-1">
  281. 以下内容需实名认证后才可导出: <a className="f-r">去认证 ></a>
  282. </div>
  283. <div className="t-2 t-s-16 m-b-2">
  284. {exportType
  285. .filter(item => item.auth)
  286. .map(item => {
  287. return (
  288. <div className="d-i-b" style={{ width: 135 }}>
  289. <Checkbox disabled className="m-r-5" />
  290. {item.title}
  291. </div>
  292. );
  293. })}
  294. </div>
  295. </Modal>,
  296. ];
  297. }
  298. }