📱 Ready-made inherited component base using ready-made abstractions for quick use and decomposed by platform.
iOS (Cupertino) | Android (Material) |
---|---|
✅ | ✅ |
VS Code Snippets have been generated for this package:
See the documentation for using the package and components here - Flutter Platform Component Wiki.
The package works according to the principle: fill out needed contracts - get all ready-made inherited platform components.
Components are separated by platform by style and behavior.
Extension themes along with the ThemeData class are very good when you use widgets only for Material Design.
In case you want to get the correct behavior of widgets for the platform, you must fill in Theme and CupertinoTheme and each time remember to separate these colors in the widgets you use.
Theme Extension works in the same way as this package.
In the case of this package - it is necessary to fill in only one contract of the theme used.
In addition to the theme, there are other entities that are managed identically to the theme - animations, dates, duraions, haptics, sizes, text styles and times.
Each entity is updated with its stateful and inherited widgets to optimize the redrawing of child widgets that are subscribed via the context to the entity data.
The color scheme was created in terms of the convenience of designers (primary, secondary, accent, success, warning and danger colors with dark/default/light shades).
In the scheme by name, permanent colors and tint colors are created (note - primaryLight and primaryDark).
Ready-made components get rid of a lot of boilerplate code.
All component property names are unified, for example, you will never see "background" and "backgroundColor".
Form fields have not only normal validation, but also separate auto-validation, which can be used for messages during the characters entered in the field.
Segment control, Gradient segment control, sliding segment control, toggle, gradient toggle components also have a validation function (IsRequired flag) and can be placed at the root of the Form widget.
Every component that can be clicked has the property to be disabled implemented.
VS Code snippets have been generated for this package for convenient development and creating your own widget wrappers.
Components follow the following design paradigm:
- The component should not contain business logic;
- All components must aspire to the behavior of the target platform;
- If there is no such component in the target platform cookbook, a component is needed that will be as similar as possible to it and has identical behavior;
- Component change the color of the disabled component, if it only has not background color;
- The design of cross-platform components and their behavior are not mix.
The package uses a fork of the following dependencies:
animate_do - fade animations;
animations - transitional animations;
badges - badges;
dotted_border - dotted border container;
flutter_vibrate - all vibrations;
modal_bottom_sheet (fork) - transitions that support modal animations and modal windows appearance method;
pinput - code fields and PIN fields.
Express our gratitude to the authors of these dependencies.
- Elevation of components;
- Support WEB & desktop;
- FPCTooltip;
- FPCDrawer;
- Script for properties comments for pub scores.
For more details see example project.
And feel free to open an issue if you find any bugs or errors or suggestions.