1
This commit is contained in:
parent
1d8b815f95
commit
cc97f6aebb
3
miniprogram/pages/module/index.json
Normal file
3
miniprogram/pages/module/index.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"enablePullDownRefresh": true
|
||||||
|
}
|
||||||
74
miniprogram/pages/timeline-create/index.js
Normal file
74
miniprogram/pages/timeline-create/index.js
Normal file
@ -0,0 +1,74 @@
|
|||||||
|
const { postForm, uploadFile } = require("../../utils/api");
|
||||||
|
const { getActiveClassId, showError } = require("../../utils/page-helpers");
|
||||||
|
|
||||||
|
Page({
|
||||||
|
data: {
|
||||||
|
title: "",
|
||||||
|
content: "",
|
||||||
|
images: [],
|
||||||
|
loading: false
|
||||||
|
},
|
||||||
|
|
||||||
|
onLoad() {
|
||||||
|
wx.setNavigationBarTitle({ title: "发布动态" });
|
||||||
|
},
|
||||||
|
|
||||||
|
onTitleInput(event) {
|
||||||
|
this.setData({ title: event.detail.value });
|
||||||
|
},
|
||||||
|
|
||||||
|
onContentInput(event) {
|
||||||
|
this.setData({ content: event.detail.value });
|
||||||
|
},
|
||||||
|
|
||||||
|
chooseImages() {
|
||||||
|
wx.chooseMedia({
|
||||||
|
count: 9 - this.data.images.length,
|
||||||
|
mediaType: ["image"],
|
||||||
|
sourceType: ["album", "camera"],
|
||||||
|
success: (res) => {
|
||||||
|
const paths = (res.tempFiles || []).map((item) => item.tempFilePath);
|
||||||
|
this.setData({ images: [...this.data.images, ...paths].slice(0, 9) });
|
||||||
|
}
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
removeImage(event) {
|
||||||
|
const index = Number(event.currentTarget.dataset.index);
|
||||||
|
this.setData({
|
||||||
|
images: this.data.images.filter((_, itemIndex) => itemIndex !== index)
|
||||||
|
});
|
||||||
|
},
|
||||||
|
|
||||||
|
async submit() {
|
||||||
|
const title = this.data.title.trim();
|
||||||
|
const content = this.data.content.trim();
|
||||||
|
if (!title) {
|
||||||
|
wx.showToast({ title: "请输入标题", icon: "none" });
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
this.setData({ loading: true });
|
||||||
|
try {
|
||||||
|
const classId = getActiveClassId();
|
||||||
|
const created = await postForm("/api/timeline/", {
|
||||||
|
title,
|
||||||
|
content,
|
||||||
|
class_id: String(classId || "")
|
||||||
|
});
|
||||||
|
for (let index = 0; index < this.data.images.length; index += 1) {
|
||||||
|
await uploadFile(`/api/timeline/${created.id}/images`, this.data.images[index]);
|
||||||
|
}
|
||||||
|
wx.showToast({ title: "已发布", icon: "success" });
|
||||||
|
const pages = getCurrentPages();
|
||||||
|
const previousPage = pages[pages.length - 2];
|
||||||
|
if (previousPage?.setData) {
|
||||||
|
previousPage.setData({ needsRefresh: true });
|
||||||
|
}
|
||||||
|
setTimeout(() => wx.navigateBack(), 500);
|
||||||
|
} catch (error) {
|
||||||
|
showError(error, "发布失败");
|
||||||
|
} finally {
|
||||||
|
this.setData({ loading: false });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
});
|
||||||
3
miniprogram/pages/timeline-create/index.json
Normal file
3
miniprogram/pages/timeline-create/index.json
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
{
|
||||||
|
"usingComponents": {}
|
||||||
|
}
|
||||||
33
miniprogram/pages/timeline-create/index.wxml
Normal file
33
miniprogram/pages/timeline-create/index.wxml
Normal file
@ -0,0 +1,33 @@
|
|||||||
|
<view class="page">
|
||||||
|
<view class="hero">
|
||||||
|
<view class="eyebrow">CLASS FEED</view>
|
||||||
|
<view class="hero-title">发布班级动态</view>
|
||||||
|
<view class="hero-subtitle">分享课程现场、活动照片、学习收获或班级提醒。</view>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<view class="section">
|
||||||
|
<view class="card">
|
||||||
|
<view class="muted">标题</view>
|
||||||
|
<input value="{{title}}" bindinput="onTitleInput" placeholder="一句话概括这条动态" />
|
||||||
|
</view>
|
||||||
|
<view class="card">
|
||||||
|
<view class="muted">正文</view>
|
||||||
|
<textarea value="{{content}}" bindinput="onContentInput" placeholder="写下想和同学分享的内容" />
|
||||||
|
</view>
|
||||||
|
<view class="card">
|
||||||
|
<view class="section-head">
|
||||||
|
<view class="card-title">图片</view>
|
||||||
|
<view class="section-action" bindtap="chooseImages">添加</view>
|
||||||
|
</view>
|
||||||
|
<view wx:if="{{images.length}}" class="image-grid">
|
||||||
|
<view wx:for="{{images}}" wx:key="*this" class="image-cell">
|
||||||
|
<image src="{{item}}" mode="aspectFill" />
|
||||||
|
<view class="image-remove" data-index="{{index}}" bindtap="removeImage">×</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
<view wx:else class="muted">最多可添加 9 张图片</view>
|
||||||
|
</view>
|
||||||
|
</view>
|
||||||
|
|
||||||
|
<button class="button" loading="{{loading}}" bindtap="submit">发布动态</button>
|
||||||
|
</view>
|
||||||
46
miniprogram/pages/timeline-create/index.wxss
Normal file
46
miniprogram/pages/timeline-create/index.wxss
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
input {
|
||||||
|
margin-top: 12rpx;
|
||||||
|
height: 72rpx;
|
||||||
|
font-size: 30rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
textarea {
|
||||||
|
width: 100%;
|
||||||
|
min-height: 220rpx;
|
||||||
|
margin-top: 12rpx;
|
||||||
|
font-size: 28rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-grid {
|
||||||
|
display: grid;
|
||||||
|
grid-template-columns: repeat(3, 1fr);
|
||||||
|
gap: 12rpx;
|
||||||
|
margin-top: 18rpx;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-cell {
|
||||||
|
position: relative;
|
||||||
|
overflow: hidden;
|
||||||
|
height: 180rpx;
|
||||||
|
border-radius: 20rpx;
|
||||||
|
background: #efe0ca;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-cell image {
|
||||||
|
width: 100%;
|
||||||
|
height: 100%;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image-remove {
|
||||||
|
position: absolute;
|
||||||
|
top: 8rpx;
|
||||||
|
right: 8rpx;
|
||||||
|
width: 42rpx;
|
||||||
|
height: 42rpx;
|
||||||
|
border-radius: 999rpx;
|
||||||
|
background: rgba(47, 33, 28, 0.72);
|
||||||
|
color: #fff;
|
||||||
|
font-size: 32rpx;
|
||||||
|
line-height: 38rpx;
|
||||||
|
text-align: center;
|
||||||
|
}
|
||||||
Loading…
Reference in New Issue
Block a user