Initial commit

This commit is contained in:
Henry Hiles 2025-01-03 18:33:59 -05:00
parent 32e425f961
commit e94d583b8b
67 changed files with 2516 additions and 698 deletions

View file

@ -0,0 +1,17 @@
import 'package:canal/widgets/appbar.dart';
import 'package:flutter/material.dart';
class AlbumPage extends StatelessWidget {
const AlbumPage({super.key});
@override
Widget build(BuildContext context) => Scaffold(
appBar: Appbar(title: "Album"),
body: Center(
child: Text(
"Coming soon...",
style: Theme.of(context).textTheme.displayMedium,
),
),
);
}

View file

@ -0,0 +1,17 @@
import 'package:canal/widgets/appbar.dart';
import 'package:flutter/material.dart';
class PlaylistPage extends StatelessWidget {
const PlaylistPage({super.key});
@override
Widget build(BuildContext context) => Scaffold(
appBar: Appbar(title: "Playlist"),
body: Center(
child: Text(
"Coming soon...",
style: Theme.of(context).textTheme.displayMedium,
),
),
);
}

View file

@ -0,0 +1,22 @@
import 'package:flutter/material.dart';
import 'package:canal/models/tab.dart';
class AccountTab extends StatelessWidget implements TabPage {
const AccountTab({super.key});
@override
IconData get icon => Icons.person;
@override
String get title => "Account";
@override
Widget build(BuildContext context) => Scaffold(
body: Center(
child: Text(
"Coming soon...",
style: Theme.of(context).textTheme.displayMedium,
),
),
);
}

View file

@ -0,0 +1,64 @@
import 'package:canal/helpers/extension_helper.dart';
import 'package:canal/providers/home_sections_provider.dart';
import 'package:canal/screens/album_page.dart';
import 'package:canal/screens/playlist_page.dart';
import 'package:canal/widgets/thumbnail.dart';
import 'package:dart_ytmusic_api/dart_ytmusic_api.dart';
import 'package:flutter/material.dart';
import 'package:canal/models/tab.dart';
import 'package:hooks_riverpod/hooks_riverpod.dart';
import 'package:yaru/yaru.dart';
class HomeTab extends ConsumerWidget implements TabPage {
const HomeTab({super.key});
@override
IconData get icon => Icons.home;
@override
String get title => "Home";
@override
Widget build(BuildContext context, WidgetRef ref) => ref
.watch(homeSectionsProvider)
.betterWhen(
data: (sections) => ListView(
padding: EdgeInsets.symmetric(vertical: 4),
children: sections
.where(
(element) => element.contents.isNotEmpty,
)
.map(
(section) => YaruSection(
margin: EdgeInsets.symmetric(horizontal: 12, vertical: 8),
padding: EdgeInsets.symmetric(horizontal: 12, vertical: 8),
headline: Text(section.title),
child: SizedBox(
height: 262,
child: ListView(
itemExtent: 268,
scrollDirection: Axis.horizontal,
children: section.contents
.map((song) => Padding(
padding:
EdgeInsets.only(right: 12, bottom: 4, top: 2),
child: Thumbnail(
url: song.thumbnails.first.url,
onClick: () => Navigator.of(context)
.push(MaterialPageRoute(
builder: (_) => switch (song) {
PlaylistDetailed _ =>
PlaylistPage(),
AlbumDetailed _ => AlbumPage(),
_ => throw "Unknown type",
})),
)))
.toList(),
),
),
),
)
.toList(),
),
);
}

View file

@ -0,0 +1,28 @@
import 'package:flutter/material.dart';
import 'package:canal/models/tab.dart';
import 'package:yaru/yaru.dart';
class SearchTab extends StatelessWidget implements TabPage {
const SearchTab({super.key});
@override
IconData get icon => Icons.search;
@override
String get title => "Search";
@override
Widget build(BuildContext context) => ListView(
padding: EdgeInsets.symmetric(horizontal: 8, vertical: 4),
children: [
SegmentedButton(
segments: [
ButtonSegment(value: 0, label: Text("Foo")),
ButtonSegment(value: 1, label: Text("Bar")),
ButtonSegment(value: 2, label: Text("Foobar"))
],
selected: {0},
)
],
);
}