clean_framework 4.0.2 clean_framework: ^4.0.2 copied to clipboard
Clean Architecture components library, inspired on the guidelines created by Uncle Bob.
Changelog #
4.0.2 #
May 28, 2024
- Bump dependencies to latest versions.
4.0.1 #
Feb 7, 2024
- Bump dependencies to latest versions.
- Rename REST example project to 'example'.
4.0.0 #
Feb 7, 2024 Breaking Change
- Deprecated and replaced a number of domain layer classes.
- Deprecated
Input
, replaced withDomainInput
. - Deprecated
Output
, replaced withDomainModel
. - Deprecated
Success
, replaced withSuccessUseCaseInput
. - Deprecated
Failure
, replaced withFailureUseCaseInput
. - Deprecated
OutputTransformer
, replaced withDomainModelTransformer
. (Breaking change) - Deprecated
InputTransformer
, replaced withDomainInputTransformer
. (Breaking change)
- Deprecated
- Deprecated and replaced a number of functions.
- Package-wide changes:
- Renamed non-optional parameters named
output
todomainModel
in a number of functions.
- Renamed non-optional parameters named
Presenter
changes:- Deprecated
onOutput(context, output, viewModel)
, replaced withonDomainModel(context, domainModel, viewModel)
. - Deprecated
onOutputUpdate(context, output)
, replaced withonDomainModelUpdate(context, domainModel)
.
- Deprecated
UseCase
changes:- Renamed
getOutput
function togetDomainModel
. (Breaking change)
- Renamed
- Package-wide changes:
- Updated documentation.
- Added new example project (
theme_example
) to accompany new documentation.
3.2.5 #
Jan 5, 2024
- Bumps dependencies to latest version.
3.2.4 #
Nov 24, 2023
- Bumps dependencies to latest version.
3.2.3 #
Aug 7, 2023
- Bumps dependencies to latest version.
3.2.2 #
Jul 3, 2023
- Fixes issue with watcher gateway sending inputs multiple times.
3.2.1 #
Jun 22, 2023
- Adds
onSuccessInput
andonFailureInput
to CleanFrameworkObserver. - Better logging.
3.2.0 #
Jun 21, 2023
- Upgrades
uniform
package.
3.1.0 #
Jun 17, 2023
- Adds family for UseCaseProvider. See the example for usages.
- Removes support for legacy use case filters.
3.0.1 #
3.0.0 #
Jun 8, 2023
- Bumps dependencies to latest version.
- Adds
UseCase.getInput
method. - Removes first type param from the
UseCase.request
method.
2.1.4 #
Jun 1, 2023
- Bumps dependencies to latest version.
- Adds
context.viewModel()
extension method to BuildContext.
2.1.3 #
Apr 6, 2023
- Adds
delegate
toExternalInterface
.
2.1.2 #
Mar 27, 2023
RequestSubscription
respects output type in subscribe method for UseCase.
2.1.1 #
Mar 21, 2023
- Checks for mounted during
request
in UseCase. - Throws assertion if duplicate gateway is added to external interfaces.
2.1.0 #
Mar 17, 2023
- Adds
ExternalInterfaceDelegate
.
2.0.10 #
Mar 16, 2023
- Adds
DependencyProvider
. - Adds
locate
method to ExternalInterface.
2.0.9 #
Mar 14, 2023
- Bumped dependencies to latest version.
- Logs error caught by External Interface with stacktrace.
2.0.8 #
Mar 9, 2023
- Fixes WatcherGateway not updating entity properly.
- Adds
getUseCaseFromContext
to UseCaseProviders.
2.0.7 #
Feb 22, 2023
- Added
debugEntity
anddebugEntityUpdate
to UseCase. Theentity
getter/setter is now protected. - Bumped dependencies to latest version.
2.0.6 #
Feb 13, 2023
- Fixed
Deserializer.getList()
returningdefaultValue
on some cases.
2.0.5 #
Feb 1, 2023
- Fixed casting issue with
Deserializer.getList()
2.0.4 #
Jan 27, 2023
- Added
withSilencedUpdate
for UseCase. onDestroy
method in Presenter will now be called immediately at dispose. Any actions that causes UI to rebuild should be avoided in this method. For entity updates that do not need to rebuild the UI, should be wrapped insidewithSilencedUpdate
in UseCase.
2.0.3 #
Jan 25, 2023
- Fixed issue with
overrideWith
for external interface provider. copyWith
method forEntity
now throws unimplemented if used without overriding.
2.0.2 #
Jan 24, 2023
- Added
overrideWith
for providers.
2.0.1 #
Jan 19, 2023
- Added
onOutput
method for Presenter - Fixed issue with Flutter Web
2.0.0 #
Jan 17, 2023 Breaking Change
- Removed dependencies on sub packages. Sub-packages can be added separately as per the requirement.
Sub-packages:
- clean_framework_router
- clean_framework_graphql
- clean_framework_rest
- clean_framework_firestore
- clean_framework_test
- Added
AppProviderScope
- Remove old feature flagging classes in favor of new open feature based classes
- Simplified Either implementation
- Introduced
transformers
to UseCase; use cases are now lazily instantiated - Simplified provider creation and usage
- Added
UseCaseProvider.autoDispose
- Added
UseCaseProviderBridge
For migration guide, please refer to the docs.
1.5.0 #
Nov 1, 2022
- Breakdown into sub packages.
- Moved test helpers to
clean_framework_test
package. - RestSuccessResponse's data is subtype of
Object
instead ofdynamic
.
1.5.0-dev.0 #
Oct 31, 2022
- Breakdown into sub packages.
- Moved test helpers to
clean_framework_test
package. - RestSuccessResponse's data is subtype of
Object
instead ofdynamic
.
1.4.2 #
Sep 13, 2022
- Added support for GraphQL Schema Stitching.
- Added support for changing GraphQL error policy in request level.
- Bumped dependencies to their latest version.
1.4.1 #
Aug 31, 2022
- Bumped dependencies to their latest version.
1.4.0 #
Aug 3, 2022
- Added
push
method to the router. - Added
AppRouter.page
andAppRouter.custom
. - Added
Deserializer
to help with deserializing JSON data. - Added support for form data and multipart request through
RestExternalInterface
. - Updated dependencies to latest version.
- [Breaking] Removed
valueType
from FeatureBuilder.
1.3.1 #
Jun 7, 2022
- Added Feature Flag Management based on OpenFeature specs.
- Added
FeatureBuilder
andFeatureScope
.
1.3.0 #
May 12, 2022
- Added
BridgeGatewayProvider
- Fixed issue with content-type being appended with charset.
- [Breaking] Added separate constructor for providing custom
GraphQLService
toGraphQLExternalInterface
. - [Breaking] Token should be passed using
GraphQLToken
instead ofGraphQLTokenBuilder
. - Added passing fetch policy to GraphQL requests.
- Added support to modify persistence option for
GraphQLExternalInterface
. - Upgraded dependencies.
- [Breaking] Bumped minimum Flutter version to
3.0.0
.
1.2.1 #
Apr 25, 2022
- Added
uiTestWidgetBuilder
. - Added
merge
property to FirebaseWriteRequest. - Made
id
in FirebaseWriteRequest optional. - Added loggers for GraphQL and REST services. The logs can be disabled with the following snippet.
CleanFrameworkObserver.instance = CleanFrameworkObserver(enableNetworkLogs: false);
1.2.0 #
Mar 20, 2022
- Added
debounce
method to UseCase. - Fixed issue with Form URLEncoded request body format.
- [Breaking] Upgraded
mockoon
to v0.3.0
[1.1.6] - Mar 1, 2022 #
- Added
didUpdatePresenter
to Presenter. - Added
timeout
support for GraphQL requests. - Upgraded dependencies.
- Migrated example app to Android v2 embedding.
[1.1.5] - Jan 10, 2022 #
- Added
tokenBuilder
andauthHeaderKey
for GraphQLExternalInterface. - Added
headers
in rest requests. - Now Map<String, dynamic> can be sent in POST request using content types other than url-encoded. (Previously, only url-encoded POST request were supported).
- Added
application/json
as default content type for all rest requests andutf-8
as default encoding. - Removed
intitialTimeout
from uiTest as it's been deprecated. - Added route state to navigator builder.
- Upgraded dependencies.
[1.1.4] - Dec 8, 2021 #
- Added
observers
andnavigatorBuilder
to AppRouter. - Improved duplication handling logic for
onOutputUpdate
. - Added
postFrame
callback to uiTest, which overrides the defaultpumpAndSettle
. Fixes #31. - Added
router
argument to uiTest to enable navigating between routes inside the test block. - Added
setupUITest()
method to setup provider context and router for all the subsequent uiTests.
1.1.3 Upgraded to stable version of riverpod
#
riverpod
version upgraded to^1.0.0
1.1.2 Introduction Codelab #
- Added the Introduction to Clean Framework Codelab under the docs folder. The codelab is also published, see the public link on the README file.
1.1.1 Mixed External Interface and Router #
-
Merged into one class the Direct and Watcher External Interfaces, this is a breaking change for any class using this ancestor. The [onTransport] method is replaced by [handleRequest]. Please refer to the code example and tests to understand the migration effort.
-
Added a new Router based on the library Go Router. This default is much easier to use and can be overridden during tests. Please refer to the code example for usage.
-
Minor refactor changes to remove unnecessary or duplicated code. This includes the removal of the Equatable ancestor on Inputs and derivatives, given that during tests is not practical to compare inputs. If your implementation does these comparisons on tests, you can implement the EquatableMixin in your Input implementations.
1.0.0-prerelease #
- First release of our improved library. The stable of classes and utilities included allows the implementation of Bob Martin's Clean Architecture with defined layer separation, using Riverpod-style Providers.