Signed-off-by: bggRGjQaUbCoE <githubaccount56556@proton.me>
This commit is contained in:
bggRGjQaUbCoE
2025-12-25 13:43:20 +08:00
parent 161bf2eedb
commit 20a36e8f9a
97 changed files with 596 additions and 436 deletions

View File

@@ -6,7 +6,7 @@ import 'package:PiliPlus/models/common/publish_panel_type.dart';
import 'package:PiliPlus/utils/extension/context_ext.dart';
import 'package:chat_bottom_container/chat_bottom_container.dart';
import 'package:flutter/material.dart';
import 'package:get/get.dart' hide ContextExtensionss;
import 'package:get/get.dart';
abstract class CommonPublishPage<T> extends StatefulWidget {
const CommonPublishPage({
@@ -26,7 +26,7 @@ abstract class CommonPublishPage<T> extends StatefulWidget {
abstract class CommonPublishPageState<T extends CommonPublishPage>
extends State<T>
with WidgetsBindingObserver {
late final focusNode = FocusNode();
late final FocusNode focusNode;
late final controller = ChatBottomPanelContainerController<PanelType>();
TextEditingController get editController;
@@ -44,6 +44,8 @@ abstract class CommonPublishPageState<T extends CommonPublishPage>
WidgetsBinding.instance.addObserver(this);
}
focusNode = FocusNode();
initPubState();
if (widget.autofocus) {

View File

@@ -13,9 +13,13 @@ abstract class CommonTextPubPage extends CommonPublishPage<String> {
abstract class CommonTextPubPageState<T extends CommonTextPubPage>
extends CommonPublishPageState<T> {
@override
late final TextEditingController editController = TextEditingController(
text: widget.initialValue,
);
late final TextEditingController editController;
@override
void initState() {
super.initState();
editController = TextEditingController(text: widget.initialValue);
}
@override
void initPubState() {

View File

@@ -0,0 +1,72 @@
import 'package:flutter/material.dart';
class PublishRoute<T> extends PopupRoute<T> {
PublishRoute({
required RoutePageBuilder pageBuilder,
bool barrierDismissible = true,
String? barrierLabel,
Color barrierColor = const Color(0x80000000),
Duration transitionDuration = const Duration(milliseconds: 500),
RouteTransitionsBuilder? transitionBuilder,
super.settings,
}) : widget = pageBuilder,
_barrierDismissible = barrierDismissible,
_barrierLabel = barrierLabel,
_barrierColor = barrierColor,
_transitionDuration = transitionDuration,
_transitionBuilder = transitionBuilder;
final RoutePageBuilder widget;
@override
bool get barrierDismissible => _barrierDismissible;
final bool _barrierDismissible;
@override
String? get barrierLabel => _barrierLabel;
final String? _barrierLabel;
@override
Color get barrierColor => _barrierColor;
final Color _barrierColor;
@override
Duration get transitionDuration => _transitionDuration;
final Duration _transitionDuration;
final RouteTransitionsBuilder? _transitionBuilder;
@override
Widget buildPage(
BuildContext context,
Animation<double> animation,
Animation<double> secondaryAnimation,
) {
return Semantics(
scopesRoute: true,
explicitChildNodes: true,
child: widget(context, animation, secondaryAnimation),
);
}
@override
Widget buildTransitions(
BuildContext context,
Animation<double> animation,
Animation<double> secondaryAnimation,
Widget child,
) {
if (_transitionBuilder != null) {
return _transitionBuilder(context, animation, secondaryAnimation, child);
}
return SlideTransition(
position: animation.drive(
Tween(
begin: const Offset(0.0, 1.0),
end: Offset.zero,
).chain(CurveTween(curve: Curves.linear)),
),
child: child,
);
}
}