活动详情接口对接

master
pan 5 years ago
parent 08a8a1b020
commit e91f3d26de
  1. 5
      src/interface.ts
  2. 20
      src/result.ts
  3. 42
      src/sub/IndexMenu.tsx
  4. 5
      src/ui/Activity.tsx

@ -2,9 +2,10 @@
const server="http://localhost:8080" const server="http://localhost:8080"
const prefix={ export const prefix={
user:"/api/user", user:"/api/user",
activity:"/api/activity" activity:"/api/activity",
image:"/image/"
} }
//服务器接口地址 //服务器接口地址
export const API={ export const API={

@ -179,4 +179,24 @@ export class FindUserTransform extends TransformData<FindUserMessage, FindUserRe
} }
} }
export enum ActivityDetailMessage {
ok="ok",
fail="fail"
}
export class ActivityDetailRes extends JSONResponse<ActivityDetailMessage>{
activity?:ActivityDetail
}
export class ActivityDetailTransform extends TransformData<ActivityDetailMessage, ActivityDetailRes>{
protected newObject(): ActivityDetailRes {
return new ActivityDetailRes();
}
protected transformBody(data: any) {
this.target.activity=data.body
}
}

@ -1,14 +1,20 @@
import React from "react"; import React from "react";
import {Button, Card, Col, Container, ListGroup, Row} from "react-bootstrap"; import {Button, Card, Col, Container, Image, ListGroup, Row} from "react-bootstrap";
import {Page} from "../ui/Page"; import {Page} from "../ui/Page";
import {ActivityDetail, PageProps} from "../entity"; import {ActivityDetail, PageProps} from "../entity";
import {MyDialog} from "../ui/MyDialog"; import {MyDialog} from "../ui/MyDialog";
import {Activity} from "../ui/Activity"; import {Activity} from "../ui/Activity";
import {Input} from "../ui/InputGroup"; import {Input} from "../ui/InputGroup";
import {activityObj} from "../ui/TestData"; import {API, Method, prefix, request} from "../interface";
import {API, Method, request} from "../interface"; import {
import {FindActivityMessage, FindActivityRes, FindActivityTransform} from "../result"; ActivityDetailMessage,
ActivityDetailRes,
ActivityDetailTransform,
FindActivityMessage,
FindActivityRes,
FindActivityTransform
} from "../result";
/** /**
* *
@ -55,9 +61,23 @@ export class IndexMenu extends React.Component<{ user:string },
* *
* @param activityId * @param activityId
*/ */
loadActivityWithId(activityId:number):ActivityDetail{ loadActivityWithId(activityId:number){
console.debug("activityId="+activityId) console.debug("activityId="+activityId)
return activityObj
let that=this
request(API.main.activity.find+"/"+activityId,Method.GET,{},new ActivityDetailTransform(),function(res:ActivityDetailRes){
switch (res.customResult) {
case ActivityDetailMessage.fail:
that.setState({
result:<h3 className="text-danger text-center"></h3>
});break;
case ActivityDetailMessage.ok:
that.setState({
openActivity:true,
activity:res.activity
});break;
}
})
} }
/** /**
@ -96,7 +116,7 @@ export class IndexMenu extends React.Component<{ user:string },
<Col className="col-4" key={"col"+subIndex}> <Col className="col-4" key={"col"+subIndex}>
<Card> <Card>
<Card.Header> <Card.Header>
<img src={"/image/"+activity.activityImg} alt="活动图片" className="activityImage"/> <Image src={prefix.image+activity.activityImg} className="activityImage"/>
</Card.Header> </Card.Header>
<Card.Body> <Card.Body>
<ListGroup> <ListGroup>
@ -109,10 +129,7 @@ export class IndexMenu extends React.Component<{ user:string },
</ListGroup> </ListGroup>
</Card.Body> </Card.Body>
<Card.Footer> <Card.Footer>
<Button variant={"info"} onClick={()=>this.setState({ <Button variant={"info"} onClick={()=>this.loadActivityWithId(activity.activityId)} className="mr-2"></Button>
activity:this.loadActivityWithId(activity.activityId),
openActivity:true
})} className="mr-2"></Button>
<Button variant="primary" ></Button> <Button variant="primary" ></Button>
</Card.Footer> </Card.Footer>
</Card> </Card>
@ -139,8 +156,7 @@ export class IndexMenu extends React.Component<{ user:string },
open={this.state.openActivity} titleId="view-active" menuName="活动详情" open={this.state.openActivity} titleId="view-active" menuName="活动详情"
onClose={()=>this.setState({activity:undefined,openActivity:false})}/>:null} onClose={()=>this.setState({activity:undefined,openActivity:false})}/>:null}
<MyDialog content={this.state.result} open={this.state.result!==null} titleId="find-activity-tip" menuName="发布求助信息反馈" onClose={()=>this.setState({result:null})}/> <MyDialog content={this.state.result} open={this.state.result!==null} titleId="find-activity-tip" menuName="活动提示" onClose={()=>this.setState({result:null})}/>
</Container> </Container>
) )
} }

@ -2,6 +2,7 @@ import React from "react";
import {Button, Image} from "react-bootstrap"; import {Button, Image} from "react-bootstrap";
import {ActivityDetail} from "../entity"; import {ActivityDetail} from "../entity";
import moment from "moment"; import moment from "moment";
import {prefix} from "../interface";
/** /**
* *
@ -22,7 +23,9 @@ export class Activity extends React.Component<
render() { render() {
return ( return (
<div className="overflow-auto activity-detail-height"> <div className="overflow-auto activity-detail-height">
<Image className="mb-3" src={this.props.activity.activityImg}/> <div className="text-center">
<Image className="mb-3 activityImage" src={prefix.image+this.props.activity.activityImg}/>
</div>
<h3 className="text-center">{this.props.activity.title}</h3> <h3 className="text-center">{this.props.activity.title}</h3>
<p className="p-2">{this.props.activity.content}</p> <p className="p-2">{this.props.activity.content}</p>
<h5 className="text-center">{"活动开始时间:"+moment(this.props.activity.activityStartTime).format("YYYY-MM-DD HH:mm:ss")}</h5> <h5 className="text-center">{"活动开始时间:"+moment(this.props.activity.activityStartTime).format("YYYY-MM-DD HH:mm:ss")}</h5>

Loading…
Cancel
Save