page.js 3.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127
  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 { Order } from '../../../stores/order';
  12. import { DataType } from '../../../../Constant';
  13. import { FAQItem, CommentItem } from '../../../components/Item';
  14. import Icon from '../../../components/Icon';
  15. const DataTypeMap = getMap(DataType, 'value', 'label');
  16. export default class extends Page {
  17. initState() {
  18. return { tab: 'content' };
  19. }
  20. initData() {
  21. const { id } = this.state;
  22. Course.getData(id).then(data => {
  23. this.setState({ data });
  24. });
  25. }
  26. buy() {
  27. Order.speedPay({ productType: 'data', productId: this.params.id });
  28. }
  29. renderText() {
  30. const { tab, data } = this.state;
  31. let content;
  32. switch (tab) {
  33. case 'content':
  34. case 'authorContent':
  35. case 'methodContent':
  36. content = <div dangerouslySetInnerHTML={{ __html: data[tab] }} />;
  37. break;
  38. case 'faq':
  39. content = (
  40. <div>
  41. {(data.faqs || []).map(row => (
  42. <FAQItem data={row} />
  43. ))}
  44. </div>
  45. );
  46. break;
  47. case 'comment':
  48. content = (
  49. <div>
  50. {(data.comments || []).map(row => (
  51. <CommentItem data={row} />
  52. ))}
  53. </div>
  54. );
  55. break;
  56. default:
  57. break;
  58. }
  59. return content;
  60. }
  61. renderView() {
  62. const { data = {}, tab } = this.state;
  63. return (
  64. <div>
  65. <div className="detail">
  66. <Assets className="info-img" name="d_b" src={data.cover} />
  67. <div className="info">
  68. <div className="title">{data.title}</div>
  69. <div className="tags">
  70. {data.isOriginal && <Tag size="small">原创</Tag>}
  71. {data.isNovice && <Tag size="small">适合新手</Tag>}
  72. </div>
  73. <div className="data">页数: {data.page}页</div>
  74. <div className="data">格式: {DataTypeMap[data.dataType]}</div>
  75. <div className="data">{formatDate(data.updateTime, 'YYYY-MM-DD HH:mm')} 更新</div>
  76. <Money value={data.price} size="lager" theme="sell" />
  77. </div>
  78. </div>
  79. <div className="desc" dangerouslySetInnerHTML={{ __html: data.description }} />
  80. <Tabs
  81. page={tab}
  82. tabs={[
  83. { title: '资料介绍', key: 'content' },
  84. { title: '作者介绍', key: 'authorContent' },
  85. { title: '获取方式', key: 'methodContent' },
  86. { title: 'FAQs', key: 'faq' },
  87. { title: '用户评价', key: 'comment' },
  88. ]}
  89. onChange={value => {
  90. this.setState({ tab: value.key });
  91. }}
  92. />
  93. {this.renderText()}
  94. <div className="fixed">
  95. <div className="action">
  96. <div className="minus">
  97. <Icon type="minus" />
  98. </div>
  99. <div className="num">10</div>
  100. <div className="add">
  101. <Icon type="plus" />
  102. </div>
  103. </div>
  104. <div className="fee">
  105. 总额: <Money value={data.price} size="lager" />
  106. </div>
  107. <Button
  108. width={110}
  109. className="f-r"
  110. radius
  111. onClick={() => {
  112. this.buy();
  113. }}
  114. >
  115. 立即购买
  116. </Button>
  117. </div>
  118. </div>
  119. );
  120. }
  121. }