This commit is contained in:
parent
ba884245b8
commit
d6b30e11b2
@ -18,7 +18,7 @@ class MountSettingsWidget extends StatefulWidget {
|
|||||||
class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
||||||
Map<String, dynamic>? _settings;
|
Map<String, dynamic>? _settings;
|
||||||
|
|
||||||
void _addBooleanSetting(list, key, value) {
|
void _addBooleanSetting(list, root, key, value) {
|
||||||
list.add(
|
list.add(
|
||||||
SettingsTile.switchTile(
|
SettingsTile.switchTile(
|
||||||
leading: Icon(Icons.check),
|
leading: Icon(Icons.check),
|
||||||
@ -26,19 +26,19 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
initialValue: (value as bool),
|
initialValue: (value as bool),
|
||||||
onPressed: (_) {
|
onPressed: (_) {
|
||||||
setState(() {
|
setState(() {
|
||||||
_settings?[key] = !value;
|
root?[key] = !value;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
onToggle: (bool nextValue) {
|
onToggle: (bool nextValue) {
|
||||||
setState(() {
|
setState(() {
|
||||||
_settings?[key] = nextValue;
|
root?[key] = nextValue;
|
||||||
});
|
});
|
||||||
},
|
},
|
||||||
),
|
),
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void _addIntSetting(list, key, value) {
|
void _addIntSetting(list, root, key, value) {
|
||||||
list.add(
|
list.add(
|
||||||
SettingsTile.navigation(
|
SettingsTile.navigation(
|
||||||
leading: Icon(Icons.onetwothree),
|
leading: Icon(Icons.onetwothree),
|
||||||
@ -48,7 +48,7 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void _addPasswordSetting(list, String key, value) {
|
void _addPasswordSetting(list, root, key, value) {
|
||||||
list.add(
|
list.add(
|
||||||
SettingsTile.navigation(
|
SettingsTile.navigation(
|
||||||
leading: Icon(Icons.password),
|
leading: Icon(Icons.password),
|
||||||
@ -58,7 +58,7 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
void _addStringSetting(list, String key, value, icon) {
|
void _addStringSetting(list, root, key, value, icon) {
|
||||||
list.add(
|
list.add(
|
||||||
SettingsTile.navigation(
|
SettingsTile.navigation(
|
||||||
leading: Icon(icon),
|
leading: Icon(icon),
|
||||||
@ -79,44 +79,56 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
|
|
||||||
_settings?.forEach((key, value) {
|
_settings?.forEach((key, value) {
|
||||||
if (key == "ApiAuth") {
|
if (key == "ApiAuth") {
|
||||||
_addPasswordSetting(commonSettings, key, value);
|
_addPasswordSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "ApiPort") {
|
} else if (key == "ApiPort") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "ApiUser") {
|
} else if (key == "ApiUser") {
|
||||||
_addStringSetting(commonSettings, key, value, Icons.person);
|
_addStringSetting(commonSettings, _settings, key, value, Icons.person);
|
||||||
} else if (key == "DatabaseType") {
|
} else if (key == "DatabaseType") {
|
||||||
_addStringSetting(commonSettings, key, value, Icons.dataset);
|
_addStringSetting(commonSettings, _settings, key, value, Icons.dataset);
|
||||||
} else if (key == "DownloadTimeoutSeconds") {
|
} else if (key == "DownloadTimeoutSeconds") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "EnableDownloadTimeout") {
|
} else if (key == "EnableDownloadTimeout") {
|
||||||
_addBooleanSetting(commonSettings, key, value);
|
_addBooleanSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "EnableDriveEvents") {
|
} else if (key == "EnableDriveEvents") {
|
||||||
_addBooleanSetting(commonSettings, key, value);
|
_addBooleanSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "EventLevel") {
|
} else if (key == "EventLevel") {
|
||||||
_addStringSetting(commonSettings, key, value, Icons.event);
|
_addStringSetting(commonSettings, _settings, key, value, Icons.event);
|
||||||
} else if (key == "EvictionDelayMinutes") {
|
} else if (key == "EvictionDelayMinutes") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "EvictionUseAccessedTime") {
|
} else if (key == "EvictionUseAccessedTime") {
|
||||||
_addBooleanSetting(commonSettings, key, value);
|
_addBooleanSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "MaxCacheSizeBytes") {
|
} else if (key == "MaxCacheSizeBytes") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "MaxUploadCount") {
|
} else if (key == "MaxUploadCount") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "OnlineCheckRetrySeconds") {
|
} else if (key == "OnlineCheckRetrySeconds") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "PreferredDownloadType") {
|
} else if (key == "PreferredDownloadType") {
|
||||||
_addStringSetting(commonSettings, key, value, Icons.download);
|
_addStringSetting(
|
||||||
|
commonSettings,
|
||||||
|
_settings,
|
||||||
|
key,
|
||||||
|
value,
|
||||||
|
Icons.download,
|
||||||
|
);
|
||||||
} else if (key == "RetryReadCount") {
|
} else if (key == "RetryReadCount") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "RingBufferFileSize") {
|
} else if (key == "RingBufferFileSize") {
|
||||||
_addIntSetting(commonSettings, key, value);
|
_addIntSetting(commonSettings, _settings, key, value);
|
||||||
} else if (key == "EncryptConfig") {
|
} else if (key == "EncryptConfig") {
|
||||||
value.forEach((subKey, subValue) {
|
value.forEach((subKey, subValue) {
|
||||||
if (subKey == "EncryptionToken") {
|
if (subKey == "EncryptionToken") {
|
||||||
_addPasswordSetting(encryptConfigSettings, subKey, subValue);
|
_addPasswordSetting(
|
||||||
|
encryptConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "Path") {
|
} else if (subKey == "Path") {
|
||||||
_addStringSetting(
|
_addStringSetting(
|
||||||
encryptConfigSettings,
|
encryptConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
subKey,
|
subKey,
|
||||||
subValue,
|
subValue,
|
||||||
Icons.folder,
|
Icons.folder,
|
||||||
@ -128,17 +140,29 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
if (subKey == "AgentString") {
|
if (subKey == "AgentString") {
|
||||||
_addStringSetting(
|
_addStringSetting(
|
||||||
hostConfigSettings,
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
subKey,
|
subKey,
|
||||||
subValue,
|
subValue,
|
||||||
Icons.support_agent,
|
Icons.support_agent,
|
||||||
);
|
);
|
||||||
} else if (subKey == "ApiPassword") {
|
} else if (subKey == "ApiPassword") {
|
||||||
_addPasswordSetting(hostConfigSettings, subKey, subValue);
|
_addPasswordSetting(
|
||||||
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "ApiPort") {
|
} else if (subKey == "ApiPort") {
|
||||||
_addIntSetting(hostConfigSettings, subKey, subValue);
|
_addIntSetting(
|
||||||
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "ApiUser") {
|
} else if (subKey == "ApiUser") {
|
||||||
_addStringSetting(
|
_addStringSetting(
|
||||||
hostConfigSettings,
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
subKey,
|
subKey,
|
||||||
subValue,
|
subValue,
|
||||||
Icons.person,
|
Icons.person,
|
||||||
@ -146,6 +170,7 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
} else if (subKey == "HostNameOrIp") {
|
} else if (subKey == "HostNameOrIp") {
|
||||||
_addStringSetting(
|
_addStringSetting(
|
||||||
hostConfigSettings,
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
subKey,
|
subKey,
|
||||||
subValue,
|
subValue,
|
||||||
Icons.computer,
|
Icons.computer,
|
||||||
@ -153,48 +178,123 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
} else if (subKey == "Path") {
|
} else if (subKey == "Path") {
|
||||||
_addStringSetting(
|
_addStringSetting(
|
||||||
hostConfigSettings,
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
subKey,
|
subKey,
|
||||||
subValue,
|
subValue,
|
||||||
Icons.route,
|
Icons.route,
|
||||||
);
|
);
|
||||||
} else if (subKey == "Protocol") {
|
} else if (subKey == "Protocol") {
|
||||||
_addStringSetting(hostConfigSettings, subKey, subValue, Icons.http);
|
_addStringSetting(
|
||||||
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
Icons.http,
|
||||||
|
);
|
||||||
} else if (subKey == "TimeoutMs") {
|
} else if (subKey == "TimeoutMs") {
|
||||||
_addIntSetting(hostConfigSettings, subKey, subValue);
|
_addIntSetting(
|
||||||
|
hostConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else if (key == "RemoteMount") {
|
} else if (key == "RemoteMount") {
|
||||||
value.forEach((subKey, subValue) {
|
value.forEach((subKey, subValue) {
|
||||||
if (subKey == "ApiPort") {
|
if (subKey == "ApiPort") {
|
||||||
_addIntSetting(remoteMountSettings, subKey, subValue);
|
_addIntSetting(
|
||||||
|
remoteMountSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "ClientPoolSize") {
|
} else if (subKey == "ClientPoolSize") {
|
||||||
_addIntSetting(remoteMountSettings, subKey, subValue);
|
_addIntSetting(
|
||||||
|
remoteMountSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "Enable") {
|
} else if (subKey == "Enable") {
|
||||||
_addBooleanSetting(remoteMountSettings, subKey, subValue);
|
_addBooleanSetting(
|
||||||
|
remoteMountSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "EncryptionToken") {
|
} else if (subKey == "EncryptionToken") {
|
||||||
_addPasswordSetting(remoteMountSettings, subKey, subValue);
|
_addPasswordSetting(
|
||||||
|
remoteMountSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else if (key == "S3Config") {
|
} else if (key == "S3Config") {
|
||||||
value.forEach((subKey, subValue) {
|
value.forEach((subKey, subValue) {
|
||||||
if (subKey == "AccessKey") {
|
if (subKey == "AccessKey") {
|
||||||
_addPasswordSetting(s3ConfigSettings, subKey, subValue);
|
_addPasswordSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "Bucket") {
|
} else if (subKey == "Bucket") {
|
||||||
_addStringSetting(s3ConfigSettings, subKey, subValue, Icons.folder);
|
_addStringSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
Icons.folder,
|
||||||
|
);
|
||||||
} else if (subKey == "EncryptionToken") {
|
} else if (subKey == "EncryptionToken") {
|
||||||
_addPasswordSetting(s3ConfigSettings, subKey, subValue);
|
_addPasswordSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "Region") {
|
} else if (subKey == "Region") {
|
||||||
_addStringSetting(s3ConfigSettings, subKey, subValue, Icons.map);
|
_addStringSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
Icons.map,
|
||||||
|
);
|
||||||
} else if (subKey == "SecretKey") {
|
} else if (subKey == "SecretKey") {
|
||||||
_addPasswordSetting(s3ConfigSettings, subKey, subValue);
|
_addPasswordSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "TimeoutMs") {
|
} else if (subKey == "TimeoutMs") {
|
||||||
_addIntSetting(s3ConfigSettings, subKey, subValue);
|
_addIntSetting(s3ConfigSettings, _settings?[key], subKey, subValue);
|
||||||
} else if (subKey == "URL") {
|
} else if (subKey == "URL") {
|
||||||
_addStringSetting(s3ConfigSettings, subKey, subValue, Icons.http);
|
_addStringSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
Icons.http,
|
||||||
|
);
|
||||||
} else if (subKey == "UsePathStyle") {
|
} else if (subKey == "UsePathStyle") {
|
||||||
_addBooleanSetting(s3ConfigSettings, subKey, subValue);
|
_addBooleanSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
} else if (subKey == "UseRegionInURL") {
|
} else if (subKey == "UseRegionInURL") {
|
||||||
_addBooleanSetting(s3ConfigSettings, subKey, subValue);
|
_addBooleanSetting(
|
||||||
|
s3ConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
|
subKey,
|
||||||
|
subValue,
|
||||||
|
);
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
} else if (key == "SiaConfig") {
|
} else if (key == "SiaConfig") {
|
||||||
@ -202,6 +302,7 @@ class _MountSettingsWidgetState extends State<MountSettingsWidget> {
|
|||||||
if (subKey == "Bucket") {
|
if (subKey == "Bucket") {
|
||||||
_addStringSetting(
|
_addStringSetting(
|
||||||
siaConfigSettings,
|
siaConfigSettings,
|
||||||
|
_settings?[key],
|
||||||
subKey,
|
subKey,
|
||||||
subValue,
|
subValue,
|
||||||
Icons.folder,
|
Icons.folder,
|
||||||
|
Loading…
x
Reference in New Issue
Block a user