|
|
@ -16,8 +16,7 @@ import '../styles.dart';
|
|
|
|
|
|
|
|
|
|
|
|
enum HomeTabs { newest, followed }
|
|
|
|
enum HomeTabs { newest, followed }
|
|
|
|
|
|
|
|
|
|
|
|
class HomeController extends GetxController
|
|
|
|
class HomeController extends GetxController with GetSingleTickerProviderStateMixin {
|
|
|
|
with GetSingleTickerProviderStateMixin {
|
|
|
|
|
|
|
|
double _navSearchButtonOffset = 90;
|
|
|
|
double _navSearchButtonOffset = 90;
|
|
|
|
|
|
|
|
|
|
|
|
var showNavSearchButton = false.obs;
|
|
|
|
var showNavSearchButton = false.obs;
|
|
|
@ -36,15 +35,12 @@ class HomeController extends GetxController
|
|
|
|
void onInit() {
|
|
|
|
void onInit() {
|
|
|
|
tabController = TabController(length: 2, vsync: this);
|
|
|
|
tabController = TabController(length: 2, vsync: this);
|
|
|
|
|
|
|
|
|
|
|
|
_navSearchButtonOffset =
|
|
|
|
_navSearchButtonOffset = 48 * MediaQuery.of(Get.context!).textScaleFactor + 48;
|
|
|
|
48 * MediaQuery.of(Get.context!).textScaleFactor + 48;
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
scrollController.addListener(() {
|
|
|
|
scrollController.addListener(() {
|
|
|
|
if (scrollController.offset >= _navSearchButtonOffset &&
|
|
|
|
if (scrollController.offset >= _navSearchButtonOffset && !showNavSearchButton.value) {
|
|
|
|
!showNavSearchButton.value) {
|
|
|
|
|
|
|
|
showNavSearchButton.value = true;
|
|
|
|
showNavSearchButton.value = true;
|
|
|
|
} else if (scrollController.offset < _navSearchButtonOffset &&
|
|
|
|
} else if (scrollController.offset < _navSearchButtonOffset && showNavSearchButton.value) {
|
|
|
|
showNavSearchButton.value) {
|
|
|
|
|
|
|
|
showNavSearchButton.value = false;
|
|
|
|
showNavSearchButton.value = false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
|
|
@ -102,11 +98,8 @@ class HomeTab extends StatelessWidget {
|
|
|
|
duration: const Duration(milliseconds: 100),
|
|
|
|
duration: const Duration(milliseconds: 100),
|
|
|
|
child: CupertinoButton(
|
|
|
|
child: CupertinoButton(
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
child: const Icon(CupertinoIcons.search,
|
|
|
|
child: const Icon(CupertinoIcons.bell, size: 26, color: Styles.themeNavTitleColor),
|
|
|
|
size: 26, color: Styles.themeNavTitleColor),
|
|
|
|
onPressed: () {},
|
|
|
|
onPressed: () {
|
|
|
|
|
|
|
|
onSearchClick?.call();
|
|
|
|
|
|
|
|
},
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
);
|
|
|
|
);
|
|
|
@ -121,8 +114,7 @@ class HomeTab extends StatelessWidget {
|
|
|
|
duration: const Duration(milliseconds: 100),
|
|
|
|
duration: const Duration(milliseconds: 100),
|
|
|
|
child: CupertinoButton(
|
|
|
|
child: CupertinoButton(
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
padding: EdgeInsets.zero,
|
|
|
|
child: const Icon(CupertinoIcons.search,
|
|
|
|
child: const Icon(CupertinoIcons.search, size: 26, color: Styles.themeNavTitleColor),
|
|
|
|
size: 26, color: Styles.themeNavTitleColor),
|
|
|
|
|
|
|
|
onPressed: () {
|
|
|
|
onPressed: () {
|
|
|
|
onSearchClick?.call();
|
|
|
|
onSearchClick?.call();
|
|
|
|
},
|
|
|
|
},
|
|
|
@ -144,13 +136,12 @@ class HomeTab extends StatelessWidget {
|
|
|
|
),
|
|
|
|
),
|
|
|
|
slivers: <Widget>[
|
|
|
|
slivers: <Widget>[
|
|
|
|
IsekaiSliverNavigationBar(
|
|
|
|
IsekaiSliverNavigationBar(
|
|
|
|
leading: _buildNotificationIconButton(),
|
|
|
|
leading: _buildSearchIconButton(),
|
|
|
|
backgroundColor: Styles.themeMainColor,
|
|
|
|
backgroundColor: Styles.themeMainColor,
|
|
|
|
brightness: Brightness.dark,
|
|
|
|
brightness: Brightness.dark,
|
|
|
|
largeTitle: const Text('首页',
|
|
|
|
largeTitle: const Text('首页', style: TextStyle(color: Styles.themeNavTitleColor)),
|
|
|
|
style: TextStyle(color: Styles.themeNavTitleColor)),
|
|
|
|
|
|
|
|
border: Border.all(style: BorderStyle.none),
|
|
|
|
border: Border.all(style: BorderStyle.none),
|
|
|
|
trailing: _buildSearchIconButton(),
|
|
|
|
trailing: _buildNotificationIconButton(),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
SliverPersistentHeader(
|
|
|
|
SliverPersistentHeader(
|
|
|
|
delegate: _SliverAppBarDelegate(
|
|
|
|
delegate: _SliverAppBarDelegate(
|
|
|
@ -181,12 +172,10 @@ class HomeTab extends StatelessWidget {
|
|
|
|
children: [
|
|
|
|
children: [
|
|
|
|
Container(
|
|
|
|
Container(
|
|
|
|
padding: const EdgeInsets.all(1),
|
|
|
|
padding: const EdgeInsets.all(1),
|
|
|
|
child: const Icon(CupertinoIcons.search,
|
|
|
|
child: const Icon(CupertinoIcons.search, color: Colors.black54),
|
|
|
|
color: Colors.black54),
|
|
|
|
|
|
|
|
),
|
|
|
|
),
|
|
|
|
const Text("搜索页面...",
|
|
|
|
const Text("搜索页面...",
|
|
|
|
textAlign: TextAlign.center,
|
|
|
|
textAlign: TextAlign.center, style: TextStyle(color: Colors.black54))
|
|
|
|
style: TextStyle(color: Colors.black54))
|
|
|
|
|
|
|
|
],
|
|
|
|
],
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
@ -216,10 +205,7 @@ class HomeTab extends StatelessWidget {
|
|
|
|
indicatorColor: Styles.themeMainColor,
|
|
|
|
indicatorColor: Styles.themeMainColor,
|
|
|
|
labelColor: Styles.themeMainColor,
|
|
|
|
labelColor: Styles.themeMainColor,
|
|
|
|
unselectedLabelColor: Colors.black45,
|
|
|
|
unselectedLabelColor: Colors.black45,
|
|
|
|
tabs: const [
|
|
|
|
tabs: const [CollapsedTabText('最新'), CollapsedTabText('关注')],
|
|
|
|
CollapsedTabText('最新'),
|
|
|
|
|
|
|
|
CollapsedTabText('关注')
|
|
|
|
|
|
|
|
],
|
|
|
|
|
|
|
|
onTap: (int selected) {},
|
|
|
|
onTap: (int selected) {},
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
|
),
|
|
|
@ -264,8 +250,7 @@ class _SliverAppBarDelegate extends SliverPersistentHeaderDelegate {
|
|
|
|
double get maxExtent => max(maxHeight, minHeight);
|
|
|
|
double get maxExtent => max(maxHeight, minHeight);
|
|
|
|
|
|
|
|
|
|
|
|
@override
|
|
|
|
@override
|
|
|
|
Widget build(
|
|
|
|
Widget build(BuildContext context, double shrinkOffset, bool overlapsContent) {
|
|
|
|
BuildContext context, double shrinkOffset, bool overlapsContent) {
|
|
|
|
|
|
|
|
return SizedBox.expand(child: child);
|
|
|
|
return SizedBox.expand(child: child);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|