Commit ee0b95fa authored by baixian's avatar baixian

微官网新版需求

parent 94c145ba
......@@ -123,6 +123,8 @@ export default {
schoolIntroDel: `${dakaapi}member/website/intro/destroy`,
moduleSort: `${dakaapi}member/website/school/module_sort`,
clockList: `${dakaapi}common/clock`,
ads: `${dakaapi}member/website/ads`,
adsSave: `${dakaapi}member/website/ad/save`,
},
schedule: `${dakaapi}member/erp/schedules`,
scheduleMgt: {
......
......@@ -54,9 +54,6 @@ export default {
{
name: 'adCarousel',
desc: '广告轮播',
}, {
name: 'course',
desc: '体验课',
}, {
name: 'clocklist',
desc: '学员动态',
......@@ -64,6 +61,14 @@ export default {
name: 'orgdesc',
desc: '机构介绍',
},
{
name: 'classmoments',
desc: '课堂瞬间',
},
{
name: 'course',
desc: '体验课',
},
],
pageInfo: [
{
......@@ -85,19 +90,24 @@ export default {
},
},
{
type: 'course',
type: 'clocklist',
data: {
},
},
{
type: 'clocklist',
type: 'orgdesc',
data: {
},
},
{
type: 'orgdesc',
type: 'classmoments',
data: {
},
},
{
type: 'course',
data: {
},
......@@ -110,6 +120,8 @@ export default {
schoolTagValue: '',
adCarousel: [], // 广告轮播
adCarouselStatus: false, // 广告轮播保存状态
classMoment: [], // 课堂瞬间
classMomentStatus: false, // 课堂瞬间保存状态
},
subscriptions: {
setup({ dispatch, history }) { // eslint-disable-line
......@@ -215,6 +227,7 @@ export default {
}
const infoLoad = message.loading('数据加载中...');
let newpageInfo = JSON.parse(JSON.stringify(pageInfo));
console.log(newpageInfo, 'newpageInfo11111111111');
const schoolDetail = yield call(officialwebajax.schoolDetail, { schoolId: sid });
let newCourse = JSON.stringify(course);
let newbannerVideo = bannerVideo;
......@@ -237,8 +250,9 @@ export default {
longitude: orgschoolDetail.data.longitude,
latitude: orgschoolDetail.data.latitude,
location_address: orgschoolDetail.data.location_address + orgschoolDetail.data.address,
address: orgschoolDetail.data.location_address + orgschoolDetail.data.address,
address: orgschoolDetail.data.address,
join_count: 0,
tags: [],
};
element.data = {
id: 0,
......@@ -248,8 +262,9 @@ export default {
longitude: orgschoolDetail.data.longitude,
latitude: orgschoolDetail.data.latitude,
location_address: orgschoolDetail.data.location_address + orgschoolDetail.data.address,
address: orgschoolDetail.data.location_address + orgschoolDetail.data.address,
address: orgschoolDetail.data.address,
join_count: 0,
tags: [],
};
}
if (element.type == 'banner') {
......@@ -267,6 +282,15 @@ export default {
const sortnewpageInfo = [];
try {
moduleSort = JSON.parse(schoolDetail.data.sort);
moduleSort.forEach((item, index) => {
if (item.name.indexOf('adCarousel') == -1) {
moduleSort.push({
name: 'adCarousel',
desc: '广告轮播',
});
}
});
console.log(newpageInfo, 'trynewpageInfo');
for (let i = 0, sLength = moduleSort.length; i < sLength; i++) {
for (let j = 0, blockLength = newpageInfo.length; i < blockLength; j++) {
if (moduleSort[i].name == newpageInfo[j].type) {
......@@ -275,6 +299,8 @@ export default {
}
}
}
console.log(moduleSort, 'moduleSort');
console.log(sortnewpageInfo, 'sortnewpageInfo111111111111111');
yield put({
type: 'updateState',
payload: {
......@@ -289,6 +315,7 @@ export default {
newpageInfo.forEach((ele) => {
const element = ele;
if (element.type == 'schoolinfo') {
schoolDetail.data.tags = JSON.parse(schoolDetail.data.tags);
element.data = schoolDetail.data;
schoolInfo = schoolDetail.data;
}
......@@ -318,8 +345,10 @@ export default {
const courseDetail = yield call(officialwebajax.courseDetail, { schoolId: sid });
if (courseDetail.code == 200) {
if (!courseDetail.data) {
console.log('无数据');
newpageInfo.forEach((ele) => {
const element = ele;
console.log('无数据course', element);
if (element.type == 'course') {
newCourse = {
school_id: 0,
......@@ -340,6 +369,7 @@ export default {
}
});
} else {
console.log('11数据');
newpageInfo.forEach((ele) => {
const element = ele;
newCourse = courseDetail.data;
......@@ -351,6 +381,7 @@ export default {
} else {
message.error(courseDetail.msg, 1);
}
console.log(newpageInfo, 'newpageInfo无数据');
const schoolIntro = yield call(officialwebajax.schoolIntroGet, { school_id: sid, page: 1, perPage: 100 });
let orgdescs = [];
if (schoolIntro.code == 200) {
......@@ -407,6 +438,8 @@ export default {
message.error(schoolIntro.msg, 1);
}
setTimeout(infoLoad);
console.log(newpageInfo, 'newpageInfo11111111111');
console.log(schoolDetail, 'schoolDetail');
yield put({
type: 'updateState',
payload: {
......@@ -418,6 +451,7 @@ export default {
course: newCourse,
orgdescs,
schoolInfo,
schoolTags: schoolDetail && schoolDetail.data ? schoolDetail.data.tags : [],
},
});
},
......@@ -454,7 +488,7 @@ export default {
},
* schoolinfopost({ payload }, { call, put, select }) { // eslint-disable-line
const {
sid, pageInfo, schoolInfo, schoolInfoPostStatus,
sid, pageInfo, schoolInfo, schoolInfoPostStatus, schoolTags,
} = yield select(state => state.officialweb);
const newpageInfo = JSON.parse(JSON.stringify(pageInfo));
const schoolinfopostload = message.loading('数据保存中...');
......@@ -471,17 +505,18 @@ export default {
id: schoolInfo.id,
school_id: sid,
title: schoolInfo.title,
address: schoolInfo.location_address,
address: schoolInfo.address,
location_address: schoolInfo.location_address,
latitude: schoolInfo.latitude,
longitude: schoolInfo.longitude,
join_count: schoolInfo.join_count,
tel_phone: schoolInfo.tel_phone,
visitor_count: schoolInfo.visitor_count,
recommend_count: schoolInfo.recommend_count,
tags: JSON.stringify(schoolTags),
notice: schoolInfo.notice,
});
setTimeout(schoolinfopostload);
if (data.code == 200) {
data.data.tags = JSON.parse(data.data.tags);
Object.assign(schoolInfo, {
id: data.data.id,
});
......@@ -492,14 +527,12 @@ export default {
id: data.data.id,
school_id: sid,
title: schoolInfo.title,
address: schoolInfo.location_address,
address: schoolInfo.address,
location_address: schoolInfo.location_address,
latitude: schoolInfo.latitude,
longitude: schoolInfo.longitude,
join_count: schoolInfo.join_count,
tel_phone: schoolInfo.tel_phone,
visitor_count: schoolInfo.visitor_count,
recommend_count: schoolInfo.recommend_count,
tags: schoolInfo.tags,
};
}
});
......@@ -509,6 +542,7 @@ export default {
schoolInfoPostStatus: false,
pageInfo: newpageInfo,
schoolInfo: { ...schoolInfo },
schoolTags: data.data.tags,
},
});
message.success('保存成功', 1);
......@@ -1180,6 +1214,145 @@ export default {
},
});
},
// 添加轮播广告版块
* handleAdCarouselPlate({ payload }, { call, put, select }) {
const { adCarousel } = yield select(state => state.officialweb);
if (adCarousel.length >= 20) {
message.error('已超出添加上限!', 0.5);
return;
}
adCarousel.push({ cover: '', title: '', location: '' });
yield put({
type: 'updateState',
payload: {
adCarousel: [...adCarousel],
},
});
},
* handleChangeAdText({ payload }, { call, put, select }) {
const { index, key, value } = payload;
const { adCarousel } = yield select(state => state.officialweb);
adCarousel[index][key] = value;
yield put({
type: 'updateState',
payload: {
adCarousel: [...adCarousel],
},
});
},
* deleteAdBanner({ payload }, { call, put, select }) {
const { index } = payload;
const { adCarousel } = yield select(state => state.officialweb);
adCarousel[index].cover = '';
yield put({
type: 'updateState',
payload: {
adCarousel: [...adCarousel],
},
});
},
* deleteAdCarouselPlate({ payload }, { call, put, select }) {
const { index } = payload;
const { adCarousel } = yield select(state => state.officialweb);
adCarousel.splice(index, 1);
yield put({
type: 'updateState',
payload: {
adCarousel: [...adCarousel],
},
});
},
* moveAdCarouselPlate({ payload }, { call, put, select }) {
const { index, direction } = payload;
const { adCarousel } = yield select(state => state.officialweb);
const newPlate = JSON.parse(JSON.stringify(adCarousel));
const currentImg = adCarousel[index];
const preImg = adCarousel[index - 1];
const afterImg = adCarousel[index + 1];
if (direction == 'up') {
newPlate.splice(index - 1, 2, currentImg, preImg);
} else if (direction == 'down') {
newPlate.splice(index, 2, afterImg, currentImg);
}
yield put({
type: 'updateState',
payload: {
adCarousel: newPlate,
},
});
},
* saveAdCarouselPlate({ payload }, { call, put, select }) {
const { adCarousel, adCarouselStatus } = yield select(state => state.officialweb);
const { sid } = yield select(state => state.webapp);
if (adCarousel.length == 0) {
message.error('请先添加内容!', 0.5);
return;
}
if (adCarousel.length > 0) {
let flag = false;
adCarousel.forEach((item, index) => {
if (item.cover == '') {
flag = true;
}
});
if (flag) {
message.error('图片不能为空', 0.5);
return;
}
}
const loading = message.loading('数据保存中...');
if (adCarouselStatus) {
return;
}
yield put({
type: 'updateState',
payload: {
adCarouselStatus: true,
},
});
const data = yield call(officialwebajax.adsSave, {
school_id: sid,
data: JSON.stringify(adCarousel),
});
yield put({
type: 'updateState',
payload: {
adCarouselStatus: false,
},
});
setTimeout(loading);
if (data.code == 200) {
message.success('保存成功', 0.3);
yield put({
type: 'updateState',
payload: {
adCarouselStatus: false,
},
});
} else {
message.error(data.msg, 1);
}
},
// 课堂瞬间
* handleClassMomentPlate({ payload }, { call, put, select }) {
const { type } = payload;
const { classMoment } = yield select(state => state.officialweb);
if (classMoment.length >= 20) {
message.error('已超出添加上限!', 0.5);
return;
}
if (type == 1) {
classMoment.push({ title: '', content: [] });
} else {
classMoment.push({ title: '', content: [] });
}
yield put({
type: 'updateState',
payload: {
classMoment: [...classMoment],
},
});
},
* pageInit({ payload }, { call, put, select }) {
yield put({
type: 'updateState',
......@@ -1223,9 +1396,6 @@ export default {
{
name: 'adCarousel',
desc: '广告轮播',
}, {
name: 'course',
desc: '体验课',
}, {
name: 'clocklist',
desc: '学员动态',
......@@ -1233,6 +1403,14 @@ export default {
name: 'orgdesc',
desc: '机构介绍',
},
{
name: 'classmoments',
desc: '课堂瞬间',
},
{
name: 'course',
desc: '体验课',
},
],
pageInfo: [
{
......@@ -1254,22 +1432,27 @@ export default {
},
},
{
type: 'course',
type: 'clocklist',
data: {
},
},
{
type: 'clocklist',
type: 'orgdesc',
data: {
},
},
{
type: 'orgdesc',
type: 'classmoments',
data: {
},
},
{
type: 'course',
data: {
},
},
],
previewQrcode: '',
previewQrcodeShow: false,
......@@ -1278,6 +1461,8 @@ export default {
schoolTagValue: '',
adCarousel: [], // 广告轮播
adCarouselStatus: false, // 广告轮播保存状态
classMoment: [], // 课堂瞬间
classMomentStatus: false, // 课堂瞬间保存状态
},
});
},
......
......@@ -171,6 +171,7 @@ export default {
});
const {
bannerImg, course, orgdescs,
adCarousel,
} = yield select(state => state.officialweb);
const {
cropperUrl, filename, uploadtype, orgType, orgIndex, imgIndex, action,
......@@ -243,6 +244,14 @@ export default {
goodImage: `${filename}?x-oss-process=${cropperUrl}`,
},
});
} else if (uploadtype == 'uploadAdBanner') {
adCarousel[imgIndex].cover = `${filename}?x-oss-process=${cropperUrl}`;
yield put({
type: 'officialweb/updateState',
payload: {
adCarousel: [...adCarousel],
},
});
}
},
* unloadstates({ payload }, { call, put }) { // 释放该页面存储的所有状态
......
......@@ -14,6 +14,8 @@ import OrgdescEditor from './pagecomponent/OrgdescEditor';
import StudentClock from './pagecomponent/StudentClock';
import AdCarousel from './pagecomponent/AdCarousel';
import AdCarouselEditor from './pagecomponent/AdCarouselEditor';
import ClassMoments from './pagecomponent/ClassMoments';
import ClassMomentsEditor from './pagecomponent/ClassMomentsEditor';
import Cropper from '../../components/Cropper';
class Officialweb extends React.Component {
componentDidMount() { // 挂载
......@@ -201,14 +203,14 @@ class Officialweb extends React.Component {
/>
{dragoverindex == index && <div className={pageStyle.dropendbox}>松开鼠标,模块会放在这里</div>}
</div>
{/* moduleSelect == index &&
<div className={pageStyle.blockOperateBox}>
{index == 0 && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index > 0 && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'up')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index < (newPageInfo.length - 1) && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'down')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
{index == (newPageInfo.length - 1) && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
</div>
*/}
{ moduleSelect == index &&
<div className={pageStyle.blockOperateBox}>
{index == 2 && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index > 2 && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'up')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index < (newPageInfo.length - 1) && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'down')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
{index == (newPageInfo.length - 1) && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
</div>
}
{moduleSelect == index &&
<div className={pageStyle.editbox}>
<AdCarouselEditor banner={ele.data} />
......@@ -217,38 +219,6 @@ class Officialweb extends React.Component {
</div>
);
break;
case 'course':
renderDom = (
<div className={pageStyle.box} key={ele.type}>
<div
className={`${pageStyle.ContentBox} ${index == moduleSelect ? pageStyle.moduleSelect : ''}`}
key={ele.type}
onClick={event => this.moduleSelect(index, event)}
>
<Course
course={ele.data}
showStatus
courseSwitch={this.courseSwitch}
coursePostStatus={coursePostStatus}
/>
{dragoverindex == index && <div className={pageStyle.dropendbox}>松开鼠标,模块会放在这里</div>}
</div>
{/* moduleSelect == index &&
<div className={pageStyle.blockOperateBox}>
{index == 2 && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index > 2 && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'up')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index < (newPageInfo.length - 1) && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'down')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
{index == (newPageInfo.length - 1) && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
</div>
*/}
{/* moduleSelect == index &&
<div className={pageStyle.editbox}>
<CourseEditor />
</div>
*/}
</div>
);
break;
case 'clocklist':
renderDom = (
<div className={pageStyle.box} key={ele.type}>
......@@ -288,8 +258,8 @@ class Officialweb extends React.Component {
</div>
{moduleSelect == index &&
<div className={pageStyle.blockOperateBox}>
{index == 3 && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index > 3 && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'up')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index == 4 && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index > 4 && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'up')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index < (newPageInfo.length - 1) && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'down')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
{index == (newPageInfo.length - 1) && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
</div>
......@@ -302,6 +272,65 @@ class Officialweb extends React.Component {
</div>
);
break;
case 'classmoments':
renderDom = (
<div className={pageStyle.box} key={ele.type}>
<div
className={`${pageStyle.ContentBox} ${index == moduleSelect ? pageStyle.moduleSelect : ''}`}
key={ele.type}
onClick={event => this.moduleSelect(index, event)}
>
<ClassMoments />
{dragoverindex == index && <div className={pageStyle.dropendbox}>松开鼠标,模块会放在这里</div>}
</div>
{moduleSelect == index &&
<div className={pageStyle.blockOperateBox}>
{index == 5 && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index > 5 && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'up')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index < (newPageInfo.length - 1) && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'down')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
{index == (newPageInfo.length - 1) && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
</div>
}
{moduleSelect == index &&
<div className={pageStyle.editbox}>
<ClassMomentsEditor />
</div>
}
</div>
);
break;
case 'course':
renderDom = (
<div className={pageStyle.box} key={ele.type}>
<div
className={`${pageStyle.ContentBox} ${index == moduleSelect ? pageStyle.moduleSelect : ''}`}
key={ele.type}
onClick={event => this.moduleSelect(index, event)}
>
<Course
course={ele.data}
showStatus
courseSwitch={this.courseSwitch}
coursePostStatus={coursePostStatus}
/>
{dragoverindex == index && <div className={pageStyle.dropendbox}>松开鼠标,模块会放在这里</div>}
</div>
{/* moduleSelect == index &&
<div className={pageStyle.blockOperateBox}>
{index == 2 && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index > 2 && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'up')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-up" /></div>}
{index < (newPageInfo.length - 1) && <div className={pageStyle.blockOperateItem} onClick={() => this.pageBlockMove(index, 'down')}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
{index == (newPageInfo.length - 1) && <div className={`${pageStyle.blockOperateItem} ${pageStyle.blockOperateItemGrey}`}><Icon className={pageStyle.blockOperateItemIcon} type="arrow-down" /></div>}
</div>
*/}
{/* moduleSelect == index &&
<div className={pageStyle.editbox}>
<CourseEditor />
</div>
*/}
</div>
);
break;
default:
break;
}
......
......@@ -14,6 +14,7 @@ import OrgdescEditor from './pagecomponent/OrgdescEditor';
import StudentClock from './pagecomponent/StudentClock';
import BtnPermission from '../../components/BtnPermission';
import AdCarousel from './pagecomponent/AdCarousel';
import ClassMoments from './pagecomponent/ClassMoments';
import Cropper from '../../components/Cropper';
class Officialweb extends React.Component {
componentDidMount() { // 挂载
......@@ -153,20 +154,6 @@ class Officialweb extends React.Component {
</div>
);
break;
case 'course':
renderDom = (ele.data.switch == 1 &&
<div className={pageStyle.box} key={ele.type}>
<div
className={`${pageStyle.ContentBox}`}
key={ele.type}
>
<Course
course={ele.data}
/>
</div>
</div>
);
break;
case 'clocklist':
renderDom = (
<div className={pageStyle.box} key={ele.type}>
......@@ -181,6 +168,20 @@ class Officialweb extends React.Component {
</div>
);
break;
case 'classmoments':
renderDom = (
<div className={pageStyle.box} key={ele.type}>
<div
className={`${pageStyle.ContentBox}`}
key={ele.type}
>
<ClassMoments
banner={ele.data}
/>
</div>
</div>
);
break;
case 'orgdesc':
renderDom = (
<div className={pageStyle.box} key={ele.type}>
......@@ -195,6 +196,20 @@ class Officialweb extends React.Component {
</div>
);
break;
case 'course':
renderDom = (ele.data.switch == 1 &&
<div className={pageStyle.box} key={ele.type}>
<div
className={`${pageStyle.ContentBox}`}
key={ele.type}
>
<Course
course={ele.data}
/>
</div>
</div>
);
break;
default:
break;
}
......
......@@ -12,7 +12,7 @@
height: auto;
background:#fff;
box-shadow:0px 0px 13px 0px rgba(0, 0, 0, 0.1);
padding-top: 75px;
padding-top: 25px;
position: relative;
padding-bottom: 80px;
}
......
......@@ -17,7 +17,7 @@ class adCarousel extends React.Component {
const { banner } = this.props;
return (
<div className={PageStyle.Bannercontainer}>
1111
广告轮播
</div>
);
}
......
import React from 'react';
import { connect } from 'dva';
import { Form, Layout, Input, Button, Icon } from 'antd';
import { Form, Layout, Input, Button, Icon, DatePicker, Modal, Popconfirm } from 'antd';
import { videoPoster, imagify } from '../../../utils/index';
import PageStyle from './AdCarouselEditor.less';
const FormItem = Form.Item;
......@@ -55,70 +55,189 @@ class AdCarouselEditor extends React.Component {
},
});
}
uploadBannerVideo = (e) => {
delvideo = () => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/delvideo',
});
}
handleSubmit = (e) => {
const { dispatch } = this.props;
e.preventDefault();
dispatch({
type: 'officialweb/bannersave',
});
}
delbannerimg = (index) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/queryvideosignature',
type: 'officialweb/delbannerimg',
payload: {
files: e.target,
uploadtype: 'banner',
index,
},
});
}
movebannerimg = (index, direction) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/movebannerimg',
payload: {
index,
direction,
},
});
}
uploadImg = (e) => {
handleAdCarouselPlate = () => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/handleAdCarouselPlate',
});
setTimeout(() => {
const element = document.getElementById('listbox');
element.scrollTop = element.scrollHeight;
}, 200);
}
uploadAdBanner = (e, index) => {
const { dispatch } = this.props;
const { avatorUploader } = this.state;
dispatch({
type: 'uploader/queryimgsignature',
payload: {
files: e.target,
uploadtype: 'banner',
uploadtype: 'uploadAdBanner',
avatorUploader,
imgIndex: index,
},
});
}
delvideo = () => {
handleChangeAdText = (e, index, key) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/delvideo',
type: 'officialweb/handleChangeAdText',
payload: {
value: e.target.value,
index,
key,
},
});
}
handleSubmit = (e) => {
deleteAdBanner = (index) => {
const { dispatch } = this.props;
e.preventDefault();
dispatch({
type: 'officialweb/bannersave',
type: 'officialweb/deleteAdBanner',
payload: {
index,
},
});
}
delbannerimg = (index) => {
deleteAdCarouselPlate = (index) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/delbannerimg',
type: 'officialweb/deleteAdCarouselPlate',
payload: {
index,
},
});
}
movebannerimg = (index, direction) => {
moveAdCarouselPlate = (index, direction) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/movebannerimg',
type: 'officialweb/moveAdCarouselPlate',
payload: {
index,
direction,
},
});
}
saveAdCarouselPlate = () => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/saveAdCarouselPlate',
payload: {
},
});
}
render() {
const {
bannerType, banner, bannerVideo, bannerImg, bannerPostStatus,
adCarousel,
adCarouselStatus,
} = this.props;
const formItemLayout = {
labelCol: {
xs: { span: 4 },
sm: { span: 4 },
},
wrapperCol: {
xs: { span: 20 },
sm: { span: 20 },
},
};
return (
<div className={`${PageStyle.SchoolInfoEditorcontainer} SchoolInfoEditorcontainer`}>
<div className={PageStyle.header}>品牌视频/轮播</div>
<Form className={PageStyle.FormBox} onSubmit={this.handleSubmit}>
111
</Form>
<div className={PageStyle.header}>广告轮播</div>
<div className={PageStyle.FormBox} id="listbox">
{
adCarousel.length > 0 && adCarousel.map((item, index) => {
return (
<div className={PageStyle.formItem}>
<div className={PageStyle.formLeft}>
{index == 0 && <div className={`${PageStyle.formItemIcon} ${PageStyle.formItemIconGray}`}><Icon className={PageStyle.itemIcon} type="arrow-up" /></div>}
{ index > 0 && <div className={PageStyle.formItemIcon} onClick={() => this.moveAdCarouselPlate(index, 'up')}><Icon className={PageStyle.itemIcon} type="arrow-up" /></div> }
{index == (adCarousel.length - 1) && <div className={`${PageStyle.formItemIcon} ${PageStyle.formItemIconGray}`}><Icon className={PageStyle.itemIcon} type="arrow-down" /></div>}
{index < (adCarousel.length - 1) && <div className={PageStyle.formItemIcon} onClick={() => this.moveAdCarouselPlate(index, 'down')}><Icon className={PageStyle.itemIcon} type="arrow-down" /></div>}
<Popconfirm
placement="topLeft"
title="确定删除?"
okText="确定"
cancelText="取消"
onConfirm={() => this.deleteAdCarouselPlate(index)}
>
<div className={PageStyle.formItemIcon}><Icon className={PageStyle.itemIcon} type="delete" /></div>
</Popconfirm>
</div>
<div className={PageStyle.formRight}>
<div className={PageStyle.formRightImg}>
{
item.cover ?
<React.Fragment>
<img src={imagify(item.cover)} alt="图片" />
<div className={PageStyle.closeAdIcon} onClick={() => this.deleteAdBanner(index)}>
<Icon type="close" />
</div>
</React.Fragment> :
<React.Fragment>
<input
type="file"
className={PageStyle.uploadInput}
accept="image/png, image/jpeg"
id="upload1"
onChange={(e) => { this.uploadAdBanner(e, index); }}
/>添加图
</React.Fragment>
}
</div>
<div className={PageStyle.formRightItem}>
<FormItem {...formItemLayout} label="标题">
<Input value={item.title} onChange={e => this.handleChangeAdText(e, index, 'title')} placeholder="请输入标题" />
<span className="ant-form-text">此标题不在页面显示</span>
</FormItem>
<FormItem {...formItemLayout} label="跳转地址">
<Input value={item.location} onChange={e => this.handleChangeAdText(e, index, 'location')} placeholder="请输入跳转地址" />
<span className="ant-form-text">若不配地址,则为静态广告无跳转</span>
</FormItem>
</div>
</div>
</div>
);
})
}
</div>
<div className={PageStyle.addPlate} onClick={this.handleAdCarouselPlate}>
继续添加({adCarousel.length}/20
</div>
<div className={PageStyle.btnbox}>
<Button type="primary" htmlType="submit" className={PageStyle.SubmitBtn} loading={adCarouselStatus} onClick={this.saveAdCarouselPlate}>{adCarouselStatus ? '保存中...' : '保存'}</Button>
</div>
</div>
);
}
......@@ -128,16 +247,12 @@ AdCarouselEditor.propTypes = {
};
function mapStateToProps(state) {
const {
bannerType,
bannerVideo,
bannerImg,
bannerPostStatus,
adCarousel,
adCarouselStatus,
} = state.officialweb;
return {
bannerType,
bannerVideo,
bannerImg,
bannerPostStatus,
adCarousel,
adCarouselStatus,
};
}
export default connect(mapStateToProps)(AdCarouselEditor);
......@@ -13,6 +13,94 @@
}
.FormBox {
padding-top: 30px;
padding-bottom: 30px;
max-height: 400px;
overflow-y: scroll;
.formItem {
display: flex;
margin-bottom: 15px;
}
.formLeft {
height: 104px;
width: 41px;
border-radius: 10px;
background-color: #fff;
margin-right: 24px;
display: flex;
flex-direction: column;
overflow: hidden;
margin-left: 12px;
.formItemIcon {
flex: 1;
text-align: center;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
&:hover {
background-color: #19B5FE;
.itemIcon {
color: #fff;
}
}
&.formItemIconGray {
color: #E5E5E5;
&:hover {
cursor: no-drop;
background-color: #fff;
}
}
}
}
.formRight {
display: flex;
align-items: center;
width: 524px;
border: 1px solid #979797;
background-color: #fff;
padding: 15px 10px;
border-radius:5px;
.formRightItem {
width: 350px;
}
.formRightImg {
width: 128px;
height: 128px;
position: relative;
border: 1px solid #979797;
margin-right: 15px;
line-height: 128px;
color: #0091FF;
text-align: center;
font-size: 14px;
.uploadInput {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
opacity: 0;
z-index: 5;
}
.closeAdIcon {
width: 30px;
height: 30px;
position: absolute;
right: 0;
top: 0;
color: #fff;
font-size: 20px;
cursor: pointer;
background-color: rgba(0,0,0,0.8);
line-height: 30px;
}
&>img {
width: 100%;
height: 100%;
display: block;
}
}
}
}
.FormItemClass {
padding-left: 30px;
......@@ -20,191 +108,60 @@
display: flex;
align-items: center;
}
.FormItemInputClass {
// height: 46px;
// line-height: 46px;
}
.divideLine {
border-bottom: 1px solid rgba(0,0,0,0.05);
}
.btnbox {
text-align: right;
padding: 14px 35px 12px 0;
}
.SubmitBtn {
// background-color: #ECECEC;
// width: 70px;
height: 34px;
line-height: 34px;
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
height: 34px;
line-height: 34px;
&:hover {
.SubmitBtn {
height: 34px;
line-height: 34px;
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
&:active {
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
&:focus {
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
}
.operatebox {
padding: 24px 0 20px 30px;
}
.fileuploadbox {
width: 104px;
height: 104px;
position: relative;
background-color: #FFFFFF;
border-radius: 7px;
cursor: pointer;
border: 1px solid rgba(236,236,236,1);
}
.fileuploadinput{
// height: 32px;
width: 100%;
height: 100%;
opacity: 0;
z-index: 3;
position: absolute;
cursor: pointer;
}
.fileuploadlayer{
width: 100%;
height: 100%;
z-index: 2;
position: absolute;
line-height: 1;
display: flex;
align-items: center;
justify-content: center;
flex-direction: column;
text-align: center;
color: #19B5FE;
font-size: 14px;
cursor: pointer;
}
.uploadcount {
color: #A5A5A5;
font-size: 14px;
line-height: 1;
margin-top: 17px;
}
.selfradiabox {
display: flex;
align-items: center;
justify-content: space-around;
}
.selfradiaitem {
display: flex;
align-items: center;
cursor: pointer;
}
.selfradia {
width: 20px;
height: 20px;
border-radius: 50%;
border: 2px solid #9A9A9A;
}
.selfradiaitemactive {
.selfradia {
border: 6px solid #19B5FE;
}
}
.radianame {
color: #000;
font-size: 14px;
padding-left: 9px;
}
.operateitembox {
display: flex;
margin-bottom: 10px;
}
.imgbox {
width: 104px;
height: 104px;
border-radius: 10px;
overflow: hidden;
margin-right: 12px;
position: relative;
}
.img {
width: 104px;
height: 104px;
display: block;
}
.imgoperatebox {
height: 104px;
width: 41px;
border-radius: 10px;
background-color: #fff;
margin-right: 24px;
display: flex;
flex-direction: column;
overflow: hidden;
}
.blockOperateItem {
flex: 1;
text-align: center;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
&:hover {
background-color: #19B5FE;
.blockOperateItemIcon {
color: #fff;
}
}
&.blockOperateItemGrey {
color: #E5E5E5;
&:hover {
cursor: no-drop;
background-color: #fff;
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
&:active {
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
&:focus {
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
}
}
.imgbox:hover {
.imgdelandupdate {
bottom: 0;
}
}
.imgdelandupdate {
position: absolute;
bottom: -30px;
left: 0;
height: 30px;
background-color: rgba(0,0,0,0.5);
width: 100%;
color: #fff;
padding: 8px 0;
display: flex;
align-items: center;
line-height: 1;
font-size: 14px;
cursor: pointer;
transition: bottom 0.2s;
}
.imgdel {
border-right: 1px solid #fff;
flex: 1;
text-align: center;
}
.imgupdate {
flex: 1;
.addPlate {
width: 524px;
height: 54px;
line-height: 54px;
text-align: center;
font-size:14px;
font-family:PingFangSC-Regular,PingFang SC;
font-weight:400;
color:rgba(0,145,255,1);
margin: 20px auto 0;
background-color: #fff;
border:1px dashed rgba(151,151,151,1);
margin-left: 75px;
}
::-webkit-scrollbar {
width: 8px;
height: 10px;
background-color: rgba(0,0,0,0);
}
::-webkit-scrollbar-thumb {
border-radius: 6px;
background-color: rgba(0,0,0,.2);
transition: all .4s ease;
-moz-transition: all .4s ease;
-webkit-transition: all .4s ease;
-o-transition: all .4s ease;
}
import React from 'react';
import { connect } from 'dva';
import { Carousel, Icon } from 'antd';
import PageStyle from './ClassMoments.less';
import { ossVideofy, imagify, videoPoster } from '../../../utils/index';
class ClassMoments extends React.Component {
constructor(props) {
super(props);
this.state = {
};
}
componentWillMount() {
}
componentWillUnmount() {
}
render() {
const { banner } = this.props;
return (
<div className={PageStyle.Bannercontainer}>
课堂瞬间
</div>
);
}
}
ClassMoments.propTypes = {
};
function mapStateToProps(state) {
const {
menus, defaultMenu, collapsed,
} = state.webapp;
return {
menus,
defaultMenu,
collapsed,
};
}
export default connect(mapStateToProps)(ClassMoments);
import React from 'react';
import { connect } from 'dva';
import { Form, Layout, Input, Button, Icon, DatePicker, Modal, Popconfirm } from 'antd';
import { videoPoster, imagify } from '../../../utils/index';
import PageStyle from './ClassMomentsEditor.less';
const FormItem = Form.Item;
const { Sider } = Layout;
class ClassMomentsEditor extends React.Component {
constructor(props) {
super(props);
this.state = {
avatorUploader: {
maxsize: 8192, // 奖品图片最大尺寸KBcropper: {
cropper: {
croppered_params: [], // 图片裁剪后的参数
config: {
dragMode: 'move',
viewMode: 1,
aspectRatio: 0.875,
autoCropArea: 0.8,
guides: !1,
center: !0,
highlight: !1,
dragCrop: !1,
cropBoxMovable: !1,
cropBoxResizable: !1,
zoom: -0.2,
checkImageOrigin: !0,
background: !1,
rotatable: !0,
},
},
},
};
}
componentWillMount() {
}
componentWillUnmount() {
}
uploadAvator = (e) => {
}
selectedMenu = (key) => {
const { dispatch } = this.props;
dispatch({
type: 'webapp/menuselected',
payload: key,
});
}
bannerTypeChoose = (type) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/bannertypechoose',
payload: {
type,
},
});
}
delvideo = () => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/delvideo',
});
}
handleSubmit = (e) => {
const { dispatch } = this.props;
e.preventDefault();
dispatch({
type: 'officialweb/bannersave',
});
}
delbannerimg = (index) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/delbannerimg',
payload: {
index,
},
});
}
movebannerimg = (index, direction) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/movebannerimg',
payload: {
index,
direction,
},
});
}
handleClassMomentPlate = (type) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/handleClassMomentPlate',
payload: {
type,
},
});
setTimeout(() => {
const element = document.getElementById('listbox');
element.scrollTop = element.scrollHeight;
}, 200);
}
uploadAdBanner = (e, index) => {
const { dispatch } = this.props;
const { avatorUploader } = this.state;
dispatch({
type: 'uploader/queryimgsignature',
payload: {
files: e.target,
uploadtype: 'uploadAdBanner',
avatorUploader,
imgIndex: index,
},
});
}
handleChangeAdText = (e, index, key) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/handleChangeAdText',
payload: {
value: e.target.value,
index,
key,
},
});
}
deleteAdBanner = (index) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/deleteAdBanner',
payload: {
index,
},
});
}
deleteAdCarouselPlate = (index) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/deleteAdCarouselPlate',
payload: {
index,
},
});
}
moveAdCarouselPlate = (index, direction) => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/moveAdCarouselPlate',
payload: {
index,
direction,
},
});
}
saveAdCarouselPlate = () => {
const { dispatch } = this.props;
dispatch({
type: 'officialweb/saveAdCarouselPlate',
payload: {
},
});
}
render() {
const {
classMoment,
classMomentStatus,
} = this.props;
const formItemLayout = {
labelCol: {
xs: { span: 4 },
sm: { span: 4 },
},
wrapperCol: {
xs: { span: 20 },
sm: { span: 20 },
},
};
return (
<div className={`${PageStyle.SchoolInfoEditorcontainer} SchoolInfoEditorcontainer`}>
<div className={PageStyle.header}><span>课堂瞬间 </span><p>支持上传图片或视频,前四个视频/图片将在微官网首页【课堂瞬间】展示</p></div>
<div className={PageStyle.FormBox} id="listbox">
{
classMoment.length > 0 && classMoment.map((item, index) => {
return (
<div className={PageStyle.formItem}>
<div className={PageStyle.formLeft}>
{index == 0 && <div className={`${PageStyle.formItemIcon} ${PageStyle.formItemIconGray}`}><Icon className={PageStyle.itemIcon} type="arrow-up" /></div>}
{ index > 0 && <div className={PageStyle.formItemIcon} onClick={() => this.moveAdCarouselPlate(index, 'up')}><Icon className={PageStyle.itemIcon} type="arrow-up" /></div> }
{index == (classMoment.length - 1) && <div className={`${PageStyle.formItemIcon} ${PageStyle.formItemIconGray}`}><Icon className={PageStyle.itemIcon} type="arrow-down" /></div>}
{index < (classMoment.length - 1) && <div className={PageStyle.formItemIcon} onClick={() => this.moveAdCarouselPlate(index, 'down')}><Icon className={PageStyle.itemIcon} type="arrow-down" /></div>}
<Popconfirm
placement="topLeft"
title="确定删除?"
okText="确定"
cancelText="取消"
onConfirm={() => this.deleteAdCarouselPlate(index)}
>
<div className={PageStyle.formItemIcon}><Icon className={PageStyle.itemIcon} type="delete" /></div>
</Popconfirm>
</div>
<div className={PageStyle.formRight}>
<div className={PageStyle.formRightImg}>
{
item.content.length > 0 && item.content.map((ele, i) => {
return (
<div className={PageStyle.imgList}>
<div className={PageStyle.imgItem}>
<img src={imagify(ele.value)} alt="图片" />
<div className={PageStyle.closeAdIcon} onClick={() => this.deleteAdBanner(index)}>
<Icon type="close" />
</div>
</div>
</div>
);
})
}
{
item.content.length <= 4 &&
<React.Fragment>
<input
type="file"
className={PageStyle.uploadInput}
accept="image/png, image/jpeg"
id="upload1"
onChange={(e) => { this.uploadAdBanner(e, index); }}
/>
<span>点击上传({item.content.length}/4)</span>
</React.Fragment>
}
</div>
<div className={PageStyle.formRightItem}>
<FormItem {...formItemLayout} label="标题">
<Input value={item.title} onChange={e => this.handleChangeAdText(e, index, 'title')} placeholder="请输入课堂瞬间标题" />
</FormItem>
</div>
</div>
</div>
);
})
}
</div>
<div className={PageStyle.addPlate} >
发布课堂瞬间({classMoment.length}/20
<div className={PageStyle.AddFloatbox}>
<div className={`${PageStyle.AddItem} ${PageStyle.AddVideoItem}`} onClick={() => this.handleClassMomentPlate(1)}>添加视频</div>
<div className={`${PageStyle.AddItem} ${PageStyle.AddImgItem}`} onClick={() => this.handleClassMomentPlate(2)}>添加图片</div>
</div>
</div>
<div className={PageStyle.btnbox}>
<Button type="primary" htmlType="submit" className={PageStyle.SubmitBtn} loading={classMomentStatus} onClick={this.saveAdCarouselPlate}>{classMomentStatus ? '保存中...' : '保存'}</Button>
</div>
</div>
);
}
}
ClassMomentsEditor.propTypes = {
};
function mapStateToProps(state) {
const {
classMoment,
classMomentStatus,
} = state.officialweb;
return {
classMoment,
classMomentStatus,
};
}
export default connect(mapStateToProps)(ClassMomentsEditor);
@import '../../../less/variables.less';
@images: '@{imagesroot}/webapp/';
.SchoolInfoEditorcontainer {
}
.header {
color: #000;
font-size: 14px;
&>span {
font-weight: 700;
line-height: 50px;
}
padding-left: 20px;
border-bottom: 1px solid rgba(0,0,0,0.05);
}
.FormBox {
padding-top: 30px;
padding-bottom: 30px;
max-height: 400px;
overflow-y: scroll;
.formItem {
display: flex;
margin-bottom: 15px;
}
.formLeft {
height: 104px;
width: 41px;
border-radius: 10px;
background-color: #fff;
margin-right: 24px;
display: flex;
flex-direction: column;
overflow: hidden;
margin-left: 12px;
.formItemIcon {
flex: 1;
text-align: center;
display: flex;
align-items: center;
justify-content: center;
cursor: pointer;
&:hover {
background-color: #19B5FE;
.itemIcon {
color: #fff;
}
}
&.formItemIconGray {
color: #E5E5E5;
&:hover {
cursor: no-drop;
background-color: #fff;
}
}
}
}
.formRight {
//display: flex;
//align-items: center;
width: 524px;
border: 1px solid #979797;
background-color: #fff;
padding: 15px 10px;
border-radius:5px;
.formRightItem {
width: 350px;
}
.formRightImg {
width: 86px;
height: 86px;
position: relative;
border: 1px solid #979797;
margin-right: 15px;
display: flex;
align-items: center;
justify-content: center;
color: #0091FF;
text-align: center;
font-size: 14px;
.imgList {
width: 100%;
height: 100%;
margin-right: 10px;
.imgItem {
width: 100%;
height: 100%;
display: block;
}
}
.uploadInput {
position: absolute;
width: 100%;
height: 100%;
left: 0;
top: 0;
opacity: 0;
z-index: 5;
}
.closeAdIcon {
width: 30px;
height: 30px;
position: absolute;
right: 0;
top: 0;
color: #fff;
font-size: 20px;
cursor: pointer;
background-color: rgba(0,0,0,0.8);
line-height: 30px;
}
&>img {
width: 100%;
height: 100%;
display: block;
}
}
}
}
.FormItemClass {
padding-left: 30px;
margin-bottom: 8px;
display: flex;
align-items: center;
}
.btnbox {
text-align: right;
padding: 14px 35px 12px 0;
.SubmitBtn {
height: 34px;
line-height: 34px;
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
&:hover {
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
&:active {
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
&:focus {
background-color: #FFFFFF;
color: #000000;
font-size: 14px;
border: 1px solid #ECECEC;
}
}
}
.addPlate {
width: 524px;
height: 54px;
line-height: 54px;
text-align: center;
font-size:14px;
font-family:PingFangSC-Regular,PingFang SC;
font-weight:400;
color:rgba(0,145,255,1);
margin: 20px auto 0;
background-color: #fff;
border:1px dashed rgba(151,151,151,1);
margin-left: 75px;
&:hover {
.AddFloatbox {
display: block;
}
}
.AddFloatbox {
border-radius: 4px;
width: 152px;
height: 88px;
background-color: #fff;
box-shadow:0px 2px 10px 0px rgba(0, 0, 0, 0.14);
position: absolute;
left: 50%;
top: 75%;
display: none;
}
.AddVideoItem {
border-bottom: 1px solid rgba(0,0,0,0.05);
}
.AddItem {
line-height: 44px;
text-align: center;
font-size: 14px;
color: #000000;
cursor: pointer;
&:hover {
color: #19B5FE;
}
}
}
::-webkit-scrollbar {
width: 8px;
height: 10px;
background-color: rgba(0,0,0,0);
}
::-webkit-scrollbar-thumb {
border-radius: 6px;
background-color: rgba(0,0,0,.2);
transition: all .4s ease;
-moz-transition: all .4s ease;
-webkit-transition: all .4s ease;
-o-transition: all .4s ease;
}
import React from 'react';
import { connect } from 'dva';
import { Menu, Icon, Layout } from 'antd';
import { Menu, Icon, Layout, Tag } from 'antd';
import PageStyle from './SchoolInfo.less';
const { Sider } = Layout;
function SchoolInfo(props) {
const { schoolinfo } = props;
console.log(schoolinfo, 'schoolinfo');
return (
<div className={PageStyle.SchoolInfocontainer}>
<div className={PageStyle.schoolinfo}>
<div className={PageStyle.schoolname}>
<div className={PageStyle.name}>{schoolinfo.title || ''}</div>
<div className={PageStyle.wantlearnstatic}>{schoolinfo.join_count || 0}人想学</div>
<div className={PageStyle.wantlearnstatic}>
{schoolinfo.tags && schoolinfo.tags.length > 0 && schoolinfo.tags.map((item, index) => {
return (<span>{index < 4 && <Tag>{item}</Tag>} {index > 4 && '...'}</span>);
})}
</div>
</div>
<div className={PageStyle.shareiconbox}>
<img className={PageStyle.shareicon} src={`${__IMGCDN__}shareicon.png`} alt="" />
</div>
</div>
{
schoolinfo.notice &&
<div className={PageStyle.soundBox}>
<Icon type="sound" />&nbsp;&nbsp;&nbsp;{schoolinfo.notice}
</div>
}
<div className={PageStyle.schoolocationbox}>
<img src={`${__IMGCDN__}locationicon.png`} className={PageStyle.locationicon} alt="" />
<span className={PageStyle.schoolocation}>{schoolinfo.location_address || ''}</span>
</div>
<p><span className={PageStyle.shareicon} style={{ display: 'inline-block' }}></span><span className={PageStyle.schooladdress}>{schoolinfo.address}</span></p>
<div className={PageStyle.schoolocationbox}>
<img src={`${__IMGCDN__}locationicon.png`} className={PageStyle.locationicon} alt="" />
<span className={PageStyle.schoolocation}>{schoolinfo.tel_phone || ''}</span>
</div>
</div>
);
}
......
......@@ -29,10 +29,10 @@
}
.name {
font-size: 15px;
font-size: 18px;
color: #000000;
font-weight:500;
line-height: 1;
font-weight:600;
line-height: 1.3;
max-width: 200px;
overflow: hidden;
text-overflow: ellipsis;
......@@ -40,17 +40,12 @@
margin-bottom: 5px;
}
.wantlearnstatic {
height:15px;
background:rgba(255,209,70,0.1);
border-radius:8px;
font-size:11px;
font-family:PingFang-SC-Regular;
font-weight:400;
color:rgba(255,180,0,1);
line-height:15px;
text-align: center;
padding: 0 10px;
display: inline-block;
width: 80%;
:global {
.ant-tag {
margin-bottom: 10px;
}
}
}
.schoolocationbox {
display: flex;
......@@ -63,6 +58,21 @@
margin-right: 11px;
}
.schoolocation {
color: #888888;
font-size: 11px;
color: #000000;
font-size: 14px;
font-weight: 600;
}
.schooladdress {
color: #000000;
font-size: 14px;
}
.soundBox {
background:rgba(247,181,0,0.24);
height: 22px;
font-size: 12px;
color:rgba(0,0,0,0.65);
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
margin-bottom: 10px;
}
......@@ -142,6 +142,7 @@ class SchoolInfoEditorForm extends React.Component {
labelCol: { span: 6 },
wrapperCol: { span: 18 },
};
console.log(schoolTags, 'schoolTags');
return (
<div className={`${PageStyle.SchoolInfoEditorcontainer} SchoolInfoEditorcontainer`}>
<div className={PageStyle.header}>机构信息</div>
......@@ -162,7 +163,7 @@ class SchoolInfoEditorForm extends React.Component {
</Form.Item>
<Form.Item label="特色标签" colon={false} className={PageStyle.FormItemClass} {...formItemLayout}>
<div>
{schoolTags.map((tag, index) => {
{schoolTags.length > 0 && schoolTags.map((tag, index) => {
const isLongTag = tag.length > 20;
const tagElem = (
<Tag key={tag} closable onClose={() => this.handleClose(tag)}>
......@@ -227,13 +228,13 @@ class SchoolInfoEditorForm extends React.Component {
{/* <span style={{ display: 'block' }}>展示在微官网主页效果为:(例)888人访问过</span> */}
{/* </Form.Item> */}
<Form.Item label="通知栏" colon={false} className={PageStyle.FormItemClass} {...formItemLayout}>
{getFieldDecorator('title', {
initialValue: schoolInfo.title || '',
{getFieldDecorator('notice', {
initialValue: schoolInfo.notice || '',
rules: [
{ max: 100, message: '通知栏字数不能超过100字!' },
{ max: 500, message: '通知栏字数不能超过500字!' },
],
})(
<Input onChange={e => this.schoolInfoChange(e, 'title')} className={PageStyle.FormItemInputClass} placeholder="请输入通知信息" />)}
<Input onChange={e => this.schoolInfoChange(e, 'notice')} className={PageStyle.FormItemInputClass} placeholder="请输入通知信息" />)}
<span className="ant-form-text">若通知栏信息为空,则不展示通知栏</span>
</Form.Item>
<Form.Item label="位置" className={PageStyle.FormItemClass} colon={false} {...formItemLayout}>
......@@ -242,13 +243,13 @@ class SchoolInfoEditorForm extends React.Component {
{/* <Input className={PageStyle.FormItemInputClass} placeholder="输入机构地址" disabled onClick={this.selectaddress} /> */}
</Form.Item>
<Form.Item label="备注地址(选填)" colon={false} className={PageStyle.FormItemClass} {...formItemLayout}>
{getFieldDecorator('title', {
initialValue: schoolInfo.title || '',
{getFieldDecorator('address', {
initialValue: schoolInfo.address || '',
rules: [
{ max: 100, message: '通知栏字数不能超过100字!' },
{ max: 300, message: '备注地址字数不能超过300字!' },
],
})(
<Input onChange={e => this.schoolInfoChange(e, 'title')} className={PageStyle.FormItemInputClass} placeholder="请输入备注地址" />)}
<Input onChange={e => this.schoolInfoChange(e, 'address')} className={PageStyle.FormItemInputClass} placeholder="请输入备注地址" />)}
<span className="ant-form-text">对详细地址进行辅助说明:()地铁一号线三坝站c出口向北100</span>
</Form.Item>
<Form.Item label="联系电话" className={PageStyle.FormItemClass} colon={false} {...formItemLayout}>
......
......@@ -104,4 +104,18 @@ export function clockList(params) {
method: 'GET',
});
}
export function adsList(params) {
const data = qs.stringify(params);
return request({
url: `${api.officaialweb.ads}?${data}`,
method: 'GET',
});
}
export function adsSave(params) {
const data = qs.stringify(params);
return request({
url: `${api.officaialweb.adsSave}`,
method: 'POST',
data,
});
}
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment