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

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

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

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

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

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

    const itemMenu = (
      <Menu>
        <Menu.Item>
jim's avatar
jim committed
75 76 77
          <a target="_blank" rel="noopener noreferrer" href="http://www.alipay.com/">
            1st menu item
          </a>
偏右's avatar
偏右 committed
78 79
        </Menu.Item>
        <Menu.Item>
jim's avatar
jim committed
80 81 82
          <a target="_blank" rel="noopener noreferrer" href="http://www.taobao.com/">
            2nd menu item
          </a>
偏右's avatar
偏右 committed
83 84
        </Menu.Item>
        <Menu.Item>
jim's avatar
jim committed
85 86 87
          <a target="_blank" rel="noopener noreferrer" href="http://www.tmall.com/">
            3d menu item
          </a>
偏右's avatar
偏右 committed
88 89 90 91 92 93 94 95 96 97 98
        </Menu.Item>
      </Menu>
    );

    return (
      <div className={styles.filterCardList}>
        <Card bordered={false}>
          <Form layout="inline">
            <StandardFormRow title="所属类目" block style={{ paddingBottom: 11 }}>
              <FormItem>
                {getFieldDecorator('category')(
99
                  <TagSelect expandable>
偏右's avatar
偏右 committed
100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115
                    <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
116
            <StandardFormRow title="其它选项" grid last>
偏右's avatar
偏右 committed
117 118
              <Row gutter={16}>
                <Col lg={8} md={10} sm={10} xs={24}>
jim's avatar
jim committed
119
                  <FormItem {...formItemLayout} label="作者">
偏右's avatar
偏右 committed
120
                    {getFieldDecorator('author', {})(
121
                      <Select placeholder="不限" style={{ maxWidth: 200, width: '100%' }}>
偏右's avatar
偏右 committed
122 123 124 125 126 127
                        <Option value="lisa">王昭君</Option>
                      </Select>
                    )}
                  </FormItem>
                </Col>
                <Col lg={8} md={10} sm={10} xs={24}>
jim's avatar
jim committed
128
                  <FormItem {...formItemLayout} label="好评度">
偏右's avatar
偏右 committed
129
                    {getFieldDecorator('rate', {})(
130
                      <Select placeholder="不限" style={{ maxWidth: 200, width: '100%' }}>
偏右's avatar
偏右 committed
131 132 133 134 135 136 137 138 139 140 141 142 143 144 145 146 147 148 149 150 151 152
                        <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
153 154 155 156 157 158 159 160 161 162 163 164
                  <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
165 166
                ]}
              >
jim's avatar
jim committed
167
                <Card.Meta avatar={<Avatar size="small" src={item.avatar} />} title={item.title} />
偏右's avatar
偏右 committed
168 169 170 171 172 173 174 175 176 177 178 179 180 181
                <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
182 183

export default FilterCardList;