page.js 2.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778
  1. import React from 'react';
  2. import './index.less';
  3. import { Tabs } from 'antd-mobile';
  4. import Page from '@src/containers/Page';
  5. import Assets from '@src/components/Assets';
  6. import { formatDate, getMap } from '@src/services/Tools';
  7. import Money from '../../../components/Money';
  8. import Button from '../../../components/Button';
  9. import Tag from '../../../components/Tag';
  10. import { Course } from '../../../stores/course';
  11. import { DataType } from '../../../../Constant';
  12. const DataTypeMap = getMap(DataType, 'value', 'label');
  13. export default class extends Page {
  14. initState() {
  15. return { tab: 'content' };
  16. }
  17. initData() {
  18. const { id } = this.state;
  19. Course.getData(id)
  20. .then((data) => {
  21. this.setState({ data });
  22. });
  23. }
  24. buy() {
  25. }
  26. renderView() {
  27. const { data = {}, tab } = this.state;
  28. return (
  29. <div>
  30. <div className="detail">
  31. <Assets className="info-img" name="d_b" src={data.cover} />
  32. <div className="info">
  33. <div className="title">{data.title}</div>
  34. <div className="tags">
  35. {data.isOriginal && <Tag size="small">原创</Tag>}
  36. {data.isNovice && <Tag size="small">适合新手</Tag>}
  37. </div>
  38. <div className="data">页数: {data.page}页</div>
  39. <div className="data">格式: {DataTypeMap[data.dataType]}</div>
  40. <div className="data">{formatDate(data.updateTime, 'YYYY-MM-DD HH:mm')} 更新</div>
  41. <Money value={data.price} size="lager" theme="sell" />
  42. </div>
  43. </div>
  44. <div className="desc" dangerouslySetInnerHTML={{ __html: data.description }} />
  45. <Tabs
  46. page={tab}
  47. tabs={[
  48. { title: '资料介绍', key: 'content' },
  49. { title: '作者介绍', key: 'author_content' },
  50. { title: '获取方式', key: 'method_content' },
  51. { title: 'FAQs', key: 'faq' },
  52. { title: '用户评价', key: 'comment' },
  53. ]}
  54. onChange={(value) => {
  55. this.setState({ tab: value.key });
  56. }}
  57. />
  58. <div dangerouslySetInnerHTML={{ __html: data[tab] }} />
  59. <div className="fixed">
  60. <div className="fee">
  61. 总额: <Money value={data.price} size="lager" />
  62. </div>
  63. <Button width={110} className="f-r" radius onClick={() => {
  64. this.buy();
  65. }}>
  66. 立即购买
  67. </Button>
  68. </div>
  69. </div>
  70. );
  71. }
  72. }