markdown_view.dart 1.6 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455
  1. import 'package:flutter/material.dart';
  2. import 'package:flutter/services.dart';
  3. import 'package:flutter_markdown/flutter_markdown.dart';
  4. import 'package:flutter_screenutil/flutter_screenutil.dart';
  5. import 'package:get/get.dart';
  6. import 'package:nomo/config/theme/theme_extensions/theme_extension.dart';
  7. import '../../../base/base_view.dart';
  8. import '../../../widgets/ix_app_bar.dart';
  9. import '../controllers/markdown_controller.dart';
  10. class MarkdownView extends BaseView<MarkdownController> {
  11. const MarkdownView({super.key});
  12. @override
  13. Widget buildContent(BuildContext context) {
  14. return Column(
  15. children: [
  16. IXAppBar(
  17. title: controller.title,
  18. // 不需要传递颜色参数,会自动使用响应式主题
  19. ),
  20. Expanded(child: _buildMarkdownContent()),
  21. ],
  22. );
  23. }
  24. Widget _buildMarkdownContent() {
  25. return FutureBuilder(
  26. future: rootBundle.loadString('assets/md/${controller.filename}.md'),
  27. builder: (BuildContext context, AsyncSnapshot snapshot) {
  28. if (snapshot.connectionState == ConnectionState.done) {
  29. if (snapshot.hasData) {
  30. return Markdown(
  31. physics: const BouncingScrollPhysics(),
  32. data: snapshot.data,
  33. );
  34. }
  35. }
  36. return Center(
  37. child: SizedBox(
  38. width: 20.w,
  39. height: 20.w,
  40. child: CircularProgressIndicator(
  41. strokeWidth: 2,
  42. valueColor: AlwaysStoppedAnimation<Color>(
  43. Get.reactiveTheme.primaryColor,
  44. ),
  45. ),
  46. ),
  47. );
  48. },
  49. );
  50. }
  51. }