LOgin
This commit is contained in:
parent
31b6d137bd
commit
a1cf8e30a4
|
|
@ -1,7 +1,7 @@
|
||||||
import 'package:flutter/material.dart';
|
import 'package:flutter/material.dart';
|
||||||
|
|
||||||
// This version must be updated in tandem with the pubspec version.
|
// This version must be updated in tandem with the pubspec version.
|
||||||
const String kAppVersion = '0.1.50';
|
const String kAppVersion = '2.0.0';
|
||||||
const String kSiteUrl = 'https://invoiceninja.com';
|
const String kSiteUrl = 'https://invoiceninja.com';
|
||||||
const String kAppUrl = 'https://admin.invoiceninja.com';
|
const String kAppUrl = 'https://admin.invoiceninja.com';
|
||||||
const String kAppPlansURL =
|
const String kAppPlansURL =
|
||||||
|
|
|
||||||
|
|
@ -15,6 +15,7 @@ abstract class CompanyEntity
|
||||||
companyKey: '',
|
companyKey: '',
|
||||||
name: '',
|
name: '',
|
||||||
plan: '',
|
plan: '',
|
||||||
|
settings: SettingsEntity(),
|
||||||
logoUrl: '',
|
logoUrl: '',
|
||||||
appUrl: '',
|
appUrl: '',
|
||||||
convertProductExchangeRate: false,
|
convertProductExchangeRate: false,
|
||||||
|
|
@ -46,7 +47,8 @@ abstract class CompanyEntity
|
||||||
showCurrencyCode: false,
|
showCurrencyCode: false,
|
||||||
showInvoiceItemTaxes: false,
|
showInvoiceItemTaxes: false,
|
||||||
startOfWeek: 1,
|
startOfWeek: 1,
|
||||||
timezoneId: '1', // TODO set to default EST timezone
|
timezoneId: '1',
|
||||||
|
// TODO set to default EST timezone
|
||||||
customPaymentTerms: BuiltList<PaymentTermEntity>(),
|
customPaymentTerms: BuiltList<PaymentTermEntity>(),
|
||||||
taxRates: BuiltList<TaxRateEntity>(),
|
taxRates: BuiltList<TaxRateEntity>(),
|
||||||
taskStatuses: BuiltList<TaskStatusEntity>(),
|
taskStatuses: BuiltList<TaskStatusEntity>(),
|
||||||
|
|
@ -104,6 +106,8 @@ abstract class CompanyEntity
|
||||||
@BuiltValueField(wireName: 'currency_id')
|
@BuiltValueField(wireName: 'currency_id')
|
||||||
String get companyCurrencyId;
|
String get companyCurrencyId;
|
||||||
|
|
||||||
|
SettingsEntity get settings;
|
||||||
|
|
||||||
// TODO remove this
|
// TODO remove this
|
||||||
@nullable
|
@nullable
|
||||||
@BuiltValueField(wireName: 'timezone_id')
|
@BuiltValueField(wireName: 'timezone_id')
|
||||||
|
|
@ -554,7 +558,8 @@ abstract class UserEntity implements Built<UserEntity, UserEntityBuilder> {
|
||||||
BuiltMap<String, bool> get permissionsMap;
|
BuiltMap<String, bool> get permissionsMap;
|
||||||
|
|
||||||
bool can(UserPermission permission, EntityType entityType) =>
|
bool can(UserPermission permission, EntityType entityType) =>
|
||||||
isAdmin || permissionsMap.containsKey('${permission}_$entityType');
|
(isAdmin ?? false) ||
|
||||||
|
permissionsMap.containsKey('${permission}_$entityType');
|
||||||
|
|
||||||
bool canView(EntityType entityType) => can(UserPermission.view, entityType);
|
bool canView(EntityType entityType) => can(UserPermission.view, entityType);
|
||||||
|
|
||||||
|
|
@ -619,3 +624,22 @@ abstract class TokenEntity implements Built<TokenEntity, TokenEntityBuilder> {
|
||||||
|
|
||||||
static Serializer<TokenEntity> get serializer => _$tokenEntitySerializer;
|
static Serializer<TokenEntity> get serializer => _$tokenEntitySerializer;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
abstract class SettingsEntity
|
||||||
|
implements Built<SettingsEntity, SettingsEntityBuilder> {
|
||||||
|
factory SettingsEntity() {
|
||||||
|
return _$SettingsEntity._(
|
||||||
|
//timezoneId: '',
|
||||||
|
);
|
||||||
|
}
|
||||||
|
|
||||||
|
SettingsEntity._();
|
||||||
|
|
||||||
|
@BuiltValueField(wireName: 'timezone_id')
|
||||||
|
int get timezoneIdInt;
|
||||||
|
|
||||||
|
String get timezoneId => timezoneId.toString();
|
||||||
|
|
||||||
|
static Serializer<SettingsEntity> get serializer =>
|
||||||
|
_$settingsEntitySerializer;
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -16,6 +16,8 @@ Serializer<UserEntity> _$userEntitySerializer = new _$UserEntitySerializer();
|
||||||
Serializer<UserCompanyEntity> _$userCompanyEntitySerializer =
|
Serializer<UserCompanyEntity> _$userCompanyEntitySerializer =
|
||||||
new _$UserCompanyEntitySerializer();
|
new _$UserCompanyEntitySerializer();
|
||||||
Serializer<TokenEntity> _$tokenEntitySerializer = new _$TokenEntitySerializer();
|
Serializer<TokenEntity> _$tokenEntitySerializer = new _$TokenEntitySerializer();
|
||||||
|
Serializer<SettingsEntity> _$settingsEntitySerializer =
|
||||||
|
new _$SettingsEntitySerializer();
|
||||||
|
|
||||||
class _$CompanyEntitySerializer implements StructuredSerializer<CompanyEntity> {
|
class _$CompanyEntitySerializer implements StructuredSerializer<CompanyEntity> {
|
||||||
@override
|
@override
|
||||||
|
|
@ -32,6 +34,9 @@ class _$CompanyEntitySerializer implements StructuredSerializer<CompanyEntity> {
|
||||||
'company_key',
|
'company_key',
|
||||||
serializers.serialize(object.companyKey,
|
serializers.serialize(object.companyKey,
|
||||||
specifiedType: const FullType(String)),
|
specifiedType: const FullType(String)),
|
||||||
|
'settings',
|
||||||
|
serializers.serialize(object.settings,
|
||||||
|
specifiedType: const FullType(SettingsEntity)),
|
||||||
'country_id',
|
'country_id',
|
||||||
serializers.serialize(object.countryId,
|
serializers.serialize(object.countryId,
|
||||||
specifiedType: const FullType(String)),
|
specifiedType: const FullType(String)),
|
||||||
|
|
@ -451,6 +456,10 @@ class _$CompanyEntitySerializer implements StructuredSerializer<CompanyEntity> {
|
||||||
result.companyCurrencyId = serializers.deserialize(value,
|
result.companyCurrencyId = serializers.deserialize(value,
|
||||||
specifiedType: const FullType(String)) as String;
|
specifiedType: const FullType(String)) as String;
|
||||||
break;
|
break;
|
||||||
|
case 'settings':
|
||||||
|
result.settings.replace(serializers.deserialize(value,
|
||||||
|
specifiedType: const FullType(SettingsEntity)) as SettingsEntity);
|
||||||
|
break;
|
||||||
case 'timezone_id':
|
case 'timezone_id':
|
||||||
result.timezoneId = serializers.deserialize(value,
|
result.timezoneId = serializers.deserialize(value,
|
||||||
specifiedType: const FullType(String)) as String;
|
specifiedType: const FullType(String)) as String;
|
||||||
|
|
@ -1029,6 +1038,48 @@ class _$TokenEntitySerializer implements StructuredSerializer<TokenEntity> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class _$SettingsEntitySerializer
|
||||||
|
implements StructuredSerializer<SettingsEntity> {
|
||||||
|
@override
|
||||||
|
final Iterable<Type> types = const [SettingsEntity, _$SettingsEntity];
|
||||||
|
@override
|
||||||
|
final String wireName = 'SettingsEntity';
|
||||||
|
|
||||||
|
@override
|
||||||
|
Iterable<Object> serialize(Serializers serializers, SettingsEntity object,
|
||||||
|
{FullType specifiedType = FullType.unspecified}) {
|
||||||
|
final result = <Object>[
|
||||||
|
'timezone_id',
|
||||||
|
serializers.serialize(object.timezoneIdInt,
|
||||||
|
specifiedType: const FullType(int)),
|
||||||
|
];
|
||||||
|
|
||||||
|
return result;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
SettingsEntity deserialize(
|
||||||
|
Serializers serializers, Iterable<Object> serialized,
|
||||||
|
{FullType specifiedType = FullType.unspecified}) {
|
||||||
|
final result = new SettingsEntityBuilder();
|
||||||
|
|
||||||
|
final iterator = serialized.iterator;
|
||||||
|
while (iterator.moveNext()) {
|
||||||
|
final key = iterator.current as String;
|
||||||
|
iterator.moveNext();
|
||||||
|
final dynamic value = iterator.current;
|
||||||
|
switch (key) {
|
||||||
|
case 'timezone_id':
|
||||||
|
result.timezoneIdInt = serializers.deserialize(value,
|
||||||
|
specifiedType: const FullType(int)) as int;
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return result.build();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
class _$CompanyEntity extends CompanyEntity {
|
class _$CompanyEntity extends CompanyEntity {
|
||||||
@override
|
@override
|
||||||
final String name;
|
final String name;
|
||||||
|
|
@ -1043,6 +1094,8 @@ class _$CompanyEntity extends CompanyEntity {
|
||||||
@override
|
@override
|
||||||
final String companyCurrencyId;
|
final String companyCurrencyId;
|
||||||
@override
|
@override
|
||||||
|
final SettingsEntity settings;
|
||||||
|
@override
|
||||||
final String timezoneId;
|
final String timezoneId;
|
||||||
@override
|
@override
|
||||||
final String countryId;
|
final String countryId;
|
||||||
|
|
@ -1169,6 +1222,7 @@ class _$CompanyEntity extends CompanyEntity {
|
||||||
this.logoUrl,
|
this.logoUrl,
|
||||||
this.appUrl,
|
this.appUrl,
|
||||||
this.companyCurrencyId,
|
this.companyCurrencyId,
|
||||||
|
this.settings,
|
||||||
this.timezoneId,
|
this.timezoneId,
|
||||||
this.countryId,
|
this.countryId,
|
||||||
this.dateFormatId,
|
this.dateFormatId,
|
||||||
|
|
@ -1234,6 +1288,9 @@ class _$CompanyEntity extends CompanyEntity {
|
||||||
if (companyKey == null) {
|
if (companyKey == null) {
|
||||||
throw new BuiltValueNullFieldError('CompanyEntity', 'companyKey');
|
throw new BuiltValueNullFieldError('CompanyEntity', 'companyKey');
|
||||||
}
|
}
|
||||||
|
if (settings == null) {
|
||||||
|
throw new BuiltValueNullFieldError('CompanyEntity', 'settings');
|
||||||
|
}
|
||||||
if (countryId == null) {
|
if (countryId == null) {
|
||||||
throw new BuiltValueNullFieldError('CompanyEntity', 'countryId');
|
throw new BuiltValueNullFieldError('CompanyEntity', 'countryId');
|
||||||
}
|
}
|
||||||
|
|
@ -1259,6 +1316,7 @@ class _$CompanyEntity extends CompanyEntity {
|
||||||
logoUrl == other.logoUrl &&
|
logoUrl == other.logoUrl &&
|
||||||
appUrl == other.appUrl &&
|
appUrl == other.appUrl &&
|
||||||
companyCurrencyId == other.companyCurrencyId &&
|
companyCurrencyId == other.companyCurrencyId &&
|
||||||
|
settings == other.settings &&
|
||||||
timezoneId == other.timezoneId &&
|
timezoneId == other.timezoneId &&
|
||||||
countryId == other.countryId &&
|
countryId == other.countryId &&
|
||||||
dateFormatId == other.dateFormatId &&
|
dateFormatId == other.dateFormatId &&
|
||||||
|
|
@ -1339,7 +1397,7 @@ class _$CompanyEntity extends CompanyEntity {
|
||||||
$jc(
|
$jc(
|
||||||
$jc(
|
$jc(
|
||||||
$jc(
|
$jc(
|
||||||
$jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc(0, name.hashCode), plan.hashCode), companyKey.hashCode), logoUrl.hashCode), appUrl.hashCode), companyCurrencyId.hashCode), timezoneId.hashCode), countryId.hashCode), dateFormatId.hashCode), datetimeFormatId.hashCode), defaultInvoiceTerms.hashCode), enableInvoiceTaxes.hashCode), enableInvoiceItemTaxes.hashCode), defaultInvoiceDesignId.hashCode), defaultQuoteDesignId.hashCode), languageId.hashCode), defaultInvoiceFooter.hashCode), showInvoiceItemTaxes.hashCode), enableMilitaryTime.hashCode), defaultTaxName1.hashCode), defaultTaxRate1.hashCode), defaultTaxName2.hashCode), defaultTaxRate2.hashCode), defaultQuoteTerms.hashCode), showCurrencyCode.hashCode), enableSecondTaxRate.hashCode), startOfWeek.hashCode), financialYearStart.hashCode), enabledModules.hashCode), defaultPaymentTerms.hashCode), defaultPaymentTypeId.hashCode), defaultTaskRate.hashCode), enableInclusiveTaxes.hashCode), convertProductExchangeRate.hashCode), enableCustomInvoiceTaxes1.hashCode), enableCustomInvoiceTaxes2.hashCode), taxRates.hashCode), taskStatuses.hashCode), taskStatusMap.hashCode), expenseCategories.hashCode), expenseCategoryMap.hashCode), users.hashCode), userMap.hashCode), customFields.hashCode), customPaymentTerms.hashCode),
|
$jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc($jc(0, name.hashCode), plan.hashCode), companyKey.hashCode), logoUrl.hashCode), appUrl.hashCode), companyCurrencyId.hashCode), settings.hashCode), timezoneId.hashCode), countryId.hashCode), dateFormatId.hashCode), datetimeFormatId.hashCode), defaultInvoiceTerms.hashCode), enableInvoiceTaxes.hashCode), enableInvoiceItemTaxes.hashCode), defaultInvoiceDesignId.hashCode), defaultQuoteDesignId.hashCode), languageId.hashCode), defaultInvoiceFooter.hashCode), showInvoiceItemTaxes.hashCode), enableMilitaryTime.hashCode), defaultTaxName1.hashCode), defaultTaxRate1.hashCode), defaultTaxName2.hashCode), defaultTaxRate2.hashCode), defaultQuoteTerms.hashCode), showCurrencyCode.hashCode), enableSecondTaxRate.hashCode), startOfWeek.hashCode), financialYearStart.hashCode), enabledModules.hashCode), defaultPaymentTerms.hashCode), defaultPaymentTypeId.hashCode), defaultTaskRate.hashCode), enableInclusiveTaxes.hashCode), convertProductExchangeRate.hashCode), enableCustomInvoiceTaxes1.hashCode), enableCustomInvoiceTaxes2.hashCode), taxRates.hashCode), taskStatuses.hashCode), taskStatusMap.hashCode), expenseCategories.hashCode), expenseCategoryMap.hashCode), users.hashCode), userMap.hashCode), customFields.hashCode), customPaymentTerms.hashCode),
|
||||||
invoiceFields.hashCode),
|
invoiceFields.hashCode),
|
||||||
emailFooter.hashCode),
|
emailFooter.hashCode),
|
||||||
emailSubjectInvoice.hashCode),
|
emailSubjectInvoice.hashCode),
|
||||||
|
|
@ -1370,6 +1428,7 @@ class _$CompanyEntity extends CompanyEntity {
|
||||||
..add('logoUrl', logoUrl)
|
..add('logoUrl', logoUrl)
|
||||||
..add('appUrl', appUrl)
|
..add('appUrl', appUrl)
|
||||||
..add('companyCurrencyId', companyCurrencyId)
|
..add('companyCurrencyId', companyCurrencyId)
|
||||||
|
..add('settings', settings)
|
||||||
..add('timezoneId', timezoneId)
|
..add('timezoneId', timezoneId)
|
||||||
..add('countryId', countryId)
|
..add('countryId', countryId)
|
||||||
..add('dateFormatId', dateFormatId)
|
..add('dateFormatId', dateFormatId)
|
||||||
|
|
@ -1461,6 +1520,11 @@ class CompanyEntityBuilder
|
||||||
set companyCurrencyId(String companyCurrencyId) =>
|
set companyCurrencyId(String companyCurrencyId) =>
|
||||||
_$this._companyCurrencyId = companyCurrencyId;
|
_$this._companyCurrencyId = companyCurrencyId;
|
||||||
|
|
||||||
|
SettingsEntityBuilder _settings;
|
||||||
|
SettingsEntityBuilder get settings =>
|
||||||
|
_$this._settings ??= new SettingsEntityBuilder();
|
||||||
|
set settings(SettingsEntityBuilder settings) => _$this._settings = settings;
|
||||||
|
|
||||||
String _timezoneId;
|
String _timezoneId;
|
||||||
String get timezoneId => _$this._timezoneId;
|
String get timezoneId => _$this._timezoneId;
|
||||||
set timezoneId(String timezoneId) => _$this._timezoneId = timezoneId;
|
set timezoneId(String timezoneId) => _$this._timezoneId = timezoneId;
|
||||||
|
|
@ -1764,6 +1828,7 @@ class CompanyEntityBuilder
|
||||||
_logoUrl = _$v.logoUrl;
|
_logoUrl = _$v.logoUrl;
|
||||||
_appUrl = _$v.appUrl;
|
_appUrl = _$v.appUrl;
|
||||||
_companyCurrencyId = _$v.companyCurrencyId;
|
_companyCurrencyId = _$v.companyCurrencyId;
|
||||||
|
_settings = _$v.settings?.toBuilder();
|
||||||
_timezoneId = _$v.timezoneId;
|
_timezoneId = _$v.timezoneId;
|
||||||
_countryId = _$v.countryId;
|
_countryId = _$v.countryId;
|
||||||
_dateFormatId = _$v.dateFormatId;
|
_dateFormatId = _$v.dateFormatId;
|
||||||
|
|
@ -1852,6 +1917,7 @@ class CompanyEntityBuilder
|
||||||
logoUrl: logoUrl,
|
logoUrl: logoUrl,
|
||||||
appUrl: appUrl,
|
appUrl: appUrl,
|
||||||
companyCurrencyId: companyCurrencyId,
|
companyCurrencyId: companyCurrencyId,
|
||||||
|
settings: settings.build(),
|
||||||
timezoneId: timezoneId,
|
timezoneId: timezoneId,
|
||||||
countryId: countryId,
|
countryId: countryId,
|
||||||
dateFormatId: dateFormatId,
|
dateFormatId: dateFormatId,
|
||||||
|
|
@ -1913,6 +1979,9 @@ class CompanyEntityBuilder
|
||||||
} catch (_) {
|
} catch (_) {
|
||||||
String _$failedField;
|
String _$failedField;
|
||||||
try {
|
try {
|
||||||
|
_$failedField = 'settings';
|
||||||
|
settings.build();
|
||||||
|
|
||||||
_$failedField = 'taxRates';
|
_$failedField = 'taxRates';
|
||||||
_taxRates?.build();
|
_taxRates?.build();
|
||||||
_$failedField = 'taskStatuses';
|
_$failedField = 'taskStatuses';
|
||||||
|
|
@ -2561,4 +2630,84 @@ class TokenEntityBuilder implements Builder<TokenEntity, TokenEntityBuilder> {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
class _$SettingsEntity extends SettingsEntity {
|
||||||
|
@override
|
||||||
|
final int timezoneIdInt;
|
||||||
|
|
||||||
|
factory _$SettingsEntity([void Function(SettingsEntityBuilder) updates]) =>
|
||||||
|
(new SettingsEntityBuilder()..update(updates)).build();
|
||||||
|
|
||||||
|
_$SettingsEntity._({this.timezoneIdInt}) : super._() {
|
||||||
|
if (timezoneIdInt == null) {
|
||||||
|
throw new BuiltValueNullFieldError('SettingsEntity', 'timezoneIdInt');
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
SettingsEntity rebuild(void Function(SettingsEntityBuilder) updates) =>
|
||||||
|
(toBuilder()..update(updates)).build();
|
||||||
|
|
||||||
|
@override
|
||||||
|
SettingsEntityBuilder toBuilder() =>
|
||||||
|
new SettingsEntityBuilder()..replace(this);
|
||||||
|
|
||||||
|
@override
|
||||||
|
bool operator ==(Object other) {
|
||||||
|
if (identical(other, this)) return true;
|
||||||
|
return other is SettingsEntity && timezoneIdInt == other.timezoneIdInt;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
int get hashCode {
|
||||||
|
return $jf($jc(0, timezoneIdInt.hashCode));
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
String toString() {
|
||||||
|
return (newBuiltValueToStringHelper('SettingsEntity')
|
||||||
|
..add('timezoneIdInt', timezoneIdInt))
|
||||||
|
.toString();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
class SettingsEntityBuilder
|
||||||
|
implements Builder<SettingsEntity, SettingsEntityBuilder> {
|
||||||
|
_$SettingsEntity _$v;
|
||||||
|
|
||||||
|
int _timezoneIdInt;
|
||||||
|
int get timezoneIdInt => _$this._timezoneIdInt;
|
||||||
|
set timezoneIdInt(int timezoneIdInt) => _$this._timezoneIdInt = timezoneIdInt;
|
||||||
|
|
||||||
|
SettingsEntityBuilder();
|
||||||
|
|
||||||
|
SettingsEntityBuilder get _$this {
|
||||||
|
if (_$v != null) {
|
||||||
|
_timezoneIdInt = _$v.timezoneIdInt;
|
||||||
|
_$v = null;
|
||||||
|
}
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void replace(SettingsEntity other) {
|
||||||
|
if (other == null) {
|
||||||
|
throw new ArgumentError.notNull('other');
|
||||||
|
}
|
||||||
|
_$v = other as _$SettingsEntity;
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
void update(void Function(SettingsEntityBuilder) updates) {
|
||||||
|
if (updates != null) updates(this);
|
||||||
|
}
|
||||||
|
|
||||||
|
@override
|
||||||
|
_$SettingsEntity build() {
|
||||||
|
final _$result =
|
||||||
|
_$v ?? new _$SettingsEntity._(timezoneIdInt: timezoneIdInt);
|
||||||
|
replace(_$result);
|
||||||
|
return _$result;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// ignore_for_file: always_put_control_body_on_new_line,always_specify_types,annotate_overrides,avoid_annotating_with_dynamic,avoid_as,avoid_catches_without_on_clauses,avoid_returning_this,lines_longer_than_80_chars,omit_local_variable_types,prefer_expression_function_bodies,sort_constructors_first,test_types_in_equals,unnecessary_const,unnecessary_new
|
// ignore_for_file: always_put_control_body_on_new_line,always_specify_types,annotate_overrides,avoid_annotating_with_dynamic,avoid_as,avoid_catches_without_on_clauses,avoid_returning_this,lines_longer_than_80_chars,omit_local_variable_types,prefer_expression_function_bodies,sort_constructors_first,test_types_in_equals,unnecessary_const,unnecessary_new
|
||||||
|
|
|
||||||
|
|
@ -96,6 +96,7 @@ Serializers _$serializers = (new Serializers().toBuilder()
|
||||||
..add(ProjectUIState.serializer)
|
..add(ProjectUIState.serializer)
|
||||||
..add(QuoteState.serializer)
|
..add(QuoteState.serializer)
|
||||||
..add(QuoteUIState.serializer)
|
..add(QuoteUIState.serializer)
|
||||||
|
..add(SettingsEntity.serializer)
|
||||||
..add(SizeEntity.serializer)
|
..add(SizeEntity.serializer)
|
||||||
..add(SizeItemResponse.serializer)
|
..add(SizeItemResponse.serializer)
|
||||||
..add(SizeListResponse.serializer)
|
..add(SizeListResponse.serializer)
|
||||||
|
|
|
||||||
|
|
@ -323,16 +323,18 @@ Middleware<AppState> _createAccountLoaded() {
|
||||||
if (action.loadCompanies) {
|
if (action.loadCompanies) {
|
||||||
for (int i = 0; i < response.userCompanies.length; i++) {
|
for (int i = 0; i < response.userCompanies.length; i++) {
|
||||||
final UserCompanyEntity userCompany = response.userCompanies[i];
|
final UserCompanyEntity userCompany = response.userCompanies[i];
|
||||||
|
print('user company: $userCompany');
|
||||||
final SharedPreferences prefs = await SharedPreferences.getInstance();
|
|
||||||
prefs.setString(getCompanyTokenKey(i), userCompany.token.token);
|
|
||||||
|
|
||||||
store.dispatch(SelectCompany(i + 1, userCompany));
|
store.dispatch(SelectCompany(i + 1, userCompany));
|
||||||
|
print('selected 1');
|
||||||
store.dispatch(LoadCompanySuccess(userCompany));
|
store.dispatch(LoadCompanySuccess(userCompany));
|
||||||
|
print('selected 2');
|
||||||
}
|
}
|
||||||
|
|
||||||
store.dispatch(SelectCompany(1, response.userCompanies[0]));
|
store.dispatch(SelectCompany(1, response.userCompanies[0]));
|
||||||
|
print('selected 3');
|
||||||
store.dispatch(UserLoginSuccess());
|
store.dispatch(UserLoginSuccess());
|
||||||
|
print('selected 4');
|
||||||
}
|
}
|
||||||
|
|
||||||
if (action.completer != null) {
|
if (action.completer != null) {
|
||||||
|
|
|
||||||
|
|
@ -275,7 +275,8 @@ abstract class AppState implements Built<AppState, AppStateBuilder> {
|
||||||
|
|
||||||
@override
|
@override
|
||||||
String toString() {
|
String toString() {
|
||||||
return 'URL: ${authState.url}, ${selectedCompany.plan}';
|
return 'Settings: ${selectedCompanyState.company.settings}';
|
||||||
|
//return 'URL: ${authState.url}, ${selectedCompany.plan}';
|
||||||
//return 'Is Testing: ${uiState.isTesting}';
|
//return 'Is Testing: ${uiState.isTesting}';
|
||||||
//return 'Route: ${uiState.currentRoute}, Previous: ${uiState.previousRoute}, Layout: ${uiState.layout}, Menu: ${uiState.isMenuVisible}, History: ${uiState.isHistoryVisible}';
|
//return 'Route: ${uiState.currentRoute}, Previous: ${uiState.previousRoute}, Layout: ${uiState.layout}, Menu: ${uiState.isMenuVisible}, History: ${uiState.isHistoryVisible}';
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -44,6 +44,8 @@ Reducer<UserCompanyEntity> companyEntityReducer = combineReducers([
|
||||||
|
|
||||||
UserCompanyEntity loadCompanySuccessReducer(
|
UserCompanyEntity loadCompanySuccessReducer(
|
||||||
UserCompanyEntity company, LoadCompanySuccess action) {
|
UserCompanyEntity company, LoadCompanySuccess action) {
|
||||||
|
return action.company;
|
||||||
|
|
||||||
var userCompany = action.company;
|
var userCompany = action.company;
|
||||||
|
|
||||||
if (userCompany.company.taskStatuses != null) {
|
if (userCompany.company.taskStatuses != null) {
|
||||||
|
|
|
||||||
|
|
@ -165,25 +165,6 @@ class AppDrawer extends StatelessWidget {
|
||||||
child: ListView(
|
child: ListView(
|
||||||
shrinkWrap: true,
|
shrinkWrap: true,
|
||||||
children: <Widget>[
|
children: <Widget>[
|
||||||
if (Platform.isIOS &&
|
|
||||||
isHosted(context) &&
|
|
||||||
!isPaidAccount(context))
|
|
||||||
Material(
|
|
||||||
color: Colors.green,
|
|
||||||
child: ListTile(
|
|
||||||
leading: Icon(
|
|
||||||
FontAwesomeIcons.superpowers,
|
|
||||||
color: Colors.white,
|
|
||||||
),
|
|
||||||
title: Text(localization.upgrade,
|
|
||||||
style: TextStyle(color: Colors.white)),
|
|
||||||
onTap: () => showDialog<UpgradeDialog>(
|
|
||||||
context: context,
|
|
||||||
builder: (BuildContext context) {
|
|
||||||
return UpgradeDialog();
|
|
||||||
}),
|
|
||||||
),
|
|
||||||
),
|
|
||||||
DrawerTile(
|
DrawerTile(
|
||||||
company: company,
|
company: company,
|
||||||
icon: FontAwesomeIcons.tachometerAlt,
|
icon: FontAwesomeIcons.tachometerAlt,
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue