Applications.js 6.33 KB
Newer Older
偏右's avatar
偏右 committed
1 2 3
import React, { PureComponent } from 'react';
import numeral from 'numeral';
import { connect } from 'dva';
4
import { FormattedMessage } from 'umi/locale';
偏右's avatar
偏右 committed
5
import { Row, Col, Form, Card, Select, Icon, Avatar, List, Tooltip, Dropdown, Menu } from 'antd';
6 7
import TagSelect from '@/components/TagSelect';
import StandardFormRow from '@/components/StandardFormRow';
偏右's avatar
偏右 committed
8

9
import { formatWan } from '@/utils/utils';
偏右's avatar
偏右 committed
10

afc163's avatar
afc163 committed
11
import styles from './Applications.less';
偏右's avatar
偏右 committed
12 13 14 15

const { Option } = Select;
const FormItem = Form.Item;

Andreas Cederström's avatar
Andreas Cederström committed
16 17 18
@connect(({ list, loading }) => ({
  list,
  loading: loading.models.list,
偏右's avatar
偏右 committed
19
}))
20
@Form.create({
afc163's avatar
afc163 committed
21
  onValuesChange({ dispatch }, changedValues, allValues) {
22 23
    // 表单项变化时请求数据
    // eslint-disable-next-line
afc163's avatar
afc163 committed
24
    console.log(changedValues, allValues);
25 26 27 28 29 30 31 32 33
    // 模拟查询表单生效
    dispatch({
      type: 'list/fetch',
      payload: {
        count: 8,
      },
    });
  },
})
afc163's avatar
afc163 committed
34
class FilterCardList extends PureComponent {
偏右's avatar
偏右 committed
35
  componentDidMount() {
陈帅's avatar
陈帅 committed
36 37
    const { dispatch } = this.props;
    dispatch({
偏右's avatar
偏右 committed
38 39 40 41 42 43 44 45
      type: 'list/fetch',
      payload: {
        count: 8,
      },
    });
  }

  render() {
陈帅's avatar
陈帅 committed
46 47 48 49 50
    const {
      list: { list },
      loading,
      form,
    } = this.props;
偏右's avatar
偏右 committed
51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72
    const { getFieldDecorator } = form;

    const CardInfo = ({ activeUser, newUser }) => (
      <div className={styles.cardInfo}>
        <div>
          <p>活跃用户</p>
          <p>{activeUser}</p>
        </div>
        <div>
          <p>新增用户</p>
          <p>{newUser}</p>
        </div>
      </div>
    );

    const formItemLayout = {
      wrapperCol: {
        xs: { span: 24 },
        sm: { span: 16 },
      },
    };

73 74 75 76 77 78 79 80
    const actionsTextMap = {
      expandText: <FormattedMessage id="component.tagSelect.expand" defaultMessage="Expand" />,
      collapseText: (
        <FormattedMessage id="component.tagSelect.collapse" defaultMessage="Collapse" />
      ),
      selectAllText: <FormattedMessage id="component.tagSelect.all" defaultMessage="All" />,
    };

偏右's avatar
偏右 committed
81 82 83
    const itemMenu = (
      <Menu>
        <Menu.Item>
84
          <a target="_blank" rel="noopener noreferrer" href="https://www.alipay.com/">
jim's avatar
jim committed
85 86
            1st menu item
          </a>
偏右's avatar
偏右 committed
87 88
        </Menu.Item>
        <Menu.Item>
89
          <a target="_blank" rel="noopener noreferrer" href="https://www.taobao.com/">
jim's avatar
jim committed
90 91
            2nd menu item
          </a>
偏右's avatar
偏右 committed
92 93
        </Menu.Item>
        <Menu.Item>
94
          <a target="_blank" rel="noopener noreferrer" href="https://www.tmall.com/">
jim's avatar
jim committed
95 96
            3d menu item
          </a>
偏右's avatar
偏右 committed
97 98 99 100 101 102 103 104 105 106 107
        </Menu.Item>
      </Menu>
    );

    return (
      <div className={styles.filterCardList}>
        <Card bordered={false}>
          <Form layout="inline">
            <StandardFormRow title="所属类目" block style={{ paddingBottom: 11 }}>
              <FormItem>
                {getFieldDecorator('category')(
108
                  <TagSelect expandable actionsText={actionsTextMap}>
偏右's avatar
偏右 committed
109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124
                    <TagSelect.Option value="cat1">类目一</TagSelect.Option>
                    <TagSelect.Option value="cat2">类目二</TagSelect.Option>
                    <TagSelect.Option value="cat3">类目三</TagSelect.Option>
                    <TagSelect.Option value="cat4">类目四</TagSelect.Option>
                    <TagSelect.Option value="cat5">类目五</TagSelect.Option>
                    <TagSelect.Option value="cat6">类目六</TagSelect.Option>
                    <TagSelect.Option value="cat7">类目七</TagSelect.Option>
                    <TagSelect.Option value="cat8">类目八</TagSelect.Option>
                    <TagSelect.Option value="cat9">类目九</TagSelect.Option>
                    <TagSelect.Option value="cat10">类目十</TagSelect.Option>
                    <TagSelect.Option value="cat11">类目十一</TagSelect.Option>
                    <TagSelect.Option value="cat12">类目十二</TagSelect.Option>
                  </TagSelect>
                )}
              </FormItem>
            </StandardFormRow>
jim's avatar
jim committed
125
            <StandardFormRow title="其它选项" grid last>
偏右's avatar
偏右 committed
126 127
              <Row gutter={16}>
                <Col lg={8} md={10} sm={10} xs={24}>
jim's avatar
jim committed
128
                  <FormItem {...formItemLayout} label="作者">
偏右's avatar
偏右 committed
129
                    {getFieldDecorator('author', {})(
130
                      <Select placeholder="不限" style={{ maxWidth: 200, width: '100%' }}>
偏右's avatar
偏右 committed
131 132 133 134 135 136
                        <Option value="lisa">王昭君</Option>
                      </Select>
                    )}
                  </FormItem>
                </Col>
                <Col lg={8} md={10} sm={10} xs={24}>
jim's avatar
jim committed
137
                  <FormItem {...formItemLayout} label="好评度">
偏右's avatar
偏右 committed
138
                    {getFieldDecorator('rate', {})(
139
                      <Select placeholder="不限" style={{ maxWidth: 200, width: '100%' }}>
偏右's avatar
偏右 committed
140 141 142 143 144 145 146 147 148 149 150 151 152 153 154 155 156 157 158 159 160 161
                        <Option value="good">优秀</Option>
                        <Option value="normal">普通</Option>
                      </Select>
                    )}
                  </FormItem>
                </Col>
              </Row>
            </StandardFormRow>
          </Form>
        </Card>
        <List
          rowKey="id"
          style={{ marginTop: 24 }}
          grid={{ gutter: 24, xl: 4, lg: 3, md: 3, sm: 2, xs: 1 }}
          loading={loading}
          dataSource={list}
          renderItem={item => (
            <List.Item key={item.id}>
              <Card
                hoverable
                bodyStyle={{ paddingBottom: 20 }}
                actions={[
jim's avatar
jim committed
162 163 164 165 166 167 168 169 170 171 172 173
                  <Tooltip title="下载">
                    <Icon type="download" />
                  </Tooltip>,
                  <Tooltip title="编辑">
                    <Icon type="edit" />
                  </Tooltip>,
                  <Tooltip title="分享">
                    <Icon type="share-alt" />
                  </Tooltip>,
                  <Dropdown overlay={itemMenu}>
                    <Icon type="ellipsis" />
                  </Dropdown>,
偏右's avatar
偏右 committed
174 175
                ]}
              >
jim's avatar
jim committed
176
                <Card.Meta avatar={<Avatar size="small" src={item.avatar} />} title={item.title} />
偏右's avatar
偏右 committed
177 178 179 180 181 182 183 184 185 186 187 188 189 190
                <div className={styles.cardItemContent}>
                  <CardInfo
                    activeUser={formatWan(item.activeUser)}
                    newUser={numeral(item.newUser).format('0,0')}
                  />
                </div>
              </Card>
            </List.Item>
          )}
        />
      </div>
    );
  }
}
lijiehua's avatar
lijiehua committed
191 192

export default FilterCardList;