1.全部完成后,修改对话内容

This commit is contained in:
zhutao
2025-09-24 11:34:55 +08:00
parent ca376d9393
commit 70479542a5
3 changed files with 76 additions and 67 deletions

View File

@@ -17,8 +17,7 @@ class _DoneStampState extends State<DoneStamp> {
return Consumer<PlanDetailStore>(
builder: (context, store, _) {
//是否全部完成
bool allDone = store.planDetail.stepsList.every((item) => item.stepStatus == 2);
if (!allDone || store.planDetail.stepsList.isEmpty) {
if (!store.isAllDone() ) {
return Container();
}
return Align(

View File

@@ -46,6 +46,11 @@ class PlanDetailStore extends ChangeNotifier {
///计划详情
PlanDetailDto planDetail = PlanDetailDto(summary: "Plan Details");
///是否全部完成
bool isAllDone() =>
planDetail.stepsList.isNotEmpty &&
planDetail.stepsList.every((item) => item.stepStatus == 2);
///是否正在编辑
bool isEdit = false;
@@ -56,7 +61,7 @@ class PlanDetailStore extends ChangeNotifier {
}
///流请求工具
StreamUtils streamUtils = StreamUtils();
final StreamUtils _streamUtils = StreamUtils();
///创建计划
void createPlan() async {
@@ -65,7 +70,7 @@ class PlanDetailStore extends ChangeNotifier {
///生成摘要---------------------------
String summary = "";
streamUtils.sendStream(
_streamUtils.sendStream(
"/plan/make_summary",
data: {"plan_id": planId},
onCall: (chunk) {
@@ -79,7 +84,7 @@ class PlanDetailStore extends ChangeNotifier {
/// 生成对白-------------------------------
String dialog = "";
await streamUtils.sendStream(
await _streamUtils.sendStream(
"/plan/make_dialog",
data: {"plan_id": planId},
onCall: (chunk) {
@@ -92,7 +97,7 @@ class PlanDetailStore extends ChangeNotifier {
);
/// 生成步骤-------------------------------
await streamUtils.sendStream(
await _streamUtils.sendStream(
"/plan/make_step",
data: {"plan_id": planId},
onCall: (chunk) {
@@ -115,7 +120,7 @@ class PlanDetailStore extends ChangeNotifier {
);
/// 生成步骤解释 -------------------------------
await streamUtils.sendStream(
await _streamUtils.sendStream(
"/plan/make_step_explain",
data: {
"plan_id": planId,
@@ -137,7 +142,7 @@ class PlanDetailStore extends ChangeNotifier {
);
/// 生成建议 ------------------
await streamUtils.sendStream(
await _streamUtils.sendStream(
"/plan/make_suggestion",
data: {
"plan_id": planId,

View File

@@ -78,6 +78,9 @@ class _AvatarCardState extends State<AvatarCard> with SingleTickerProviderStateM
@override
Widget build(BuildContext context) {
return Selector<PlanDetailStore, bool>(
selector: (_, store) => store.isAllDone(),
builder: (context, isAllDone, _) {
return Padding(
padding: const EdgeInsets.symmetric(horizontal: 30),
child: Transform.translate(
@@ -101,7 +104,7 @@ class _AvatarCardState extends State<AvatarCard> with SingleTickerProviderStateM
border: Border.all(color: Colors.black, width: 1),
),
child: Text(
_dialog,
isAllDone ? "🎉 Great — youve completed everything! 🎉" : _dialog,
style: TextStyle(fontSize: 12),
textAlign: TextAlign.center,
),
@@ -146,6 +149,8 @@ class _AvatarCardState extends State<AvatarCard> with SingleTickerProviderStateM
),
),
);
},
);
}
}