Compare commits
16 Commits
| Author | SHA1 | Date | |
|---|---|---|---|
|
|
5b02be9ae7 | ||
|
|
8049165f44 | ||
|
|
34a73c62f7 | ||
| b75903e3cb | |||
|
|
039fde6dbe | ||
|
|
7aa8c8dcbc | ||
|
|
a58721a6f4 | ||
| 64b4f64f8c | |||
| 52d7defb75 | |||
| 782bbebce9 | |||
| 05386ac20f | |||
| 9f26bc8595 | |||
|
|
c35684c8f1 | ||
| 205f575db5 | |||
| ecf7011302 | |||
| 58e013a709 |
@@ -2,6 +2,7 @@ plugins {
|
|||||||
id "com.android.application"
|
id "com.android.application"
|
||||||
id "kotlin-android"
|
id "kotlin-android"
|
||||||
id "dev.flutter.flutter-gradle-plugin"
|
id "dev.flutter.flutter-gradle-plugin"
|
||||||
|
id 'com.google.gms.google-services'
|
||||||
}
|
}
|
||||||
|
|
||||||
def localProperties = new Properties()
|
def localProperties = new Properties()
|
||||||
@@ -64,4 +65,7 @@ flutter {
|
|||||||
source '../..'
|
source '../..'
|
||||||
}
|
}
|
||||||
|
|
||||||
dependencies {}
|
dependencies {
|
||||||
|
implementation platform('com.google.firebase:firebase-bom:32.3.1')
|
||||||
|
implementation 'com.google.firebase:firebase-analytics-ktx'
|
||||||
|
}
|
||||||
|
|||||||
803
ios/Podfile.lock
Normal file
803
ios/Podfile.lock
Normal file
@@ -0,0 +1,803 @@
|
|||||||
|
PODS:
|
||||||
|
- abseil/algorithm (1.20220623.0):
|
||||||
|
- abseil/algorithm/algorithm (= 1.20220623.0)
|
||||||
|
- abseil/algorithm/container (= 1.20220623.0)
|
||||||
|
- abseil/algorithm/algorithm (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/algorithm/container (1.20220623.0):
|
||||||
|
- abseil/algorithm/algorithm
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/base (1.20220623.0):
|
||||||
|
- abseil/base/atomic_hook (= 1.20220623.0)
|
||||||
|
- abseil/base/base (= 1.20220623.0)
|
||||||
|
- abseil/base/base_internal (= 1.20220623.0)
|
||||||
|
- abseil/base/config (= 1.20220623.0)
|
||||||
|
- abseil/base/core_headers (= 1.20220623.0)
|
||||||
|
- abseil/base/dynamic_annotations (= 1.20220623.0)
|
||||||
|
- abseil/base/endian (= 1.20220623.0)
|
||||||
|
- abseil/base/errno_saver (= 1.20220623.0)
|
||||||
|
- abseil/base/fast_type_id (= 1.20220623.0)
|
||||||
|
- abseil/base/log_severity (= 1.20220623.0)
|
||||||
|
- abseil/base/malloc_internal (= 1.20220623.0)
|
||||||
|
- abseil/base/prefetch (= 1.20220623.0)
|
||||||
|
- abseil/base/pretty_function (= 1.20220623.0)
|
||||||
|
- abseil/base/raw_logging_internal (= 1.20220623.0)
|
||||||
|
- abseil/base/spinlock_wait (= 1.20220623.0)
|
||||||
|
- abseil/base/strerror (= 1.20220623.0)
|
||||||
|
- abseil/base/throw_delegate (= 1.20220623.0)
|
||||||
|
- abseil/base/atomic_hook (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/base (1.20220623.0):
|
||||||
|
- abseil/base/atomic_hook
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/dynamic_annotations
|
||||||
|
- abseil/base/log_severity
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/base/spinlock_wait
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/base/base_internal (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/base/config (1.20220623.0)
|
||||||
|
- abseil/base/core_headers (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/dynamic_annotations (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/errno_saver (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/fast_type_id (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/log_severity (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/malloc_internal (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/dynamic_annotations
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/base/prefetch (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/pretty_function (1.20220623.0)
|
||||||
|
- abseil/base/raw_logging_internal (1.20220623.0):
|
||||||
|
- abseil/base/atomic_hook
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/errno_saver
|
||||||
|
- abseil/base/log_severity
|
||||||
|
- abseil/base/spinlock_wait (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/errno_saver
|
||||||
|
- abseil/base/strerror (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/errno_saver
|
||||||
|
- abseil/base/throw_delegate (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/cleanup/cleanup (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/cleanup/cleanup_internal
|
||||||
|
- abseil/cleanup/cleanup_internal (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/container/common (1.20220623.0):
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/types/optional
|
||||||
|
- abseil/container/compressed_tuple (1.20220623.0):
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/container/container_memory (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/container/fixed_array (1.20220623.0):
|
||||||
|
- abseil/algorithm/algorithm
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/dynamic_annotations
|
||||||
|
- abseil/base/throw_delegate
|
||||||
|
- abseil/container/compressed_tuple
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/container/flat_hash_map (1.20220623.0):
|
||||||
|
- abseil/algorithm/container
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/container/container_memory
|
||||||
|
- abseil/container/hash_function_defaults
|
||||||
|
- abseil/container/raw_hash_map
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/container/flat_hash_set (1.20220623.0):
|
||||||
|
- abseil/algorithm/container
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/container/container_memory
|
||||||
|
- abseil/container/hash_function_defaults
|
||||||
|
- abseil/container/raw_hash_set
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/container/hash_function_defaults (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/hash/hash
|
||||||
|
- abseil/strings/cord
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/container/hash_policy_traits (1.20220623.0):
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/container/hashtable_debug_hooks (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/container/hashtablez_sampler (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/debugging/stacktrace
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/profiling/exponential_biased
|
||||||
|
- abseil/profiling/sample_recorder
|
||||||
|
- abseil/synchronization/synchronization
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/container/inlined_vector (1.20220623.0):
|
||||||
|
- abseil/algorithm/algorithm
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/throw_delegate
|
||||||
|
- abseil/container/inlined_vector_internal
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/container/inlined_vector_internal (1.20220623.0):
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/container/compressed_tuple
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/container/layout (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/container/raw_hash_map (1.20220623.0):
|
||||||
|
- abseil/base/throw_delegate
|
||||||
|
- abseil/container/container_memory
|
||||||
|
- abseil/container/raw_hash_set
|
||||||
|
- abseil/container/raw_hash_set (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/base/prefetch
|
||||||
|
- abseil/container/common
|
||||||
|
- abseil/container/compressed_tuple
|
||||||
|
- abseil/container/container_memory
|
||||||
|
- abseil/container/hash_policy_traits
|
||||||
|
- abseil/container/hashtable_debug_hooks
|
||||||
|
- abseil/container/hashtablez_sampler
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/debugging/debugging_internal (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/dynamic_annotations
|
||||||
|
- abseil/base/errno_saver
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/debugging/demangle_internal (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/debugging/stacktrace (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/debugging/debugging_internal
|
||||||
|
- abseil/debugging/symbolize (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/dynamic_annotations
|
||||||
|
- abseil/base/malloc_internal
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/debugging/debugging_internal
|
||||||
|
- abseil/debugging/demangle_internal
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/functional/any_invocable (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/functional/bind_front (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/container/compressed_tuple
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/functional/function_ref (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/hash/city (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/hash/hash (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/container/fixed_array
|
||||||
|
- abseil/functional/function_ref
|
||||||
|
- abseil/hash/city
|
||||||
|
- abseil/hash/low_level_hash
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/optional
|
||||||
|
- abseil/types/variant
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/hash/low_level_hash (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/memory (1.20220623.0):
|
||||||
|
- abseil/memory/memory (= 1.20220623.0)
|
||||||
|
- abseil/memory/memory (1.20220623.0):
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/meta (1.20220623.0):
|
||||||
|
- abseil/meta/type_traits (= 1.20220623.0)
|
||||||
|
- abseil/meta/type_traits (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/numeric/bits (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/numeric/int128 (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/numeric/representation (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/profiling/exponential_biased (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/profiling/sample_recorder (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/synchronization/synchronization
|
||||||
|
- abseil/time/time
|
||||||
|
- abseil/random/distributions (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/random/internal/distribution_caller
|
||||||
|
- abseil/random/internal/fast_uniform_bits
|
||||||
|
- abseil/random/internal/fastmath
|
||||||
|
- abseil/random/internal/generate_real
|
||||||
|
- abseil/random/internal/iostream_state_saver
|
||||||
|
- abseil/random/internal/traits
|
||||||
|
- abseil/random/internal/uniform_helper
|
||||||
|
- abseil/random/internal/wide_multiply
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/random/internal/distribution_caller (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/fast_type_id
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/random/internal/fast_uniform_bits (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/random/internal/traits
|
||||||
|
- abseil/random/internal/fastmath (1.20220623.0):
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/random/internal/generate_real (1.20220623.0):
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/random/internal/fastmath
|
||||||
|
- abseil/random/internal/traits
|
||||||
|
- abseil/random/internal/iostream_state_saver (1.20220623.0):
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/random/internal/nonsecure_base (1.20220623.0):
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/container/inlined_vector
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/random/internal/pool_urbg
|
||||||
|
- abseil/random/internal/salted_seed_seq
|
||||||
|
- abseil/random/internal/seed_material
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/random/internal/pcg_engine (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/random/internal/fastmath
|
||||||
|
- abseil/random/internal/iostream_state_saver
|
||||||
|
- abseil/random/internal/platform (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/random/internal/pool_urbg (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/random/internal/randen
|
||||||
|
- abseil/random/internal/seed_material
|
||||||
|
- abseil/random/internal/traits
|
||||||
|
- abseil/random/seed_gen_exception
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/random/internal/randen (1.20220623.0):
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/random/internal/platform
|
||||||
|
- abseil/random/internal/randen_hwaes
|
||||||
|
- abseil/random/internal/randen_slow
|
||||||
|
- abseil/random/internal/randen_engine (1.20220623.0):
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/random/internal/iostream_state_saver
|
||||||
|
- abseil/random/internal/randen
|
||||||
|
- abseil/random/internal/randen_hwaes (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/random/internal/platform
|
||||||
|
- abseil/random/internal/randen_hwaes_impl
|
||||||
|
- abseil/random/internal/randen_hwaes_impl (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/random/internal/platform
|
||||||
|
- abseil/random/internal/randen_slow (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/random/internal/platform
|
||||||
|
- abseil/random/internal/salted_seed_seq (1.20220623.0):
|
||||||
|
- abseil/container/inlined_vector
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/random/internal/seed_material
|
||||||
|
- abseil/types/optional
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/random/internal/seed_material (1.20220623.0):
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/dynamic_annotations
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/random/internal/fast_uniform_bits
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/optional
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/random/internal/traits (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/random/internal/uniform_helper (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/random/internal/traits
|
||||||
|
- abseil/random/internal/wide_multiply (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/random/internal/traits
|
||||||
|
- abseil/random/random (1.20220623.0):
|
||||||
|
- abseil/random/distributions
|
||||||
|
- abseil/random/internal/nonsecure_base
|
||||||
|
- abseil/random/internal/pcg_engine
|
||||||
|
- abseil/random/internal/pool_urbg
|
||||||
|
- abseil/random/internal/randen_engine
|
||||||
|
- abseil/random/seed_sequences
|
||||||
|
- abseil/random/seed_gen_exception (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/random/seed_sequences (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/random/internal/pool_urbg
|
||||||
|
- abseil/random/internal/salted_seed_seq
|
||||||
|
- abseil/random/internal/seed_material
|
||||||
|
- abseil/random/seed_gen_exception
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/status/status (1.20220623.0):
|
||||||
|
- abseil/base/atomic_hook
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/base/strerror
|
||||||
|
- abseil/container/inlined_vector
|
||||||
|
- abseil/debugging/stacktrace
|
||||||
|
- abseil/debugging/symbolize
|
||||||
|
- abseil/functional/function_ref
|
||||||
|
- abseil/strings/cord
|
||||||
|
- abseil/strings/str_format
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/optional
|
||||||
|
- abseil/status/statusor (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/status/status
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/variant
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/strings/cord (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/container/fixed_array
|
||||||
|
- abseil/container/inlined_vector
|
||||||
|
- abseil/functional/function_ref
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/strings/cord_internal
|
||||||
|
- abseil/strings/cordz_functions
|
||||||
|
- abseil/strings/cordz_info
|
||||||
|
- abseil/strings/cordz_statistics
|
||||||
|
- abseil/strings/cordz_update_scope
|
||||||
|
- abseil/strings/cordz_update_tracker
|
||||||
|
- abseil/strings/internal
|
||||||
|
- abseil/strings/str_format
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/optional
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/strings/cord_internal (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/base/throw_delegate
|
||||||
|
- abseil/container/compressed_tuple
|
||||||
|
- abseil/container/inlined_vector
|
||||||
|
- abseil/container/layout
|
||||||
|
- abseil/functional/function_ref
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/strings/cordz_functions (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/profiling/exponential_biased
|
||||||
|
- abseil/strings/cordz_handle (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/synchronization/synchronization
|
||||||
|
- abseil/strings/cordz_info (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/container/inlined_vector
|
||||||
|
- abseil/debugging/stacktrace
|
||||||
|
- abseil/strings/cord_internal
|
||||||
|
- abseil/strings/cordz_functions
|
||||||
|
- abseil/strings/cordz_handle
|
||||||
|
- abseil/strings/cordz_statistics
|
||||||
|
- abseil/strings/cordz_update_tracker
|
||||||
|
- abseil/synchronization/synchronization
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/strings/cordz_statistics (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/strings/cordz_update_tracker
|
||||||
|
- abseil/strings/cordz_update_scope (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/strings/cord_internal
|
||||||
|
- abseil/strings/cordz_info
|
||||||
|
- abseil/strings/cordz_update_tracker
|
||||||
|
- abseil/strings/cordz_update_tracker (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/strings/internal (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/strings/str_format (1.20220623.0):
|
||||||
|
- abseil/strings/str_format_internal
|
||||||
|
- abseil/strings/str_format_internal (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/functional/function_ref
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/numeric/representation
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/types/optional
|
||||||
|
- abseil/types/span
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/strings/strings (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/endian
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/base/throw_delegate
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/numeric/bits
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/strings/internal
|
||||||
|
- abseil/synchronization/graphcycles_internal (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/malloc_internal
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/synchronization/kernel_timeout_internal (1.20220623.0):
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/time/time
|
||||||
|
- abseil/synchronization/synchronization (1.20220623.0):
|
||||||
|
- abseil/base/atomic_hook
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/dynamic_annotations
|
||||||
|
- abseil/base/malloc_internal
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/debugging/stacktrace
|
||||||
|
- abseil/debugging/symbolize
|
||||||
|
- abseil/synchronization/graphcycles_internal
|
||||||
|
- abseil/synchronization/kernel_timeout_internal
|
||||||
|
- abseil/time/time
|
||||||
|
- abseil/time (1.20220623.0):
|
||||||
|
- abseil/time/internal (= 1.20220623.0)
|
||||||
|
- abseil/time/time (= 1.20220623.0)
|
||||||
|
- abseil/time/internal (1.20220623.0):
|
||||||
|
- abseil/time/internal/cctz (= 1.20220623.0)
|
||||||
|
- abseil/time/internal/cctz (1.20220623.0):
|
||||||
|
- abseil/time/internal/cctz/civil_time (= 1.20220623.0)
|
||||||
|
- abseil/time/internal/cctz/time_zone (= 1.20220623.0)
|
||||||
|
- abseil/time/internal/cctz/civil_time (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/time/internal/cctz/time_zone (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/time/internal/cctz/civil_time
|
||||||
|
- abseil/time/time (1.20220623.0):
|
||||||
|
- abseil/base/base
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/numeric/int128
|
||||||
|
- abseil/strings/strings
|
||||||
|
- abseil/time/internal/cctz/civil_time
|
||||||
|
- abseil/time/internal/cctz/time_zone
|
||||||
|
- abseil/types (1.20220623.0):
|
||||||
|
- abseil/types/any (= 1.20220623.0)
|
||||||
|
- abseil/types/bad_any_cast (= 1.20220623.0)
|
||||||
|
- abseil/types/bad_any_cast_impl (= 1.20220623.0)
|
||||||
|
- abseil/types/bad_optional_access (= 1.20220623.0)
|
||||||
|
- abseil/types/bad_variant_access (= 1.20220623.0)
|
||||||
|
- abseil/types/compare (= 1.20220623.0)
|
||||||
|
- abseil/types/optional (= 1.20220623.0)
|
||||||
|
- abseil/types/span (= 1.20220623.0)
|
||||||
|
- abseil/types/variant (= 1.20220623.0)
|
||||||
|
- abseil/types/any (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/fast_type_id
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/types/bad_any_cast
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/types/bad_any_cast (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/types/bad_any_cast_impl
|
||||||
|
- abseil/types/bad_any_cast_impl (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/types/bad_optional_access (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/types/bad_variant_access (1.20220623.0):
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/raw_logging_internal
|
||||||
|
- abseil/types/compare (1.20220623.0):
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/types/optional (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/memory/memory
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/types/bad_optional_access
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/types/span (1.20220623.0):
|
||||||
|
- abseil/algorithm/algorithm
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/base/throw_delegate
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/types/variant (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/base/core_headers
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- abseil/types/bad_variant_access
|
||||||
|
- abseil/utility/utility
|
||||||
|
- abseil/utility/utility (1.20220623.0):
|
||||||
|
- abseil/base/base_internal
|
||||||
|
- abseil/base/config
|
||||||
|
- abseil/meta/type_traits
|
||||||
|
- BoringSSL-GRPC (0.0.24):
|
||||||
|
- BoringSSL-GRPC/Implementation (= 0.0.24)
|
||||||
|
- BoringSSL-GRPC/Interface (= 0.0.24)
|
||||||
|
- BoringSSL-GRPC/Implementation (0.0.24):
|
||||||
|
- BoringSSL-GRPC/Interface (= 0.0.24)
|
||||||
|
- BoringSSL-GRPC/Interface (0.0.24)
|
||||||
|
- cloud_firestore (4.9.2):
|
||||||
|
- Firebase/Firestore (= 10.15.0)
|
||||||
|
- firebase_core
|
||||||
|
- Flutter
|
||||||
|
- nanopb (< 2.30910.0, >= 2.30908.0)
|
||||||
|
- Firebase/CoreOnly (10.15.0):
|
||||||
|
- FirebaseCore (= 10.15.0)
|
||||||
|
- Firebase/Firestore (10.15.0):
|
||||||
|
- Firebase/CoreOnly
|
||||||
|
- FirebaseFirestore (~> 10.15.0)
|
||||||
|
- firebase_core (2.16.0):
|
||||||
|
- Firebase/CoreOnly (= 10.15.0)
|
||||||
|
- Flutter
|
||||||
|
- FirebaseCore (10.15.0):
|
||||||
|
- FirebaseCoreInternal (~> 10.0)
|
||||||
|
- GoogleUtilities/Environment (~> 7.8)
|
||||||
|
- GoogleUtilities/Logger (~> 7.8)
|
||||||
|
- FirebaseCoreInternal (10.15.0):
|
||||||
|
- "GoogleUtilities/NSData+zlib (~> 7.8)"
|
||||||
|
- FirebaseFirestore (10.15.0):
|
||||||
|
- abseil/algorithm (~> 1.20220623.0)
|
||||||
|
- abseil/base (~> 1.20220623.0)
|
||||||
|
- abseil/container/flat_hash_map (~> 1.20220623.0)
|
||||||
|
- abseil/memory (~> 1.20220623.0)
|
||||||
|
- abseil/meta (~> 1.20220623.0)
|
||||||
|
- abseil/strings/strings (~> 1.20220623.0)
|
||||||
|
- abseil/time (~> 1.20220623.0)
|
||||||
|
- abseil/types (~> 1.20220623.0)
|
||||||
|
- FirebaseCore (~> 10.0)
|
||||||
|
- "gRPC-C++ (~> 1.50.1)"
|
||||||
|
- leveldb-library (~> 1.22)
|
||||||
|
- nanopb (< 2.30910.0, >= 2.30908.0)
|
||||||
|
- Flutter (1.0.0)
|
||||||
|
- FMDB (2.7.5):
|
||||||
|
- FMDB/standard (= 2.7.5)
|
||||||
|
- FMDB/standard (2.7.5)
|
||||||
|
- GoogleUtilities/Environment (7.11.5):
|
||||||
|
- PromisesObjC (< 3.0, >= 1.2)
|
||||||
|
- GoogleUtilities/Logger (7.11.5):
|
||||||
|
- GoogleUtilities/Environment
|
||||||
|
- "GoogleUtilities/NSData+zlib (7.11.5)"
|
||||||
|
- "gRPC-C++ (1.50.1)":
|
||||||
|
- "gRPC-C++/Implementation (= 1.50.1)"
|
||||||
|
- "gRPC-C++/Interface (= 1.50.1)"
|
||||||
|
- "gRPC-C++/Implementation (1.50.1)":
|
||||||
|
- abseil/base/base (= 1.20220623.0)
|
||||||
|
- abseil/base/core_headers (= 1.20220623.0)
|
||||||
|
- abseil/cleanup/cleanup (= 1.20220623.0)
|
||||||
|
- abseil/container/flat_hash_map (= 1.20220623.0)
|
||||||
|
- abseil/container/flat_hash_set (= 1.20220623.0)
|
||||||
|
- abseil/container/inlined_vector (= 1.20220623.0)
|
||||||
|
- abseil/functional/any_invocable (= 1.20220623.0)
|
||||||
|
- abseil/functional/bind_front (= 1.20220623.0)
|
||||||
|
- abseil/functional/function_ref (= 1.20220623.0)
|
||||||
|
- abseil/hash/hash (= 1.20220623.0)
|
||||||
|
- abseil/memory/memory (= 1.20220623.0)
|
||||||
|
- abseil/meta/type_traits (= 1.20220623.0)
|
||||||
|
- abseil/random/random (= 1.20220623.0)
|
||||||
|
- abseil/status/status (= 1.20220623.0)
|
||||||
|
- abseil/status/statusor (= 1.20220623.0)
|
||||||
|
- abseil/strings/cord (= 1.20220623.0)
|
||||||
|
- abseil/strings/str_format (= 1.20220623.0)
|
||||||
|
- abseil/strings/strings (= 1.20220623.0)
|
||||||
|
- abseil/synchronization/synchronization (= 1.20220623.0)
|
||||||
|
- abseil/time/time (= 1.20220623.0)
|
||||||
|
- abseil/types/optional (= 1.20220623.0)
|
||||||
|
- abseil/types/span (= 1.20220623.0)
|
||||||
|
- abseil/types/variant (= 1.20220623.0)
|
||||||
|
- abseil/utility/utility (= 1.20220623.0)
|
||||||
|
- "gRPC-C++/Interface (= 1.50.1)"
|
||||||
|
- gRPC-Core (= 1.50.1)
|
||||||
|
- "gRPC-C++/Interface (1.50.1)"
|
||||||
|
- gRPC-Core (1.50.1):
|
||||||
|
- gRPC-Core/Implementation (= 1.50.1)
|
||||||
|
- gRPC-Core/Interface (= 1.50.1)
|
||||||
|
- gRPC-Core/Implementation (1.50.1):
|
||||||
|
- abseil/base/base (= 1.20220623.0)
|
||||||
|
- abseil/base/core_headers (= 1.20220623.0)
|
||||||
|
- abseil/container/flat_hash_map (= 1.20220623.0)
|
||||||
|
- abseil/container/flat_hash_set (= 1.20220623.0)
|
||||||
|
- abseil/container/inlined_vector (= 1.20220623.0)
|
||||||
|
- abseil/functional/any_invocable (= 1.20220623.0)
|
||||||
|
- abseil/functional/bind_front (= 1.20220623.0)
|
||||||
|
- abseil/functional/function_ref (= 1.20220623.0)
|
||||||
|
- abseil/hash/hash (= 1.20220623.0)
|
||||||
|
- abseil/memory/memory (= 1.20220623.0)
|
||||||
|
- abseil/meta/type_traits (= 1.20220623.0)
|
||||||
|
- abseil/random/random (= 1.20220623.0)
|
||||||
|
- abseil/status/status (= 1.20220623.0)
|
||||||
|
- abseil/status/statusor (= 1.20220623.0)
|
||||||
|
- abseil/strings/cord (= 1.20220623.0)
|
||||||
|
- abseil/strings/str_format (= 1.20220623.0)
|
||||||
|
- abseil/strings/strings (= 1.20220623.0)
|
||||||
|
- abseil/synchronization/synchronization (= 1.20220623.0)
|
||||||
|
- abseil/time/time (= 1.20220623.0)
|
||||||
|
- abseil/types/optional (= 1.20220623.0)
|
||||||
|
- abseil/types/span (= 1.20220623.0)
|
||||||
|
- abseil/types/variant (= 1.20220623.0)
|
||||||
|
- abseil/utility/utility (= 1.20220623.0)
|
||||||
|
- BoringSSL-GRPC (= 0.0.24)
|
||||||
|
- gRPC-Core/Interface (= 1.50.1)
|
||||||
|
- gRPC-Core/Interface (1.50.1)
|
||||||
|
- leveldb-library (1.22.2)
|
||||||
|
- nanopb (2.30909.0):
|
||||||
|
- nanopb/decode (= 2.30909.0)
|
||||||
|
- nanopb/encode (= 2.30909.0)
|
||||||
|
- nanopb/decode (2.30909.0)
|
||||||
|
- nanopb/encode (2.30909.0)
|
||||||
|
- PromisesObjC (2.3.1)
|
||||||
|
- sqflite (0.0.3):
|
||||||
|
- Flutter
|
||||||
|
- FMDB (>= 2.7.5)
|
||||||
|
|
||||||
|
DEPENDENCIES:
|
||||||
|
- cloud_firestore (from `.symlinks/plugins/cloud_firestore/ios`)
|
||||||
|
- firebase_core (from `.symlinks/plugins/firebase_core/ios`)
|
||||||
|
- Flutter (from `Flutter`)
|
||||||
|
- sqflite (from `.symlinks/plugins/sqflite/ios`)
|
||||||
|
|
||||||
|
SPEC REPOS:
|
||||||
|
trunk:
|
||||||
|
- abseil
|
||||||
|
- BoringSSL-GRPC
|
||||||
|
- Firebase
|
||||||
|
- FirebaseCore
|
||||||
|
- FirebaseCoreInternal
|
||||||
|
- FirebaseFirestore
|
||||||
|
- FMDB
|
||||||
|
- GoogleUtilities
|
||||||
|
- "gRPC-C++"
|
||||||
|
- gRPC-Core
|
||||||
|
- leveldb-library
|
||||||
|
- nanopb
|
||||||
|
- PromisesObjC
|
||||||
|
|
||||||
|
EXTERNAL SOURCES:
|
||||||
|
cloud_firestore:
|
||||||
|
:path: ".symlinks/plugins/cloud_firestore/ios"
|
||||||
|
firebase_core:
|
||||||
|
:path: ".symlinks/plugins/firebase_core/ios"
|
||||||
|
Flutter:
|
||||||
|
:path: Flutter
|
||||||
|
sqflite:
|
||||||
|
:path: ".symlinks/plugins/sqflite/ios"
|
||||||
|
|
||||||
|
SPEC CHECKSUMS:
|
||||||
|
abseil: 926fb7a82dc6d2b8e1f2ed7f3a718bce691d1e46
|
||||||
|
BoringSSL-GRPC: 3175b25143e648463a56daeaaa499c6cb86dad33
|
||||||
|
cloud_firestore: ac000d8c5a79d57dc69238ea06bb422880fb825e
|
||||||
|
Firebase: 66043bd4579e5b73811f96829c694c7af8d67435
|
||||||
|
firebase_core: 77172d0a9d8d19d07606e24406e4c2fc14d3265b
|
||||||
|
FirebaseCore: 2cec518b43635f96afe7ac3a9c513e47558abd2e
|
||||||
|
FirebaseCoreInternal: 2f4bee5ed00301b5e56da0849268797a2dd31fb4
|
||||||
|
FirebaseFirestore: b4c0eaaf24efda5732ec21d9e6c788d083118ca6
|
||||||
|
Flutter: f04841e97a9d0b0a8025694d0796dd46242b2854
|
||||||
|
FMDB: 2ce00b547f966261cd18927a3ddb07cb6f3db82a
|
||||||
|
GoogleUtilities: 13e2c67ede716b8741c7989e26893d151b2b2084
|
||||||
|
"gRPC-C++": 0968bace703459fd3e5dcb0b2bed4c573dbff046
|
||||||
|
gRPC-Core: 17108291d84332196d3c8466b48f016fc17d816d
|
||||||
|
leveldb-library: f03246171cce0484482ec291f88b6d563699ee06
|
||||||
|
nanopb: b552cce312b6c8484180ef47159bc0f65a1f0431
|
||||||
|
PromisesObjC: c50d2056b5253dadbd6c2bea79b0674bd5a52fa4
|
||||||
|
sqflite: 31f7eba61e3074736dff8807a9b41581e4f7f15a
|
||||||
|
|
||||||
|
PODFILE CHECKSUM: 70d9d25280d0dd177a5f637cdb0f0b0b12c6a189
|
||||||
|
|
||||||
|
COCOAPODS: 1.13.0
|
||||||
@@ -7,7 +7,9 @@
|
|||||||
objects = {
|
objects = {
|
||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
|
14598A476CDD143A9163A8D0 /* Pods_Runner.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = A22145BC7083143C8550C1DF /* Pods_Runner.framework */; };
|
||||||
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
|
1498D2341E8E89220040F4C2 /* GeneratedPluginRegistrant.m in Sources */ = {isa = PBXBuildFile; fileRef = 1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */; };
|
||||||
|
2D769578FD696D1EDCE6D84F /* Pods_RunnerTests.framework in Frameworks */ = {isa = PBXBuildFile; fileRef = 3537C17B34EEAED6124A6923 /* Pods_RunnerTests.framework */; };
|
||||||
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; };
|
331C808B294A63AB00263BE5 /* RunnerTests.swift in Sources */ = {isa = PBXBuildFile; fileRef = 331C807B294A618700263BE5 /* RunnerTests.swift */; };
|
||||||
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
|
3B3967161E833CAA004F5970 /* AppFrameworkInfo.plist in Resources */ = {isa = PBXBuildFile; fileRef = 3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */; };
|
||||||
59B838D7BCD1FCB0EF703652 /* GoogleService-Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = 543BBA514F0FE7A2C874CB88 /* GoogleService-Info.plist */; };
|
59B838D7BCD1FCB0EF703652 /* GoogleService-Info.plist in Resources */ = {isa = PBXBuildFile; fileRef = 543BBA514F0FE7A2C874CB88 /* GoogleService-Info.plist */; };
|
||||||
@@ -43,13 +45,18 @@
|
|||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; };
|
1498D2321E8E86230040F4C2 /* GeneratedPluginRegistrant.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = GeneratedPluginRegistrant.h; sourceTree = "<group>"; };
|
||||||
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; };
|
1498D2331E8E89220040F4C2 /* GeneratedPluginRegistrant.m */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.objc; path = GeneratedPluginRegistrant.m; sourceTree = "<group>"; };
|
||||||
|
27CEB3A1A0CD7E4F0CD2D1EE /* Pods-Runner.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.debug.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.debug.xcconfig"; sourceTree = "<group>"; };
|
||||||
331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = "<group>"; };
|
331C807B294A618700263BE5 /* RunnerTests.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = RunnerTests.swift; sourceTree = "<group>"; };
|
||||||
331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
331C8081294A63A400263BE5 /* RunnerTests.xctest */ = {isa = PBXFileReference; explicitFileType = wrapper.cfbundle; includeInIndex = 0; path = RunnerTests.xctest; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
|
3537C17B34EEAED6124A6923 /* Pods_RunnerTests.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_RunnerTests.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; };
|
3B3967151E833CAA004F5970 /* AppFrameworkInfo.plist */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.plist.xml; name = AppFrameworkInfo.plist; path = Flutter/AppFrameworkInfo.plist; sourceTree = "<group>"; };
|
||||||
|
4522E91C2F197AEAF11E6C08 /* Pods-RunnerTests.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.profile.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.profile.xcconfig"; sourceTree = "<group>"; };
|
||||||
543BBA514F0FE7A2C874CB88 /* GoogleService-Info.plist */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.plist.xml; name = "GoogleService-Info.plist"; path = "Runner/GoogleService-Info.plist"; sourceTree = "<group>"; };
|
543BBA514F0FE7A2C874CB88 /* GoogleService-Info.plist */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.plist.xml; name = "GoogleService-Info.plist"; path = "Runner/GoogleService-Info.plist"; sourceTree = "<group>"; };
|
||||||
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; };
|
74858FAD1ED2DC5600515810 /* Runner-Bridging-Header.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = "Runner-Bridging-Header.h"; sourceTree = "<group>"; };
|
||||||
74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
74858FAE1ED2DC5600515810 /* AppDelegate.swift */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.swift; path = AppDelegate.swift; sourceTree = "<group>"; };
|
||||||
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; };
|
7AFA3C8E1D35360C0083082E /* Release.xcconfig */ = {isa = PBXFileReference; lastKnownFileType = text.xcconfig; name = Release.xcconfig; path = Flutter/Release.xcconfig; sourceTree = "<group>"; };
|
||||||
|
7D249F16ED68C041D85B3071 /* Pods-RunnerTests.debug.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.debug.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.debug.xcconfig"; sourceTree = "<group>"; };
|
||||||
|
9686E1D9CB7869EA9A44F131 /* Pods-Runner.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.release.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.release.xcconfig"; sourceTree = "<group>"; };
|
||||||
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; };
|
9740EEB21CF90195004384FC /* Debug.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Debug.xcconfig; path = Flutter/Debug.xcconfig; sourceTree = "<group>"; };
|
||||||
9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; };
|
9740EEB31CF90195004384FC /* Generated.xcconfig */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xcconfig; name = Generated.xcconfig; path = Flutter/Generated.xcconfig; sourceTree = "<group>"; };
|
||||||
97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
97C146EE1CF9000F007C117D /* Runner.app */ = {isa = PBXFileReference; explicitFileType = wrapper.application; includeInIndex = 0; path = Runner.app; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
@@ -57,13 +64,25 @@
|
|||||||
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
|
97C146FD1CF9000F007C117D /* Assets.xcassets */ = {isa = PBXFileReference; lastKnownFileType = folder.assetcatalog; path = Assets.xcassets; sourceTree = "<group>"; };
|
||||||
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
|
97C147001CF9000F007C117D /* Base */ = {isa = PBXFileReference; lastKnownFileType = file.storyboard; name = Base; path = Base.lproj/LaunchScreen.storyboard; sourceTree = "<group>"; };
|
||||||
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
97C147021CF9000F007C117D /* Info.plist */ = {isa = PBXFileReference; lastKnownFileType = text.plist.xml; path = Info.plist; sourceTree = "<group>"; };
|
||||||
|
A22145BC7083143C8550C1DF /* Pods_Runner.framework */ = {isa = PBXFileReference; explicitFileType = wrapper.framework; includeInIndex = 0; path = Pods_Runner.framework; sourceTree = BUILT_PRODUCTS_DIR; };
|
||||||
|
C58B8C366954D0DE8AA14A33 /* Pods-Runner.profile.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-Runner.profile.xcconfig"; path = "Target Support Files/Pods-Runner/Pods-Runner.profile.xcconfig"; sourceTree = "<group>"; };
|
||||||
|
C99E9AAEFDCBB3C6B2126798 /* Pods-RunnerTests.release.xcconfig */ = {isa = PBXFileReference; includeInIndex = 1; lastKnownFileType = text.xcconfig; name = "Pods-RunnerTests.release.xcconfig"; path = "Target Support Files/Pods-RunnerTests/Pods-RunnerTests.release.xcconfig"; sourceTree = "<group>"; };
|
||||||
/* End PBXFileReference section */
|
/* End PBXFileReference section */
|
||||||
|
|
||||||
/* Begin PBXFrameworksBuildPhase section */
|
/* Begin PBXFrameworksBuildPhase section */
|
||||||
|
18D8EA36989EDBC7D3B01AE5 /* Frameworks */ = {
|
||||||
|
isa = PBXFrameworksBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
2D769578FD696D1EDCE6D84F /* Pods_RunnerTests.framework in Frameworks */,
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
};
|
||||||
97C146EB1CF9000F007C117D /* Frameworks */ = {
|
97C146EB1CF9000F007C117D /* Frameworks */ = {
|
||||||
isa = PBXFrameworksBuildPhase;
|
isa = PBXFrameworksBuildPhase;
|
||||||
buildActionMask = 2147483647;
|
buildActionMask = 2147483647;
|
||||||
files = (
|
files = (
|
||||||
|
14598A476CDD143A9163A8D0 /* Pods_Runner.framework in Frameworks */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
};
|
};
|
||||||
@@ -78,6 +97,20 @@
|
|||||||
path = RunnerTests;
|
path = RunnerTests;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
4746143E2707AFFC395924AD /* Pods */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
27CEB3A1A0CD7E4F0CD2D1EE /* Pods-Runner.debug.xcconfig */,
|
||||||
|
9686E1D9CB7869EA9A44F131 /* Pods-Runner.release.xcconfig */,
|
||||||
|
C58B8C366954D0DE8AA14A33 /* Pods-Runner.profile.xcconfig */,
|
||||||
|
7D249F16ED68C041D85B3071 /* Pods-RunnerTests.debug.xcconfig */,
|
||||||
|
C99E9AAEFDCBB3C6B2126798 /* Pods-RunnerTests.release.xcconfig */,
|
||||||
|
4522E91C2F197AEAF11E6C08 /* Pods-RunnerTests.profile.xcconfig */,
|
||||||
|
);
|
||||||
|
name = Pods;
|
||||||
|
path = Pods;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
9740EEB11CF90186004384FC /* Flutter */ = {
|
9740EEB11CF90186004384FC /* Flutter */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
@@ -97,6 +130,8 @@
|
|||||||
97C146EF1CF9000F007C117D /* Products */,
|
97C146EF1CF9000F007C117D /* Products */,
|
||||||
331C8082294A63A400263BE5 /* RunnerTests */,
|
331C8082294A63A400263BE5 /* RunnerTests */,
|
||||||
543BBA514F0FE7A2C874CB88 /* GoogleService-Info.plist */,
|
543BBA514F0FE7A2C874CB88 /* GoogleService-Info.plist */,
|
||||||
|
4746143E2707AFFC395924AD /* Pods */,
|
||||||
|
BEF8BC261C065D847E7C23E0 /* Frameworks */,
|
||||||
);
|
);
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
@@ -124,6 +159,15 @@
|
|||||||
path = Runner;
|
path = Runner;
|
||||||
sourceTree = "<group>";
|
sourceTree = "<group>";
|
||||||
};
|
};
|
||||||
|
BEF8BC261C065D847E7C23E0 /* Frameworks */ = {
|
||||||
|
isa = PBXGroup;
|
||||||
|
children = (
|
||||||
|
A22145BC7083143C8550C1DF /* Pods_Runner.framework */,
|
||||||
|
3537C17B34EEAED6124A6923 /* Pods_RunnerTests.framework */,
|
||||||
|
);
|
||||||
|
name = Frameworks;
|
||||||
|
sourceTree = "<group>";
|
||||||
|
};
|
||||||
/* End PBXGroup section */
|
/* End PBXGroup section */
|
||||||
|
|
||||||
/* Begin PBXNativeTarget section */
|
/* Begin PBXNativeTarget section */
|
||||||
@@ -131,8 +175,10 @@
|
|||||||
isa = PBXNativeTarget;
|
isa = PBXNativeTarget;
|
||||||
buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
|
buildConfigurationList = 331C8087294A63A400263BE5 /* Build configuration list for PBXNativeTarget "RunnerTests" */;
|
||||||
buildPhases = (
|
buildPhases = (
|
||||||
|
8A5F9DF6FA4CCC4C75BDDE8A /* [CP] Check Pods Manifest.lock */,
|
||||||
331C807D294A63A400263BE5 /* Sources */,
|
331C807D294A63A400263BE5 /* Sources */,
|
||||||
331C807F294A63A400263BE5 /* Resources */,
|
331C807F294A63A400263BE5 /* Resources */,
|
||||||
|
18D8EA36989EDBC7D3B01AE5 /* Frameworks */,
|
||||||
);
|
);
|
||||||
buildRules = (
|
buildRules = (
|
||||||
);
|
);
|
||||||
@@ -148,12 +194,14 @@
|
|||||||
isa = PBXNativeTarget;
|
isa = PBXNativeTarget;
|
||||||
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
|
buildConfigurationList = 97C147051CF9000F007C117D /* Build configuration list for PBXNativeTarget "Runner" */;
|
||||||
buildPhases = (
|
buildPhases = (
|
||||||
|
A2E3A3F6E09A36780D84C246 /* [CP] Check Pods Manifest.lock */,
|
||||||
9740EEB61CF901F6004384FC /* Run Script */,
|
9740EEB61CF901F6004384FC /* Run Script */,
|
||||||
97C146EA1CF9000F007C117D /* Sources */,
|
97C146EA1CF9000F007C117D /* Sources */,
|
||||||
97C146EB1CF9000F007C117D /* Frameworks */,
|
97C146EB1CF9000F007C117D /* Frameworks */,
|
||||||
97C146EC1CF9000F007C117D /* Resources */,
|
97C146EC1CF9000F007C117D /* Resources */,
|
||||||
9705A1C41CF9048500538489 /* Embed Frameworks */,
|
9705A1C41CF9048500538489 /* Embed Frameworks */,
|
||||||
3B06AD1E1E4923F5004D2608 /* Thin Binary */,
|
3B06AD1E1E4923F5004D2608 /* Thin Binary */,
|
||||||
|
4557F1C65EFFB341DAC93FDF /* [CP] Embed Pods Frameworks */,
|
||||||
);
|
);
|
||||||
buildRules = (
|
buildRules = (
|
||||||
);
|
);
|
||||||
@@ -242,6 +290,45 @@
|
|||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
|
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" embed_and_thin";
|
||||||
};
|
};
|
||||||
|
4557F1C65EFFB341DAC93FDF /* [CP] Embed Pods Frameworks */ = {
|
||||||
|
isa = PBXShellScriptBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
);
|
||||||
|
inputFileListPaths = (
|
||||||
|
"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-input-files.xcfilelist",
|
||||||
|
);
|
||||||
|
name = "[CP] Embed Pods Frameworks";
|
||||||
|
outputFileListPaths = (
|
||||||
|
"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks-${CONFIGURATION}-output-files.xcfilelist",
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
shellPath = /bin/sh;
|
||||||
|
shellScript = "\"${PODS_ROOT}/Target Support Files/Pods-Runner/Pods-Runner-frameworks.sh\"\n";
|
||||||
|
showEnvVarsInLog = 0;
|
||||||
|
};
|
||||||
|
8A5F9DF6FA4CCC4C75BDDE8A /* [CP] Check Pods Manifest.lock */ = {
|
||||||
|
isa = PBXShellScriptBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
);
|
||||||
|
inputFileListPaths = (
|
||||||
|
);
|
||||||
|
inputPaths = (
|
||||||
|
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
||||||
|
"${PODS_ROOT}/Manifest.lock",
|
||||||
|
);
|
||||||
|
name = "[CP] Check Pods Manifest.lock";
|
||||||
|
outputFileListPaths = (
|
||||||
|
);
|
||||||
|
outputPaths = (
|
||||||
|
"$(DERIVED_FILE_DIR)/Pods-RunnerTests-checkManifestLockResult.txt",
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
shellPath = /bin/sh;
|
||||||
|
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
||||||
|
showEnvVarsInLog = 0;
|
||||||
|
};
|
||||||
9740EEB61CF901F6004384FC /* Run Script */ = {
|
9740EEB61CF901F6004384FC /* Run Script */ = {
|
||||||
isa = PBXShellScriptBuildPhase;
|
isa = PBXShellScriptBuildPhase;
|
||||||
alwaysOutOfDate = 1;
|
alwaysOutOfDate = 1;
|
||||||
@@ -257,6 +344,28 @@
|
|||||||
shellPath = /bin/sh;
|
shellPath = /bin/sh;
|
||||||
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build";
|
shellScript = "/bin/sh \"$FLUTTER_ROOT/packages/flutter_tools/bin/xcode_backend.sh\" build";
|
||||||
};
|
};
|
||||||
|
A2E3A3F6E09A36780D84C246 /* [CP] Check Pods Manifest.lock */ = {
|
||||||
|
isa = PBXShellScriptBuildPhase;
|
||||||
|
buildActionMask = 2147483647;
|
||||||
|
files = (
|
||||||
|
);
|
||||||
|
inputFileListPaths = (
|
||||||
|
);
|
||||||
|
inputPaths = (
|
||||||
|
"${PODS_PODFILE_DIR_PATH}/Podfile.lock",
|
||||||
|
"${PODS_ROOT}/Manifest.lock",
|
||||||
|
);
|
||||||
|
name = "[CP] Check Pods Manifest.lock";
|
||||||
|
outputFileListPaths = (
|
||||||
|
);
|
||||||
|
outputPaths = (
|
||||||
|
"$(DERIVED_FILE_DIR)/Pods-Runner-checkManifestLockResult.txt",
|
||||||
|
);
|
||||||
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
shellPath = /bin/sh;
|
||||||
|
shellScript = "diff \"${PODS_PODFILE_DIR_PATH}/Podfile.lock\" \"${PODS_ROOT}/Manifest.lock\" > /dev/null\nif [ $? != 0 ] ; then\n # print error to STDERR\n echo \"error: The sandbox is not in sync with the Podfile.lock. Run 'pod install' or update your CocoaPods installation.\" >&2\n exit 1\nfi\n# This output is used by Xcode 'outputs' to avoid re-running this script phase.\necho \"SUCCESS\" > \"${SCRIPT_OUTPUT_FILE_0}\"\n";
|
||||||
|
showEnvVarsInLog = 0;
|
||||||
|
};
|
||||||
/* End PBXShellScriptBuildPhase section */
|
/* End PBXShellScriptBuildPhase section */
|
||||||
|
|
||||||
/* Begin PBXSourcesBuildPhase section */
|
/* Begin PBXSourcesBuildPhase section */
|
||||||
@@ -380,6 +489,7 @@
|
|||||||
};
|
};
|
||||||
331C8088294A63A400263BE5 /* Debug */ = {
|
331C8088294A63A400263BE5 /* Debug */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
|
baseConfigurationReference = 7D249F16ED68C041D85B3071 /* Pods-RunnerTests.debug.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
@@ -397,6 +507,7 @@
|
|||||||
};
|
};
|
||||||
331C8089294A63A400263BE5 /* Release */ = {
|
331C8089294A63A400263BE5 /* Release */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
|
baseConfigurationReference = C99E9AAEFDCBB3C6B2126798 /* Pods-RunnerTests.release.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
@@ -412,6 +523,7 @@
|
|||||||
};
|
};
|
||||||
331C808A294A63A400263BE5 /* Profile */ = {
|
331C808A294A63A400263BE5 /* Profile */ = {
|
||||||
isa = XCBuildConfiguration;
|
isa = XCBuildConfiguration;
|
||||||
|
baseConfigurationReference = 4522E91C2F197AEAF11E6C08 /* Pods-RunnerTests.profile.xcconfig */;
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
BUNDLE_LOADER = "$(TEST_HOST)";
|
BUNDLE_LOADER = "$(TEST_HOST)";
|
||||||
CODE_SIGN_STYLE = Automatic;
|
CODE_SIGN_STYLE = Automatic;
|
||||||
|
|||||||
3
ios/Runner.xcworkspace/contents.xcworkspacedata
generated
3
ios/Runner.xcworkspace/contents.xcworkspacedata
generated
@@ -4,4 +4,7 @@
|
|||||||
<FileRef
|
<FileRef
|
||||||
location = "group:Runner.xcodeproj">
|
location = "group:Runner.xcodeproj">
|
||||||
</FileRef>
|
</FileRef>
|
||||||
|
<FileRef
|
||||||
|
location = "group:Pods/Pods.xcodeproj">
|
||||||
|
</FileRef>
|
||||||
</Workspace>
|
</Workspace>
|
||||||
|
|||||||
@@ -1,7 +1,7 @@
|
|||||||
{
|
{
|
||||||
"file_generated_by": "FlutterFire CLI",
|
"file_generated_by": "FlutterFire CLI",
|
||||||
"purpose": "FirebaseAppID & ProjectID for this Firebase app in this directory",
|
"purpose": "FirebaseAppID & ProjectID for this Firebase app in this directory",
|
||||||
"GOOGLE_APP_ID": "1:23966937248:ios:d7915a6ac5618efeb599c5",
|
"GOOGLE_APP_ID": "1:164857321043:ios:b497e5d24254d60e1ad8a6",
|
||||||
"FIREBASE_PROJECT_ID": "m-335-3d14b",
|
"FIREBASE_PROJECT_ID": "progetto-m335",
|
||||||
"GCM_SENDER_ID": "23966937248"
|
"GCM_SENDER_ID": "164857321043"
|
||||||
}
|
}
|
||||||
@@ -1,339 +0,0 @@
|
|||||||
// Copyright 2021 The Flutter team. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
import 'package:flutter/gestures.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:url_launcher/url_launcher.dart';
|
|
||||||
|
|
||||||
const Widget divider = SizedBox(height: 10);
|
|
||||||
|
|
||||||
// If screen content width is greater or equal to this value, the light and dark
|
|
||||||
// color schemes will be displayed in a column. Otherwise, they will
|
|
||||||
// be displayed in a row.
|
|
||||||
const double narrowScreenWidthThreshold = 400;
|
|
||||||
|
|
||||||
class ColorPalettesScreen extends StatelessWidget {
|
|
||||||
const ColorPalettesScreen({super.key});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
Color selectedColor = Theme.of(context).primaryColor;
|
|
||||||
ThemeData lightTheme = ThemeData(
|
|
||||||
colorSchemeSeed: selectedColor,
|
|
||||||
brightness: Brightness.light,
|
|
||||||
);
|
|
||||||
ThemeData darkTheme = ThemeData(
|
|
||||||
colorSchemeSeed: selectedColor,
|
|
||||||
brightness: Brightness.dark,
|
|
||||||
);
|
|
||||||
|
|
||||||
Widget schemeLabel(String brightness) {
|
|
||||||
return Padding(
|
|
||||||
padding: const EdgeInsets.symmetric(vertical: 15),
|
|
||||||
child: Text(
|
|
||||||
brightness,
|
|
||||||
style: const TextStyle(fontWeight: FontWeight.bold),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
Widget schemeView(ThemeData theme) {
|
|
||||||
return Padding(
|
|
||||||
padding: const EdgeInsets.symmetric(horizontal: 15),
|
|
||||||
child: ColorSchemeView(
|
|
||||||
colorScheme: theme.colorScheme,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
Widget dynamicColorNotice() => RichText(
|
|
||||||
textAlign: TextAlign.center,
|
|
||||||
text: TextSpan(
|
|
||||||
style: Theme.of(context).textTheme.bodySmall,
|
|
||||||
children: [
|
|
||||||
const TextSpan(
|
|
||||||
text: 'To create color schemes based on a '
|
|
||||||
'platform\'s implementation of dynamic color, '
|
|
||||||
'use the '),
|
|
||||||
TextSpan(
|
|
||||||
text: 'dynamic_color',
|
|
||||||
style: const TextStyle(decoration: TextDecoration.underline),
|
|
||||||
recognizer: TapGestureRecognizer()
|
|
||||||
..onTap = () async {
|
|
||||||
final url = Uri.parse(
|
|
||||||
'https://pub.dev/packages/dynamic_color',
|
|
||||||
);
|
|
||||||
if (!await launchUrl(url)) {
|
|
||||||
throw Exception('Could not launch $url');
|
|
||||||
}
|
|
||||||
},
|
|
||||||
),
|
|
||||||
const TextSpan(text: ' package.'),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
|
|
||||||
return Expanded(
|
|
||||||
child: LayoutBuilder(builder: (context, constraints) {
|
|
||||||
if (constraints.maxWidth < narrowScreenWidthThreshold) {
|
|
||||||
return SingleChildScrollView(
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
dynamicColorNotice(),
|
|
||||||
divider,
|
|
||||||
schemeLabel('Light ColorScheme'),
|
|
||||||
schemeView(lightTheme),
|
|
||||||
divider,
|
|
||||||
divider,
|
|
||||||
schemeLabel('Dark ColorScheme'),
|
|
||||||
schemeView(darkTheme),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
return SingleChildScrollView(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.only(top: 5),
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
dynamicColorNotice(),
|
|
||||||
Row(
|
|
||||||
children: [
|
|
||||||
Expanded(
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
schemeLabel('Light ColorScheme'),
|
|
||||||
schemeView(lightTheme),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Expanded(
|
|
||||||
child: Column(
|
|
||||||
children: [
|
|
||||||
schemeLabel('Dark ColorScheme'),
|
|
||||||
schemeView(darkTheme),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ColorSchemeView extends StatelessWidget {
|
|
||||||
const ColorSchemeView({super.key, required this.colorScheme});
|
|
||||||
|
|
||||||
final ColorScheme colorScheme;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Column(
|
|
||||||
children: [
|
|
||||||
ColorGroup(children: [
|
|
||||||
ColorChip(
|
|
||||||
label: 'primary',
|
|
||||||
color: colorScheme.primary,
|
|
||||||
onColor: colorScheme.onPrimary,
|
|
||||||
),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onPrimary',
|
|
||||||
color: colorScheme.onPrimary,
|
|
||||||
onColor: colorScheme.primary),
|
|
||||||
ColorChip(
|
|
||||||
label: 'primaryContainer',
|
|
||||||
color: colorScheme.primaryContainer,
|
|
||||||
onColor: colorScheme.onPrimaryContainer,
|
|
||||||
),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onPrimaryContainer',
|
|
||||||
color: colorScheme.onPrimaryContainer,
|
|
||||||
onColor: colorScheme.primaryContainer,
|
|
||||||
),
|
|
||||||
]),
|
|
||||||
divider,
|
|
||||||
ColorGroup(children: [
|
|
||||||
ColorChip(
|
|
||||||
label: 'secondary',
|
|
||||||
color: colorScheme.secondary,
|
|
||||||
onColor: colorScheme.onSecondary,
|
|
||||||
),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onSecondary',
|
|
||||||
color: colorScheme.onSecondary,
|
|
||||||
onColor: colorScheme.secondary,
|
|
||||||
),
|
|
||||||
ColorChip(
|
|
||||||
label: 'secondaryContainer',
|
|
||||||
color: colorScheme.secondaryContainer,
|
|
||||||
onColor: colorScheme.onSecondaryContainer,
|
|
||||||
),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onSecondaryContainer',
|
|
||||||
color: colorScheme.onSecondaryContainer,
|
|
||||||
onColor: colorScheme.secondaryContainer),
|
|
||||||
]),
|
|
||||||
divider,
|
|
||||||
ColorGroup(
|
|
||||||
children: [
|
|
||||||
ColorChip(
|
|
||||||
label: 'tertiary',
|
|
||||||
color: colorScheme.tertiary,
|
|
||||||
onColor: colorScheme.onTertiary),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onTertiary',
|
|
||||||
color: colorScheme.onTertiary,
|
|
||||||
onColor: colorScheme.tertiary),
|
|
||||||
ColorChip(
|
|
||||||
label: 'tertiaryContainer',
|
|
||||||
color: colorScheme.tertiaryContainer,
|
|
||||||
onColor: colorScheme.onTertiaryContainer),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onTertiaryContainer',
|
|
||||||
color: colorScheme.onTertiaryContainer,
|
|
||||||
onColor: colorScheme.tertiaryContainer),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
divider,
|
|
||||||
ColorGroup(
|
|
||||||
children: [
|
|
||||||
ColorChip(
|
|
||||||
label: 'error',
|
|
||||||
color: colorScheme.error,
|
|
||||||
onColor: colorScheme.onError),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onError',
|
|
||||||
color: colorScheme.onError,
|
|
||||||
onColor: colorScheme.error),
|
|
||||||
ColorChip(
|
|
||||||
label: 'errorContainer',
|
|
||||||
color: colorScheme.errorContainer,
|
|
||||||
onColor: colorScheme.onErrorContainer),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onErrorContainer',
|
|
||||||
color: colorScheme.onErrorContainer,
|
|
||||||
onColor: colorScheme.errorContainer),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
divider,
|
|
||||||
ColorGroup(
|
|
||||||
children: [
|
|
||||||
ColorChip(
|
|
||||||
label: 'background',
|
|
||||||
color: colorScheme.background,
|
|
||||||
onColor: colorScheme.onBackground),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onBackground',
|
|
||||||
color: colorScheme.onBackground,
|
|
||||||
onColor: colorScheme.background),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
divider,
|
|
||||||
ColorGroup(
|
|
||||||
children: [
|
|
||||||
ColorChip(
|
|
||||||
label: 'surface',
|
|
||||||
color: colorScheme.surface,
|
|
||||||
onColor: colorScheme.onSurface),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onSurface',
|
|
||||||
color: colorScheme.onSurface,
|
|
||||||
onColor: colorScheme.surface),
|
|
||||||
ColorChip(
|
|
||||||
label: 'surfaceVariant',
|
|
||||||
color: colorScheme.surfaceVariant,
|
|
||||||
onColor: colorScheme.onSurfaceVariant),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onSurfaceVariant',
|
|
||||||
color: colorScheme.onSurfaceVariant,
|
|
||||||
onColor: colorScheme.surfaceVariant),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
divider,
|
|
||||||
ColorGroup(
|
|
||||||
children: [
|
|
||||||
ColorChip(label: 'outline', color: colorScheme.outline),
|
|
||||||
ColorChip(label: 'shadow', color: colorScheme.shadow),
|
|
||||||
ColorChip(
|
|
||||||
label: 'inverseSurface',
|
|
||||||
color: colorScheme.inverseSurface,
|
|
||||||
onColor: colorScheme.onInverseSurface),
|
|
||||||
ColorChip(
|
|
||||||
label: 'onInverseSurface',
|
|
||||||
color: colorScheme.onInverseSurface,
|
|
||||||
onColor: colorScheme.inverseSurface),
|
|
||||||
ColorChip(
|
|
||||||
label: 'inversePrimary',
|
|
||||||
color: colorScheme.inversePrimary,
|
|
||||||
onColor: colorScheme.primary),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ColorGroup extends StatelessWidget {
|
|
||||||
const ColorGroup({super.key, required this.children});
|
|
||||||
|
|
||||||
final List<Widget> children;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return RepaintBoundary(
|
|
||||||
child: Card(
|
|
||||||
clipBehavior: Clip.antiAlias,
|
|
||||||
child: Column(
|
|
||||||
children: children,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ColorChip extends StatelessWidget {
|
|
||||||
const ColorChip({
|
|
||||||
super.key,
|
|
||||||
required this.color,
|
|
||||||
required this.label,
|
|
||||||
this.onColor,
|
|
||||||
});
|
|
||||||
|
|
||||||
final Color color;
|
|
||||||
final Color? onColor;
|
|
||||||
final String label;
|
|
||||||
|
|
||||||
static Color contrastColor(Color color) {
|
|
||||||
final brightness = ThemeData.estimateBrightnessForColor(color);
|
|
||||||
switch (brightness) {
|
|
||||||
case Brightness.dark:
|
|
||||||
return Colors.white;
|
|
||||||
case Brightness.light:
|
|
||||||
return Colors.black;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
final Color labelColor = onColor ?? contrastColor(color);
|
|
||||||
|
|
||||||
return Container(
|
|
||||||
color: color,
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(16),
|
|
||||||
child: Row(
|
|
||||||
children: [
|
|
||||||
Expanded(child: Text(label, style: TextStyle(color: labelColor))),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
File diff suppressed because it is too large
Load Diff
@@ -1,67 +0,0 @@
|
|||||||
// Copyright 2021 The Flutter team. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
|
|
||||||
// NavigationRail shows if the screen width is greater or equal to
|
|
||||||
// narrowScreenWidthThreshold; otherwise, NavigationBar is used for navigation.
|
|
||||||
const double narrowScreenWidthThreshold = 450;
|
|
||||||
|
|
||||||
const double mediumWidthBreakpoint = 1000;
|
|
||||||
const double largeWidthBreakpoint = 1500;
|
|
||||||
|
|
||||||
const double transitionLength = 500;
|
|
||||||
|
|
||||||
// Whether the user has chosen a theme color via a direct [ColorSeed] selection,
|
|
||||||
// or an image [ColorImageProvider].
|
|
||||||
enum ColorSelectionMethod {
|
|
||||||
colorSeed,
|
|
||||||
image,
|
|
||||||
}
|
|
||||||
|
|
||||||
enum ColorSeed {
|
|
||||||
baseColor('M3 Baseline', Color(0xff6750a4)),
|
|
||||||
indigo('Indigo', Colors.indigo),
|
|
||||||
blue('Blue', Colors.blue),
|
|
||||||
teal('Teal', Colors.teal),
|
|
||||||
green('Green', Colors.green),
|
|
||||||
yellow('Yellow', Colors.yellow),
|
|
||||||
orange('Orange', Colors.orange),
|
|
||||||
deepOrange('Deep Orange', Colors.deepOrange),
|
|
||||||
pink('Pink', Colors.pink);
|
|
||||||
|
|
||||||
const ColorSeed(this.label, this.color);
|
|
||||||
final String label;
|
|
||||||
final Color color;
|
|
||||||
}
|
|
||||||
|
|
||||||
enum ColorImageProvider {
|
|
||||||
leaves('Leaves',
|
|
||||||
'https://flutter.github.io/assets-for-api-docs/assets/material/content_based_color_scheme_1.png'),
|
|
||||||
peonies('Peonies',
|
|
||||||
'https://flutter.github.io/assets-for-api-docs/assets/material/content_based_color_scheme_2.png'),
|
|
||||||
bubbles('Bubbles',
|
|
||||||
'https://flutter.github.io/assets-for-api-docs/assets/material/content_based_color_scheme_3.png'),
|
|
||||||
seaweed('Seaweed',
|
|
||||||
'https://flutter.github.io/assets-for-api-docs/assets/material/content_based_color_scheme_4.png'),
|
|
||||||
seagrapes('Sea Grapes',
|
|
||||||
'https://flutter.github.io/assets-for-api-docs/assets/material/content_based_color_scheme_5.png'),
|
|
||||||
petals('Petals',
|
|
||||||
'https://flutter.github.io/assets-for-api-docs/assets/material/content_based_color_scheme_6.png');
|
|
||||||
|
|
||||||
const ColorImageProvider(this.label, this.url);
|
|
||||||
final String label;
|
|
||||||
final String url;
|
|
||||||
}
|
|
||||||
|
|
||||||
enum ScreenSelected {
|
|
||||||
component(0),
|
|
||||||
color(1),
|
|
||||||
typography(2),
|
|
||||||
elevation(3),
|
|
||||||
home(4);
|
|
||||||
|
|
||||||
const ScreenSelected(this.value);
|
|
||||||
final int value;
|
|
||||||
}
|
|
||||||
167
lib/database/FireDb.dart
Normal file
167
lib/database/FireDb.dart
Normal file
@@ -0,0 +1,167 @@
|
|||||||
|
import 'package:cloud_firestore/cloud_firestore.dart';
|
||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:progetto_m335_flutter/model/promemoria.dart';
|
||||||
|
import 'package:progetto_m335_flutter/model/note.dart';
|
||||||
|
|
||||||
|
class FireDb {
|
||||||
|
|
||||||
|
Future createPromemoria(Promemoria promemoria) async {
|
||||||
|
final docPromemoria =
|
||||||
|
FirebaseFirestore.instance.collection('promemoria').doc();
|
||||||
|
|
||||||
|
final json = {
|
||||||
|
'id': docPromemoria.id,
|
||||||
|
'title': promemoria.getTitle(),
|
||||||
|
'creationDate': promemoria.getCreationDate(),
|
||||||
|
'lastModificationDate': promemoria.getLastModificationDate(),
|
||||||
|
'expirationDate': promemoria.getExpirationDate(),
|
||||||
|
'arrayPromemoria': promemoria.getArrayPromemoria(),
|
||||||
|
'description': promemoria.getDescription(),
|
||||||
|
'priority': promemoria.getPriority(),
|
||||||
|
'color': promemoria.getColor(),
|
||||||
|
};
|
||||||
|
|
||||||
|
await docPromemoria.set(json);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future createAllPromemoria(List<Promemoria> promemorias) async {
|
||||||
|
for (var promemoria in promemorias) {
|
||||||
|
await createPromemoria(promemoria);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future createNote(Note note) async {
|
||||||
|
final docNote = FirebaseFirestore.instance.collection('note').doc();
|
||||||
|
|
||||||
|
final json = {
|
||||||
|
'id': docNote.id,
|
||||||
|
'title': note.getTitle(),
|
||||||
|
'creationDate': note.getCreationDate(),
|
||||||
|
'lastModificationDate': note.getLastModificationDate(),
|
||||||
|
'arrayPromemoria': note.getArrayPromemoria(),
|
||||||
|
'description': note.getDescription(),
|
||||||
|
};
|
||||||
|
|
||||||
|
await docNote.set(json);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future createAllNotes(List<Note> notes) async {
|
||||||
|
for (var note in notes) {
|
||||||
|
await createNote(note);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<List<Promemoria>> readAllPromemoria() async {
|
||||||
|
var promemorias =
|
||||||
|
await FirebaseFirestore.instance.collection('promemoria').get();
|
||||||
|
|
||||||
|
List<Promemoria> promemoriaList = [];
|
||||||
|
|
||||||
|
for (var promemoria in promemorias.docs) {
|
||||||
|
promemoriaList.add(Promemoria.fromJson(promemoria.data()));
|
||||||
|
}
|
||||||
|
|
||||||
|
return promemoriaList;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<List<Note>> readAllNotes() async {
|
||||||
|
var notes = await FirebaseFirestore.instance.collection('note').get();
|
||||||
|
|
||||||
|
List<Note> noteList = [];
|
||||||
|
|
||||||
|
for (var note in notes.docs) {
|
||||||
|
noteList.add(Note.fromJson(note.data()));
|
||||||
|
}
|
||||||
|
|
||||||
|
return noteList;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<Note?> readNoteById(String id) async {
|
||||||
|
var docNote = await FirebaseFirestore.instance.collection('note').doc(id);
|
||||||
|
final snapshot = await docNote.get();
|
||||||
|
|
||||||
|
if (snapshot.exists) {
|
||||||
|
return Note.fromJson(snapshot.data()!);
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<Promemoria?> readPromemoriaById(String id) async {
|
||||||
|
final docPromemoria =
|
||||||
|
await FirebaseFirestore.instance.collection('promemoria').doc(id);
|
||||||
|
final snapshot = await docPromemoria.get();
|
||||||
|
|
||||||
|
if (snapshot.exists) {
|
||||||
|
return Promemoria.fromJson(snapshot.data()!);
|
||||||
|
} else {
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
/*
|
||||||
|
|
||||||
|
Future updateNote(Note note) async {
|
||||||
|
final docNote = FirebaseFirestore.instance.collection('note').doc(note.getId());
|
||||||
|
|
||||||
|
final json = {
|
||||||
|
'id': note.getId(),
|
||||||
|
'title': note.getTitle(),
|
||||||
|
'creationDate': note.getCreationDate(),
|
||||||
|
'lastModificationDate': note.getLastModificationDate(),
|
||||||
|
'arrayPromemoria': note.getArrayPromemoria(),
|
||||||
|
'description': note.getDescription(),
|
||||||
|
};
|
||||||
|
|
||||||
|
await docNote.update(json);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future updatePromemoria(Promemoria promemoria) async {
|
||||||
|
final docPromemoria = FirebaseFirestore.instance.collection('promemoria').doc(promemoria.getId());
|
||||||
|
|
||||||
|
final json = {
|
||||||
|
'id': docPromemoria.id,
|
||||||
|
'title': promemoria.getTitle(),
|
||||||
|
'creationDate': promemoria.getCreationDate(),
|
||||||
|
'lastModificationDate': promemoria.getLastModificationDate(),
|
||||||
|
'expirationDate': promemoria.getExpirationDate(),
|
||||||
|
'arrayPromemoria': promemoria.getArrayPromemoria(),
|
||||||
|
'description': promemoria.getDescription(),
|
||||||
|
'priority': promemoria.getPriority(),
|
||||||
|
'color': promemoria.getColor(),
|
||||||
|
};
|
||||||
|
|
||||||
|
await docPromemoria.update(json);
|
||||||
|
}
|
||||||
|
|
||||||
|
*/
|
||||||
|
|
||||||
|
Future deleteNoteById(String id) async {
|
||||||
|
final docNote = FirebaseFirestore.instance.collection('note').doc(id);
|
||||||
|
|
||||||
|
await docNote.delete();
|
||||||
|
}
|
||||||
|
|
||||||
|
Future deletePromemoriaById(String id) async {
|
||||||
|
final docPromemoria = FirebaseFirestore.instance.collection('promemoria').doc(id);
|
||||||
|
|
||||||
|
await docPromemoria.delete();
|
||||||
|
}
|
||||||
|
|
||||||
|
Future deleteAllNotes() async {
|
||||||
|
var notes = await FirebaseFirestore.instance.collection('note').get();
|
||||||
|
|
||||||
|
for (var note in notes.docs) {
|
||||||
|
await deleteNoteById(note.id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
Future deleteAllPromemoria() async {
|
||||||
|
var promemorias = await FirebaseFirestore.instance.collection('promemoria').get();
|
||||||
|
|
||||||
|
for (var promemoria in promemorias.docs) {
|
||||||
|
await deletePromemoriaById(promemoria.id);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
168
lib/database/database.dart
Normal file
168
lib/database/database.dart
Normal file
@@ -0,0 +1,168 @@
|
|||||||
|
import 'package:path/path.dart';
|
||||||
|
import 'package:sqflite/sqflite.dart';
|
||||||
|
import '../model/note.dart';
|
||||||
|
import 'FireDb.dart';
|
||||||
|
import 'package:progetto_m335_flutter/model/promemoria.dart';
|
||||||
|
|
||||||
|
class NoteDatabase {
|
||||||
|
static final NoteDatabase instance = NoteDatabase._init();
|
||||||
|
static Database? _database;
|
||||||
|
FireDb fireDb = FireDb();
|
||||||
|
|
||||||
|
NoteDatabase._init();
|
||||||
|
|
||||||
|
Future<Database> get database async {
|
||||||
|
if (_database != null) return _database!;
|
||||||
|
|
||||||
|
_database = await _initDB('note.db');
|
||||||
|
return _database!;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<Database> _initDB(String filePath) async {
|
||||||
|
final databasePath = await getDatabasesPath();
|
||||||
|
|
||||||
|
final path = join(databasePath, filePath);
|
||||||
|
return await openDatabase(path, version: 1, onCreate: _createDB);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future _createDB(Database database, int version) async {
|
||||||
|
await database.execute('''CREATE TABLE promemoria (
|
||||||
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||||
|
title TEXT NOT NULL,
|
||||||
|
creationDate TEXT NOT NULL,
|
||||||
|
lastModificationDate TEXT,
|
||||||
|
expirationDate TEXT,
|
||||||
|
arrayPromemoria TEXT,
|
||||||
|
description TEXT,
|
||||||
|
priority TEXT,
|
||||||
|
color TEXT
|
||||||
|
);
|
||||||
|
''');
|
||||||
|
|
||||||
|
await database.execute('''CREATE TABLE note (
|
||||||
|
id INTEGER PRIMARY KEY AUTOINCREMENT,
|
||||||
|
title TEXT NOT NULL,
|
||||||
|
creationDate TEXT NOT NULL,
|
||||||
|
lastModificationDate TEXT,
|
||||||
|
arrayPromemoria TEXT,
|
||||||
|
description TEXT
|
||||||
|
);
|
||||||
|
''');
|
||||||
|
|
||||||
|
print("database created");
|
||||||
|
getDataFromFirebase(database, version);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<List<Map>> selectAllPromemoria() async {
|
||||||
|
final db = await database;
|
||||||
|
|
||||||
|
final List<Map<String, dynamic>> maps = await db.query(promemoriaTable);
|
||||||
|
|
||||||
|
return maps;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<List<Note>> getAllNote() async {
|
||||||
|
var notes = await _database?.query(noteTable);
|
||||||
|
List<Note> noteList = notes!.map((e) => Note.fromJson(e)).toList();
|
||||||
|
return noteList;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<List<Promemoria>> getAllPromemoria() async {
|
||||||
|
var promemorias = await _database?.query(promemoriaTable);
|
||||||
|
List<Promemoria> promemoriaList =
|
||||||
|
promemorias!.map((e) => Promemoria.fromJson(e)).toList();
|
||||||
|
return promemoriaList;
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<Note> getNoteById(int id) async {
|
||||||
|
var note = await _database?.query(noteTable, where: 'id = ?', whereArgs: [id]);
|
||||||
|
return Note.fromJson(note!.first);
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<Promemoria> getPromemoriaById(int id) async {
|
||||||
|
var promemoria =
|
||||||
|
await _database?.query(promemoriaTable, where: 'id = ?', whereArgs: [id]);
|
||||||
|
return Promemoria.fromJson(promemoria!.first);
|
||||||
|
}
|
||||||
|
|
||||||
|
//add note
|
||||||
|
void addNote(Note note) async {
|
||||||
|
await _database?.execute('''
|
||||||
|
INSERT INTO note (
|
||||||
|
title,
|
||||||
|
creationDate,
|
||||||
|
lastModificationDate,
|
||||||
|
arrayPromemoria,
|
||||||
|
description
|
||||||
|
) VALUES (
|
||||||
|
'${note.title}',
|
||||||
|
'${note.creationDate}',
|
||||||
|
'${note.lastModificationDate}',
|
||||||
|
'${note.arrayPromemoria}',
|
||||||
|
'${note.description}'
|
||||||
|
)
|
||||||
|
''');
|
||||||
|
}
|
||||||
|
|
||||||
|
//add Promemoria
|
||||||
|
void addPromemoria(Promemoria promemoria) async {
|
||||||
|
await _database?.execute('''
|
||||||
|
INSERT INTO promemoria (
|
||||||
|
title,
|
||||||
|
creationDate,
|
||||||
|
lastModificationDate,
|
||||||
|
expirationDate,
|
||||||
|
arrayPromemoria,
|
||||||
|
description,
|
||||||
|
priority,
|
||||||
|
color
|
||||||
|
) VALUES (
|
||||||
|
'${promemoria.title}',
|
||||||
|
'${promemoria.creationDate}',
|
||||||
|
'${promemoria.lastModificationDate}',
|
||||||
|
'${promemoria.expirationDate}',
|
||||||
|
'${promemoria.arrayPromemoria}',
|
||||||
|
'${promemoria.description}',
|
||||||
|
'${promemoria.priority}',
|
||||||
|
'${promemoria.color}'
|
||||||
|
)
|
||||||
|
''');
|
||||||
|
}
|
||||||
|
|
||||||
|
void deleteAll() async {
|
||||||
|
await _database?.execute('''
|
||||||
|
DELETE FROM promemoria
|
||||||
|
''');
|
||||||
|
|
||||||
|
await _database?.execute('''
|
||||||
|
DELETE FROM note
|
||||||
|
''');
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
void getDataFromFirebase(Database database, int version) async {
|
||||||
|
this.deleteAll();
|
||||||
|
|
||||||
|
var promemorias = await fireDb.readAllPromemoria();
|
||||||
|
var notes = await fireDb.readAllNotes();
|
||||||
|
|
||||||
|
for (var promemoria in promemorias) {
|
||||||
|
this.addPromemoria(promemoria);
|
||||||
|
}
|
||||||
|
|
||||||
|
for (var note in notes) {
|
||||||
|
this.addNote(note);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void syncData() async {
|
||||||
|
var promemorias = await getAllPromemoria();
|
||||||
|
var notes = await getAllNote();
|
||||||
|
|
||||||
|
await fireDb.deleteAllPromemoria();
|
||||||
|
await fireDb.deleteAllNotes();
|
||||||
|
|
||||||
|
await fireDb.createAllPromemoria(promemorias);
|
||||||
|
await fireDb.createAllNotes(notes);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,187 +0,0 @@
|
|||||||
// Copyright 2021 The Flutter team. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
|
|
||||||
class ElevationScreen extends StatelessWidget {
|
|
||||||
const ElevationScreen({super.key});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
Color shadowColor = Theme.of(context).colorScheme.shadow;
|
|
||||||
Color surfaceTint = Theme.of(context).colorScheme.primary;
|
|
||||||
return Expanded(
|
|
||||||
child: CustomScrollView(
|
|
||||||
slivers: [
|
|
||||||
SliverToBoxAdapter(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.fromLTRB(16.0, 20, 16.0, 0),
|
|
||||||
child: Text(
|
|
||||||
'Surface Tint Color Only',
|
|
||||||
style: Theme.of(context).textTheme.titleLarge,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
ElevationGrid(
|
|
||||||
surfaceTintColor: surfaceTint,
|
|
||||||
shadowColor: Colors.transparent,
|
|
||||||
),
|
|
||||||
SliverList(
|
|
||||||
delegate: SliverChildListDelegate(<Widget>[
|
|
||||||
const SizedBox(height: 10),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.fromLTRB(16.0, 8.0, 16.0, 0),
|
|
||||||
child: Text(
|
|
||||||
'Surface Tint Color and Shadow Color',
|
|
||||||
style: Theme.of(context).textTheme.titleLarge,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
]),
|
|
||||||
),
|
|
||||||
ElevationGrid(
|
|
||||||
shadowColor: shadowColor,
|
|
||||||
surfaceTintColor: surfaceTint,
|
|
||||||
),
|
|
||||||
SliverList(
|
|
||||||
delegate: SliverChildListDelegate(<Widget>[
|
|
||||||
const SizedBox(height: 10),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.fromLTRB(16.0, 8.0, 16.0, 0),
|
|
||||||
child: Text(
|
|
||||||
'Shadow Color Only',
|
|
||||||
style: Theme.of(context).textTheme.titleLarge,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
]),
|
|
||||||
),
|
|
||||||
ElevationGrid(shadowColor: shadowColor),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
const double narrowScreenWidthThreshold = 450;
|
|
||||||
|
|
||||||
class ElevationGrid extends StatelessWidget {
|
|
||||||
const ElevationGrid({super.key, this.shadowColor, this.surfaceTintColor});
|
|
||||||
|
|
||||||
final Color? shadowColor;
|
|
||||||
final Color? surfaceTintColor;
|
|
||||||
|
|
||||||
List<ElevationCard> elevationCards(
|
|
||||||
Color? shadowColor, Color? surfaceTintColor) {
|
|
||||||
return elevations
|
|
||||||
.map(
|
|
||||||
(elevationInfo) => ElevationCard(
|
|
||||||
info: elevationInfo,
|
|
||||||
shadowColor: shadowColor,
|
|
||||||
surfaceTint: surfaceTintColor,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
.toList();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return SliverPadding(
|
|
||||||
padding: const EdgeInsets.all(8),
|
|
||||||
sliver: SliverLayoutBuilder(builder: (context, constraints) {
|
|
||||||
if (constraints.crossAxisExtent < narrowScreenWidthThreshold) {
|
|
||||||
return SliverGrid.count(
|
|
||||||
crossAxisCount: 3,
|
|
||||||
children: elevationCards(shadowColor, surfaceTintColor),
|
|
||||||
);
|
|
||||||
} else {
|
|
||||||
return SliverGrid.count(
|
|
||||||
crossAxisCount: 6,
|
|
||||||
children: elevationCards(shadowColor, surfaceTintColor),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ElevationCard extends StatefulWidget {
|
|
||||||
const ElevationCard(
|
|
||||||
{super.key, required this.info, this.shadowColor, this.surfaceTint});
|
|
||||||
|
|
||||||
final ElevationInfo info;
|
|
||||||
final Color? shadowColor;
|
|
||||||
final Color? surfaceTint;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<ElevationCard> createState() => _ElevationCardState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _ElevationCardState extends State<ElevationCard> {
|
|
||||||
late double _elevation;
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
_elevation = widget.info.elevation;
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
const BorderRadius borderRadius = BorderRadius.all(Radius.circular(4.0));
|
|
||||||
final Color color = Theme.of(context).colorScheme.surface;
|
|
||||||
|
|
||||||
return Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: Material(
|
|
||||||
borderRadius: borderRadius,
|
|
||||||
elevation: _elevation,
|
|
||||||
color: color,
|
|
||||||
shadowColor: widget.shadowColor,
|
|
||||||
surfaceTintColor: widget.surfaceTint,
|
|
||||||
type: MaterialType.card,
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: Column(
|
|
||||||
crossAxisAlignment: CrossAxisAlignment.start,
|
|
||||||
children: <Widget>[
|
|
||||||
Text(
|
|
||||||
'Level ${widget.info.level}',
|
|
||||||
style: Theme.of(context).textTheme.labelMedium,
|
|
||||||
),
|
|
||||||
Text(
|
|
||||||
'${widget.info.elevation.toInt()} dp',
|
|
||||||
style: Theme.of(context).textTheme.labelMedium,
|
|
||||||
),
|
|
||||||
if (widget.surfaceTint != null)
|
|
||||||
Expanded(
|
|
||||||
child: Align(
|
|
||||||
alignment: Alignment.bottomRight,
|
|
||||||
child: Text(
|
|
||||||
'${widget.info.overlayPercent}%',
|
|
||||||
style: Theme.of(context).textTheme.bodySmall,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class ElevationInfo {
|
|
||||||
const ElevationInfo(this.level, this.elevation, this.overlayPercent);
|
|
||||||
final int level;
|
|
||||||
final double elevation;
|
|
||||||
final int overlayPercent;
|
|
||||||
}
|
|
||||||
|
|
||||||
const List<ElevationInfo> elevations = <ElevationInfo>[
|
|
||||||
ElevationInfo(0, 0.0, 0),
|
|
||||||
ElevationInfo(1, 1.0, 5),
|
|
||||||
ElevationInfo(2, 3.0, 8),
|
|
||||||
ElevationInfo(3, 6.0, 11),
|
|
||||||
ElevationInfo(4, 8.0, 12),
|
|
||||||
ElevationInfo(5, 12.0, 14),
|
|
||||||
];
|
|
||||||
@@ -15,6 +15,7 @@ import 'package:flutter/foundation.dart'
|
|||||||
/// );
|
/// );
|
||||||
/// ```
|
/// ```
|
||||||
class DefaultFirebaseOptions {
|
class DefaultFirebaseOptions {
|
||||||
|
|
||||||
static FirebaseOptions get currentPlatform {
|
static FirebaseOptions get currentPlatform {
|
||||||
if (kIsWeb) {
|
if (kIsWeb) {
|
||||||
throw UnsupportedError(
|
throw UnsupportedError(
|
||||||
@@ -50,19 +51,21 @@ class DefaultFirebaseOptions {
|
|||||||
}
|
}
|
||||||
|
|
||||||
static const FirebaseOptions android = FirebaseOptions(
|
static const FirebaseOptions android = FirebaseOptions(
|
||||||
apiKey: 'AIzaSyA5Mz_Az4vCKnFl_qJwiQ07cJzXSYDAqmw',
|
apiKey: 'AIzaSyCh2cA5AHNIS3e1Wnf48dfoCUKvmEM9J34',
|
||||||
appId: '1:23966937248:android:9694d7a3e940cff3b599c5',
|
appId: '1:164857321043:android:0a67e4973f9208721ad8a6',
|
||||||
messagingSenderId: '23966937248',
|
messagingSenderId: '164857321043',
|
||||||
projectId: 'm-335-3d14b',
|
projectId: 'progetto-m335',
|
||||||
storageBucket: 'm-335-3d14b.appspot.com',
|
databaseURL: 'https://progetto-m335-default-rtdb.europe-west1.firebasedatabase.app',
|
||||||
|
storageBucket: 'progetto-m335.appspot.com',
|
||||||
);
|
);
|
||||||
|
|
||||||
static const FirebaseOptions ios = FirebaseOptions(
|
static const FirebaseOptions ios = FirebaseOptions(
|
||||||
apiKey: 'AIzaSyDEJpIubqU-jFzjLP2s8S01B3Gh6W0eNgM',
|
apiKey: 'AIzaSyAhEex7OfyJHETyC-uSydOFGABBn5KX16Q',
|
||||||
appId: '1:23966937248:ios:d7915a6ac5618efeb599c5',
|
appId: '1:164857321043:ios:b497e5d24254d60e1ad8a6',
|
||||||
messagingSenderId: '23966937248',
|
messagingSenderId: '164857321043',
|
||||||
projectId: 'm-335-3d14b',
|
projectId: 'progetto-m335',
|
||||||
storageBucket: 'm-335-3d14b.appspot.com',
|
databaseURL: 'https://progetto-m335-default-rtdb.europe-west1.firebasedatabase.app',
|
||||||
|
storageBucket: 'progetto-m335.appspot.com',
|
||||||
iosBundleId: 'ch.ameti.progettoM335Flutter',
|
iosBundleId: 'ch.ameti.progettoM335Flutter',
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
877
lib/home.dart
877
lib/home.dart
@@ -1,877 +0,0 @@
|
|||||||
// Copyright 2021 The Flutter team. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
|
|
||||||
import 'color_palettes_screen.dart';
|
|
||||||
import 'component_screen.dart';
|
|
||||||
import 'constants.dart';
|
|
||||||
import 'elevation_screen.dart';
|
|
||||||
import 'typography_screen.dart';
|
|
||||||
import 'pages/home_page.dart';
|
|
||||||
|
|
||||||
class Home extends StatefulWidget {
|
|
||||||
const Home({
|
|
||||||
super.key,
|
|
||||||
required this.useLightMode,
|
|
||||||
required this.useMaterial3,
|
|
||||||
required this.colorSelected,
|
|
||||||
required this.handleBrightnessChange,
|
|
||||||
required this.handleMaterialVersionChange,
|
|
||||||
required this.handleColorSelect,
|
|
||||||
required this.handleImageSelect,
|
|
||||||
required this.colorSelectionMethod,
|
|
||||||
required this.imageSelected,
|
|
||||||
});
|
|
||||||
|
|
||||||
final bool useLightMode;
|
|
||||||
final bool useMaterial3;
|
|
||||||
final ColorSeed colorSelected;
|
|
||||||
final ColorImageProvider imageSelected;
|
|
||||||
final ColorSelectionMethod colorSelectionMethod;
|
|
||||||
|
|
||||||
final void Function(bool useLightMode) handleBrightnessChange;
|
|
||||||
final void Function() handleMaterialVersionChange;
|
|
||||||
final void Function(int value) handleColorSelect;
|
|
||||||
final void Function(int value) handleImageSelect;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<Home> createState() => _HomeState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _HomeState extends State<Home> with SingleTickerProviderStateMixin {
|
|
||||||
final GlobalKey<ScaffoldState> scaffoldKey = GlobalKey<ScaffoldState>();
|
|
||||||
late final AnimationController controller;
|
|
||||||
late final CurvedAnimation railAnimation;
|
|
||||||
bool controllerInitialized = false;
|
|
||||||
bool showMediumSizeLayout = false;
|
|
||||||
bool showLargeSizeLayout = false;
|
|
||||||
|
|
||||||
int screenIndex = ScreenSelected.component.value;
|
|
||||||
|
|
||||||
@override
|
|
||||||
initState() {
|
|
||||||
super.initState();
|
|
||||||
controller = AnimationController(
|
|
||||||
duration: Duration(milliseconds: transitionLength.toInt() * 2),
|
|
||||||
value: 0,
|
|
||||||
vsync: this,
|
|
||||||
);
|
|
||||||
railAnimation = CurvedAnimation(
|
|
||||||
parent: controller,
|
|
||||||
curve: const Interval(0.5, 1.0),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void dispose() {
|
|
||||||
controller.dispose();
|
|
||||||
super.dispose();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void didChangeDependencies() {
|
|
||||||
super.didChangeDependencies();
|
|
||||||
|
|
||||||
final double width = MediaQuery.of(context).size.width;
|
|
||||||
final AnimationStatus status = controller.status;
|
|
||||||
if (width > mediumWidthBreakpoint) {
|
|
||||||
if (width > largeWidthBreakpoint) {
|
|
||||||
showMediumSizeLayout = false;
|
|
||||||
showLargeSizeLayout = true;
|
|
||||||
} else {
|
|
||||||
showMediumSizeLayout = true;
|
|
||||||
showLargeSizeLayout = false;
|
|
||||||
}
|
|
||||||
if (status != AnimationStatus.forward &&
|
|
||||||
status != AnimationStatus.completed) {
|
|
||||||
controller.forward();
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
showMediumSizeLayout = false;
|
|
||||||
showLargeSizeLayout = false;
|
|
||||||
if (status != AnimationStatus.reverse &&
|
|
||||||
status != AnimationStatus.dismissed) {
|
|
||||||
controller.reverse();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
if (!controllerInitialized) {
|
|
||||||
controllerInitialized = true;
|
|
||||||
controller.value = width > mediumWidthBreakpoint ? 1 : 0;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
void handleScreenChanged(int screenSelected) {
|
|
||||||
setState(() {
|
|
||||||
screenIndex = screenSelected;
|
|
||||||
});
|
|
||||||
}
|
|
||||||
|
|
||||||
Widget createScreenFor(
|
|
||||||
ScreenSelected screenSelected, bool showNavBarExample) {
|
|
||||||
switch (screenSelected) {
|
|
||||||
case ScreenSelected.component:
|
|
||||||
return Expanded(
|
|
||||||
child: OneTwoTransition(
|
|
||||||
animation: railAnimation,
|
|
||||||
one: FirstComponentList(
|
|
||||||
showNavBottomBar: showNavBarExample,
|
|
||||||
scaffoldKey: scaffoldKey,
|
|
||||||
showSecondList: showMediumSizeLayout || showLargeSizeLayout),
|
|
||||||
two: SecondComponentList(
|
|
||||||
scaffoldKey: scaffoldKey,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
case ScreenSelected.color:
|
|
||||||
return const ColorPalettesScreen();
|
|
||||||
case ScreenSelected.typography:
|
|
||||||
return const TypographyScreen();
|
|
||||||
case ScreenSelected.elevation:
|
|
||||||
return const ElevationScreen();
|
|
||||||
case ScreenSelected.home:
|
|
||||||
return const HomePage();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
PreferredSizeWidget createAppBar() {
|
|
||||||
return AppBar(
|
|
||||||
title: widget.useMaterial3
|
|
||||||
? const Text('Material 3')
|
|
||||||
: const Text('Material 2'),
|
|
||||||
actions: !showMediumSizeLayout && !showLargeSizeLayout
|
|
||||||
? [
|
|
||||||
_BrightnessButton(
|
|
||||||
handleBrightnessChange: widget.handleBrightnessChange,
|
|
||||||
),
|
|
||||||
_Material3Button(
|
|
||||||
handleMaterialVersionChange: widget.handleMaterialVersionChange,
|
|
||||||
),
|
|
||||||
_ColorSeedButton(
|
|
||||||
handleColorSelect: widget.handleColorSelect,
|
|
||||||
colorSelected: widget.colorSelected,
|
|
||||||
colorSelectionMethod: widget.colorSelectionMethod,
|
|
||||||
),
|
|
||||||
_ColorImageButton(
|
|
||||||
handleImageSelect: widget.handleImageSelect,
|
|
||||||
imageSelected: widget.imageSelected,
|
|
||||||
colorSelectionMethod: widget.colorSelectionMethod,
|
|
||||||
)
|
|
||||||
]
|
|
||||||
: [Container()],
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
Widget _trailingActions() => Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.end,
|
|
||||||
children: [
|
|
||||||
Flexible(
|
|
||||||
child: _BrightnessButton(
|
|
||||||
handleBrightnessChange: widget.handleBrightnessChange,
|
|
||||||
showTooltipBelow: false,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Flexible(
|
|
||||||
child: _Material3Button(
|
|
||||||
handleMaterialVersionChange: widget.handleMaterialVersionChange,
|
|
||||||
showTooltipBelow: false,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Flexible(
|
|
||||||
child: _ColorSeedButton(
|
|
||||||
handleColorSelect: widget.handleColorSelect,
|
|
||||||
colorSelected: widget.colorSelected,
|
|
||||||
colorSelectionMethod: widget.colorSelectionMethod,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Flexible(
|
|
||||||
child: _ColorImageButton(
|
|
||||||
handleImageSelect: widget.handleImageSelect,
|
|
||||||
imageSelected: widget.imageSelected,
|
|
||||||
colorSelectionMethod: widget.colorSelectionMethod,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
);
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return AnimatedBuilder(
|
|
||||||
animation: controller,
|
|
||||||
builder: (context, child) {
|
|
||||||
return NavigationTransition(
|
|
||||||
scaffoldKey: scaffoldKey,
|
|
||||||
animationController: controller,
|
|
||||||
railAnimation: railAnimation,
|
|
||||||
appBar: createAppBar(),
|
|
||||||
body: createScreenFor(
|
|
||||||
ScreenSelected.values[screenIndex], controller.value == 1),
|
|
||||||
navigationRail: NavigationRail(
|
|
||||||
extended: showLargeSizeLayout,
|
|
||||||
destinations: navRailDestinations,
|
|
||||||
selectedIndex: screenIndex,
|
|
||||||
onDestinationSelected: (index) {
|
|
||||||
setState(() {
|
|
||||||
screenIndex = index;
|
|
||||||
handleScreenChanged(screenIndex);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
trailing: Expanded(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.only(bottom: 20),
|
|
||||||
child: showLargeSizeLayout
|
|
||||||
? _ExpandedTrailingActions(
|
|
||||||
useLightMode: widget.useLightMode,
|
|
||||||
handleBrightnessChange: widget.handleBrightnessChange,
|
|
||||||
useMaterial3: widget.useMaterial3,
|
|
||||||
handleMaterialVersionChange:
|
|
||||||
widget.handleMaterialVersionChange,
|
|
||||||
handleImageSelect: widget.handleImageSelect,
|
|
||||||
handleColorSelect: widget.handleColorSelect,
|
|
||||||
colorSelectionMethod: widget.colorSelectionMethod,
|
|
||||||
imageSelected: widget.imageSelected,
|
|
||||||
colorSelected: widget.colorSelected,
|
|
||||||
)
|
|
||||||
: _trailingActions(),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
navigationBar: NavigationBars(
|
|
||||||
onSelectItem: (index) {
|
|
||||||
setState(() {
|
|
||||||
screenIndex = index;
|
|
||||||
handleScreenChanged(screenIndex);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
selectedIndex: screenIndex,
|
|
||||||
isExampleBar: false,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _BrightnessButton extends StatelessWidget {
|
|
||||||
const _BrightnessButton({
|
|
||||||
required this.handleBrightnessChange,
|
|
||||||
this.showTooltipBelow = true,
|
|
||||||
});
|
|
||||||
|
|
||||||
final Function handleBrightnessChange;
|
|
||||||
final bool showTooltipBelow;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
final isBright = Theme.of(context).brightness == Brightness.light;
|
|
||||||
return Tooltip(
|
|
||||||
preferBelow: showTooltipBelow,
|
|
||||||
message: 'Toggle brightness',
|
|
||||||
child: IconButton(
|
|
||||||
icon: isBright
|
|
||||||
? const Icon(Icons.dark_mode_outlined)
|
|
||||||
: const Icon(Icons.light_mode_outlined),
|
|
||||||
onPressed: () => handleBrightnessChange(!isBright),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _Material3Button extends StatelessWidget {
|
|
||||||
const _Material3Button({
|
|
||||||
required this.handleMaterialVersionChange,
|
|
||||||
this.showTooltipBelow = true,
|
|
||||||
});
|
|
||||||
|
|
||||||
final void Function() handleMaterialVersionChange;
|
|
||||||
final bool showTooltipBelow;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
final useMaterial3 = Theme.of(context).useMaterial3;
|
|
||||||
return Tooltip(
|
|
||||||
preferBelow: showTooltipBelow,
|
|
||||||
message: 'Switch to Material ${useMaterial3 ? 2 : 3}',
|
|
||||||
child: IconButton(
|
|
||||||
icon: useMaterial3
|
|
||||||
? const Icon(Icons.filter_2)
|
|
||||||
: const Icon(Icons.filter_3),
|
|
||||||
onPressed: handleMaterialVersionChange,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _ColorSeedButton extends StatelessWidget {
|
|
||||||
const _ColorSeedButton({
|
|
||||||
required this.handleColorSelect,
|
|
||||||
required this.colorSelected,
|
|
||||||
required this.colorSelectionMethod,
|
|
||||||
});
|
|
||||||
|
|
||||||
final void Function(int) handleColorSelect;
|
|
||||||
final ColorSeed colorSelected;
|
|
||||||
final ColorSelectionMethod colorSelectionMethod;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return PopupMenuButton(
|
|
||||||
icon: Icon(
|
|
||||||
Icons.palette_outlined,
|
|
||||||
color: Theme.of(context).colorScheme.onSurfaceVariant,
|
|
||||||
),
|
|
||||||
tooltip: 'Select a seed color',
|
|
||||||
shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10)),
|
|
||||||
itemBuilder: (context) {
|
|
||||||
return List.generate(ColorSeed.values.length, (index) {
|
|
||||||
ColorSeed currentColor = ColorSeed.values[index];
|
|
||||||
|
|
||||||
return PopupMenuItem(
|
|
||||||
value: index,
|
|
||||||
enabled: currentColor != colorSelected ||
|
|
||||||
colorSelectionMethod != ColorSelectionMethod.colorSeed,
|
|
||||||
child: Wrap(
|
|
||||||
children: [
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(left: 10),
|
|
||||||
child: Icon(
|
|
||||||
currentColor == colorSelected &&
|
|
||||||
colorSelectionMethod != ColorSelectionMethod.image
|
|
||||||
? Icons.color_lens
|
|
||||||
: Icons.color_lens_outlined,
|
|
||||||
color: currentColor.color,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(left: 20),
|
|
||||||
child: Text(currentColor.label),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
onSelected: handleColorSelect,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _ColorImageButton extends StatelessWidget {
|
|
||||||
const _ColorImageButton({
|
|
||||||
required this.handleImageSelect,
|
|
||||||
required this.imageSelected,
|
|
||||||
required this.colorSelectionMethod,
|
|
||||||
});
|
|
||||||
|
|
||||||
final void Function(int) handleImageSelect;
|
|
||||||
final ColorImageProvider imageSelected;
|
|
||||||
final ColorSelectionMethod colorSelectionMethod;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return PopupMenuButton(
|
|
||||||
icon: Icon(
|
|
||||||
Icons.image_outlined,
|
|
||||||
color: Theme.of(context).colorScheme.onSurfaceVariant,
|
|
||||||
),
|
|
||||||
tooltip: 'Select a color extraction image',
|
|
||||||
shape: RoundedRectangleBorder(borderRadius: BorderRadius.circular(10)),
|
|
||||||
itemBuilder: (context) {
|
|
||||||
return List.generate(ColorImageProvider.values.length, (index) {
|
|
||||||
ColorImageProvider currentImageProvider =
|
|
||||||
ColorImageProvider.values[index];
|
|
||||||
|
|
||||||
return PopupMenuItem(
|
|
||||||
value: index,
|
|
||||||
enabled: currentImageProvider != imageSelected ||
|
|
||||||
colorSelectionMethod != ColorSelectionMethod.image,
|
|
||||||
child: Wrap(
|
|
||||||
crossAxisAlignment: WrapCrossAlignment.center,
|
|
||||||
children: [
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(left: 10),
|
|
||||||
child: ConstrainedBox(
|
|
||||||
constraints: const BoxConstraints(maxWidth: 48),
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(4.0),
|
|
||||||
child: ClipRRect(
|
|
||||||
borderRadius: BorderRadius.circular(8.0),
|
|
||||||
child: Image(
|
|
||||||
image: NetworkImage(
|
|
||||||
ColorImageProvider.values[index].url),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.only(left: 20),
|
|
||||||
child: Text(currentImageProvider.label),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
});
|
|
||||||
},
|
|
||||||
onSelected: handleImageSelect,
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _ExpandedTrailingActions extends StatelessWidget {
|
|
||||||
const _ExpandedTrailingActions({
|
|
||||||
required this.useLightMode,
|
|
||||||
required this.handleBrightnessChange,
|
|
||||||
required this.useMaterial3,
|
|
||||||
required this.handleMaterialVersionChange,
|
|
||||||
required this.handleColorSelect,
|
|
||||||
required this.handleImageSelect,
|
|
||||||
required this.imageSelected,
|
|
||||||
required this.colorSelected,
|
|
||||||
required this.colorSelectionMethod,
|
|
||||||
});
|
|
||||||
|
|
||||||
final void Function(bool) handleBrightnessChange;
|
|
||||||
final void Function() handleMaterialVersionChange;
|
|
||||||
final void Function(int) handleImageSelect;
|
|
||||||
final void Function(int) handleColorSelect;
|
|
||||||
|
|
||||||
final bool useLightMode;
|
|
||||||
final bool useMaterial3;
|
|
||||||
|
|
||||||
final ColorImageProvider imageSelected;
|
|
||||||
final ColorSeed colorSelected;
|
|
||||||
final ColorSelectionMethod colorSelectionMethod;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
final screenHeight = MediaQuery.of(context).size.height;
|
|
||||||
final trailingActionsBody = Container(
|
|
||||||
constraints: const BoxConstraints.tightFor(width: 250),
|
|
||||||
padding: const EdgeInsets.symmetric(horizontal: 30),
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.end,
|
|
||||||
crossAxisAlignment: CrossAxisAlignment.stretch,
|
|
||||||
children: [
|
|
||||||
Row(
|
|
||||||
children: [
|
|
||||||
const Text('Brightness'),
|
|
||||||
Expanded(child: Container()),
|
|
||||||
Switch(
|
|
||||||
value: useLightMode,
|
|
||||||
onChanged: (value) {
|
|
||||||
handleBrightnessChange(value);
|
|
||||||
})
|
|
||||||
],
|
|
||||||
),
|
|
||||||
Row(
|
|
||||||
children: [
|
|
||||||
useMaterial3
|
|
||||||
? const Text('Material 3')
|
|
||||||
: const Text('Material 2'),
|
|
||||||
Expanded(child: Container()),
|
|
||||||
Switch(
|
|
||||||
value: useMaterial3,
|
|
||||||
onChanged: (_) {
|
|
||||||
handleMaterialVersionChange();
|
|
||||||
})
|
|
||||||
],
|
|
||||||
),
|
|
||||||
const Divider(),
|
|
||||||
_ExpandedColorSeedAction(
|
|
||||||
handleColorSelect: handleColorSelect,
|
|
||||||
colorSelected: colorSelected,
|
|
||||||
colorSelectionMethod: colorSelectionMethod,
|
|
||||||
),
|
|
||||||
const Divider(),
|
|
||||||
_ExpandedImageColorAction(
|
|
||||||
handleImageSelect: handleImageSelect,
|
|
||||||
imageSelected: imageSelected,
|
|
||||||
colorSelectionMethod: colorSelectionMethod,
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
return screenHeight > 740
|
|
||||||
? trailingActionsBody
|
|
||||||
: SingleChildScrollView(child: trailingActionsBody);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _ExpandedColorSeedAction extends StatelessWidget {
|
|
||||||
const _ExpandedColorSeedAction({
|
|
||||||
required this.handleColorSelect,
|
|
||||||
required this.colorSelected,
|
|
||||||
required this.colorSelectionMethod,
|
|
||||||
});
|
|
||||||
|
|
||||||
final void Function(int) handleColorSelect;
|
|
||||||
final ColorSeed colorSelected;
|
|
||||||
final ColorSelectionMethod colorSelectionMethod;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return ConstrainedBox(
|
|
||||||
constraints: const BoxConstraints(maxHeight: 200.0),
|
|
||||||
child: GridView.count(
|
|
||||||
crossAxisCount: 3,
|
|
||||||
children: List.generate(
|
|
||||||
ColorSeed.values.length,
|
|
||||||
(i) => IconButton(
|
|
||||||
icon: const Icon(Icons.radio_button_unchecked),
|
|
||||||
color: ColorSeed.values[i].color,
|
|
||||||
isSelected: colorSelected.color == ColorSeed.values[i].color &&
|
|
||||||
colorSelectionMethod == ColorSelectionMethod.colorSeed,
|
|
||||||
selectedIcon: const Icon(Icons.circle),
|
|
||||||
onPressed: () {
|
|
||||||
handleColorSelect(i);
|
|
||||||
},
|
|
||||||
tooltip: ColorSeed.values[i].label,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class _ExpandedImageColorAction extends StatelessWidget {
|
|
||||||
const _ExpandedImageColorAction({
|
|
||||||
required this.handleImageSelect,
|
|
||||||
required this.imageSelected,
|
|
||||||
required this.colorSelectionMethod,
|
|
||||||
});
|
|
||||||
|
|
||||||
final void Function(int) handleImageSelect;
|
|
||||||
final ColorImageProvider imageSelected;
|
|
||||||
final ColorSelectionMethod colorSelectionMethod;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return ConstrainedBox(
|
|
||||||
constraints: const BoxConstraints(maxHeight: 150.0),
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.symmetric(vertical: 8.0),
|
|
||||||
child: GridView.count(
|
|
||||||
crossAxisCount: 3,
|
|
||||||
children: List.generate(
|
|
||||||
ColorImageProvider.values.length,
|
|
||||||
(i) => Tooltip(
|
|
||||||
message: ColorImageProvider.values[i].name,
|
|
||||||
child: InkWell(
|
|
||||||
borderRadius: BorderRadius.circular(4.0),
|
|
||||||
onTap: () => handleImageSelect(i),
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: Material(
|
|
||||||
borderRadius: BorderRadius.circular(4.0),
|
|
||||||
elevation: imageSelected == ColorImageProvider.values[i] &&
|
|
||||||
colorSelectionMethod == ColorSelectionMethod.image
|
|
||||||
? 3
|
|
||||||
: 0,
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(4.0),
|
|
||||||
child: ClipRRect(
|
|
||||||
borderRadius: BorderRadius.circular(4.0),
|
|
||||||
child: Image(
|
|
||||||
image: NetworkImage(ColorImageProvider.values[i].url),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class NavigationTransition extends StatefulWidget {
|
|
||||||
const NavigationTransition(
|
|
||||||
{super.key,
|
|
||||||
required this.scaffoldKey,
|
|
||||||
required this.animationController,
|
|
||||||
required this.railAnimation,
|
|
||||||
required this.navigationRail,
|
|
||||||
required this.navigationBar,
|
|
||||||
required this.appBar,
|
|
||||||
required this.body});
|
|
||||||
|
|
||||||
final GlobalKey<ScaffoldState> scaffoldKey;
|
|
||||||
final AnimationController animationController;
|
|
||||||
final CurvedAnimation railAnimation;
|
|
||||||
final Widget navigationRail;
|
|
||||||
final Widget navigationBar;
|
|
||||||
final PreferredSizeWidget appBar;
|
|
||||||
final Widget body;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<NavigationTransition> createState() => _NavigationTransitionState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _NavigationTransitionState extends State<NavigationTransition> {
|
|
||||||
late final AnimationController controller;
|
|
||||||
late final CurvedAnimation railAnimation;
|
|
||||||
late final ReverseAnimation barAnimation;
|
|
||||||
bool controllerInitialized = false;
|
|
||||||
bool showDivider = false;
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
|
|
||||||
controller = widget.animationController;
|
|
||||||
railAnimation = widget.railAnimation;
|
|
||||||
|
|
||||||
barAnimation = ReverseAnimation(
|
|
||||||
CurvedAnimation(
|
|
||||||
parent: controller,
|
|
||||||
curve: const Interval(0.0, 0.5),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
final ColorScheme colorScheme = Theme.of(context).colorScheme;
|
|
||||||
|
|
||||||
return Scaffold(
|
|
||||||
key: widget.scaffoldKey,
|
|
||||||
appBar: widget.appBar,
|
|
||||||
body: Row(
|
|
||||||
children: <Widget>[
|
|
||||||
RailTransition(
|
|
||||||
animation: railAnimation,
|
|
||||||
backgroundColor: colorScheme.surface,
|
|
||||||
child: widget.navigationRail,
|
|
||||||
),
|
|
||||||
widget.body,
|
|
||||||
],
|
|
||||||
),
|
|
||||||
bottomNavigationBar: BarTransition(
|
|
||||||
animation: barAnimation,
|
|
||||||
backgroundColor: colorScheme.surface,
|
|
||||||
child: widget.navigationBar,
|
|
||||||
),
|
|
||||||
endDrawer: const NavigationDrawerSection(),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
final List<NavigationRailDestination> navRailDestinations = appBarDestinations
|
|
||||||
.map(
|
|
||||||
(destination) => NavigationRailDestination(
|
|
||||||
icon: Tooltip(
|
|
||||||
message: destination.label,
|
|
||||||
child: destination.icon,
|
|
||||||
),
|
|
||||||
selectedIcon: Tooltip(
|
|
||||||
message: destination.label,
|
|
||||||
child: destination.selectedIcon,
|
|
||||||
),
|
|
||||||
label: Text(destination.label),
|
|
||||||
),
|
|
||||||
)
|
|
||||||
.toList();
|
|
||||||
|
|
||||||
class SizeAnimation extends CurvedAnimation {
|
|
||||||
SizeAnimation(Animation<double> parent)
|
|
||||||
: super(
|
|
||||||
parent: parent,
|
|
||||||
curve: const Interval(
|
|
||||||
0.2,
|
|
||||||
0.8,
|
|
||||||
curve: Curves.easeInOutCubicEmphasized,
|
|
||||||
),
|
|
||||||
reverseCurve: Interval(
|
|
||||||
0,
|
|
||||||
0.2,
|
|
||||||
curve: Curves.easeInOutCubicEmphasized.flipped,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
class OffsetAnimation extends CurvedAnimation {
|
|
||||||
OffsetAnimation(Animation<double> parent)
|
|
||||||
: super(
|
|
||||||
parent: parent,
|
|
||||||
curve: const Interval(
|
|
||||||
0.4,
|
|
||||||
1.0,
|
|
||||||
curve: Curves.easeInOutCubicEmphasized,
|
|
||||||
),
|
|
||||||
reverseCurve: Interval(
|
|
||||||
0,
|
|
||||||
0.2,
|
|
||||||
curve: Curves.easeInOutCubicEmphasized.flipped,
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
class RailTransition extends StatefulWidget {
|
|
||||||
const RailTransition(
|
|
||||||
{super.key,
|
|
||||||
required this.animation,
|
|
||||||
required this.backgroundColor,
|
|
||||||
required this.child});
|
|
||||||
|
|
||||||
final Animation<double> animation;
|
|
||||||
final Widget child;
|
|
||||||
final Color backgroundColor;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<RailTransition> createState() => _RailTransition();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _RailTransition extends State<RailTransition> {
|
|
||||||
late Animation<Offset> offsetAnimation;
|
|
||||||
late Animation<double> widthAnimation;
|
|
||||||
|
|
||||||
@override
|
|
||||||
void didChangeDependencies() {
|
|
||||||
super.didChangeDependencies();
|
|
||||||
|
|
||||||
// The animations are only rebuilt by this method when the text
|
|
||||||
// direction changes because this widget only depends on Directionality.
|
|
||||||
final bool ltr = Directionality.of(context) == TextDirection.ltr;
|
|
||||||
|
|
||||||
widthAnimation = Tween<double>(
|
|
||||||
begin: 0,
|
|
||||||
end: 1,
|
|
||||||
).animate(SizeAnimation(widget.animation));
|
|
||||||
|
|
||||||
offsetAnimation = Tween<Offset>(
|
|
||||||
begin: ltr ? const Offset(-1, 0) : const Offset(1, 0),
|
|
||||||
end: Offset.zero,
|
|
||||||
).animate(OffsetAnimation(widget.animation));
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return ClipRect(
|
|
||||||
child: DecoratedBox(
|
|
||||||
decoration: BoxDecoration(color: widget.backgroundColor),
|
|
||||||
child: Align(
|
|
||||||
alignment: Alignment.topLeft,
|
|
||||||
widthFactor: widthAnimation.value,
|
|
||||||
child: FractionalTranslation(
|
|
||||||
translation: offsetAnimation.value,
|
|
||||||
child: widget.child,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class BarTransition extends StatefulWidget {
|
|
||||||
const BarTransition(
|
|
||||||
{super.key,
|
|
||||||
required this.animation,
|
|
||||||
required this.backgroundColor,
|
|
||||||
required this.child});
|
|
||||||
|
|
||||||
final Animation<double> animation;
|
|
||||||
final Color backgroundColor;
|
|
||||||
final Widget child;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<BarTransition> createState() => _BarTransition();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _BarTransition extends State<BarTransition> {
|
|
||||||
late final Animation<Offset> offsetAnimation;
|
|
||||||
late final Animation<double> heightAnimation;
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
|
|
||||||
offsetAnimation = Tween<Offset>(
|
|
||||||
begin: const Offset(0, 1),
|
|
||||||
end: Offset.zero,
|
|
||||||
).animate(OffsetAnimation(widget.animation));
|
|
||||||
|
|
||||||
heightAnimation = Tween<double>(
|
|
||||||
begin: 0,
|
|
||||||
end: 1,
|
|
||||||
).animate(SizeAnimation(widget.animation));
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return ClipRect(
|
|
||||||
child: DecoratedBox(
|
|
||||||
decoration: BoxDecoration(color: widget.backgroundColor),
|
|
||||||
child: Align(
|
|
||||||
alignment: Alignment.topLeft,
|
|
||||||
heightFactor: heightAnimation.value,
|
|
||||||
child: FractionalTranslation(
|
|
||||||
translation: offsetAnimation.value,
|
|
||||||
child: widget.child,
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class OneTwoTransition extends StatefulWidget {
|
|
||||||
const OneTwoTransition({
|
|
||||||
super.key,
|
|
||||||
required this.animation,
|
|
||||||
required this.one,
|
|
||||||
required this.two,
|
|
||||||
});
|
|
||||||
|
|
||||||
final Animation<double> animation;
|
|
||||||
final Widget one;
|
|
||||||
final Widget two;
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<OneTwoTransition> createState() => _OneTwoTransitionState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _OneTwoTransitionState extends State<OneTwoTransition> {
|
|
||||||
late final Animation<Offset> offsetAnimation;
|
|
||||||
late final Animation<double> widthAnimation;
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
super.initState();
|
|
||||||
|
|
||||||
offsetAnimation = Tween<Offset>(
|
|
||||||
begin: const Offset(1, 0),
|
|
||||||
end: Offset.zero,
|
|
||||||
).animate(OffsetAnimation(widget.animation));
|
|
||||||
|
|
||||||
widthAnimation = Tween<double>(
|
|
||||||
begin: 0,
|
|
||||||
end: mediumWidthBreakpoint,
|
|
||||||
).animate(SizeAnimation(widget.animation));
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Row(
|
|
||||||
children: <Widget>[
|
|
||||||
Flexible(
|
|
||||||
flex: mediumWidthBreakpoint.toInt(),
|
|
||||||
child: widget.one,
|
|
||||||
),
|
|
||||||
if (widthAnimation.value.toInt() > 0) ...[
|
|
||||||
Flexible(
|
|
||||||
flex: widthAnimation.value.toInt(),
|
|
||||||
child: FractionalTranslation(
|
|
||||||
translation: offsetAnimation.value,
|
|
||||||
child: widget.two,
|
|
||||||
),
|
|
||||||
)
|
|
||||||
],
|
|
||||||
],
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,15 +1,11 @@
|
|||||||
import 'package:firebase_core/firebase_core.dart';
|
import 'package:firebase_core/firebase_core.dart';
|
||||||
import 'firebase_options.dart';
|
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'myApp.dart';
|
import 'myApp.dart';
|
||||||
|
|
||||||
void main() async {
|
|
||||||
|
|
||||||
|
Future<void> main() async {
|
||||||
WidgetsFlutterBinding.ensureInitialized();
|
WidgetsFlutterBinding.ensureInitialized();
|
||||||
await Firebase.initializeApp(
|
await Firebase.initializeApp();
|
||||||
options: DefaultFirebaseOptions.currentPlatform,
|
|
||||||
);
|
|
||||||
|
|
||||||
runApp(MyApp());
|
runApp(MyApp());
|
||||||
|
print("App started");
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,19 +0,0 @@
|
|||||||
abstract class BaseEntity{
|
|
||||||
static String id = 'id';
|
|
||||||
static String title = 'Title';
|
|
||||||
static String creationDate = 'CreationDate';
|
|
||||||
static String lastEditDate = 'LastEditDate';
|
|
||||||
|
|
||||||
static String get getId{
|
|
||||||
return id;
|
|
||||||
}
|
|
||||||
static String get getTitle{
|
|
||||||
return title;
|
|
||||||
}
|
|
||||||
static String get getCreationDate{
|
|
||||||
return creationDate;
|
|
||||||
}
|
|
||||||
static String get getLastEditDate{
|
|
||||||
return lastEditDate;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,8 +1,96 @@
|
|||||||
import 'base_entity.dart';
|
|
||||||
|
|
||||||
class Note extends BaseEntity{
|
|
||||||
static String id = BaseEntity.getId;
|
|
||||||
static String Title = BaseEntity.getTitle;
|
|
||||||
static String CreationDate = BaseEntity.getCreationDate;
|
|
||||||
|
|
||||||
|
const String noteTable = 'note';
|
||||||
|
|
||||||
|
class Note{
|
||||||
|
String id='';
|
||||||
|
String title;
|
||||||
|
String creationDate;
|
||||||
|
String lastModificationDate;
|
||||||
|
String? arrayPromemoria;
|
||||||
|
String description;
|
||||||
|
|
||||||
|
Map<String, dynamic> toMap() {
|
||||||
|
return {
|
||||||
|
'id': id,
|
||||||
|
'title': title,
|
||||||
|
'creationDate': creationDate,
|
||||||
|
'lastModificationDate': lastModificationDate,
|
||||||
|
'arrayPromemoria': arrayPromemoria,
|
||||||
|
'description': description
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
Note(
|
||||||
|
this.id,
|
||||||
|
this.title,
|
||||||
|
this.creationDate,
|
||||||
|
this.lastModificationDate,
|
||||||
|
this.arrayPromemoria,
|
||||||
|
this.description,
|
||||||
|
);
|
||||||
|
|
||||||
|
Note.newConstructor(
|
||||||
|
this.title,
|
||||||
|
this.creationDate,
|
||||||
|
this.lastModificationDate,
|
||||||
|
this.arrayPromemoria,
|
||||||
|
this.description,
|
||||||
|
);
|
||||||
|
|
||||||
|
String getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setId(String id1) {
|
||||||
|
id = id1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getTitle() {
|
||||||
|
return title;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setTitle(String title1) {
|
||||||
|
title = title1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getCreationDate() {
|
||||||
|
return creationDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setCreationDate(String creationDate1) {
|
||||||
|
creationDate = creationDate1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getLastModificationDate() {
|
||||||
|
return lastModificationDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setLastModificationDate(String lastModificationDate1) {
|
||||||
|
lastModificationDate = lastModificationDate1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String? getArrayPromemoria() {
|
||||||
|
return arrayPromemoria;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setArrayPromemoria(String arrayPromemoria1) {
|
||||||
|
arrayPromemoria = arrayPromemoria1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getDescription() {
|
||||||
|
return description;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setDescription(String description1) {
|
||||||
|
description = description1;
|
||||||
|
}
|
||||||
|
|
||||||
|
static Note fromJson(Map<String, dynamic> data) => Note(
|
||||||
|
data['id'].toString(),
|
||||||
|
data['title'],
|
||||||
|
data['creationDate'],
|
||||||
|
data['lastModificationDate'],
|
||||||
|
data['arrayPromemoria'],
|
||||||
|
data['description']);
|
||||||
}
|
}
|
||||||
@@ -1,11 +1,140 @@
|
|||||||
import 'base_entity.dart';
|
import 'identifiers/enum/color.dart';
|
||||||
import 'identifiers/enum/priority.dart';
|
import 'identifiers/enum/priority.dart';
|
||||||
|
|
||||||
class Note extends BaseEntity{
|
const String promemoriaTable = 'promemoria';
|
||||||
static String id = BaseEntity.getId;
|
|
||||||
static String title = BaseEntity.getTitle;
|
class Promemoria {
|
||||||
static String creationDate = BaseEntity.getCreationDate;
|
String id = '';
|
||||||
static String expirationDate = 'expirationDate';
|
String title;
|
||||||
Priority priority = Priority.low;
|
String creationDate;
|
||||||
|
String lastModificationDate;
|
||||||
|
String expirationDate;
|
||||||
|
String? arrayPromemoria;
|
||||||
|
String description;
|
||||||
|
String priority;
|
||||||
|
String color;
|
||||||
|
|
||||||
|
Promemoria(
|
||||||
|
this.id,
|
||||||
|
this.title,
|
||||||
|
this.creationDate,
|
||||||
|
this.lastModificationDate,
|
||||||
|
this.expirationDate,
|
||||||
|
this.arrayPromemoria,
|
||||||
|
this.description,
|
||||||
|
this.priority,
|
||||||
|
this.color);
|
||||||
|
|
||||||
|
Promemoria.newConstructor(
|
||||||
|
this.title,
|
||||||
|
this.creationDate,
|
||||||
|
this.lastModificationDate,
|
||||||
|
this.expirationDate,
|
||||||
|
this.arrayPromemoria,
|
||||||
|
this.description,
|
||||||
|
this.priority,
|
||||||
|
this.color);
|
||||||
|
|
||||||
|
Map<String, dynamic> toMap() {
|
||||||
|
return {
|
||||||
|
'id': id,
|
||||||
|
'title': title,
|
||||||
|
'creationDate': creationDate,
|
||||||
|
'lastModificationDate': lastModificationDate,
|
||||||
|
'expirationDate': expirationDate,
|
||||||
|
'arrayPromemoria': arrayPromemoria,
|
||||||
|
'description': description,
|
||||||
|
'priority': priority,
|
||||||
|
'color': color,
|
||||||
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
String getId() {
|
||||||
|
return id;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setId(String id1) {
|
||||||
|
id = id1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getTitle() {
|
||||||
|
return title;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setTitle(String title1) {
|
||||||
|
title = title1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getCreationDate() {
|
||||||
|
return creationDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setCreationDate(String creationDate1) {
|
||||||
|
creationDate = creationDate1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getLastModificationDate() {
|
||||||
|
return lastModificationDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setLastModificationDate(String lastModificationDate1) {
|
||||||
|
lastModificationDate = lastModificationDate1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getExpirationDate() {
|
||||||
|
return expirationDate;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setExpirationDate(String expirationDate1) {
|
||||||
|
expirationDate = expirationDate1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String? getArrayPromemoria() {
|
||||||
|
return arrayPromemoria;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setArrayPromemoria(String arrayPromemoria1) {
|
||||||
|
arrayPromemoria = arrayPromemoria1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getDescription() {
|
||||||
|
return description;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setDescription(String description1) {
|
||||||
|
description = description1;
|
||||||
|
}
|
||||||
|
|
||||||
|
String getPriority() {
|
||||||
|
return priority;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setPriority(Priority priority1) {
|
||||||
|
priority = priority1.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
String getColor() {
|
||||||
|
return color;
|
||||||
|
}
|
||||||
|
|
||||||
|
void setColor(Color color1) {
|
||||||
|
color = color1.toString();
|
||||||
|
}
|
||||||
|
|
||||||
|
static Promemoria fromJson(Map<String, dynamic> data) {
|
||||||
|
Promemoria promemoria = Promemoria(
|
||||||
|
data['id'].toString(),
|
||||||
|
data['title'],
|
||||||
|
data['creationDate'],
|
||||||
|
data['lastModificationDate'],
|
||||||
|
data['expirationDate'],
|
||||||
|
data['arrayPromemoria'],
|
||||||
|
data['description'],
|
||||||
|
data['priority'],
|
||||||
|
data['color']);
|
||||||
|
|
||||||
|
print(promemoria.getId().toString());
|
||||||
|
|
||||||
|
return promemoria;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|||||||
@@ -10,7 +10,8 @@ class MyApp extends StatelessWidget {
|
|||||||
return MaterialApp(
|
return MaterialApp(
|
||||||
title: 'My App',
|
title: 'My App',
|
||||||
theme: ThemeData(
|
theme: ThemeData(
|
||||||
useMaterial3: true
|
useMaterial3: true,
|
||||||
|
primaryColor: Colors.red,
|
||||||
),
|
),
|
||||||
home: Navigation()
|
home: Navigation()
|
||||||
);
|
);
|
||||||
|
|||||||
@@ -1,12 +1,11 @@
|
|||||||
import 'package:firebase_auth/firebase_auth.dart';
|
import 'dart:ffi';
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:progetto_m335_flutter/pages/LoginView.dart';
|
import 'pages/testUI.dart';
|
||||||
import 'package:progetto_m335_flutter/pages/RegisterView.dart';
|
|
||||||
import 'pages/TodayView.dart';
|
import 'pages/TodayView.dart';
|
||||||
import 'pages/InboxView.dart';
|
import 'pages/InboxView.dart';
|
||||||
import 'pages/NotesView.dart';
|
import 'pages/NotesView.dart';
|
||||||
|
import 'pages/test.dart';
|
||||||
|
|
||||||
|
|
||||||
class Navigation extends StatefulWidget {
|
class Navigation extends StatefulWidget {
|
||||||
const Navigation({super.key});
|
const Navigation({super.key});
|
||||||
@@ -17,15 +16,13 @@ class Navigation extends StatefulWidget {
|
|||||||
|
|
||||||
class _NavigationState extends State<Navigation> {
|
class _NavigationState extends State<Navigation> {
|
||||||
|
|
||||||
int _selectedIndex = 1;
|
int _selectedIndex = 3;
|
||||||
static const List<Widget> _widgetOptions = <Widget>[
|
static const List<Widget> _widgetOptions = <Widget>[
|
||||||
LoginView(),
|
|
||||||
RegisterView(),
|
|
||||||
TodayView(),
|
TodayView(),
|
||||||
InboxView(),
|
InboxView(),
|
||||||
NotesView(),
|
NotesView(),
|
||||||
|
Test()
|
||||||
];
|
];
|
||||||
FirebaseAuth auth = FirebaseAuth.instance;
|
|
||||||
|
|
||||||
void _onItemTapped(int index) {
|
void _onItemTapped(int index) {
|
||||||
setState(() {
|
setState(() {
|
||||||
@@ -33,20 +30,6 @@ class _NavigationState extends State<Navigation> {
|
|||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
FirebaseAuth.instance
|
|
||||||
.authStateChanges()
|
|
||||||
.listen((User? user) {
|
|
||||||
if (user == null) {
|
|
||||||
print('User is currently signed out!');
|
|
||||||
} else {
|
|
||||||
print('User is signed in!');
|
|
||||||
}
|
|
||||||
});
|
|
||||||
super.initState();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
@override
|
||||||
Widget build(BuildContext context) {
|
Widget build(BuildContext context) {
|
||||||
return Scaffold(
|
return Scaffold(
|
||||||
@@ -56,16 +39,14 @@ class _NavigationState extends State<Navigation> {
|
|||||||
body: Center(child: _widgetOptions.elementAt(_selectedIndex)),
|
body: Center(child: _widgetOptions.elementAt(_selectedIndex)),
|
||||||
bottomNavigationBar: BottomNavigationBar(
|
bottomNavigationBar: BottomNavigationBar(
|
||||||
items: const <BottomNavigationBarItem>[
|
items: const <BottomNavigationBarItem>[
|
||||||
BottomNavigationBarItem(icon: Icon(Icons.login), label: "Login"),
|
|
||||||
BottomNavigationBarItem(icon: Icon(Icons.app_registration), label: "Register"),
|
|
||||||
BottomNavigationBarItem(
|
BottomNavigationBarItem(
|
||||||
icon: Icon(Icons.calendar_today), label: "today"),
|
icon: Icon(Icons.calendar_today), label: "today"),
|
||||||
BottomNavigationBarItem(icon: Icon(Icons.inbox), label: "Inbox"),
|
BottomNavigationBarItem(icon: Icon(Icons.inbox), label: "Inbox"),
|
||||||
BottomNavigationBarItem(icon: Icon(Icons.note), label: "Notes"),
|
BottomNavigationBarItem(icon: Icon(Icons.note), label: "Notes"),
|
||||||
|
BottomNavigationBarItem(icon: Icon(Icons.settings), label: "Settings")
|
||||||
],
|
],
|
||||||
currentIndex: _selectedIndex,
|
currentIndex: _selectedIndex,
|
||||||
onTap: _onItemTapped,
|
onTap: _onItemTapped,
|
||||||
type: BottomNavigationBarType.fixed,
|
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -1,71 +0,0 @@
|
|||||||
// File generated by FlutterFire CLI.
|
|
||||||
// ignore_for_file: lines_longer_than_80_chars, avoid_classes_with_only_static_members
|
|
||||||
import 'package:firebase_core/firebase_core.dart' show FirebaseOptions;
|
|
||||||
import 'package:flutter/foundation.dart'
|
|
||||||
show defaultTargetPlatform, kIsWeb, TargetPlatform;
|
|
||||||
|
|
||||||
/// Default [FirebaseOptions] for use with your Firebase apps.
|
|
||||||
///
|
|
||||||
/// Example:
|
|
||||||
/// ```dart
|
|
||||||
/// import 'firebase_options.dart';
|
|
||||||
/// // ...
|
|
||||||
/// await Firebase.initializeApp(
|
|
||||||
/// options: DefaultFirebaseOptions.currentPlatform,
|
|
||||||
/// );
|
|
||||||
/// ```
|
|
||||||
class DefaultFirebaseOptions {
|
|
||||||
|
|
||||||
static FirebaseOptions get currentPlatform {
|
|
||||||
if (kIsWeb) {
|
|
||||||
throw UnsupportedError(
|
|
||||||
'DefaultFirebaseOptions have not been configured for web - '
|
|
||||||
'you can reconfigure this by running the FlutterFire CLI again.',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
switch (defaultTargetPlatform) {
|
|
||||||
case TargetPlatform.android:
|
|
||||||
return android;
|
|
||||||
case TargetPlatform.iOS:
|
|
||||||
return ios;
|
|
||||||
case TargetPlatform.macOS:
|
|
||||||
throw UnsupportedError(
|
|
||||||
'DefaultFirebaseOptions have not been configured for macos - '
|
|
||||||
'you can reconfigure this by running the FlutterFire CLI again.',
|
|
||||||
);
|
|
||||||
case TargetPlatform.windows:
|
|
||||||
throw UnsupportedError(
|
|
||||||
'DefaultFirebaseOptions have not been configured for windows - '
|
|
||||||
'you can reconfigure this by running the FlutterFire CLI again.',
|
|
||||||
);
|
|
||||||
case TargetPlatform.linux:
|
|
||||||
throw UnsupportedError(
|
|
||||||
'DefaultFirebaseOptions have not been configured for linux - '
|
|
||||||
'you can reconfigure this by running the FlutterFire CLI again.',
|
|
||||||
);
|
|
||||||
default:
|
|
||||||
throw UnsupportedError(
|
|
||||||
'DefaultFirebaseOptions are not supported for this platform.',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
static const FirebaseOptions android = FirebaseOptions(
|
|
||||||
apiKey: 'AIzaSyCh2cA5AHNIS3e1Wnf48dfoCUKvmEM9J34',
|
|
||||||
appId: '1:164857321043:android:0a67e4973f9208721ad8a6',
|
|
||||||
messagingSenderId: '164857321043',
|
|
||||||
projectId: 'progetto-m335',
|
|
||||||
databaseURL: 'https://progetto-m335-default-rtdb.europe-west1.firebasedatabase.app',
|
|
||||||
storageBucket: 'progetto-m335.appspot.com',
|
|
||||||
);
|
|
||||||
|
|
||||||
static const FirebaseOptions ios = FirebaseOptions(
|
|
||||||
apiKey: 'AIzaSyAhEex7OfyJHETyC-uSydOFGABBn5KX16Q',
|
|
||||||
appId: '1:164857321043:ios:b497e5d24254d60e1ad8a6',
|
|
||||||
messagingSenderId: '164857321043',
|
|
||||||
projectId: 'progetto-m335',
|
|
||||||
databaseURL: 'https://progetto-m335-default-rtdb.europe-west1.firebasedatabase.app',
|
|
||||||
storageBucket: 'progetto-m335.appspot.com',
|
|
||||||
iosBundleId: 'ch.ameti.progettoM335Flutter',
|
|
||||||
);
|
|
||||||
}
|
|
||||||
@@ -1,45 +0,0 @@
|
|||||||
/*
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import '../pages/welcome_page.dart';
|
|
||||||
import '../pages/home_page.dart';
|
|
||||||
|
|
||||||
void main() {
|
|
||||||
runApp(const MyApp());
|
|
||||||
}
|
|
||||||
|
|
||||||
class MyApp extends StatelessWidget {
|
|
||||||
const MyApp({super.key});
|
|
||||||
|
|
||||||
// This widget is the root of your application.
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return MaterialApp(
|
|
||||||
title: 'Flutter Demo',
|
|
||||||
theme: ThemeData(
|
|
||||||
primaryColor: Colors.red,
|
|
||||||
accentCoulor: Colors.blue,
|
|
||||||
fontFamily: 'Roboto',
|
|
||||||
textTheme: TextTheme(
|
|
||||||
headline1: TextStyle(fontSize: 24),
|
|
||||||
headline2: TextStyle(fontSize: 20),
|
|
||||||
headline3: TextStyle(fontSize: 16),
|
|
||||||
)),
|
|
||||||
// Cambia la proprietà `home` con `WelcomePage()`
|
|
||||||
home: WelcomePage(),
|
|
||||||
// Aggiungi un nuovo `onGenerateRoute`
|
|
||||||
onGenerateRoute: (settings) {
|
|
||||||
// Se la route è `/home`, esci dal `WelcomePage()` e vai alla `HomePage()`
|
|
||||||
if (settings.name == '/home') {
|
|
||||||
Navigator.pop(context);
|
|
||||||
return MaterialPageRoute(
|
|
||||||
builder: (context) => const HomePage(
|
|
||||||
title: 'Titolo',
|
|
||||||
));
|
|
||||||
}
|
|
||||||
// Altrimenti, restituisci la route predefinita
|
|
||||||
return MaterialPageRoute(builder: (context) => WelcomePage());
|
|
||||||
},
|
|
||||||
);
|
|
||||||
}
|
|
||||||
} */
|
|
||||||
@@ -1,45 +0,0 @@
|
|||||||
import 'package:firebase_auth/firebase_auth.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:google_sign_in/google_sign_in.dart';
|
|
||||||
|
|
||||||
class LoginView extends StatefulWidget {
|
|
||||||
const LoginView({super.key});
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<LoginView> createState() => _LoginViewState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _LoginViewState extends State<LoginView> {
|
|
||||||
|
|
||||||
Future<UserCredential> signInWithGoogle() async {
|
|
||||||
// Trigger the authentication flow
|
|
||||||
final GoogleSignInAccount? googleUser = await GoogleSignIn().signIn();
|
|
||||||
|
|
||||||
// Obtain the auth details from the request
|
|
||||||
final GoogleSignInAuthentication? googleAuth = await googleUser?.authentication;
|
|
||||||
|
|
||||||
// Create a new credential
|
|
||||||
final credential = GoogleAuthProvider.credential(
|
|
||||||
accessToken: googleAuth?.accessToken,
|
|
||||||
idToken: googleAuth?.idToken,
|
|
||||||
);
|
|
||||||
|
|
||||||
// Once signed in, return the UserCredential
|
|
||||||
return await FirebaseAuth.instance.signInWithCredential(credential);
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
void initState() {
|
|
||||||
signInWithGoogle().then((value) => print(value));
|
|
||||||
super.initState();
|
|
||||||
}
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return const Scaffold(
|
|
||||||
body: Center(
|
|
||||||
child: Icon(Icons.login)
|
|
||||||
)
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,186 +0,0 @@
|
|||||||
import 'package:firebase_auth/firebase_auth.dart';
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
import 'package:form_field_validator/form_field_validator.dart';
|
|
||||||
import 'package:flutter/foundation.dart';
|
|
||||||
import 'package:progetto_m335_flutter/pages/LoginView.dart';
|
|
||||||
|
|
||||||
class RegisterView extends StatefulWidget {
|
|
||||||
const RegisterView({Key? key}) : super(key: key);
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<RegisterView> createState() => _RegisterViewState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _RegisterViewState extends State<RegisterView> {
|
|
||||||
String email = '';
|
|
||||||
String password = '';
|
|
||||||
bool showPassword = false;
|
|
||||||
Color buttonColor = Colors.blue[200]!;
|
|
||||||
|
|
||||||
void register() async {
|
|
||||||
print("$email $password");
|
|
||||||
if (_formkey.currentState!.validate()) {
|
|
||||||
try {
|
|
||||||
final credential =
|
|
||||||
await FirebaseAuth.instance.createUserWithEmailAndPassword(
|
|
||||||
email: email,
|
|
||||||
password: password,
|
|
||||||
);
|
|
||||||
} on FirebaseAuthException catch (e) {
|
|
||||||
if (e.code == 'weak-password') {
|
|
||||||
print('The password provided is too weak.');
|
|
||||||
} else if (e.code == 'email-already-in-use') {
|
|
||||||
print('The account already exists for that email.');
|
|
||||||
}
|
|
||||||
} catch (e) {
|
|
||||||
print(e);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
Map userData = {};
|
|
||||||
final _formkey = GlobalKey<FormState>();
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Scaffold(
|
|
||||||
appBar: AppBar(
|
|
||||||
title: Text('Register'),
|
|
||||||
),
|
|
||||||
body: SingleChildScrollView(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(12.0),
|
|
||||||
child: Form(
|
|
||||||
key: _formkey,
|
|
||||||
child: Column(
|
|
||||||
crossAxisAlignment: CrossAxisAlignment.start,
|
|
||||||
children: <Widget>[
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: TextFormField(
|
|
||||||
onChanged: (val) {
|
|
||||||
setState(() {
|
|
||||||
email = val;
|
|
||||||
if (password.length > 6 && _formkey.currentState!.validate()) {
|
|
||||||
buttonColor = Colors.blue[400]!;
|
|
||||||
} else {
|
|
||||||
buttonColor = Colors.blue[200]!;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
validator: MultiValidator([
|
|
||||||
RequiredValidator(errorText: 'Enter email address'),
|
|
||||||
EmailValidator(
|
|
||||||
errorText: 'Please correct email filled'),
|
|
||||||
]),
|
|
||||||
decoration: const InputDecoration(
|
|
||||||
hintText: 'Email',
|
|
||||||
labelText: 'Email',
|
|
||||||
prefixIcon: Icon(
|
|
||||||
Icons.email,
|
|
||||||
color: Colors.grey,
|
|
||||||
),
|
|
||||||
errorStyle: TextStyle(fontSize: 18.0),
|
|
||||||
border: OutlineInputBorder(
|
|
||||||
borderSide: BorderSide(color: Colors.red),
|
|
||||||
borderRadius:
|
|
||||||
BorderRadius.all(Radius.circular(9.0)))),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: TextFormField(
|
|
||||||
obscureText: !showPassword,
|
|
||||||
onChanged: (val) {
|
|
||||||
setState(() {
|
|
||||||
password = val;
|
|
||||||
if (password.length > 6 && _formkey.currentState!.validate()) {
|
|
||||||
buttonColor = Colors.blue[400]!;
|
|
||||||
} else {
|
|
||||||
buttonColor = Colors.blue[200]!;
|
|
||||||
}
|
|
||||||
});
|
|
||||||
},
|
|
||||||
validator: MultiValidator([
|
|
||||||
RequiredValidator(errorText: 'Enter a password'),
|
|
||||||
PatternValidator(
|
|
||||||
r'^(?=.*[a-z])(?=.*[A-Z])(?=.*\d)(?=.*[@$!%*?&])[A-Za-z\d@$!%*?&]{6,}$',
|
|
||||||
errorText: 'enter a valid password'),
|
|
||||||
]),
|
|
||||||
decoration: InputDecoration(
|
|
||||||
hintText: 'Password',
|
|
||||||
labelText: 'Password',
|
|
||||||
prefixIcon: const Icon(
|
|
||||||
Icons.key,
|
|
||||||
color: Colors.grey,
|
|
||||||
),
|
|
||||||
suffixIcon: Padding(
|
|
||||||
padding: const EdgeInsets.only(right: 20.0),
|
|
||||||
child: IconButton(
|
|
||||||
icon: Icon(
|
|
||||||
showPassword
|
|
||||||
? Icons.visibility_off
|
|
||||||
: Icons.visibility,
|
|
||||||
color: Colors.grey,
|
|
||||||
),
|
|
||||||
onPressed: () {
|
|
||||||
setState(() {
|
|
||||||
showPassword = !showPassword;
|
|
||||||
});
|
|
||||||
}),
|
|
||||||
),
|
|
||||||
errorStyle: const TextStyle(fontSize: 18.0),
|
|
||||||
border: const OutlineInputBorder(
|
|
||||||
borderSide: BorderSide(color: Colors.red),
|
|
||||||
borderRadius:
|
|
||||||
BorderRadius.all(Radius.circular(9.0)))),
|
|
||||||
)),
|
|
||||||
Center(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.all(18.0),
|
|
||||||
child: SizedBox(
|
|
||||||
// margin: EdgeInsets.fromLTRB(200, 20, 50, 0),
|
|
||||||
width: MediaQuery.of(context).size.width,
|
|
||||||
|
|
||||||
height: 50,
|
|
||||||
// margin: EdgeInsets.fromLTRB(200, 20, 50, 0),
|
|
||||||
child: ElevatedButton(
|
|
||||||
style: ElevatedButton.styleFrom(
|
|
||||||
backgroundColor: buttonColor,
|
|
||||||
shape: RoundedRectangleBorder(
|
|
||||||
borderRadius: BorderRadius.circular(10),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
child: const Text(
|
|
||||||
'Register',
|
|
||||||
style: TextStyle(color: Colors.white, fontSize: 22),
|
|
||||||
),
|
|
||||||
onPressed: () {
|
|
||||||
register();
|
|
||||||
},
|
|
||||||
),
|
|
||||||
),
|
|
||||||
)),
|
|
||||||
Center(
|
|
||||||
child: Padding(
|
|
||||||
padding: const EdgeInsets.only(top: 20),
|
|
||||||
child: Center(
|
|
||||||
child: TextButton(
|
|
||||||
child: const Text('Already have an account? Login'),
|
|
||||||
onPressed: () {
|
|
||||||
Navigator.push(
|
|
||||||
context,
|
|
||||||
MaterialPageRoute(
|
|
||||||
builder: (context) => const LoginView()),
|
|
||||||
);
|
|
||||||
},
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
)),
|
|
||||||
),
|
|
||||||
));
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,24 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
|
|
||||||
class HomePage extends StatefulWidget {
|
|
||||||
const HomePage({super.key});
|
|
||||||
|
|
||||||
final String title = "home page";
|
|
||||||
|
|
||||||
@override
|
|
||||||
State<HomePage> createState() => _HomePageState();
|
|
||||||
}
|
|
||||||
|
|
||||||
class _HomePageState extends State<HomePage> {
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Scaffold(
|
|
||||||
appBar: AppBar(
|
|
||||||
title: Text('Hello world'),
|
|
||||||
),
|
|
||||||
body: Center(
|
|
||||||
child: Text('Hello world!'),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
78
lib/pages/test.dart
Normal file
78
lib/pages/test.dart
Normal file
@@ -0,0 +1,78 @@
|
|||||||
|
import 'package:flutter/material.dart';
|
||||||
|
import 'package:progetto_m335_flutter/database/database.dart';
|
||||||
|
import 'package:progetto_m335_flutter/model/note.dart';
|
||||||
|
import 'package:progetto_m335_flutter/model/promemoria.dart';
|
||||||
|
|
||||||
|
import '../database/database.dart';
|
||||||
|
|
||||||
|
class Test extends StatefulWidget {
|
||||||
|
const Test({super.key});
|
||||||
|
|
||||||
|
@override
|
||||||
|
State<Test> createState() => _TestState();
|
||||||
|
}
|
||||||
|
|
||||||
|
class _TestState extends State<Test> {
|
||||||
|
NoteDatabase noteDatabase = NoteDatabase.instance;
|
||||||
|
|
||||||
|
Future<void> _pressed() async {
|
||||||
|
print("Inserting demo data");
|
||||||
|
final db = await noteDatabase.database;
|
||||||
|
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
Future<void> _printdata() async {
|
||||||
|
|
||||||
|
|
||||||
|
var nota = Note.newConstructor(
|
||||||
|
"nota 5",
|
||||||
|
"2023-09-56",
|
||||||
|
"2028-03-1",
|
||||||
|
"1,2,3,4,5",
|
||||||
|
"Questo è un esempio di nota gesu benedetto 1.");
|
||||||
|
|
||||||
|
var promemoria = Promemoria.newConstructor(
|
||||||
|
"promemoria 5",
|
||||||
|
"2023-09-56",
|
||||||
|
"2028-03-1",
|
||||||
|
"2028-03-1",
|
||||||
|
"1,2,3,4,5",
|
||||||
|
"Questo è un esempio di promemoria gesu benedetto 1.",
|
||||||
|
"alta",
|
||||||
|
"rosso");
|
||||||
|
|
||||||
|
noteDatabase.addNote(nota);
|
||||||
|
noteDatabase.addPromemoria(promemoria);
|
||||||
|
|
||||||
|
final db = await noteDatabase.database;
|
||||||
|
|
||||||
|
print("Printing data");
|
||||||
|
print((await noteDatabase.getAllPromemoria()).first);
|
||||||
|
print((await noteDatabase.getAllNote()).first);
|
||||||
|
print("promemoria");
|
||||||
|
print(await db.query(promemoriaTable));
|
||||||
|
print("note");
|
||||||
|
print(await db.query(noteTable));
|
||||||
|
print("Data printed");
|
||||||
|
|
||||||
|
print("savedata from database to firebase");
|
||||||
|
noteDatabase.syncData();
|
||||||
|
print("data saved");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
Widget build(BuildContext context) {
|
||||||
|
return Scaffold(
|
||||||
|
body: Center(
|
||||||
|
child: Column(
|
||||||
|
children: [
|
||||||
|
FloatingActionButton(onPressed: _pressed),
|
||||||
|
FloatingActionButton(onPressed: _printdata)
|
||||||
|
],
|
||||||
|
)
|
||||||
|
)
|
||||||
|
);
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -1,31 +0,0 @@
|
|||||||
import 'package:flutter/material.dart';
|
|
||||||
|
|
||||||
|
|
||||||
class WelcomePage extends StatelessWidget {
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return MaterialApp(
|
|
||||||
title: 'Pagina di benvenuto',
|
|
||||||
home: Scaffold(
|
|
||||||
appBar: AppBar(
|
|
||||||
title: Text('Benvenuto'),
|
|
||||||
),
|
|
||||||
body: Center(
|
|
||||||
child: Column(
|
|
||||||
mainAxisAlignment: MainAxisAlignment.center,
|
|
||||||
children: [
|
|
||||||
Text('Benvenuto nella pagina di benvenuto!'),
|
|
||||||
SizedBox(height: 20),
|
|
||||||
Text('Clicca sul pulsante per continuare'),
|
|
||||||
SizedBox(height: 20),
|
|
||||||
ElevatedButton(
|
|
||||||
onPressed: () {},
|
|
||||||
child: Text('Continua'),
|
|
||||||
),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -1,63 +0,0 @@
|
|||||||
// Copyright 2021 The Flutter team. All rights reserved.
|
|
||||||
// Use of this source code is governed by a BSD-style license that can be
|
|
||||||
// found in the LICENSE file.
|
|
||||||
|
|
||||||
import 'package:flutter/material.dart';
|
|
||||||
|
|
||||||
class TypographyScreen extends StatelessWidget {
|
|
||||||
const TypographyScreen({super.key});
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
final textTheme = Theme.of(context)
|
|
||||||
.textTheme
|
|
||||||
.apply(displayColor: Theme.of(context).colorScheme.onSurface);
|
|
||||||
return Expanded(
|
|
||||||
child: ListView(
|
|
||||||
children: <Widget>[
|
|
||||||
const SizedBox(height: 7),
|
|
||||||
TextStyleExample(
|
|
||||||
name: 'Display Large', style: textTheme.displayLarge!),
|
|
||||||
TextStyleExample(
|
|
||||||
name: 'Display Medium', style: textTheme.displayMedium!),
|
|
||||||
TextStyleExample(
|
|
||||||
name: 'Display Small', style: textTheme.displaySmall!),
|
|
||||||
TextStyleExample(
|
|
||||||
name: 'Headline Large', style: textTheme.headlineLarge!),
|
|
||||||
TextStyleExample(
|
|
||||||
name: 'Headline Medium', style: textTheme.headlineMedium!),
|
|
||||||
TextStyleExample(
|
|
||||||
name: 'Headline Small', style: textTheme.headlineSmall!),
|
|
||||||
TextStyleExample(name: 'Title Large', style: textTheme.titleLarge!),
|
|
||||||
TextStyleExample(name: 'Title Medium', style: textTheme.titleMedium!),
|
|
||||||
TextStyleExample(name: 'Title Small', style: textTheme.titleSmall!),
|
|
||||||
TextStyleExample(name: 'Label Large', style: textTheme.labelLarge!),
|
|
||||||
TextStyleExample(name: 'Label Medium', style: textTheme.labelMedium!),
|
|
||||||
TextStyleExample(name: 'Label Small', style: textTheme.labelSmall!),
|
|
||||||
TextStyleExample(name: 'Body Large', style: textTheme.bodyLarge!),
|
|
||||||
TextStyleExample(name: 'Body Medium', style: textTheme.bodyMedium!),
|
|
||||||
TextStyleExample(name: 'Body Small', style: textTheme.bodySmall!),
|
|
||||||
],
|
|
||||||
),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
class TextStyleExample extends StatelessWidget {
|
|
||||||
const TextStyleExample({
|
|
||||||
super.key,
|
|
||||||
required this.name,
|
|
||||||
required this.style,
|
|
||||||
});
|
|
||||||
|
|
||||||
final String name;
|
|
||||||
final TextStyle style;
|
|
||||||
|
|
||||||
@override
|
|
||||||
Widget build(BuildContext context) {
|
|
||||||
return Padding(
|
|
||||||
padding: const EdgeInsets.all(8.0),
|
|
||||||
child: Text(name, style: style),
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
148
pubspec.lock
148
pubspec.lock
@@ -1,6 +1,14 @@
|
|||||||
# Generated by pub
|
# Generated by pub
|
||||||
# See https://dart.dev/tools/pub/glossary#lockfile
|
# See https://dart.dev/tools/pub/glossary#lockfile
|
||||||
packages:
|
packages:
|
||||||
|
_flutterfire_internals:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: _flutterfire_internals
|
||||||
|
sha256: "2d8e8e123ca3675625917f535fcc0d3a50092eef44334168f9b18adc050d4c6e"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "1.3.6"
|
||||||
async:
|
async:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -33,6 +41,30 @@ packages:
|
|||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.1.1"
|
version: "1.1.1"
|
||||||
|
cloud_firestore:
|
||||||
|
dependency: "direct main"
|
||||||
|
description:
|
||||||
|
name: cloud_firestore
|
||||||
|
sha256: "50e1ffa143fc5c49db1800392f8d9524fd015f9d26a9e4fc01b5ddb1e603e01b"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "4.9.2"
|
||||||
|
cloud_firestore_platform_interface:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: cloud_firestore_platform_interface
|
||||||
|
sha256: "150e603a40d52b3199e46b1e38d9f8ef8c2dee9e1fb2122d58d456c50015bf7c"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "5.16.1"
|
||||||
|
cloud_firestore_web:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: cloud_firestore_web
|
||||||
|
sha256: f033aef13b13f94b0f361898df39307d8710859c8912626cfb08e439e350bd66
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "3.7.1"
|
||||||
collection:
|
collection:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -57,6 +89,14 @@ packages:
|
|||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.3.1"
|
version: "1.3.1"
|
||||||
|
ffi:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: ffi
|
||||||
|
sha256: "7bf0adc28a23d395f19f3f1eb21dd7cfd1dd9f8e1c50051c069122e6853bc878"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "2.1.0"
|
||||||
firebase_core:
|
firebase_core:
|
||||||
dependency: "direct main"
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
@@ -145,7 +185,7 @@ packages:
|
|||||||
source: hosted
|
source: hosted
|
||||||
version: "1.9.1"
|
version: "1.9.1"
|
||||||
path:
|
path:
|
||||||
dependency: transitive
|
dependency: "direct main"
|
||||||
description:
|
description:
|
||||||
name: path
|
name: path
|
||||||
sha256: "8829d8a55c13fc0e37127c29fedf290c102f4e40ae94ada574091fe0ff96c917"
|
sha256: "8829d8a55c13fc0e37127c29fedf290c102f4e40ae94ada574091fe0ff96c917"
|
||||||
@@ -173,6 +213,38 @@ packages:
|
|||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.10.0"
|
version: "1.10.0"
|
||||||
|
sqflite:
|
||||||
|
dependency: "direct main"
|
||||||
|
description:
|
||||||
|
name: sqflite
|
||||||
|
sha256: "591f1602816e9c31377d5f008c2d9ef7b8aca8941c3f89cc5fd9d84da0c38a9a"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "2.3.0"
|
||||||
|
sqflite_common:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: sqflite_common
|
||||||
|
sha256: "1b92f368f44b0dee2425bb861cfa17b6f6cf3961f762ff6f941d20b33355660a"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "2.5.0"
|
||||||
|
sqflite_common_ffi:
|
||||||
|
dependency: "direct main"
|
||||||
|
description:
|
||||||
|
name: sqflite_common_ffi
|
||||||
|
sha256: "0d5cc1be2eb18400ac6701c31211d44164393aa75886093002ecdd947be04f93"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "2.3.0+2"
|
||||||
|
sqlite3:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: sqlite3
|
||||||
|
sha256: db65233e6b99e99b2548932f55a987961bc06d82a31a0665451fa0b4fff4c3fb
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "2.1.0"
|
||||||
stack_trace:
|
stack_trace:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -197,6 +269,14 @@ packages:
|
|||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "1.2.0"
|
version: "1.2.0"
|
||||||
|
synchronized:
|
||||||
|
dependency: transitive
|
||||||
|
description:
|
||||||
|
name: synchronized
|
||||||
|
sha256: "5fcbd27688af6082f5abd611af56ee575342c30e87541d0245f7ff99faa02c60"
|
||||||
|
url: "https://pub.dev"
|
||||||
|
source: hosted
|
||||||
|
version: "3.1.0"
|
||||||
term_glyph:
|
term_glyph:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -213,70 +293,6 @@ packages:
|
|||||||
url: "https://pub.dev"
|
url: "https://pub.dev"
|
||||||
source: hosted
|
source: hosted
|
||||||
version: "0.6.0"
|
version: "0.6.0"
|
||||||
url_launcher:
|
|
||||||
dependency: "direct main"
|
|
||||||
description:
|
|
||||||
name: url_launcher
|
|
||||||
sha256: "47e208a6711459d813ba18af120d9663c20bdf6985d6ad39fe165d2538378d27"
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "6.1.14"
|
|
||||||
url_launcher_android:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: url_launcher_android
|
|
||||||
sha256: b04af59516ab45762b2ca6da40fa830d72d0f6045cd97744450b73493fa76330
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "6.1.0"
|
|
||||||
url_launcher_ios:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: url_launcher_ios
|
|
||||||
sha256: "7c65021d5dee51813d652357bc65b8dd4a6177082a9966bc8ba6ee477baa795f"
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "6.1.5"
|
|
||||||
url_launcher_linux:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: url_launcher_linux
|
|
||||||
sha256: b651aad005e0cb06a01dbd84b428a301916dc75f0e7ea6165f80057fee2d8e8e
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "3.0.6"
|
|
||||||
url_launcher_macos:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: url_launcher_macos
|
|
||||||
sha256: b55486791f666e62e0e8ff825e58a023fd6b1f71c49926483f1128d3bbd8fe88
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "3.0.7"
|
|
||||||
url_launcher_platform_interface:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: url_launcher_platform_interface
|
|
||||||
sha256: "95465b39f83bfe95fcb9d174829d6476216f2d548b79c38ab2506e0458787618"
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "2.1.5"
|
|
||||||
url_launcher_web:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: url_launcher_web
|
|
||||||
sha256: "2942294a500b4fa0b918685aff406773ba0a4cd34b7f42198742a94083020ce5"
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "2.0.20"
|
|
||||||
url_launcher_windows:
|
|
||||||
dependency: transitive
|
|
||||||
description:
|
|
||||||
name: url_launcher_windows
|
|
||||||
sha256: "95fef3129dc7cfaba2bc3d5ba2e16063bb561fc6d78e63eee16162bc70029069"
|
|
||||||
url: "https://pub.dev"
|
|
||||||
source: hosted
|
|
||||||
version: "3.0.8"
|
|
||||||
vector_math:
|
vector_math:
|
||||||
dependency: transitive
|
dependency: transitive
|
||||||
description:
|
description:
|
||||||
@@ -295,4 +311,4 @@ packages:
|
|||||||
version: "0.1.4-beta"
|
version: "0.1.4-beta"
|
||||||
sdks:
|
sdks:
|
||||||
dart: ">=3.1.2 <4.0.0"
|
dart: ">=3.1.2 <4.0.0"
|
||||||
flutter: ">=3.13.0"
|
flutter: ">=3.3.0"
|
||||||
|
|||||||
@@ -31,16 +31,15 @@ dependencies:
|
|||||||
flutter:
|
flutter:
|
||||||
sdk: flutter
|
sdk: flutter
|
||||||
|
|
||||||
google_sign_in: ^6.1.5
|
|
||||||
|
|
||||||
|
|
||||||
# The following adds the Cupertino Icons font to your application.
|
# The following adds the Cupertino Icons font to your application.
|
||||||
# Use with the CupertinoIcons class for iOS style icons.
|
# Use with the CupertinoIcons class for iOS style icons.
|
||||||
cupertino_icons: ^1.0.2
|
cupertino_icons: ^1.0.2
|
||||||
firebase_core: ^2.16.0
|
firebase_core: ^2.16.0
|
||||||
url_launcher: ^6.1.14
|
sqflite: ^2.3.0
|
||||||
firebase_auth: ^4.10.0
|
path: ^1.8.3
|
||||||
form_field_validator: ^1.1.0
|
sqflite_common_ffi: ^2.3.0+2
|
||||||
|
cloud_firestore: ^4.9.2
|
||||||
|
|
||||||
dev_dependencies:
|
dev_dependencies:
|
||||||
flutter_test:
|
flutter_test:
|
||||||
|
|||||||
@@ -8,12 +8,12 @@
|
|||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
import 'package:flutter_test/flutter_test.dart';
|
import 'package:flutter_test/flutter_test.dart';
|
||||||
|
|
||||||
import 'package:progetto_m335_flutter/main.dart';
|
import 'package:progetto_m335_flutter/myApp.dart';
|
||||||
|
|
||||||
void main() {
|
void main() {
|
||||||
testWidgets('Counter increments smoke test', (WidgetTester tester) async {
|
testWidgets('Counter increments smoke test', (WidgetTester tester) async {
|
||||||
// Build our app and trigger a frame.
|
// Build our app and trigger a frame.
|
||||||
await tester.pumpWidget(const App());
|
await tester.pumpWidget(const MyApp());
|
||||||
|
|
||||||
// Verify that our counter starts at 0.
|
// Verify that our counter starts at 0.
|
||||||
expect(find.text('0'), findsOneWidget);
|
expect(find.text('0'), findsOneWidget);
|
||||||
|
|||||||
Reference in New Issue
Block a user