-
Notifications
You must be signed in to change notification settings - Fork 68
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
1 parent
40a53fa
commit 73e8c3e
Showing
31 changed files
with
10,072 additions
and
15,967 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file was deleted.
Oops, something went wrong.
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,7 @@ | ||
{ | ||
"label": "Core Concepts", | ||
"position": 4, | ||
"link": { | ||
"type": "generated-index" | ||
} | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,111 @@ | ||
--- | ||
sidebar_position: 2 | ||
--- | ||
|
||
# Action Parsers | ||
|
||
Mirai supports a variety of built-in action parsers to handle different types of actions. However, you can also create custom action parsers to handle custom actions or actions that are not supported by Mirai out of the box. This guide will walk you through the basics of creating and using action parsers in Mirai. | ||
|
||
## What is a Mirai Action Parser? | ||
|
||
A Mirai action parser is a custom class that interprets specific JSON objects representing actions and executes the corresponding logic in your Flutter application. This allows for highly flexible and customizable behavior tailored to the specific needs of your application. | ||
|
||
## Creating a Custom Action Parser | ||
|
||
To create a custom action parser, you need to follow these steps: | ||
|
||
1. **Define the JSON Structure**: Define the structure of the JSON object that your action parser will interpret. This structure should be well-documented and easy to understand. | ||
2. **Create the Action Parser Class**: Create a new Dart class that implements the `MiraiActionParser` interface provided by Mirai. This class will contain the logic to interpret the JSON object and execute the corresponding action. | ||
3. **Register the Action Parser**: Register the custom action parser with Mirai so that it can be used to interpret JSON objects. | ||
|
||
## Example Action Parser | ||
|
||
In this example, we will create a custom action parser that calls a print function with a provided message. | ||
|
||
### Step 1: Define the JSON Structure | ||
|
||
The JSON structure for the custom action might look like this: | ||
|
||
```json | ||
{ | ||
"actionType": "print", | ||
"message": "Hello, Mirai!" | ||
} | ||
``` | ||
For this JSON Structure, we can create a data class to represent the custom action and to provide the `fromJson` method to convert the JSON object to the custom action object. | ||
|
||
```dart | ||
@freezed | ||
class PrintAction with _$PrintAction { | ||
const factory PrintAction({ | ||
required String message, | ||
}) = _PrintAction; | ||
factory PrintAction.fromJson(Map<String, dynamic> json) => | ||
_$PrintActionFromJson(json); | ||
} | ||
``` | ||
:::note | ||
Here we are using the freezed package to create the data class. But you can use any other method to create the data class. | ||
::: | ||
|
||
### Step 2: Create the Action Parser Class | ||
|
||
Next, we create a custom action parser class that implements the `MiraiActionParser` interface. This class will interpret the JSON object and execute the corresponding logic. | ||
|
||
```dart | ||
class PrintActionParser implements MiraiActionParser<PrintAction> { | ||
@override | ||
String get actionType => 'print'; | ||
@override | ||
PrintAction getModel(Map<String, dynamic> json) => PrintAction.fromJson(json); | ||
@override | ||
FutureOr onCall(BuildContext context, MiraiNavigateAction model) { | ||
print(model.message); | ||
} | ||
} | ||
``` | ||
|
||
### Step 3: Register the Action Parser | ||
|
||
Finally, you need to register the custom action parser with Mirai. | ||
|
||
There are 2 ways to register the custom action parser: | ||
|
||
1. **Register in `Mirai.initialize`**: You can register the parser when initializing Mirai by passing it in the `actionParser` parameter. | ||
|
||
```dart | ||
void main() async { | ||
await Mirai.initialize( | ||
actionParsers: const [ | ||
PrintActionParser(), | ||
], | ||
); | ||
runApp(const MyApp()); | ||
} | ||
``` | ||
|
||
2. **Register through MiraiRegistry**: You can also register the action parser anywhere using the `MiraiRegistry` class. | ||
|
||
`MiraiRegistry` provides you with two method to register the action parser. | ||
|
||
1. Register a single action parser: | ||
|
||
```dart | ||
MiraiRegistry.instance.registerAction(parser); | ||
``` | ||
|
||
2. Register multiple action parsers: | ||
|
||
```dart | ||
MiraiRegistry.instance.registerAllActions([ | ||
MiraiShareParser(), | ||
MiraiBluetoothParser(), | ||
]); | ||
``` | ||
|
||
## Conclusion | ||
|
||
Creating custom action parsers in Mirai not only allows you to extend the functionality of the library but also enables you to define highly customizable behaviors within your application. By defining custom parsers for actions, you can leverage the full power of server-driven UI in your Flutter application, ensuring dynamic and responsive user interactions. |
Oops, something went wrong.