Appainter uses the package json_theme to encode and decode the theme JSON file.
From version to version, Flutter may deprecate certain properties in ThemeData. When this happens, the serialisation package will also update their JSON schema with the latest properties.
The Flutter version that Appainter is running will pop-up whenever you use Appainter, on both web and desktop apps. It is highly recommended to use the same Flutter version when running your app. Otherwise, there may be compatibility issues when using the theme JSON file in your app.
If you need to use the theme JSON file in a specific Flutter version, you can find and download the desktop version of Appainter that uses your Flutter version from the releases page.
To use the theme JSON file in your app, follow the steps below:
-
Add
json_theme
as a dependency in yourpubspec.yaml
file.dependencies: json_theme: ^7.0.0+3
-
Copy the generated
json
file to your app project and place it under theassets/
folder. -
Update your
pubspec.yaml
file to include your asset.flutter: assets: - assets/appainter_theme.json
-
Update your
main
function to be async, load your theme and pass it into your Appimport 'package:flutter/material.dart'; import 'package:json_theme/json_theme.dart'; import 'package:flutter/services.dart'; // For rootBundle import 'dart:convert'; // For jsonDecode void main() async { WidgetsFlutterBinding.ensureInitialized(); final themeStr = await rootBundle.loadString('assets/appainter_theme.json'); final themeJson = jsonDecode(themeStr); final theme = ThemeDecoder.decodeThemeData(themeJson)!; runApp(MyApp(theme: theme)); } class MyApp extends StatelessWidget { final ThemeData theme; const MyApp({Key? key, required this.theme}) : super(key: key); // This widget is the root of your application. @override Widget build(BuildContext context) { return MaterialApp(home: HomePage(), theme: theme); } }
If you've generated the json
theme file with a custom font, you'll need to import a custom font file:
-
Search and download your font from Google Fonts. Appainter uses Google Fonts as the list of font options so you should be able to find your font there.
-
Copy the font file to your app project and place it under the
fonts/
folder. -
Update your
pubspec.yaml
file to include your font. Here we useMontserrat
as our font.flutter: assets: - assets/appainter_theme.json fonts: - family: Montserrat fonts: - asset: fonts/Montserrat-Regular.ttf
-
Your font will be loaded automatically when you use the generated theme.
For a complete example app using the generated json
theme file and a custom font, see the app under the example folder.