diff --git a/.DS_Store b/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..12630dfe06e20498e0ffad36b20832b86f10bd70 Binary files /dev/null and b/.DS_Store differ diff --git a/.idea/.DS_Store b/.idea/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..4e30f4fde49661db81f7af37419b605bee15a047 Binary files /dev/null and b/.idea/.DS_Store differ diff --git a/.idea/libraries/Dart_SDK.xml b/.idea/libraries/Dart_SDK.xml new file mode 100644 index 0000000000000000000000000000000000000000..5c6074254599adbdeda9e410308b500058bab807 --- /dev/null +++ b/.idea/libraries/Dart_SDK.xml @@ -0,0 +1,19 @@ + + + + + + + + + + + + + + + + + + + \ No newline at end of file diff --git a/.idea/libraries/KotlinJavaRuntime.xml b/.idea/libraries/KotlinJavaRuntime.xml new file mode 100644 index 0000000000000000000000000000000000000000..2b96ac4b75c02b556cd5829e3d9e2fa629342b12 --- /dev/null +++ b/.idea/libraries/KotlinJavaRuntime.xml @@ -0,0 +1,15 @@ + + + + + + + + + + + + + + + diff --git a/.idea/modules.xml b/.idea/modules.xml new file mode 100644 index 0000000000000000000000000000000000000000..8d65d967bcc8751b137829c4c9aaf41f2d1fca68 --- /dev/null +++ b/.idea/modules.xml @@ -0,0 +1,9 @@ + + + + + + + + + diff --git a/.idea/runConfigurations/main_dart.xml b/.idea/runConfigurations/main_dart.xml new file mode 100644 index 0000000000000000000000000000000000000000..aab7b5cd8325696835286f195527e16ffb1f675a --- /dev/null +++ b/.idea/runConfigurations/main_dart.xml @@ -0,0 +1,6 @@ + + + + \ No newline at end of file diff --git a/.idea/workspace.xml b/.idea/workspace.xml new file mode 100644 index 0000000000000000000000000000000000000000..5b3388cc1afe59399989af57ab870fba219cf804 --- /dev/null +++ b/.idea/workspace.xml @@ -0,0 +1,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/.metadata b/.metadata new file mode 100644 index 0000000000000000000000000000000000000000..b4fb385315ded82c228b37acfc4ffd859a2379da --- /dev/null +++ b/.metadata @@ -0,0 +1,30 @@ +# This file tracks properties of this Flutter project. +# Used by Flutter tool to assess capabilities and perform upgrades etc. +# +# This file should be version controlled and should not be manually edited. + +version: + revision: "35c388afb57ef061d06a39b537336c87e0e3d1b1" + channel: "stable" + +project_type: app + +# Tracks metadata for the flutter migrate command +migration: + platforms: + - platform: root + create_revision: 35c388afb57ef061d06a39b537336c87e0e3d1b1 + base_revision: 35c388afb57ef061d06a39b537336c87e0e3d1b1 + - platform: ios + create_revision: 35c388afb57ef061d06a39b537336c87e0e3d1b1 + base_revision: 35c388afb57ef061d06a39b537336c87e0e3d1b1 + + # User provided section + + # List of Local paths (relative to this file) that should be + # ignored by the migrate tool. + # + # Files that are not part of the templates will be ignored by default. + unmanaged_files: + - 'lib/main.dart' + - 'ios/Runner.xcodeproj/project.pbxproj' diff --git a/.vscode/launch.json b/.vscode/launch.json new file mode 100644 index 0000000000000000000000000000000000000000..6771c8c0431ec23443ee23e524882ae349825892 --- /dev/null +++ b/.vscode/launch.json @@ -0,0 +1,25 @@ +{ + // Use IntelliSense to learn about possible attributes. + // Hover to view descriptions of existing attributes. + // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387 + "version": "0.2.0", + "configurations": [ + { + "name": "Debug", + "request": "launch", + "type": "dart" + }, + { + "name": "Profile", + "request": "launch", + "type": "dart", + "flutterMode": "profile" + }, + { + "name": "Release", + "request": "launch", + "type": "dart", + "flutterMode": "release" + } + ] +} \ No newline at end of file diff --git a/README.md b/README.md index bea8c78070a3cef9509ea662662ed6faad20e42d..6d363250f8bf200218f93c0cc00f6d4c8cc1f1f9 100644 --- a/README.md +++ b/README.md @@ -1,93 +1,73 @@ -# teste-flutter - - - -## Getting started - -To make it easy for you to get started with GitLab, here's a list of recommended next steps. - -Already a pro? Just edit this README.md and make it your own. Want to make it easy? [Use the template at the bottom](#editing-this-readme)! - -## Add your files - -- [ ] [Create](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#create-a-file) or [upload](https://docs.gitlab.com/ee/user/project/repository/web_editor.html#upload-a-file) files -- [ ] [Add files using the command line](https://docs.gitlab.com/ee/gitlab-basics/add-file.html#add-a-file-using-the-command-line) or push an existing Git repository with the following command: - -``` -cd existing_repo -git remote add origin https://git.rarolabs.com.br/teste-conhecimento/teste-flutter.git -git branch -M main -git push -uf origin main -``` - -## Integrate with your tools - -- [ ] [Set up project integrations](https://git.rarolabs.com.br/teste-conhecimento/teste-flutter/-/settings/integrations) - -## Collaborate with your team - -- [ ] [Invite team members and collaborators](https://docs.gitlab.com/ee/user/project/members/) -- [ ] [Create a new merge request](https://docs.gitlab.com/ee/user/project/merge_requests/creating_merge_requests.html) -- [ ] [Automatically close issues from merge requests](https://docs.gitlab.com/ee/user/project/issues/managing_issues.html#closing-issues-automatically) -- [ ] [Enable merge request approvals](https://docs.gitlab.com/ee/user/project/merge_requests/approvals/) -- [ ] [Set auto-merge](https://docs.gitlab.com/ee/user/project/merge_requests/merge_when_pipeline_succeeds.html) - -## Test and Deploy - -Use the built-in continuous integration in GitLab. - -- [ ] [Get started with GitLab CI/CD](https://docs.gitlab.com/ee/ci/quick_start/index.html) -- [ ] [Analyze your code for known vulnerabilities with Static Application Security Testing (SAST)](https://docs.gitlab.com/ee/user/application_security/sast/) -- [ ] [Deploy to Kubernetes, Amazon EC2, or Amazon ECS using Auto Deploy](https://docs.gitlab.com/ee/topics/autodevops/requirements.html) -- [ ] [Use pull-based deployments for improved Kubernetes management](https://docs.gitlab.com/ee/user/clusters/agent/) -- [ ] [Set up protected environments](https://docs.gitlab.com/ee/ci/environments/protected_environments.html) - -*** - -# Editing this README - -When you're ready to make this README your own, just edit this file and use the handy template below (or feel free to structure it however you want - this is just a starting point!). Thanks to [makeareadme.com](https://www.makeareadme.com/) for this template. - -## Suggestions for a good README - -Every project is different, so consider which of these sections apply to yours. The sections used in the template are suggestions for most open source projects. Also keep in mind that while a README can be too long and detailed, too long is better than too short. If you think your README is too long, consider utilizing another form of documentation rather than cutting out information. - -## Name -Choose a self-explaining name for your project. - -## Description -Let people know what your project can do specifically. Provide context and add a link to any reference visitors might be unfamiliar with. A list of Features or a Background subsection can also be added here. If there are alternatives to your project, this is a good place to list differentiating factors. - -## Badges -On some READMEs, you may see small images that convey metadata, such as whether or not all the tests are passing for the project. You can use Shields to add some to your README. Many services also have instructions for adding a badge. - -## Visuals -Depending on what you are making, it can be a good idea to include screenshots or even a video (you'll frequently see GIFs rather than actual videos). Tools like ttygif can help, but check out Asciinema for a more sophisticated method. - -## Installation -Within a particular ecosystem, there may be a common way of installing things, such as using Yarn, NuGet, or Homebrew. However, consider the possibility that whoever is reading your README is a novice and would like more guidance. Listing specific steps helps remove ambiguity and gets people to using your project as quickly as possible. If it only runs in a specific context like a particular programming language version or operating system or has dependencies that have to be installed manually, also add a Requirements subsection. - -## Usage -Use examples liberally, and show the expected output if you can. It's helpful to have inline the smallest example of usage that you can demonstrate, while providing links to more sophisticated examples if they are too long to reasonably include in the README. - -## Support -Tell people where they can go to for help. It can be any combination of an issue tracker, a chat room, an email address, etc. - -## Roadmap -If you have ideas for releases in the future, it is a good idea to list them in the README. - -## Contributing -State if you are open to contributions and what your requirements are for accepting them. - -For people who want to make changes to your project, it's helpful to have some documentation on how to get started. Perhaps there is a script that they should run or some environment variables that they need to set. Make these steps explicit. These instructions could also be useful to your future self. - -You can also document commands to lint the code or run tests. These steps help to ensure high code quality and reduce the likelihood that the changes inadvertently break something. Having instructions for running tests is especially helpful if it requires external setup, such as starting a Selenium server for testing in a browser. - -## Authors and acknowledgment -Show your appreciation to those who have contributed to the project. - -## License -For open source projects, say how it is licensed. - -## Project status -If you have run out of energy or time for your project, put a note at the top of the README saying that development has slowed down or stopped completely. Someone may choose to fork your project or volunteer to step in as a maintainer or owner, allowing your project to keep going. You can also make an explicit request for maintainers. +# Teste Técnico - Desenvolvedor Flutter + +## Objetivo +O objetivo deste teste técnico é avaliar suas habilidades no desenvolvimento de interfaces em Flutter, seguindo boas práticas de código, organização do projeto e implementação de testes. Você deverá dar sequência à base do projeto fornecido, reproduzindo a tela conforme o protótipo no [Figma](https://www.figma.com/design/QWC5IksyTx2k65ZzkPz3r1/Processo-seletivo---Dev-flutter?node-id=1-4313&t=WNNCW8T4MMI6Z9M8-1). + +***Alguns packages já foram incluídos no projeto, fique a vontade para substitui-los, propor melhorias na arquitetura atual.*** + +## Requisitos +- Implementar uma tela onde o usuário poderá visualizar uma **lista de informações** sobre **transactions** e **schedules**. +- Implementar um **BottomSheet** que permitirá ocultar ou exibir dados sobre os itens do **schedule**. +- Seguir as diretrizes do **protótipo no Figma**. +- Escrever **testes unitários** e **testes de widget**. +- Utilizar o BLoC como gerenciamento de estado. +- Comportamentos esperados para a tela: + - Em estado de loading os widgets devem exibir um shimmer no lugar dos dados; + - A tela deve ter um scroll único de forma geral, não sendo permitido a existência de scrolls aninhados; + +## Boas Práticas +Para garantir um código bem estruturado e manutenível, siga as seguintes diretrizes: + +- **Responsividade:** Certifique-se de que a tela funcione corretamente em diferentes tamanhos de dispositivos. +- **Componentização:** Separe os widgets reutilizáveis para facilitar a organização do código. +- **Acessibilidade:** Considere a acessibilidade ao desenvolver os componentes visuais. +- **Manutenção:** Nomeie variáveis, métodos e classes de forma clara e significativa. +- **Tratamento de Erros:** Implemente tratamento de erros para melhorar a experiência do usuário. +- **Seguir a Arquitetura do Projeto:** Mantenha o código organizado e dentro da estrutura já existente no projeto base. + +## Testes +- É **obrigatório** implementar **testes unitários** para as regras de negócio, validações e/ou camadas que julgar necessário. +- **Opcional:** Implementação de **testes de integração** para garantir a funcionalidade correta da interface e interação do usuário. + +## Entrega +1. Faça um fork ou clone do repositório base fornecido. +2. Desenvolva as funcionalidades seguindo os requisitos. +3. Submeta o código em um repositório público ou envie um link para o repositório privado. + +Boa sorte! 🚀 + +## Informações adicionais +- Versão do Flutter utilizado para criação do projeto base: 3.29.0; +- As telas do Figma estão em protótipo, então é possível navegar para entender melhor o comportamento das telas; +- Estrutura base do Projeto + ``` + lib/ + └── src/ + ├── core/ + │ ├── base/ + │ │ ├── constants/ # Constantes globais do projeto + │ │ ├── errors/ # Definições de erros e exceções + │ │ ├── interfaces/ # Interfaces para abstração + │ │ ├── base.dart + │ ├── utils/ # Funções auxiliares e extensões + │ ├── core.dart # Arquivo principal do core + ├── modules/ + │ ├── payments/ # Módulo de pagamentos + │ │ ├── data/ # Camada de dados + │ │ │ ├── datasource/ + │ │ │ ├── model/ + │ │ │ ├── repository/ + │ │ ├── domain/ # Camada de domínio + │ │ │ ├── entity/ + │ │ │ ├── repository/ + │ │ │ ├── usecase/ + │ │ ├── infra/ # Infraestrutura + │ │ │ ├── datasource/ + │ │ │ ├── mock/ + │ │ ├── presentation/ # Camada de apresentação + │ │ │ ├── bloc/ + │ │ │ ├── page/ + ├── app_widget.dart # Widget principal do app + ├── main.dart # Ponto de entrada do app + test/ # Testes unitários + ``` \ No newline at end of file diff --git a/analysis_options.yaml b/analysis_options.yaml new file mode 100644 index 0000000000000000000000000000000000000000..0d2902135caece481a035652d88970c80e29cc7e --- /dev/null +++ b/analysis_options.yaml @@ -0,0 +1,28 @@ +# This file configures the analyzer, which statically analyzes Dart code to +# check for errors, warnings, and lints. +# +# The issues identified by the analyzer are surfaced in the UI of Dart-enabled +# IDEs (https://dart.dev/tools#ides-and-editors). The analyzer can also be +# invoked from the command line by running `flutter analyze`. + +# The following line activates a set of recommended lints for Flutter apps, +# packages, and plugins designed to encourage good coding practices. +include: package:flutter_lints/flutter.yaml + +linter: + # The lint rules applied to this project can be customized in the + # section below to disable rules from the `package:flutter_lints/flutter.yaml` + # included above or to enable additional rules. A list of all available lints + # and their documentation is published at https://dart.dev/lints. + # + # Instead of disabling a lint rule for the entire project in the + # section below, it can also be suppressed for a single line of code + # or a specific dart file by using the `// ignore: name_of_lint` and + # `// ignore_for_file: name_of_lint` syntax on the line or in the file + # producing the lint. + rules: + # avoid_print: false # Uncomment to disable the `avoid_print` rule + # prefer_single_quotes: true # Uncomment to enable the `prefer_single_quotes` rule + +# Additional information about this file can be found at +# https://dart.dev/guides/language/analysis-options diff --git a/android/.DS_Store b/android/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..e3719c81a6d9224f435c8549faf60f6b167da6d5 Binary files /dev/null and b/android/.DS_Store differ diff --git a/android/.gitignore b/android/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..be3943c96d8eed92e2a329ce8327616d5e7dc440 --- /dev/null +++ b/android/.gitignore @@ -0,0 +1,14 @@ +gradle-wrapper.jar +/.gradle +/captures/ +/gradlew +/gradlew.bat +/local.properties +GeneratedPluginRegistrant.java +.cxx/ + +# Remember to never publicly share your keystore. +# See https://flutter.dev/to/reference-keystore +key.properties +**/*.keystore +**/*.jks diff --git a/android/app/build.gradle.kts b/android/app/build.gradle.kts new file mode 100644 index 0000000000000000000000000000000000000000..7d4ef0b0d39d5d91aba2e46befefaf5ef7da2db5 --- /dev/null +++ b/android/app/build.gradle.kts @@ -0,0 +1,44 @@ +plugins { + id("com.android.application") + id("kotlin-android") + // The Flutter Gradle Plugin must be applied after the Android and Kotlin Gradle plugins. + id("dev.flutter.flutter-gradle-plugin") +} + +android { + namespace = "br.com.exemplo.base_project" + compileSdk = flutter.compileSdkVersion + ndkVersion = flutter.ndkVersion + + compileOptions { + sourceCompatibility = JavaVersion.VERSION_11 + targetCompatibility = JavaVersion.VERSION_11 + } + + kotlinOptions { + jvmTarget = JavaVersion.VERSION_11.toString() + } + + defaultConfig { + // TODO: Specify your own unique Application ID (https://developer.android.com/studio/build/application-id.html). + applicationId = "br.com.exemplo.base_project" + // You can update the following values to match your application needs. + // For more information, see: https://flutter.dev/to/review-gradle-config. + minSdk = flutter.minSdkVersion + targetSdk = flutter.targetSdkVersion + versionCode = flutter.versionCode + versionName = flutter.versionName + } + + buildTypes { + release { + // TODO: Add your own signing config for the release build. + // Signing with the debug keys for now, so `flutter run --release` works. + signingConfig = signingConfigs.getByName("debug") + } + } +} + +flutter { + source = "../.." +} diff --git a/android/app/src/debug/AndroidManifest.xml b/android/app/src/debug/AndroidManifest.xml new file mode 100644 index 0000000000000000000000000000000000000000..399f6981d5d35475eb18e6068ae67cdd7c731978 --- /dev/null +++ b/android/app/src/debug/AndroidManifest.xml @@ -0,0 +1,7 @@ + + + + diff --git a/android/app/src/main/AndroidManifest.xml b/android/app/src/main/AndroidManifest.xml new file mode 100644 index 0000000000000000000000000000000000000000..44ec2506da49e2b64d034d14fc2da09668c95bb8 --- /dev/null +++ b/android/app/src/main/AndroidManifest.xml @@ -0,0 +1,45 @@ + + + + + + + + + + + + + + + + + + + + + diff --git a/android/app/src/main/kotlin/br/com/exemplo/base_project/MainActivity.kt b/android/app/src/main/kotlin/br/com/exemplo/base_project/MainActivity.kt new file mode 100644 index 0000000000000000000000000000000000000000..0c7ff12871bd776ed7cac8659006c4ba7b69c77d --- /dev/null +++ b/android/app/src/main/kotlin/br/com/exemplo/base_project/MainActivity.kt @@ -0,0 +1,5 @@ +package br.com.exemplo.base_project + +import io.flutter.embedding.android.FlutterActivity + +class MainActivity : FlutterActivity() diff --git a/android/app/src/main/res/drawable-v21/launch_background.xml b/android/app/src/main/res/drawable-v21/launch_background.xml new file mode 100644 index 0000000000000000000000000000000000000000..f74085f3f6a2b995f8ad1f9ff7b2c46dc118a9e0 --- /dev/null +++ b/android/app/src/main/res/drawable-v21/launch_background.xml @@ -0,0 +1,12 @@ + + + + + + + + diff --git a/android/app/src/main/res/drawable/launch_background.xml b/android/app/src/main/res/drawable/launch_background.xml new file mode 100644 index 0000000000000000000000000000000000000000..304732f8842013497e14bd02f67a55f2614fb8f7 --- /dev/null +++ b/android/app/src/main/res/drawable/launch_background.xml @@ -0,0 +1,12 @@ + + + + + + + + diff --git a/android/app/src/main/res/mipmap-hdpi/ic_launcher.png b/android/app/src/main/res/mipmap-hdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..db77bb4b7b0906d62b1847e87f15cdcacf6a4f29 Binary files /dev/null and b/android/app/src/main/res/mipmap-hdpi/ic_launcher.png differ diff --git a/android/app/src/main/res/mipmap-mdpi/ic_launcher.png b/android/app/src/main/res/mipmap-mdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..17987b79bb8a35cc66c3c1fd44f5a5526c1b78be Binary files /dev/null and b/android/app/src/main/res/mipmap-mdpi/ic_launcher.png differ diff --git a/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png b/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..09d4391482be68e9e4a07fab769b5de337d16eb1 Binary files /dev/null and b/android/app/src/main/res/mipmap-xhdpi/ic_launcher.png differ diff --git a/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png b/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..d5f1c8d34e7a88e3f88bea192c3a370d44689c3c Binary files /dev/null and b/android/app/src/main/res/mipmap-xxhdpi/ic_launcher.png differ diff --git a/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png b/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png new file mode 100644 index 0000000000000000000000000000000000000000..4d6372eebdb28e45604e46eeda8dd24651419bc0 Binary files /dev/null and b/android/app/src/main/res/mipmap-xxxhdpi/ic_launcher.png differ diff --git a/android/app/src/main/res/values-night/styles.xml b/android/app/src/main/res/values-night/styles.xml new file mode 100644 index 0000000000000000000000000000000000000000..06952be745f9fa6fa75196e830d9578eb2ee631d --- /dev/null +++ b/android/app/src/main/res/values-night/styles.xml @@ -0,0 +1,18 @@ + + + + + + + diff --git a/android/app/src/main/res/values/styles.xml b/android/app/src/main/res/values/styles.xml new file mode 100644 index 0000000000000000000000000000000000000000..cb1ef88056edd1caf99a935e434e7ff6943a0ef6 --- /dev/null +++ b/android/app/src/main/res/values/styles.xml @@ -0,0 +1,18 @@ + + + + + + + diff --git a/android/app/src/profile/AndroidManifest.xml b/android/app/src/profile/AndroidManifest.xml new file mode 100644 index 0000000000000000000000000000000000000000..399f6981d5d35475eb18e6068ae67cdd7c731978 --- /dev/null +++ b/android/app/src/profile/AndroidManifest.xml @@ -0,0 +1,7 @@ + + + + diff --git a/android/base_project_android.iml b/android/base_project_android.iml new file mode 100644 index 0000000000000000000000000000000000000000..18999696a6a38a49db82f0985800071ee2884f24 --- /dev/null +++ b/android/base_project_android.iml @@ -0,0 +1,29 @@ + + + + + + + + + + + + + + + + + + + + + diff --git a/android/build.gradle.kts b/android/build.gradle.kts new file mode 100644 index 0000000000000000000000000000000000000000..89176ef44e8c7931fa32322d576e7f3f54d225c9 --- /dev/null +++ b/android/build.gradle.kts @@ -0,0 +1,21 @@ +allprojects { + repositories { + google() + mavenCentral() + } +} + +val newBuildDir: Directory = rootProject.layout.buildDirectory.dir("../../build").get() +rootProject.layout.buildDirectory.value(newBuildDir) + +subprojects { + val newSubprojectBuildDir: Directory = newBuildDir.dir(project.name) + project.layout.buildDirectory.value(newSubprojectBuildDir) +} +subprojects { + project.evaluationDependsOn(":app") +} + +tasks.register("clean") { + delete(rootProject.layout.buildDirectory) +} diff --git a/android/gradle.properties b/android/gradle.properties new file mode 100644 index 0000000000000000000000000000000000000000..f018a61817f55e78bb92ce8df2dda423ec570a4a --- /dev/null +++ b/android/gradle.properties @@ -0,0 +1,3 @@ +org.gradle.jvmargs=-Xmx8G -XX:MaxMetaspaceSize=4G -XX:ReservedCodeCacheSize=512m -XX:+HeapDumpOnOutOfMemoryError +android.useAndroidX=true +android.enableJetifier=true diff --git a/android/gradle/wrapper/gradle-wrapper.properties b/android/gradle/wrapper/gradle-wrapper.properties new file mode 100644 index 0000000000000000000000000000000000000000..afa1e8eb0a835ba6be2286d1b399c4e47b7a79a0 --- /dev/null +++ b/android/gradle/wrapper/gradle-wrapper.properties @@ -0,0 +1,5 @@ +distributionBase=GRADLE_USER_HOME +distributionPath=wrapper/dists +zipStoreBase=GRADLE_USER_HOME +zipStorePath=wrapper/dists +distributionUrl=https\://services.gradle.org/distributions/gradle-8.10.2-all.zip diff --git a/android/settings.gradle.kts b/android/settings.gradle.kts new file mode 100644 index 0000000000000000000000000000000000000000..a439442c20990307318ed9ca06dcc7b0bc49f871 --- /dev/null +++ b/android/settings.gradle.kts @@ -0,0 +1,25 @@ +pluginManagement { + val flutterSdkPath = run { + val properties = java.util.Properties() + file("local.properties").inputStream().use { properties.load(it) } + val flutterSdkPath = properties.getProperty("flutter.sdk") + require(flutterSdkPath != null) { "flutter.sdk not set in local.properties" } + flutterSdkPath + } + + includeBuild("$flutterSdkPath/packages/flutter_tools/gradle") + + repositories { + google() + mavenCentral() + gradlePluginPortal() + } +} + +plugins { + id("dev.flutter.flutter-plugin-loader") version "1.0.0" + id("com.android.application") version "8.7.0" apply false + id("org.jetbrains.kotlin.android") version "1.8.22" apply false +} + +include(":app") diff --git a/base_project.iml b/base_project.iml new file mode 100644 index 0000000000000000000000000000000000000000..f66303d5303cad853ed5f0cbceeb742c6bc9a025 --- /dev/null +++ b/base_project.iml @@ -0,0 +1,17 @@ + + + + + + + + + + + + + + + + + diff --git a/ios/.DS_Store b/ios/.DS_Store new file mode 100644 index 0000000000000000000000000000000000000000..94e1cb0ae32746d8439a6629896f5475e856c445 Binary files /dev/null and b/ios/.DS_Store differ diff --git a/ios/.gitignore b/ios/.gitignore new file mode 100644 index 0000000000000000000000000000000000000000..7a7f9873ad7dceb4dc17087fb06c800fa0191376 --- /dev/null +++ b/ios/.gitignore @@ -0,0 +1,34 @@ +**/dgph +*.mode1v3 +*.mode2v3 +*.moved-aside +*.pbxuser +*.perspectivev3 +**/*sync/ +.sconsign.dblite +.tags* +**/.vagrant/ +**/DerivedData/ +Icon? +**/Pods/ +**/.symlinks/ +profile +xcuserdata +**/.generated/ +Flutter/App.framework +Flutter/Flutter.framework +Flutter/Flutter.podspec +Flutter/Generated.xcconfig +Flutter/ephemeral/ +Flutter/app.flx +Flutter/app.zip +Flutter/flutter_assets/ +Flutter/flutter_export_environment.sh +ServiceDefinitions.json +Runner/GeneratedPluginRegistrant.* + +# Exceptions to above rules. +!default.mode1v3 +!default.mode2v3 +!default.pbxuser +!default.perspectivev3 diff --git a/ios/Flutter/AppFrameworkInfo.plist b/ios/Flutter/AppFrameworkInfo.plist new file mode 100644 index 0000000000000000000000000000000000000000..7c56964006274498b0edaa77763cdd72c6d42b6a --- /dev/null +++ b/ios/Flutter/AppFrameworkInfo.plist @@ -0,0 +1,26 @@ + + + + + CFBundleDevelopmentRegion + en + CFBundleExecutable + App + CFBundleIdentifier + io.flutter.flutter.app + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + App + CFBundlePackageType + FMWK + CFBundleShortVersionString + 1.0 + CFBundleSignature + ???? + CFBundleVersion + 1.0 + MinimumOSVersion + 12.0 + + diff --git a/ios/Flutter/Debug.xcconfig b/ios/Flutter/Debug.xcconfig new file mode 100644 index 0000000000000000000000000000000000000000..592ceee85b89bd111b779db6116b130509ab6d4b --- /dev/null +++ b/ios/Flutter/Debug.xcconfig @@ -0,0 +1 @@ +#include "Generated.xcconfig" diff --git a/ios/Flutter/Release.xcconfig b/ios/Flutter/Release.xcconfig new file mode 100644 index 0000000000000000000000000000000000000000..592ceee85b89bd111b779db6116b130509ab6d4b --- /dev/null +++ b/ios/Flutter/Release.xcconfig @@ -0,0 +1 @@ +#include "Generated.xcconfig" diff --git a/ios/Runner.xcodeproj/project.pbxproj b/ios/Runner.xcodeproj/project.pbxproj new file mode 100644 index 0000000000000000000000000000000000000000..05cdc9a94ec7df2ac76bc71a23ed419ed6a59bfc --- /dev/null +++ b/ios/Runner.xcodeproj/project.pbxproj @@ -0,0 +1,619 @@ +// !$*UTF8*$! +{ + archiveVersion = 1; + classes = { + }; + objectVersion = 54; + objects = { + +/* Begin PBXBuildFile section */ + 1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; }; + 331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; }; + 3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; }; + 74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */ = {isa = PBXBuildFile; fileRef = 74858FAE1ED2DC5600515810 /* AppDelegate.swift */; }; + 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FA1CF9000F007C117D /* Main.storyboard */; }; + 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FD1CF9000F007C117D /* Assets.xcassets */; }; + 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */ = {isa = PBXBuildFile; fileRef = 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */; }; +/* End PBXBuildFile section */ + +/* Begin PBXContainerItemProxy section */ + 331C8085294A63A400263BE5 /* PBXContainerItemProxy */ = { + isa = PBXContainerItemProxy; + containerPortal = 97C146E61CF9000F007C117D /* Project object */; + proxyType = 1; + remoteGlobalIDString = 97C146ED1CF9000F007C117D; + remoteInfo = Runner; + }; +/* End PBXContainerItemProxy section */ + +/* Begin PBXCopyFilesBuildPhase section */ + 9705A1C41CF9048500538489 /* Embed Frameworks */ = { + isa = PBXCopyFilesBuildPhase; + buildActionMask = 2147483647; + dstPath = ""; + dstSubfolderSpec = 10; + files = ( + ); + name = "Embed Frameworks"; + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXCopyFilesBuildPhase section */ + +/* Begin PBXFileReference section */ + 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = ""; }; + 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = ""; }; + 331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = ""; }; + 331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; }; + 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = ""; }; + 74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = ""; }; + 74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = ""; }; + 7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = ""; }; + 9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = ""; }; + 9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = ""; }; + 97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; }; + 97C146FB1CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/Main.storyboard; sourceTree = ""; }; + 97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = ""; }; + 97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = ""; }; + 97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = ""; }; +/* End PBXFileReference section */ + +/* Begin PBXFrameworksBuildPhase section */ + 97C146EB1CF9000F007C117D /* Frameworks */ = { + isa = PBXFrameworksBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXFrameworksBuildPhase section */ + +/* Begin PBXGroup section */ + 331C8082294A63A400263BE5 /* RunnerTests */ = { + isa = PBXGroup; + children = ( + 331C807B294A618700263BE5 /* RunnerTests.swift */, + ); + path = RunnerTests; + sourceTree = ""; + }; + 9740EEB11CF90186004384FC /* Flutter */ = { + isa = PBXGroup; + children = ( + 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */, + 9740EEB21CF90195004384FC /* Debug.xcconfig */, + 7AFA3C8E1D35360C0083082E /* Release.xcconfig */, + 9740EEB31CF90195004384FC /* Generated.xcconfig */, + ); + name = Flutter; + sourceTree = ""; + }; + 97C146E51CF9000F007C117D = { + isa = PBXGroup; + children = ( + 9740EEB11CF90186004384FC /* Flutter */, + 97C146F01CF9000F007C117D /* Runner */, + 97C146EF1CF9000F007C117D /* Products */, + 331C8082294A63A400263BE5 /* RunnerTests */, + ); + sourceTree = ""; + }; + 97C146EF1CF9000F007C117D /* Products */ = { + isa = PBXGroup; + children = ( + 97C146EE1CF9000F007C117D /* Runner.app */, + 331C8081294A63A400263BE5 /* RunnerTests.xctest */, + ); + name = Products; + sourceTree = ""; + }; + 97C146F01CF9000F007C117D /* Runner */ = { + isa = PBXGroup; + children = ( + 97C146FA1CF9000F007C117D /* Main.storyboard */, + 97C146FD1CF9000F007C117D /* Assets.xcassets */, + 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */, + 97C147021CF9000F007C117D /* Info.plist */, + 1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */, + 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */, + 74858FAE1ED2DC5600515810 /* AppDelegate.swift */, + 74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */, + ); + path = Runner; + sourceTree = ""; + }; +/* End PBXGroup section */ + +/* Begin PBXNativeTarget section */ + 331C8080294A63A400263BE5 /* RunnerTests */ = { + isa = PBXNativeTarget; + buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */; + buildPhases = ( + 331C807D294A63A400263BE5 /* Sources */, + 331C807F294A63A400263BE5 /* Resources */, + ); + buildRules = ( + ); + dependencies = ( + 331C8086294A63A400263BE5 /* PBXTargetDependency */, + ); + name = RunnerTests; + productName = RunnerTests; + productReference = 331C8081294A63A400263BE5 /* RunnerTests.xctest */; + productType = "com.apple.product-type.bundle.unit-test"; + }; + 97C146ED1CF9000F007C117D /* Runner */ = { + isa = PBXNativeTarget; + buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */; + buildPhases = ( + 9740EEB61CF901F6004384FC /* Run Script */, + 97C146EA1CF9000F007C117D /* Sources */, + 97C146EB1CF9000F007C117D /* Frameworks */, + 97C146EC1CF9000F007C117D /* Resources */, + 9705A1C41CF9048500538489 /* Embed Frameworks */, + 3B06AD1E1E4923F5004D2608 /* Thin Binary */, + ); + buildRules = ( + ); + dependencies = ( + ); + name = Runner; + productName = Runner; + productReference = 97C146EE1CF9000F007C117D /* Runner.app */; + productType = "com.apple.product-type.application"; + }; +/* End PBXNativeTarget section */ + +/* Begin PBXProject section */ + 97C146E61CF9000F007C117D /* Project object */ = { + isa = PBXProject; + attributes = { + BuildIndependentTargetsInParallel = YES; + LastUpgradeCheck = 1510; + ORGANIZATIONNAME = ""; + TargetAttributes = { + 331C8080294A63A400263BE5 = { + CreatedOnToolsVersion = 14.0; + TestTargetID = 97C146ED1CF9000F007C117D; + }; + 97C146ED1CF9000F007C117D = { + CreatedOnToolsVersion = 7.3.1; + LastSwiftMigration = 1100; + }; + }; + }; + buildConfigurationList = 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */; + compatibilityVersion = "Xcode 9.3"; + developmentRegion = en; + hasScannedForEncodings = 0; + knownRegions = ( + en, + Base, + ); + mainGroup = 97C146E51CF9000F007C117D; + productRefGroup = 97C146EF1CF9000F007C117D /* Products */; + projectDirPath = ""; + projectRoot = ""; + targets = ( + 97C146ED1CF9000F007C117D /* Runner */, + 331C8080294A63A400263BE5 /* RunnerTests */, + ); + }; +/* End PBXProject section */ + +/* Begin PBXResourcesBuildPhase section */ + 331C807F294A63A400263BE5 /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 97C146EC1CF9000F007C117D /* Resources */ = { + isa = PBXResourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 97C147011CF9000F007C117D /* LaunchScreen.storyboard in Resources */, + 3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */, + 97C146FE1CF9000F007C117D /* Assets.xcassets in Resources */, + 97C146FC1CF9000F007C117D /* Main.storyboard in Resources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXResourcesBuildPhase section */ + +/* Begin PBXShellScriptBuildPhase section */ + 3B06AD1E1E4923F5004D2608 /* Thin Binary */ = { + isa = PBXShellScriptBuildPhase; + alwaysOutOfDate = 1; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + "${TARGET_BUILD_DIR}/${INFOPLIST_PATH}", + ); + name = "Thin Binary"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin"; + }; + 9740EEB61CF901F6004384FC /* Run Script */ = { + isa = PBXShellScriptBuildPhase; + alwaysOutOfDate = 1; + buildActionMask = 2147483647; + files = ( + ); + inputPaths = ( + ); + name = "Run Script"; + outputPaths = ( + ); + runOnlyForDeploymentPostprocessing = 0; + shellPath = /bin/sh; + shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build"; + }; +/* End PBXShellScriptBuildPhase section */ + +/* Begin PBXSourcesBuildPhase section */ + 331C807D294A63A400263BE5 /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; + 97C146EA1CF9000F007C117D /* Sources */ = { + isa = PBXSourcesBuildPhase; + buildActionMask = 2147483647; + files = ( + 74858FAF1ED2DC5600515810 /* AppDelegate.swift in Sources */, + 1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */, + ); + runOnlyForDeploymentPostprocessing = 0; + }; +/* End PBXSourcesBuildPhase section */ + +/* Begin PBXTargetDependency section */ + 331C8086294A63A400263BE5 /* PBXTargetDependency */ = { + isa = PBXTargetDependency; + target = 97C146ED1CF9000F007C117D /* Runner */; + targetProxy = 331C8085294A63A400263BE5 /* PBXContainerItemProxy */; + }; +/* End PBXTargetDependency section */ + +/* Begin PBXVariantGroup section */ + 97C146FA1CF9000F007C117D /* Main.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 97C146FB1CF9000F007C117D /* Base */, + ); + name = Main.storyboard; + sourceTree = ""; + }; + 97C146FF1CF9000F007C117D /* LaunchScreen.storyboard */ = { + isa = PBXVariantGroup; + children = ( + 97C147001CF9000F007C117D /* Base */, + ); + name = LaunchScreen.storyboard; + sourceTree = ""; + }; +/* End PBXVariantGroup section */ + +/* Begin XCBuildConfiguration section */ + 249021D3217E4FDB00AE95B9 /* Profile */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_USER_SCRIPT_SANDBOXING = NO; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + SUPPORTED_PLATFORMS = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + }; + name = Profile; + }; + 249021D4217E4FDB00AE95B9 /* Profile */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; + DEVELOPMENT_TEAM = FN8N8V3YS6; + ENABLE_BITCODE = NO; + INFOPLIST_FILE = Runner/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = br.com.exemplo.baseProject; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; + SWIFT_VERSION = 5.0; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = Profile; + }; + 331C8088294A63A400263BE5 /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 1; + GENERATE_INFOPLIST_FILE = YES; + MARKETING_VERSION = 1.0; + PRODUCT_BUNDLE_IDENTIFIER = br.com.exemplo.baseProject.RunnerTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_ACTIVE_COMPILATION_CONDITIONS = DEBUG; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 5.0; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner"; + }; + name = Debug; + }; + 331C8089294A63A400263BE5 /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 1; + GENERATE_INFOPLIST_FILE = YES; + MARKETING_VERSION = 1.0; + PRODUCT_BUNDLE_IDENTIFIER = br.com.exemplo.baseProject.RunnerTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner"; + }; + name = Release; + }; + 331C808A294A63A400263BE5 /* Profile */ = { + isa = XCBuildConfiguration; + buildSettings = { + BUNDLE_LOADER = "$(TEST_HOST)"; + CODE_SIGN_STYLE = Automatic; + CURRENT_PROJECT_VERSION = 1; + GENERATE_INFOPLIST_FILE = YES; + MARKETING_VERSION = 1.0; + PRODUCT_BUNDLE_IDENTIFIER = br.com.exemplo.baseProject.RunnerTests; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_VERSION = 5.0; + TEST_HOST = "$(BUILT_PRODUCTS_DIR)/Runner.app/$(BUNDLE_EXECUTABLE_FOLDER_PATH)/Runner"; + }; + name = Profile; + }; + 97C147031CF9000F007C117D /* Debug */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = dwarf; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_TESTABILITY = YES; + ENABLE_USER_SCRIPT_SANDBOXING = NO; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_DYNAMIC_NO_PIC = NO; + GCC_NO_COMMON_BLOCKS = YES; + GCC_OPTIMIZATION_LEVEL = 0; + GCC_PREPROCESSOR_DEFINITIONS = ( + "DEBUG=1", + "$(inherited)", + ); + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + MTL_ENABLE_DEBUG_INFO = YES; + ONLY_ACTIVE_ARCH = YES; + SDKROOT = iphoneos; + TARGETED_DEVICE_FAMILY = "1,2"; + }; + name = Debug; + }; + 97C147041CF9000F007C117D /* Release */ = { + isa = XCBuildConfiguration; + buildSettings = { + ALWAYS_SEARCH_USER_PATHS = NO; + ASSETCATALOG_COMPILER_GENERATE_SWIFT_ASSET_SYMBOL_EXTENSIONS = YES; + CLANG_ANALYZER_NONNULL = YES; + CLANG_CXX_LANGUAGE_STANDARD = "gnu++0x"; + CLANG_CXX_LIBRARY = "libc++"; + CLANG_ENABLE_MODULES = YES; + CLANG_ENABLE_OBJC_ARC = YES; + CLANG_WARN_BLOCK_CAPTURE_AUTORELEASING = YES; + CLANG_WARN_BOOL_CONVERSION = YES; + CLANG_WARN_COMMA = YES; + CLANG_WARN_CONSTANT_CONVERSION = YES; + CLANG_WARN_DEPRECATED_OBJC_IMPLEMENTATIONS = YES; + CLANG_WARN_DIRECT_OBJC_ISA_USAGE = YES_ERROR; + CLANG_WARN_EMPTY_BODY = YES; + CLANG_WARN_ENUM_CONVERSION = YES; + CLANG_WARN_INFINITE_RECURSION = YES; + CLANG_WARN_INT_CONVERSION = YES; + CLANG_WARN_NON_LITERAL_NULL_CONVERSION = YES; + CLANG_WARN_OBJC_IMPLICIT_RETAIN_SELF = YES; + CLANG_WARN_OBJC_LITERAL_CONVERSION = YES; + CLANG_WARN_OBJC_ROOT_CLASS = YES_ERROR; + CLANG_WARN_RANGE_LOOP_ANALYSIS = YES; + CLANG_WARN_STRICT_PROTOTYPES = YES; + CLANG_WARN_SUSPICIOUS_MOVE = YES; + CLANG_WARN_UNREACHABLE_CODE = YES; + CLANG_WARN__DUPLICATE_METHOD_MATCH = YES; + "CODE_SIGN_IDENTITY[sdk=iphoneos*]" = "iPhone Developer"; + COPY_PHASE_STRIP = NO; + DEBUG_INFORMATION_FORMAT = "dwarf-with-dsym"; + ENABLE_NS_ASSERTIONS = NO; + ENABLE_STRICT_OBJC_MSGSEND = YES; + ENABLE_USER_SCRIPT_SANDBOXING = NO; + GCC_C_LANGUAGE_STANDARD = gnu99; + GCC_NO_COMMON_BLOCKS = YES; + GCC_WARN_64_TO_32_BIT_CONVERSION = YES; + GCC_WARN_ABOUT_RETURN_TYPE = YES_ERROR; + GCC_WARN_UNDECLARED_SELECTOR = YES; + GCC_WARN_UNINITIALIZED_AUTOS = YES_AGGRESSIVE; + GCC_WARN_UNUSED_FUNCTION = YES; + GCC_WARN_UNUSED_VARIABLE = YES; + IPHONEOS_DEPLOYMENT_TARGET = 12.0; + MTL_ENABLE_DEBUG_INFO = NO; + SDKROOT = iphoneos; + SUPPORTED_PLATFORMS = iphoneos; + SWIFT_COMPILATION_MODE = wholemodule; + SWIFT_OPTIMIZATION_LEVEL = "-O"; + TARGETED_DEVICE_FAMILY = "1,2"; + VALIDATE_PRODUCT = YES; + }; + name = Release; + }; + 97C147061CF9000F007C117D /* Debug */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 9740EEB21CF90195004384FC /* Debug.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; + DEVELOPMENT_TEAM = FN8N8V3YS6; + ENABLE_BITCODE = NO; + INFOPLIST_FILE = Runner/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = br.com.exemplo.baseProject; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; + SWIFT_OPTIMIZATION_LEVEL = "-Onone"; + SWIFT_VERSION = 5.0; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = Debug; + }; + 97C147071CF9000F007C117D /* Release */ = { + isa = XCBuildConfiguration; + baseConfigurationReference = 7AFA3C8E1D35360C0083082E /* Release.xcconfig */; + buildSettings = { + ASSETCATALOG_COMPILER_APPICON_NAME = AppIcon; + CLANG_ENABLE_MODULES = YES; + CURRENT_PROJECT_VERSION = "$(FLUTTER_BUILD_NUMBER)"; + DEVELOPMENT_TEAM = FN8N8V3YS6; + ENABLE_BITCODE = NO; + INFOPLIST_FILE = Runner/Info.plist; + LD_RUNPATH_SEARCH_PATHS = ( + "$(inherited)", + "@executable_path/Frameworks", + ); + PRODUCT_BUNDLE_IDENTIFIER = br.com.exemplo.baseProject; + PRODUCT_NAME = "$(TARGET_NAME)"; + SWIFT_OBJC_BRIDGING_HEADER = "Runner/Runner-Bridging-Header.h"; + SWIFT_VERSION = 5.0; + VERSIONING_SYSTEM = "apple-generic"; + }; + name = Release; + }; +/* End XCBuildConfiguration section */ + +/* Begin XCConfigurationList section */ + 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 331C8088294A63A400263BE5 /* Debug */, + 331C8089294A63A400263BE5 /* Release */, + 331C808A294A63A400263BE5 /* Profile */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 97C146E91CF9000F007C117D /* Build configuration list for PBXProject "Runner" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 97C147031CF9000F007C117D /* Debug */, + 97C147041CF9000F007C117D /* Release */, + 249021D3217E4FDB00AE95B9 /* Profile */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; + 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */ = { + isa = XCConfigurationList; + buildConfigurations = ( + 97C147061CF9000F007C117D /* Debug */, + 97C147071CF9000F007C117D /* Release */, + 249021D4217E4FDB00AE95B9 /* Profile */, + ); + defaultConfigurationIsVisible = 0; + defaultConfigurationName = Release; + }; +/* End XCConfigurationList section */ + }; + rootObject = 97C146E61CF9000F007C117D /* Project object */; +} diff --git a/ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata b/ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000000000000000000000000000000000000..919434a6254f0e9651f402737811be6634a03e9c --- /dev/null +++ b/ios/Runner.xcodeproj/project.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 0000000000000000000000000000000000000000..18d981003d68d0546c4804ac2ff47dd97c6e7921 --- /dev/null +++ b/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings b/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings new file mode 100644 index 0000000000000000000000000000000000000000..f9b0d7c5ea15f194be85eb6ee8e6721a87ff4644 --- /dev/null +++ b/ios/Runner.xcodeproj/project.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings @@ -0,0 +1,8 @@ + + + + + PreviewsEnabled + + + diff --git a/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme b/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme new file mode 100644 index 0000000000000000000000000000000000000000..15cada4838e2f4cac66c351178305967e0887c1d --- /dev/null +++ b/ios/Runner.xcodeproj/xcshareddata/xcschemes/Runner.xcscheme @@ -0,0 +1,99 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ios/Runner.xcworkspace/contents.xcworkspacedata b/ios/Runner.xcworkspace/contents.xcworkspacedata new file mode 100644 index 0000000000000000000000000000000000000000..1d526a16ed0f1cd0c2409d848bf489b93fefa3b2 --- /dev/null +++ b/ios/Runner.xcworkspace/contents.xcworkspacedata @@ -0,0 +1,7 @@ + + + + + diff --git a/ios/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist b/ios/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist new file mode 100644 index 0000000000000000000000000000000000000000..18d981003d68d0546c4804ac2ff47dd97c6e7921 --- /dev/null +++ b/ios/Runner.xcworkspace/xcshareddata/IDEWorkspaceChecks.plist @@ -0,0 +1,8 @@ + + + + + IDEDidComputeMac32BitWarning + + + diff --git a/ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings b/ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings new file mode 100644 index 0000000000000000000000000000000000000000..f9b0d7c5ea15f194be85eb6ee8e6721a87ff4644 --- /dev/null +++ b/ios/Runner.xcworkspace/xcshareddata/WorkspaceSettings.xcsettings @@ -0,0 +1,8 @@ + + + + + PreviewsEnabled + + + diff --git a/ios/Runner/AppDelegate.swift b/ios/Runner/AppDelegate.swift new file mode 100644 index 0000000000000000000000000000000000000000..626664468b8914efda0addf1322b12b8c0071710 --- /dev/null +++ b/ios/Runner/AppDelegate.swift @@ -0,0 +1,13 @@ +import Flutter +import UIKit + +@main +@objc class AppDelegate: FlutterAppDelegate { + override func application( + _ application: UIApplication, + didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]? + ) -> Bool { + GeneratedPluginRegistrant.register(with: self) + return super.application(application, didFinishLaunchingWithOptions: launchOptions) + } +} diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json new file mode 100644 index 0000000000000000000000000000000000000000..d36b1fab2d9dea668a4f83df94d525897d9e68dd --- /dev/null +++ b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Contents.json @@ -0,0 +1,122 @@ +{ + "images" : [ + { + "size" : "20x20", + "idiom" : "iphone", + "filename" : "Icon-App-20x20@2x.png", + "scale" : "2x" + }, + { + "size" : "20x20", + "idiom" : "iphone", + "filename" : "Icon-App-20x20@3x.png", + "scale" : "3x" + }, + { + "size" : "29x29", + "idiom" : "iphone", + "filename" : "Icon-App-29x29@1x.png", + "scale" : "1x" + }, + { + "size" : "29x29", + "idiom" : "iphone", + "filename" : "Icon-App-29x29@2x.png", + "scale" : "2x" + }, + { + "size" : "29x29", + "idiom" : "iphone", + "filename" : "Icon-App-29x29@3x.png", + "scale" : "3x" + }, + { + "size" : "40x40", + "idiom" : "iphone", + "filename" : "Icon-App-40x40@2x.png", + "scale" : "2x" + }, + { + "size" : "40x40", + "idiom" : "iphone", + "filename" : "Icon-App-40x40@3x.png", + "scale" : "3x" + }, + { + "size" : "60x60", + "idiom" : "iphone", + "filename" : "Icon-App-60x60@2x.png", + "scale" : "2x" + }, + { + "size" : "60x60", + "idiom" : "iphone", + "filename" : "Icon-App-60x60@3x.png", + "scale" : "3x" + }, + { + "size" : "20x20", + "idiom" : "ipad", + "filename" : "Icon-App-20x20@1x.png", + "scale" : "1x" + }, + { + "size" : "20x20", + "idiom" : "ipad", + "filename" : "Icon-App-20x20@2x.png", + "scale" : "2x" + }, + { + "size" : "29x29", + "idiom" : "ipad", + "filename" : "Icon-App-29x29@1x.png", + "scale" : "1x" + }, + { + "size" : "29x29", + "idiom" : "ipad", + "filename" : "Icon-App-29x29@2x.png", + "scale" : "2x" + }, + { + "size" : "40x40", + "idiom" : "ipad", + "filename" : "Icon-App-40x40@1x.png", + "scale" : "1x" + }, + { + "size" : "40x40", + "idiom" : "ipad", + "filename" : "Icon-App-40x40@2x.png", + "scale" : "2x" + }, + { + "size" : "76x76", + "idiom" : "ipad", + "filename" : "Icon-App-76x76@1x.png", + "scale" : "1x" + }, + { + "size" : "76x76", + "idiom" : "ipad", + "filename" : "Icon-App-76x76@2x.png", + "scale" : "2x" + }, + { + "size" : "83.5x83.5", + "idiom" : "ipad", + "filename" : "Icon-App-83.5x83.5@2x.png", + "scale" : "2x" + }, + { + "size" : "1024x1024", + "idiom" : "ios-marketing", + "filename" : "Icon-App-1024x1024@1x.png", + "scale" : "1x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png new file mode 100644 index 0000000000000000000000000000000000000000..dc9ada4725e9b0ddb1deab583e5b5102493aa332 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-1024x1024@1x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png new file mode 100644 index 0000000000000000000000000000000000000000..7353c41ecf9ca08017312dc233d9830079b50717 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@1x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..797d452e458972bab9d994556c8305db4c827017 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@2x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..6ed2d933e1120817fe9182483a228007b18ab6ae Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-20x20@3x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png new file mode 100644 index 0000000000000000000000000000000000000000..4cd7b0099ca80c806f8fe495613e8d6c69460d76 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@1x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..fe730945a01f64a61e2235dbe3f45b08f7729182 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@2x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..321773cd857a8a0f0c9c7d3dc3f5ff4fb298dc10 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-29x29@3x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png new file mode 100644 index 0000000000000000000000000000000000000000..797d452e458972bab9d994556c8305db4c827017 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@1x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..502f463a9bc882b461c96aadf492d1729e49e725 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@2x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..0ec303439225b78712f49115768196d8d76f6790 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-40x40@3x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..0ec303439225b78712f49115768196d8d76f6790 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@2x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..e9f5fea27c705180eb716271f41b582e76dcbd90 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-60x60@3x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png new file mode 100644 index 0000000000000000000000000000000000000000..84ac32ae7d989f82d5e46a60405adcc8279e8001 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@1x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..8953cba09064923c5daf2d37e7c3c836ccdd794b Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-76x76@2x.png differ diff --git a/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..0467bf12aa4d28f374bb26596605a46dcbb3e7c8 Binary files /dev/null and b/ios/Runner/Assets.xcassets/AppIcon.appiconset/Icon-App-83.5x83.5@2x.png differ diff --git a/ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json b/ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json new file mode 100644 index 0000000000000000000000000000000000000000..0bedcf2fd46788ae3a01a423467513ff59b5c120 --- /dev/null +++ b/ios/Runner/Assets.xcassets/LaunchImage.imageset/Contents.json @@ -0,0 +1,23 @@ +{ + "images" : [ + { + "idiom" : "universal", + "filename" : "LaunchImage.png", + "scale" : "1x" + }, + { + "idiom" : "universal", + "filename" : "LaunchImage@2x.png", + "scale" : "2x" + }, + { + "idiom" : "universal", + "filename" : "LaunchImage@3x.png", + "scale" : "3x" + } + ], + "info" : { + "version" : 1, + "author" : "xcode" + } +} diff --git a/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png new file mode 100644 index 0000000000000000000000000000000000000000..9da19eacad3b03bb08bbddbbf4ac48dd78b3d838 Binary files /dev/null and b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage.png differ diff --git a/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png new file mode 100644 index 0000000000000000000000000000000000000000..9da19eacad3b03bb08bbddbbf4ac48dd78b3d838 Binary files /dev/null and b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@2x.png differ diff --git a/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png new file mode 100644 index 0000000000000000000000000000000000000000..9da19eacad3b03bb08bbddbbf4ac48dd78b3d838 Binary files /dev/null and b/ios/Runner/Assets.xcassets/LaunchImage.imageset/LaunchImage@3x.png differ diff --git a/ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md b/ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md new file mode 100644 index 0000000000000000000000000000000000000000..89c2725b70f1882be97f5214fafe22d27a0ec01e --- /dev/null +++ b/ios/Runner/Assets.xcassets/LaunchImage.imageset/README.md @@ -0,0 +1,5 @@ +# Launch Screen Assets + +You can customize the launch screen with your own desired assets by replacing the image files in this directory. + +You can also do it by opening your Flutter project's Xcode project with `open ios/Runner.xcworkspace`, selecting `Runner/Assets.xcassets` in the Project Navigator and dropping in the desired images. \ No newline at end of file diff --git a/ios/Runner/Base.lproj/LaunchScreen.storyboard b/ios/Runner/Base.lproj/LaunchScreen.storyboard new file mode 100644 index 0000000000000000000000000000000000000000..f2e259c7c9390ff69a6bbe1e0907e6dc366848e7 --- /dev/null +++ b/ios/Runner/Base.lproj/LaunchScreen.storyboard @@ -0,0 +1,37 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ios/Runner/Base.lproj/Main.storyboard b/ios/Runner/Base.lproj/Main.storyboard new file mode 100644 index 0000000000000000000000000000000000000000..f3c28516fb38e64d88cfcf5fb1791175df078f2f --- /dev/null +++ b/ios/Runner/Base.lproj/Main.storyboard @@ -0,0 +1,26 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/ios/Runner/Info.plist b/ios/Runner/Info.plist new file mode 100644 index 0000000000000000000000000000000000000000..cb022b0ce0784243b8a3e5d79043c55eda8bc694 --- /dev/null +++ b/ios/Runner/Info.plist @@ -0,0 +1,49 @@ + + + + + CFBundleDevelopmentRegion + $(DEVELOPMENT_LANGUAGE) + CFBundleDisplayName + Base Project + CFBundleExecutable + $(EXECUTABLE_NAME) + CFBundleIdentifier + $(PRODUCT_BUNDLE_IDENTIFIER) + CFBundleInfoDictionaryVersion + 6.0 + CFBundleName + base_project + CFBundlePackageType + APPL + CFBundleShortVersionString + $(FLUTTER_BUILD_NAME) + CFBundleSignature + ???? + CFBundleVersion + $(FLUTTER_BUILD_NUMBER) + LSRequiresIPhoneOS + + UILaunchStoryboardName + LaunchScreen + UIMainStoryboardFile + Main + UISupportedInterfaceOrientations + + UIInterfaceOrientationPortrait + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + UISupportedInterfaceOrientations~ipad + + UIInterfaceOrientationPortrait + UIInterfaceOrientationPortraitUpsideDown + UIInterfaceOrientationLandscapeLeft + UIInterfaceOrientationLandscapeRight + + CADisableMinimumFrameDurationOnPhone + + UIApplicationSupportsIndirectInputEvents + + + diff --git a/ios/Runner/Runner-Bridging-Header.h b/ios/Runner/Runner-Bridging-Header.h new file mode 100644 index 0000000000000000000000000000000000000000..308a2a560b42f17aaf3c36e4e9c8cd07182fbb7e --- /dev/null +++ b/ios/Runner/Runner-Bridging-Header.h @@ -0,0 +1 @@ +#import "GeneratedPluginRegistrant.h" diff --git a/ios/RunnerTests/RunnerTests.swift b/ios/RunnerTests/RunnerTests.swift new file mode 100644 index 0000000000000000000000000000000000000000..86a7c3b1b6119f7dbdb8cec74f1b5b3e076bf949 --- /dev/null +++ b/ios/RunnerTests/RunnerTests.swift @@ -0,0 +1,12 @@ +import Flutter +import UIKit +import XCTest + +class RunnerTests: XCTestCase { + + func testExample() { + // If you add code to the Runner application, consider adding tests here. + // See https://developer.apple.com/documentation/xctest for more information about using XCTest. + } + +} diff --git a/lib/main.dart b/lib/main.dart new file mode 100644 index 0000000000000000000000000000000000000000..d78d105cac48f631283d5d6cd73cf6c6bf91f1b9 --- /dev/null +++ b/lib/main.dart @@ -0,0 +1,6 @@ +import 'package:base_project/src/app_widget.dart'; +import 'package:flutter/material.dart'; + +void main() { + runApp(const AppWidget()); +} diff --git a/lib/src/app_widget.dart b/lib/src/app_widget.dart new file mode 100644 index 0000000000000000000000000000000000000000..522238edf642cffbaf72ddd808ebbbd70f715b3b --- /dev/null +++ b/lib/src/app_widget.dart @@ -0,0 +1,23 @@ +import 'package:flutter/material.dart'; + +class AppWidget extends StatelessWidget { + const AppWidget({super.key}); + + @override + Widget build(BuildContext context) { + return MaterialApp( + title: 'Flutter Demo', + theme: ThemeData(colorScheme: ColorScheme.fromSeed(seedColor: Color(0xFF232F69))), + home: const PaymentsTransactionsPage(), + ); + } +} + +class PaymentsTransactionsPage extends StatelessWidget { + const PaymentsTransactionsPage({super.key}); + + @override + Widget build(BuildContext context) { + return Scaffold(body: Container(color: Color(0xFF232F69))); + } +} diff --git a/lib/src/core/base/base.dart b/lib/src/core/base/base.dart new file mode 100644 index 0000000000000000000000000000000000000000..0ddb74cf500cb94705b65013a73babaf77e20825 --- /dev/null +++ b/lib/src/core/base/base.dart @@ -0,0 +1,3 @@ +export 'constants/constants.dart'; +export 'errors/errors.dart'; +export 'interfaces/interfaces.dart'; diff --git a/lib/src/core/base/constants/app_constants.dart b/lib/src/core/base/constants/app_constants.dart new file mode 100644 index 0000000000000000000000000000000000000000..2d83cdd2340931f73dc4fb39dcee90e3dc519d25 --- /dev/null +++ b/lib/src/core/base/constants/app_constants.dart @@ -0,0 +1,3 @@ +abstract class AppConstants { + static String genericError001 = 'Sorry, we couldn’t process your request. Please try again later.'; +} diff --git a/lib/src/core/base/constants/constants.dart b/lib/src/core/base/constants/constants.dart new file mode 100644 index 0000000000000000000000000000000000000000..399560b69c19d8b48d41d1dd48e40d5d0f851ced --- /dev/null +++ b/lib/src/core/base/constants/constants.dart @@ -0,0 +1 @@ +export 'app_constants.dart'; diff --git a/lib/src/core/base/errors/errors.dart b/lib/src/core/base/errors/errors.dart new file mode 100644 index 0000000000000000000000000000000000000000..d4087b367de0f824625304a55dee8331bfc1d2c9 --- /dev/null +++ b/lib/src/core/base/errors/errors.dart @@ -0,0 +1 @@ +export 'infra_error.dart'; diff --git a/lib/src/core/base/errors/infra_error.dart b/lib/src/core/base/errors/infra_error.dart new file mode 100644 index 0000000000000000000000000000000000000000..c2bb386180852ae91af50f0c406cc0786b41fd56 --- /dev/null +++ b/lib/src/core/base/errors/infra_error.dart @@ -0,0 +1,13 @@ +import 'package:equatable/equatable.dart'; + +enum InfraCode { unexpected } + +class InfraError extends Equatable { + final InfraCode code; + final dynamic error; + + const InfraError(this.code, {this.error}); + + @override + List get props => [code, error]; +} diff --git a/lib/src/core/base/interfaces/failures.dart b/lib/src/core/base/interfaces/failures.dart new file mode 100644 index 0000000000000000000000000000000000000000..b696aab3268d8cab6ee3cf36bfc44186bb1efa99 --- /dev/null +++ b/lib/src/core/base/interfaces/failures.dart @@ -0,0 +1,18 @@ +import 'package:base_project/src/core/base/constants/app_constants.dart'; +import 'package:equatable/equatable.dart'; + +abstract class Failure extends Equatable { + final String message; + final String? errorDetail; + final dynamic error; + + const Failure({required this.message, this.errorDetail, this.error}); + + @override + List get props => [message, error, errorDetail]; +} + +class GenericFailure extends Failure { + GenericFailure({String? message, super.errorDetail, super.error}) + : super(message: message ?? AppConstants.genericError001); +} diff --git a/lib/src/core/base/interfaces/interfaces.dart b/lib/src/core/base/interfaces/interfaces.dart new file mode 100644 index 0000000000000000000000000000000000000000..d33131d60a2bafbb470d72bb68f56596dc2b8a8a --- /dev/null +++ b/lib/src/core/base/interfaces/interfaces.dart @@ -0,0 +1,2 @@ +export 'failures.dart'; +export 'usecase_interface.dart'; diff --git a/lib/src/core/base/interfaces/usecase_interface.dart b/lib/src/core/base/interfaces/usecase_interface.dart new file mode 100644 index 0000000000000000000000000000000000000000..6e56ef29d81918ea3100560e6d1c6905dabfde9d --- /dev/null +++ b/lib/src/core/base/interfaces/usecase_interface.dart @@ -0,0 +1,24 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:dartz/dartz.dart'; +import 'package:equatable/equatable.dart'; + +abstract class UseCase { + Future> call(Params params); +} + +class NoParams extends Equatable { + @override + List get props => []; +} + +abstract class DefaultBlocState extends Equatable { + final Failure? failure; + final T? refreshEvent; + + const DefaultBlocState({this.failure, this.refreshEvent}); + + bool get shouldRefresh => failure != null && refreshEvent != null; + + @override + List get props => [failure, refreshEvent]; +} diff --git a/lib/src/core/core.dart b/lib/src/core/core.dart new file mode 100644 index 0000000000000000000000000000000000000000..0511e5faa57a381c20cd0fde78e1878a7b875385 --- /dev/null +++ b/lib/src/core/core.dart @@ -0,0 +1,2 @@ +export 'base/base.dart'; +export 'utils/utils.dart'; diff --git a/lib/src/core/utils/converter_helper.dart b/lib/src/core/utils/converter_helper.dart new file mode 100644 index 0000000000000000000000000000000000000000..52024641038f7883a07d62fdf51f03e9b87fffa0 --- /dev/null +++ b/lib/src/core/utils/converter_helper.dart @@ -0,0 +1,29 @@ +import 'package:intl/intl.dart'; + +class ConverterHelper { + ConverterHelper._(); + + static double dynamicToDouble(dynamic value) { + if (value is double) { + return value; + } else if (value is int) { + return value + 0.0; + } else { + throw Exception('ConverterHelper.intToDouble: Invalid type'); + } + } + + static String stringNullableToMMDDYYYY(String? date) { + if (date == null || date.isEmpty) return ''; + final formattedString = DateFormat("yyyy-MM-dd'T'HH:mm:ss").parse(date); + final inputDate = DateTime.parse(formattedString.toString()); + return DateFormat('MM/dd/yyyy').format(inputDate); + } + + static String currencyFormatter(double value, [String replacedSymbol = '--']) { + if (value == 0.0) return replacedSymbol; + final bool isWholeNumber = value % 1 == 0; + final String formattedValue = isWholeNumber ? value.toInt().toString() : value.toStringAsFixed(2); + return '\$$formattedValue'; + } +} diff --git a/lib/src/core/utils/extensions.dart b/lib/src/core/utils/extensions.dart new file mode 100644 index 0000000000000000000000000000000000000000..22286476030565e7b412cf003eafc764cebaf92e --- /dev/null +++ b/lib/src/core/utils/extensions.dart @@ -0,0 +1,5 @@ +import 'package:dartz/dartz.dart'; + +extension EitherExt on Either { + R asRight() => (this as Right).value; +} diff --git a/lib/src/core/utils/utils.dart b/lib/src/core/utils/utils.dart new file mode 100644 index 0000000000000000000000000000000000000000..99dcc21581907d2988e7816e09444d49b8318965 --- /dev/null +++ b/lib/src/core/utils/utils.dart @@ -0,0 +1,2 @@ +export 'converter_helper.dart'; +export 'extensions.dart'; diff --git a/lib/src/modules/payments/data/data.dart b/lib/src/modules/payments/data/data.dart new file mode 100644 index 0000000000000000000000000000000000000000..18cedccd7927997640e26fb6c47c031b547502d7 --- /dev/null +++ b/lib/src/modules/payments/data/data.dart @@ -0,0 +1,3 @@ +export 'datasource/datasource.dart'; +export 'model/model.dart'; +export 'repository/repository.dart'; diff --git a/lib/src/modules/payments/data/datasource/datasource.dart b/lib/src/modules/payments/data/datasource/datasource.dart new file mode 100644 index 0000000000000000000000000000000000000000..5b17157925e044a3041cd0de0ffc2ed9443a456d --- /dev/null +++ b/lib/src/modules/payments/data/datasource/datasource.dart @@ -0,0 +1 @@ +export 'payments_datasource.dart'; diff --git a/lib/src/modules/payments/data/datasource/payments_datasource.dart b/lib/src/modules/payments/data/datasource/payments_datasource.dart new file mode 100644 index 0000000000000000000000000000000000000000..7559b5d54769d6206d3d41ea94a1799f1bd9ed33 --- /dev/null +++ b/lib/src/modules/payments/data/datasource/payments_datasource.dart @@ -0,0 +1,5 @@ +import 'package:base_project/src/modules/payments/domain/domain.dart'; + +abstract class PaymentsDataSource { + Future getPaymentsInfo(); +} diff --git a/lib/src/modules/payments/data/model/model.dart b/lib/src/modules/payments/data/model/model.dart new file mode 100644 index 0000000000000000000000000000000000000000..ffcf92e5c6bd8ae1f1a0a350c3f26af62865e1f1 --- /dev/null +++ b/lib/src/modules/payments/data/model/model.dart @@ -0,0 +1 @@ +export 'payments/payments.dart'; diff --git a/lib/src/modules/payments/data/model/payments/payments.dart b/lib/src/modules/payments/data/model/payments/payments.dart new file mode 100644 index 0000000000000000000000000000000000000000..9b4603c5f5f50c8508f5b6905421f81e635bea79 --- /dev/null +++ b/lib/src/modules/payments/data/model/payments/payments.dart @@ -0,0 +1,5 @@ +export 'payments_info_model.dart'; +export 'payments_scheduled_model.dart'; +export 'payments_summary_model.dart'; +export 'payments_transactions_header_model.dart'; +export 'payments_transactions_model.dart'; diff --git a/lib/src/modules/payments/data/model/payments/payments_info_model.dart b/lib/src/modules/payments/data/model/payments/payments_info_model.dart new file mode 100644 index 0000000000000000000000000000000000000000..839003974e2c3e46faf689f7cb0765ae8e990f13 --- /dev/null +++ b/lib/src/modules/payments/data/model/payments/payments_info_model.dart @@ -0,0 +1,31 @@ +import 'package:base_project/src/modules/payments/data/data.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; + +class PaymentsInfoModel extends PaymentsInfoEntity { + PaymentsInfoModel.fromJson(Map json) + : super( + paymentsScheduled: + json['paymentsScheduled'] != null + ? json['paymentsScheduled'] + .map((json) => PaymentsScheduledModel.fromJson(json)) + .toList() + : [], + transactionFilter: + json['transactionFilters'] != null + ? json['transactionFilters'] + .map((json) => PaymentsTransactionHeadersModel.fromJson(json)) + .toList() + : [], + transactions: + json['transactions'] != null + ? json['transactions'] + .map((json) => PaymentsTransactionsModel.fromJson(json)) + .toList() + : [], + summary: + json['summary'] != null + ? json['summary'].map((json) => PaymentsSummaryModel.fromJson(json)).toList() + : [], + ); + PaymentsInfoModel.empty() : this.fromJson({}); +} diff --git a/lib/src/modules/payments/data/model/payments/payments_scheduled_model.dart b/lib/src/modules/payments/data/model/payments/payments_scheduled_model.dart new file mode 100644 index 0000000000000000000000000000000000000000..e6ae2605650225b8451aeac7ffbb72501e4e67ee --- /dev/null +++ b/lib/src/modules/payments/data/model/payments/payments_scheduled_model.dart @@ -0,0 +1,30 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; + +class PaymentsScheduledModel extends PaymentsScheduledEntity { + const PaymentsScheduledModel({ + required super.paymentDate, + required super.principal, + required super.interest, + required super.total, + required super.outstandingBalance, + required super.pastDue, + required super.status, + required super.paymentType, + required super.paymentDateFormatted, + }); + + factory PaymentsScheduledModel.fromJson(Map map) { + return PaymentsScheduledModel( + paymentDate: DateTime.parse(map['paymentDate'] ?? ""), + paymentDateFormatted: ConverterHelper.stringNullableToMMDDYYYY(map['paymentDate']), + principal: ConverterHelper.dynamicToDouble(map['principal'] ?? 0.0), + interest: ConverterHelper.dynamicToDouble(map['interest'] ?? 0.0), + total: ConverterHelper.dynamicToDouble(map['total'] ?? 0.0), + outstandingBalance: ConverterHelper.dynamicToDouble(map['outstandingBalance'] ?? 0.0), + pastDue: map['pastDue'] ?? false, + status: map['status'] ?? "", + paymentType: map['paymentType'] ?? "", + ); + } +} diff --git a/lib/src/modules/payments/data/model/payments/payments_summary_model.dart b/lib/src/modules/payments/data/model/payments/payments_summary_model.dart new file mode 100644 index 0000000000000000000000000000000000000000..81fcb1e2d9b3a4a819d10a580f114a6d990c0646 --- /dev/null +++ b/lib/src/modules/payments/data/model/payments/payments_summary_model.dart @@ -0,0 +1,10 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; + +class PaymentsSummaryModel extends PaymentsSummaryEntity { + const PaymentsSummaryModel({required super.label, required super.value}); + + factory PaymentsSummaryModel.fromJson(Map map) { + return PaymentsSummaryModel(label: map["label"] ?? "", value: ConverterHelper.dynamicToDouble(map['value'] ?? 0.0)); + } +} diff --git a/lib/src/modules/payments/data/model/payments/payments_transactions_header_model.dart b/lib/src/modules/payments/data/model/payments/payments_transactions_header_model.dart new file mode 100644 index 0000000000000000000000000000000000000000..b7d5f6f5a9d5b6178bed28c1db196eb5b6129e6d --- /dev/null +++ b/lib/src/modules/payments/data/model/payments/payments_transactions_header_model.dart @@ -0,0 +1,13 @@ +import 'package:base_project/src/modules/payments/domain/domain.dart'; + +class PaymentsTransactionHeadersModel extends PaymentsTransactionFilterEntity { + const PaymentsTransactionHeadersModel({required super.key, required super.label, required super.isDefault}); + + factory PaymentsTransactionHeadersModel.fromJson(Map map) { + return PaymentsTransactionHeadersModel( + key: map['key'] ?? "", + label: map['label'] ?? "", + isDefault: map['isDefault'] ?? false, + ); + } +} diff --git a/lib/src/modules/payments/data/model/payments/payments_transactions_model.dart b/lib/src/modules/payments/data/model/payments/payments_transactions_model.dart new file mode 100644 index 0000000000000000000000000000000000000000..9fc821c641fa597d2384cf7f925bb973acd1049b --- /dev/null +++ b/lib/src/modules/payments/data/model/payments/payments_transactions_model.dart @@ -0,0 +1,48 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; + +class PaymentsTransactionsModel extends PaymentsTransactionsEntity { + const PaymentsTransactionsModel({ + required super.key, + required super.actualPaymentPostDate, + required super.processDate, + required super.actualPaymentAmount, + required super.actualPrincipalPaymentAmount, + required super.actualInterestPaymentAmount, + required super.outstandingPrincipalBalance, + required super.outstandingLoanBalance, + required super.actualFee, + required super.paymentType, + }); + + factory PaymentsTransactionsModel.fromJson(Map map) { + return PaymentsTransactionsModel( + key: map['key'] ?? "", + actualPaymentPostDate: DateTime.parse(map['actualPaymentPostDate']), + processDate: DateTime.parse(map['processDate']), + actualPaymentAmount: ConverterHelper.dynamicToDouble(map['actualPaymentAmount'] ?? 0.0), + actualPrincipalPaymentAmount: ConverterHelper.dynamicToDouble(map['actualPrincipalPaymentAmount'] ?? 0.0), + actualInterestPaymentAmount: ConverterHelper.dynamicToDouble(map['actualInterestPaymentAmount'] ?? 0.0), + outstandingPrincipalBalance: ConverterHelper.dynamicToDouble(map['outstandingPrincipalBalance'] ?? 0.0), + outstandingLoanBalance: ConverterHelper.dynamicToDouble(map['outstandingLoanBalance'] ?? 0.0), + actualFee: ConverterHelper.dynamicToDouble(map['actualFee'] ?? 0.0), + paymentType: map['paymentType'] ?? "", + ); + } + + @override + Map toMap() { + return { + 'key': key, + 'actualPaymentPostDate': ConverterHelper.stringNullableToMMDDYYYY(actualPaymentPostDate.toIso8601String()), + 'processDate': ConverterHelper.stringNullableToMMDDYYYY(processDate.toIso8601String()), + 'actualPaymentAmount': ConverterHelper.currencyFormatter(actualPaymentAmount, "--"), + 'actualPrincipalPaymentAmount': ConverterHelper.currencyFormatter(actualPrincipalPaymentAmount, "--"), + 'actualInterestPaymentAmount': ConverterHelper.currencyFormatter(actualInterestPaymentAmount, "--"), + 'outstandingPrincipalBalance': ConverterHelper.currencyFormatter(outstandingPrincipalBalance, "--"), + 'outstandingLoanBalance': ConverterHelper.currencyFormatter(outstandingLoanBalance, "--"), + 'actualFee': ConverterHelper.currencyFormatter(actualFee, "--"), + 'type': paymentType, + }; + } +} diff --git a/lib/src/modules/payments/data/repository/payment_repository_impl.dart b/lib/src/modules/payments/data/repository/payment_repository_impl.dart new file mode 100644 index 0000000000000000000000000000000000000000..70910ad9577f394f9e8c3c38ed8e60db07052957 --- /dev/null +++ b/lib/src/modules/payments/data/repository/payment_repository_impl.dart @@ -0,0 +1,19 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:base_project/src/modules/payments/data/data.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; +import 'package:dartz/dartz.dart'; + +class PaymentsRepositoryImpl implements PaymentsRepository { + final PaymentsDataSource _datasource; + + const PaymentsRepositoryImpl(this._datasource); + + @override + Future> getPayments() async { + try { + return Right(await _datasource.getPaymentsInfo()); + } catch (e) { + return Left(GenericFailure(error: e)); + } + } +} diff --git a/lib/src/modules/payments/data/repository/repository.dart b/lib/src/modules/payments/data/repository/repository.dart new file mode 100644 index 0000000000000000000000000000000000000000..c521fdc8e1414823137d089fce3e2ee013d36bdc --- /dev/null +++ b/lib/src/modules/payments/data/repository/repository.dart @@ -0,0 +1 @@ +export 'payment_repository_impl.dart'; diff --git a/lib/src/modules/payments/domain/domain.dart b/lib/src/modules/payments/domain/domain.dart new file mode 100644 index 0000000000000000000000000000000000000000..4b7d743c2a85f84c1e0dbc334a875786b52642b7 --- /dev/null +++ b/lib/src/modules/payments/domain/domain.dart @@ -0,0 +1,3 @@ +export 'entity/entity.dart'; +export 'repository/repository.dart'; +export 'usecase/usecase.dart'; diff --git a/lib/src/modules/payments/domain/entity/entity.dart b/lib/src/modules/payments/domain/entity/entity.dart new file mode 100644 index 0000000000000000000000000000000000000000..c0e8722b61093b205630701dcf23d59615266177 --- /dev/null +++ b/lib/src/modules/payments/domain/entity/entity.dart @@ -0,0 +1,5 @@ +export 'payments_info_entity.dart'; +export 'payments_schedule_entity.dart'; +export 'payments_summary_entity.dart'; +export 'payments_transactions_entity.dart'; +export 'payments_transactions_filter_entity.dart'; diff --git a/lib/src/modules/payments/domain/entity/payments_info_entity.dart b/lib/src/modules/payments/domain/entity/payments_info_entity.dart new file mode 100644 index 0000000000000000000000000000000000000000..365089699f32800551e156959f3326e21c99a1f1 --- /dev/null +++ b/lib/src/modules/payments/domain/entity/payments_info_entity.dart @@ -0,0 +1,20 @@ +import 'package:equatable/equatable.dart'; + +import 'entity.dart'; + +abstract class PaymentsInfoEntity extends Equatable { + final List paymentsScheduled; + final List summary; + final List transactionFilter; + final List transactions; + + const PaymentsInfoEntity({ + required this.paymentsScheduled, + required this.summary, + required this.transactionFilter, + required this.transactions, + }); + + @override + List get props => [paymentsScheduled, summary, transactionFilter, transactions]; +} diff --git a/lib/src/modules/payments/domain/entity/payments_schedule_entity.dart b/lib/src/modules/payments/domain/entity/payments_schedule_entity.dart new file mode 100644 index 0000000000000000000000000000000000000000..fecd557c3770a2f52d60b874bf243457812b1d87 --- /dev/null +++ b/lib/src/modules/payments/domain/entity/payments_schedule_entity.dart @@ -0,0 +1,38 @@ +import 'package:equatable/equatable.dart'; + +abstract class PaymentsScheduledEntity extends Equatable { + final DateTime paymentDate; + final String paymentDateFormatted; + final double principal; + final double interest; + final double total; + final double outstandingBalance; + final bool pastDue; + final String status; + final String paymentType; + + const PaymentsScheduledEntity({ + required this.paymentDateFormatted, + required this.paymentDate, + required this.principal, + required this.interest, + required this.total, + required this.outstandingBalance, + required this.pastDue, + required this.status, + required this.paymentType, + }); + + @override + List get props => [ + paymentDate, + principal, + interest, + total, + outstandingBalance, + pastDue, + status, + paymentType, + paymentDateFormatted, + ]; +} diff --git a/lib/src/modules/payments/domain/entity/payments_summary_entity.dart b/lib/src/modules/payments/domain/entity/payments_summary_entity.dart new file mode 100644 index 0000000000000000000000000000000000000000..8d3adf9d9467bf2700f3bd7953c9254aa008699e --- /dev/null +++ b/lib/src/modules/payments/domain/entity/payments_summary_entity.dart @@ -0,0 +1,11 @@ +import 'package:equatable/equatable.dart'; + +abstract class PaymentsSummaryEntity extends Equatable { + final String label; + final double value; + + const PaymentsSummaryEntity({required this.label, required this.value}); + + @override + List get props => [label, value]; +} diff --git a/lib/src/modules/payments/domain/entity/payments_transactions_entity.dart b/lib/src/modules/payments/domain/entity/payments_transactions_entity.dart new file mode 100644 index 0000000000000000000000000000000000000000..3be868aa57707bb066b383d281f6b4ff56d689fb --- /dev/null +++ b/lib/src/modules/payments/domain/entity/payments_transactions_entity.dart @@ -0,0 +1,44 @@ +import 'package:equatable/equatable.dart'; + +abstract class PaymentsTransactionsEntity extends Equatable { + final String key; + final DateTime actualPaymentPostDate; + final DateTime processDate; + final double actualPaymentAmount; + final double actualPrincipalPaymentAmount; + final double actualInterestPaymentAmount; + final double outstandingPrincipalBalance; + final double outstandingLoanBalance; + final double actualFee; + final String paymentType; + + const PaymentsTransactionsEntity({ + required this.key, + required this.actualPaymentPostDate, + required this.processDate, + required this.actualPaymentAmount, + required this.actualPrincipalPaymentAmount, + required this.actualInterestPaymentAmount, + required this.outstandingPrincipalBalance, + required this.outstandingLoanBalance, + required this.actualFee, + required this.paymentType, + }); + + @override + List get props { + return [ + actualPaymentPostDate, + processDate, + actualPaymentAmount, + actualPrincipalPaymentAmount, + actualInterestPaymentAmount, + outstandingPrincipalBalance, + outstandingLoanBalance, + actualFee, + paymentType, + ]; + } + + Map toMap(); +} diff --git a/lib/src/modules/payments/domain/entity/payments_transactions_filter_entity.dart b/lib/src/modules/payments/domain/entity/payments_transactions_filter_entity.dart new file mode 100644 index 0000000000000000000000000000000000000000..95d6ad06163978e71ccfda99bfa4ce62b586676d --- /dev/null +++ b/lib/src/modules/payments/domain/entity/payments_transactions_filter_entity.dart @@ -0,0 +1,12 @@ +import 'package:equatable/equatable.dart'; + +abstract class PaymentsTransactionFilterEntity extends Equatable { + final String key; + final String label; + final bool isDefault; + + const PaymentsTransactionFilterEntity({required this.key, required this.label, required this.isDefault}); + + @override + List get props => [key, label, isDefault]; +} diff --git a/lib/src/modules/payments/domain/repository/payment_repository.dart b/lib/src/modules/payments/domain/repository/payment_repository.dart new file mode 100644 index 0000000000000000000000000000000000000000..83ac1d33c883ea965268dfbe173b7503c4d6e266 --- /dev/null +++ b/lib/src/modules/payments/domain/repository/payment_repository.dart @@ -0,0 +1,7 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; +import 'package:dartz/dartz.dart'; + +abstract class PaymentsRepository { + Future> getPayments(); +} diff --git a/lib/src/modules/payments/domain/repository/repository.dart b/lib/src/modules/payments/domain/repository/repository.dart new file mode 100644 index 0000000000000000000000000000000000000000..c41d0c244dc62d1fe19143882ea5b95752cc934a --- /dev/null +++ b/lib/src/modules/payments/domain/repository/repository.dart @@ -0,0 +1 @@ +export 'payment_repository.dart'; diff --git a/lib/src/modules/payments/domain/usecase/get_payments_use_case.dart b/lib/src/modules/payments/domain/usecase/get_payments_use_case.dart new file mode 100644 index 0000000000000000000000000000000000000000..6c16d48ed3182b4d24977c04ad5688a2f47e4889 --- /dev/null +++ b/lib/src/modules/payments/domain/usecase/get_payments_use_case.dart @@ -0,0 +1,26 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; +import 'package:dartz/dartz.dart'; + +class GetPaymentsUseCase implements UseCase { + final PaymentsRepository _repository; + + GetPaymentsUseCase(this._repository); + + @override + Future> call([NoParams? params]) async { + final result = await _repository.getPayments(); + + if (result.isRight()) { + final paymentsInfo = result.asRight(); + + paymentsInfo.paymentsScheduled + ..removeWhere((payment) => payment.paymentDate.isBefore(DateTime.now())) + ..sort((a, b) => a.paymentDate.compareTo(b.paymentDate)); + + return Right(paymentsInfo); + } else { + return result; + } + } +} diff --git a/lib/src/modules/payments/domain/usecase/usecase.dart b/lib/src/modules/payments/domain/usecase/usecase.dart new file mode 100644 index 0000000000000000000000000000000000000000..67571e07ccc058dafd6d599ec6c94cc3701ca0d5 --- /dev/null +++ b/lib/src/modules/payments/domain/usecase/usecase.dart @@ -0,0 +1 @@ +export 'get_payments_use_case.dart'; diff --git a/lib/src/modules/payments/infra/datasource/datasource.dart b/lib/src/modules/payments/infra/datasource/datasource.dart new file mode 100644 index 0000000000000000000000000000000000000000..96d0e7bfa69ef61e0d2437f7931eb8c3820f4459 --- /dev/null +++ b/lib/src/modules/payments/infra/datasource/datasource.dart @@ -0,0 +1 @@ +export 'payments_datasource_impl.dart'; diff --git a/lib/src/modules/payments/infra/datasource/payments_datasource_impl.dart b/lib/src/modules/payments/infra/datasource/payments_datasource_impl.dart new file mode 100644 index 0000000000000000000000000000000000000000..2ff244202df1e70930273ea168e46cb6b3e403ff --- /dev/null +++ b/lib/src/modules/payments/infra/datasource/payments_datasource_impl.dart @@ -0,0 +1,21 @@ +import 'package:base_project/src/core/core.dart'; +import 'package:base_project/src/modules/payments/data/data.dart'; +import 'package:base_project/src/modules/payments/domain/domain.dart'; +import 'package:base_project/src/modules/payments/infra/mock/mock.dart'; + +class PaymentsDatasourceImpl implements PaymentsDataSource { + PaymentsDatasourceImpl(); + + @override + Future getPaymentsInfo() async { + try { + final response = await Future.delayed(Duration(milliseconds: 1500)).then((_) { + // INFO: use mockEmptyJson or mockPaymentsJson + return mockPaymentsJson; /* mockEmptyJson */ + }); + return PaymentsInfoModel.fromJson(response); + } catch (e) { + throw InfraError(InfraCode.unexpected, error: e); + } + } +} diff --git a/lib/src/modules/payments/infra/mock/mock.dart b/lib/src/modules/payments/infra/mock/mock.dart new file mode 100644 index 0000000000000000000000000000000000000000..cad765ebb69103d2452ba2abe4ddff2b4c90a046 --- /dev/null +++ b/lib/src/modules/payments/infra/mock/mock.dart @@ -0,0 +1 @@ +export 'payments_json.dart'; diff --git a/lib/src/modules/payments/infra/mock/payments_json.dart b/lib/src/modules/payments/infra/mock/payments_json.dart new file mode 100644 index 0000000000000000000000000000000000000000..c90400f51a2269c254b9fa26239cfae0bc4c0816 --- /dev/null +++ b/lib/src/modules/payments/infra/mock/payments_json.dart @@ -0,0 +1,704 @@ +final mockPaymentsJson = { + "paymentsScheduled": [ + { + "paymentDate": "2024-07-03T00:00:00", + "principal": 0, + "interest": 40, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-07-18T00:00:00", + "principal": 0, + "interest": 40, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-08-01T00:00:00", + "principal": 0, + "interest": 40, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-08-15T00:00:00", + "principal": 0, + "interest": 40, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-08-29T00:00:00", + "principal": 10.75, + "interest": 29.25, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-09-12T00:00:00", + "principal": 14.09, + "interest": 25.91, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-09-26T00:00:00", + "principal": 14.27, + "interest": 25.73, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-10-10T00:00:00", + "principal": 14.46, + "interest": 25.54, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-10-24T00:00:00", + "principal": 14.65, + "interest": 25.35, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-11-07T00:00:00", + "principal": 14.84, + "interest": 25.16, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-11-21T00:00:00", + "principal": 15.03, + "interest": 24.97, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-12-05T00:00:00", + "principal": 15.23, + "interest": 24.77, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2024-12-19T00:00:00", + "principal": 15.42, + "interest": 24.58, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2025-01-02T00:00:00", + "principal": 15.63, + "interest": 24.37, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "ok", + "paymentType": "PaymentType1", + }, + { + "paymentDate": "2025-01-16T00:00:00", + "principal": 0, + "interest": 0, + "total": 40, + "outstandingBalance": 0, + "pastDue": true, + "loanModification": false, + "status": "past_duo", + "paymentType": "", + }, + { + "paymentDate": "2025-01-30T00:00:00", + "principal": 0, + "interest": 0, + "total": 40, + "outstandingBalance": 0, + "pastDue": true, + "loanModification": false, + "status": "past_duo", + "paymentType": "", + }, + { + "paymentDate": "2025-02-13T00:00:00", + "principal": 0, + "interest": 0, + "total": 40, + "outstandingBalance": 0, + "pastDue": true, + "loanModification": false, + "status": "past_duo", + "paymentType": "", + }, + { + "paymentDate": "2025-02-27T00:00:00", + "principal": 16.07, + "interest": 23.93, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-03-13T00:00:00", + "principal": 16.28, + "interest": 23.72, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-03-27T00:00:00", + "principal": 16.49, + "interest": 23.51, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-04-10T00:00:00", + "principal": 16.7, + "interest": 23.3, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-04-24T00:00:00", + "principal": 16.92, + "interest": 23.08, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-05-08T00:00:00", + "principal": 17.14, + "interest": 22.86, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-05-22T00:00:00", + "principal": 17.37, + "interest": 22.63, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-06-05T00:00:00", + "principal": 17.59, + "interest": 22.41, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-06-19T00:00:00", + "principal": 17.82, + "interest": 22.18, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-07-03T00:00:00", + "principal": 18.06, + "interest": 21.94, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-07-17T00:00:00", + "principal": 18.29, + "interest": 21.71, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-07-31T00:00:00", + "principal": 18.53, + "interest": 21.47, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-08-14T00:00:00", + "principal": 18.77, + "interest": 21.23, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-08-28T00:00:00", + "principal": 19.02, + "interest": 20.98, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-09-11T00:00:00", + "principal": 19.27, + "interest": 20.73, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-09-25T00:00:00", + "principal": 19.52, + "interest": 20.48, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-10-09T00:00:00", + "principal": 19.77, + "interest": 20.23, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-10-23T00:00:00", + "principal": 20.03, + "interest": 19.97, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-11-06T00:00:00", + "principal": 20.29, + "interest": 19.71, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-11-20T00:00:00", + "principal": 20.56, + "interest": 19.44, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + { + "paymentDate": "2025-12-04T00:00:00", + "principal": 20.83, + "interest": 19.17, + "total": 40, + "outstandingBalance": 0, + "pastDue": false, + "loanModification": false, + "status": "scheduled", + "paymentType": "", + }, + ], + "summary": [ + {"label": "Outstanding Balance", "value": 8888.88}, + {"label": "Total Paid", "value": 777}, + {"label": "Principal Paid", "value": 666.66}, + {"label": "Interest Paid", "value": 555.55}, + ], + "transactionFilters": [ + {"key": "processDate", "label": "Process Date", "isDefault": true}, + {"key": "actualPaymentAmount", "label": "Amount", "isDefault": true}, + {"key": "type", "label": "Type", "isDefault": true}, + {"key": "actualPrincipalPaymentAmount", "label": "Principal", "isDefault": false}, + {"key": "actualInterestPaymentAmount", "label": "Interest", "isDefault": false}, + {"key": "actualFee", "label": "Late Fee", "isDefault": false}, + {"key": "actualPaymentPostDate", "label": "Post Date", "isDefault": false}, + {"key": "outstandingPrincipalBalance", "label": "Principal Balance", "isDefault": false}, + ], + "transactions": [ + { + "paymentId": 1, + "actualPaymentPostDate": "2024-06-20T00:00:00", + "processDate": "2024-06-20T02:24:00", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 0, + "actualInterestPaymentAmount": 40, + "outstandingPrincipalBalance": 2000, + "outstandingLoanBalance": 2040, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 2, + "actualPaymentPostDate": "2024-07-03T00:00:00", + "processDate": "2024-07-04T05:23:51", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 0, + "actualInterestPaymentAmount": 40, + "outstandingPrincipalBalance": 2000, + "outstandingLoanBalance": 2040, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 3, + "actualPaymentPostDate": "2024-07-18T00:00:00", + "processDate": "2024-07-18T12:58:55", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 0, + "actualInterestPaymentAmount": 40, + "outstandingPrincipalBalance": 2000, + "outstandingLoanBalance": 2040, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 4, + "actualPaymentPostDate": "2024-08-01T00:00:00", + "processDate": "2024-08-01T13:01:28", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 0, + "actualInterestPaymentAmount": 40, + "outstandingPrincipalBalance": 2000, + "outstandingLoanBalance": 2040, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 5, + "actualPaymentPostDate": "2024-08-15T00:00:00", + "processDate": "2024-08-15T12:47:22", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 10.75, + "actualInterestPaymentAmount": 29.25, + "outstandingPrincipalBalance": 1989.25, + "outstandingLoanBalance": 2029.25, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 6, + "actualPaymentPostDate": "2024-08-29T00:00:00", + "processDate": "2024-08-29T12:46:23", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 14.09, + "actualInterestPaymentAmount": 25.91, + "outstandingPrincipalBalance": 1975.16, + "outstandingLoanBalance": 2015.16, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 7, + "actualPaymentPostDate": "2024-09-12T00:00:00", + "processDate": "2024-09-12T12:47:22", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 14.27, + "actualInterestPaymentAmount": 25.73, + "outstandingPrincipalBalance": 1960.89, + "outstandingLoanBalance": 2000.89, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 8, + "actualPaymentPostDate": "2024-09-26T00:00:00", + "processDate": "2024-09-26T12:46:54", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 14.46, + "actualInterestPaymentAmount": 25.54, + "outstandingPrincipalBalance": 1946.43, + "outstandingLoanBalance": 1986.43, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 9, + "actualPaymentPostDate": "2024-10-10T00:00:00", + "processDate": "2024-10-10T12:52:27", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 14.65, + "actualInterestPaymentAmount": 25.35, + "outstandingPrincipalBalance": 1931.78, + "outstandingLoanBalance": 1971.78, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 10, + "actualPaymentPostDate": "2024-10-24T00:00:00", + "processDate": "2024-10-24T13:01:22", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 14.84, + "actualInterestPaymentAmount": 25.16, + "outstandingPrincipalBalance": 1916.94, + "outstandingLoanBalance": 1956.94, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 11, + "actualPaymentPostDate": "2024-11-07T00:00:00", + "processDate": "2024-11-07T13:03:37", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 15.03, + "actualInterestPaymentAmount": 24.97, + "outstandingPrincipalBalance": 1901.91, + "outstandingLoanBalance": 1941.91, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 12, + "actualPaymentPostDate": "2024-11-21T00:00:00", + "processDate": "2024-11-21T13:05:14", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 15.23, + "actualInterestPaymentAmount": 24.77, + "outstandingPrincipalBalance": 1886.68, + "outstandingLoanBalance": 1926.68, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 13, + "actualPaymentPostDate": "2024-12-05T00:00:00", + "processDate": "2024-12-05T13:09:57", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 15.42, + "actualInterestPaymentAmount": 24.58, + "outstandingPrincipalBalance": 1871.26, + "outstandingLoanBalance": 1911.26, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + { + "paymentId": 14, + "actualPaymentPostDate": "2024-12-19T00:00:00", + "processDate": "2024-12-19T22:06:13", + "actualPaymentAmount": 40, + "actualPrincipalPaymentAmount": 15.63, + "actualInterestPaymentAmount": 24.37, + "outstandingPrincipalBalance": 1855.63, + "outstandingLoanBalance": 1895.63, + "actualFee": 0, + "paymentType": "PaymentType1", + "note": "", + "userName": "", + "type": 1, + "status": null, + "reversedAt": "0001-01-01T00:00:00", + "reimbursementMade": false, + }, + ], +}; + +final mockEmptyJson = { + "paymentsScheduled": [], + "summary": [ + {"label": "Outstanding Balance", "value": 0}, + {"label": "Total Paid", "value": 0}, + {"label": "Principal Paid", "value": 0}, + {"label": "Interest Paid", "value": 0}, + ], + "transactionHeaders": [], + "transactions": [], +}; diff --git a/pubspec.lock b/pubspec.lock new file mode 100644 index 0000000000000000000000000000000000000000..effe28102aecc7b017c38fe457520fc485ceaac9 --- /dev/null +++ b/pubspec.lock @@ -0,0 +1,237 @@ +# Generated by pub +# See https://dart.dev/tools/pub/glossary#lockfile +packages: + async: + dependency: transitive + description: + name: async + sha256: d2872f9c19731c2e5f10444b14686eb7cc85c76274bd6c16e1816bff9a3bab63 + url: "https://pub.dev" + source: hosted + version: "2.12.0" + boolean_selector: + dependency: transitive + description: + name: boolean_selector + sha256: "8aab1771e1243a5063b8b0ff68042d67334e3feab9e95b9490f9a6ebf73b42ea" + url: "https://pub.dev" + source: hosted + version: "2.1.2" + characters: + dependency: transitive + description: + name: characters + sha256: f71061c654a3380576a52b451dd5532377954cf9dbd272a78fc8479606670803 + url: "https://pub.dev" + source: hosted + version: "1.4.0" + clock: + dependency: transitive + description: + name: clock + sha256: fddb70d9b5277016c77a80201021d40a2247104d9f4aa7bab7157b7e3f05b84b + url: "https://pub.dev" + source: hosted + version: "1.1.2" + collection: + dependency: transitive + description: + name: collection + sha256: "2f5709ae4d3d59dd8f7cd309b4e023046b57d8a6c82130785d2b0e5868084e76" + url: "https://pub.dev" + source: hosted + version: "1.19.1" + cupertino_icons: + dependency: "direct main" + description: + name: cupertino_icons + sha256: ba631d1c7f7bef6b729a622b7b752645a2d076dba9976925b8f25725a30e1ee6 + url: "https://pub.dev" + source: hosted + version: "1.0.8" + dartz: + dependency: "direct main" + description: + name: dartz + sha256: e6acf34ad2e31b1eb00948692468c30ab48ac8250e0f0df661e29f12dd252168 + url: "https://pub.dev" + source: hosted + version: "0.10.1" + equatable: + dependency: "direct main" + description: + name: equatable + sha256: "567c64b3cb4cf82397aac55f4f0cbd3ca20d77c6c03bedbc4ceaddc08904aef7" + url: "https://pub.dev" + source: hosted + version: "2.0.7" + fake_async: + dependency: transitive + description: + name: fake_async + sha256: "6a95e56b2449df2273fd8c45a662d6947ce1ebb7aafe80e550a3f68297f3cacc" + url: "https://pub.dev" + source: hosted + version: "1.3.2" + flutter: + dependency: "direct main" + description: flutter + source: sdk + version: "0.0.0" + flutter_lints: + dependency: "direct dev" + description: + name: flutter_lints + sha256: "5398f14efa795ffb7a33e9b6a08798b26a180edac4ad7db3f231e40f82ce11e1" + url: "https://pub.dev" + source: hosted + version: "5.0.0" + flutter_test: + dependency: "direct dev" + description: flutter + source: sdk + version: "0.0.0" + intl: + dependency: "direct main" + description: + name: intl + sha256: "3df61194eb431efc39c4ceba583b95633a403f46c9fd341e550ce0bfa50e9aa5" + url: "https://pub.dev" + source: hosted + version: "0.20.2" + leak_tracker: + dependency: transitive + description: + name: leak_tracker + sha256: c35baad643ba394b40aac41080300150a4f08fd0fd6a10378f8f7c6bc161acec + url: "https://pub.dev" + source: hosted + version: "10.0.8" + leak_tracker_flutter_testing: + dependency: transitive + description: + name: leak_tracker_flutter_testing + sha256: f8b613e7e6a13ec79cfdc0e97638fddb3ab848452eff057653abd3edba760573 + url: "https://pub.dev" + source: hosted + version: "3.0.9" + leak_tracker_testing: + dependency: transitive + description: + name: leak_tracker_testing + sha256: "6ba465d5d76e67ddf503e1161d1f4a6bc42306f9d66ca1e8f079a47290fb06d3" + url: "https://pub.dev" + source: hosted + version: "3.0.1" + lints: + dependency: transitive + description: + name: lints + sha256: c35bb79562d980e9a453fc715854e1ed39e24e7d0297a880ef54e17f9874a9d7 + url: "https://pub.dev" + source: hosted + version: "5.1.1" + matcher: + dependency: transitive + description: + name: matcher + sha256: dc58c723c3c24bf8d3e2d3ad3f2f9d7bd9cf43ec6feaa64181775e60190153f2 + url: "https://pub.dev" + source: hosted + version: "0.12.17" + material_color_utilities: + dependency: transitive + description: + name: material_color_utilities + sha256: f7142bb1154231d7ea5f96bc7bde4bda2a0945d2806bb11670e30b850d56bdec + url: "https://pub.dev" + source: hosted + version: "0.11.1" + meta: + dependency: transitive + description: + name: meta + sha256: e3641ec5d63ebf0d9b41bd43201a66e3fc79a65db5f61fc181f04cd27aab950c + url: "https://pub.dev" + source: hosted + version: "1.16.0" + path: + dependency: transitive + description: + name: path + sha256: "75cca69d1490965be98c73ceaea117e8a04dd21217b37b292c9ddbec0d955bc5" + url: "https://pub.dev" + source: hosted + version: "1.9.1" + sky_engine: + dependency: transitive + description: flutter + source: sdk + version: "0.0.0" + source_span: + dependency: transitive + description: + name: source_span + sha256: "254ee5351d6cb365c859e20ee823c3bb479bf4a293c22d17a9f1bf144ce86f7c" + url: "https://pub.dev" + source: hosted + version: "1.10.1" + stack_trace: + dependency: transitive + description: + name: stack_trace + sha256: "8b27215b45d22309b5cddda1aa2b19bdfec9df0e765f2de506401c071d38d1b1" + url: "https://pub.dev" + source: hosted + version: "1.12.1" + stream_channel: + dependency: transitive + description: + name: stream_channel + sha256: "969e04c80b8bcdf826f8f16579c7b14d780458bd97f56d107d3950fdbeef059d" + url: "https://pub.dev" + source: hosted + version: "2.1.4" + string_scanner: + dependency: transitive + description: + name: string_scanner + sha256: "921cd31725b72fe181906c6a94d987c78e3b98c2e205b397ea399d4054872b43" + url: "https://pub.dev" + source: hosted + version: "1.4.1" + term_glyph: + dependency: transitive + description: + name: term_glyph + sha256: "7f554798625ea768a7518313e58f83891c7f5024f88e46e7182a4558850a4b8e" + url: "https://pub.dev" + source: hosted + version: "1.2.2" + test_api: + dependency: transitive + description: + name: test_api + sha256: fb31f383e2ee25fbbfe06b40fe21e1e458d14080e3c67e7ba0acfde4df4e0bbd + url: "https://pub.dev" + source: hosted + version: "0.7.4" + vector_math: + dependency: transitive + description: + name: vector_math + sha256: "80b3257d1492ce4d091729e3a67a60407d227c27241d6927be0130c98e741803" + url: "https://pub.dev" + source: hosted + version: "2.1.4" + vm_service: + dependency: transitive + description: + name: vm_service + sha256: "0968250880a6c5fe7edc067ed0a13d4bae1577fe2771dcf3010d52c4a9d3ca14" + url: "https://pub.dev" + source: hosted + version: "14.3.1" +sdks: + dart: ">=3.7.0 <4.0.0" + flutter: ">=3.18.0-18.0.pre.54" diff --git a/pubspec.yaml b/pubspec.yaml new file mode 100644 index 0000000000000000000000000000000000000000..191987f8d48f6fd895d202274d15edaee1bf65a1 --- /dev/null +++ b/pubspec.yaml @@ -0,0 +1,92 @@ +name: base_project +description: "A new Flutter project." +# The following line prevents the package from being accidentally published to +# pub.dev using `flutter pub publish`. This is preferred for private packages. +publish_to: 'none' # Remove this line if you wish to publish to pub.dev + +# The following defines the version and build number for your application. +# A version number is three numbers separated by dots, like 1.2.43 +# followed by an optional build number separated by a +. +# Both the version and the builder number may be overridden in flutter +# build by specifying --build-name and --build-number, respectively. +# In Android, build-name is used as versionName while build-number used as versionCode. +# Read more about Android versioning at https://developer.android.com/studio/publish/versioning +# In iOS, build-name is used as CFBundleShortVersionString while build-number is used as CFBundleVersion. +# Read more about iOS versioning at +# https://developer.apple.com/library/archive/documentation/General/Reference/InfoPlistKeyReference/Articles/CoreFoundationKeys.html +# In Windows, build-name is used as the major, minor, and patch parts +# of the product and file versions while build-number is used as the build suffix. +version: 1.0.0+1 + +environment: + sdk: ^3.7.0 + +# Dependencies specify other packages that your package needs in order to work. +# To automatically upgrade your package dependencies to the latest versions +# consider running `flutter pub upgrade --major-versions`. Alternatively, +# dependencies can be manually updated by changing the version numbers below to +# the latest version available on pub.dev. To see which dependencies have newer +# versions available, run `flutter pub outdated`. +dependencies: + flutter: + sdk: flutter + + # The following adds the Cupertino Icons font to your application. + # Use with the CupertinoIcons class for iOS style icons. + cupertino_icons: ^1.0.8 + equatable: ^2.0.7 + dartz: ^0.10.1 + intl: ^0.20.2 + +dev_dependencies: + flutter_test: + sdk: flutter + + # The "flutter_lints" package below contains a set of recommended lints to + # encourage good coding practices. The lint set provided by the package is + # activated in the `analysis_options.yaml` file located at the root of your + # package. See that file for information about deactivating specific lint + # rules and activating additional ones. + flutter_lints: ^5.0.0 + +# For information on the generic Dart part of this file, see the +# following page: https://dart.dev/tools/pub/pubspec + +# The following section is specific to Flutter packages. +flutter: + + # The following line ensures that the Material Icons font is + # included with your application, so that you can use the icons in + # the material Icons class. + uses-material-design: true + + # To add assets to your application, add an assets section, like this: + # assets: + # - images/a_dot_burr.jpeg + # - images/a_dot_ham.jpeg + + # An image asset can refer to one or more resolution-specific "variants", see + # https://flutter.dev/to/resolution-aware-images + + # For details regarding adding assets from package dependencies, see + # https://flutter.dev/to/asset-from-package + + # To add custom fonts to your application, add a fonts section here, + # in this "flutter" section. Each entry in this list should have a + # "family" key with the font family name, and a "fonts" key with a + # list giving the asset and other descriptors for the font. For + # example: + # fonts: + # - family: Schyler + # fonts: + # - asset: fonts/Schyler-Regular.ttf + # - asset: fonts/Schyler-Italic.ttf + # style: italic + # - family: Trajan Pro + # fonts: + # - asset: fonts/TrajanPro.ttf + # - asset: fonts/TrajanPro_Bold.ttf + # weight: 700 + # + # For details regarding fonts from package dependencies, + # see https://flutter.dev/to/font-from-package diff --git a/test/widget_test.dart b/test/widget_test.dart new file mode 100644 index 0000000000000000000000000000000000000000..ab73b3a234abf58d9009026cfa184dd11ca56bf2 --- /dev/null +++ b/test/widget_test.dart @@ -0,0 +1 @@ +void main() {}