mirror of
https://github.com/bitwarden/android.git
synced 2025-01-12 19:27:37 +03:00
accessibility service autofill
This commit is contained in:
parent
21bbb2af42
commit
dc7b37c8f2
2 changed files with 136 additions and 12 deletions
|
@ -14,6 +14,22 @@
|
||||||
|
|
||||||
<ScrollView>
|
<ScrollView>
|
||||||
<StackLayout Padding="0" Spacing="20">
|
<StackLayout Padding="0" Spacing="20">
|
||||||
|
<StackLayout StyleClass="box">
|
||||||
|
<StackLayout StyleClass="box-row, box-row-input">
|
||||||
|
<Label
|
||||||
|
Text="{u:I18n Theme}"
|
||||||
|
StyleClass="box-label" />
|
||||||
|
<Picker
|
||||||
|
x:Name="_themePicker"
|
||||||
|
ItemsSource="{Binding ThemeOptions, Mode=OneTime}"
|
||||||
|
SelectedIndex="{Binding ThemeSelectedIndex}"
|
||||||
|
StyleClass="box-value" />
|
||||||
|
</StackLayout>
|
||||||
|
<Label
|
||||||
|
StyleClass="box-footer-label"
|
||||||
|
Text="{u:I18n ThemeDescription}"
|
||||||
|
x:Name="_themeDescriptionLabel" />
|
||||||
|
</StackLayout>
|
||||||
<StackLayout StyleClass="box">
|
<StackLayout StyleClass="box">
|
||||||
<StackLayout StyleClass="box-row, box-row-input">
|
<StackLayout StyleClass="box-row, box-row-input">
|
||||||
<Label
|
<Label
|
||||||
|
@ -75,20 +91,53 @@
|
||||||
StyleClass="box-footer-label" />
|
StyleClass="box-footer-label" />
|
||||||
</StackLayout>
|
</StackLayout>
|
||||||
<StackLayout StyleClass="box">
|
<StackLayout StyleClass="box">
|
||||||
<StackLayout StyleClass="box-row, box-row-input">
|
<StackLayout StyleClass="box-row-header">
|
||||||
|
<Label Text="{u:I18n AutofillAccessibilityService}"
|
||||||
|
StyleClass="box-header, box-header-platform" />
|
||||||
|
</StackLayout>
|
||||||
|
<StackLayout StyleClass="box-row, box-row-switch">
|
||||||
<Label
|
<Label
|
||||||
Text="{u:I18n Theme}"
|
Text="{u:I18n AutofillAlways}"
|
||||||
StyleClass="box-label" />
|
StyleClass="box-label, box-label-regular"
|
||||||
<Picker
|
HorizontalOptions="StartAndExpand" />
|
||||||
x:Name="_themePicker"
|
<Switch
|
||||||
ItemsSource="{Binding ThemeOptions, Mode=OneTime}"
|
IsToggled="{Binding AutofillAlwaysScan}"
|
||||||
SelectedIndex="{Binding ThemeSelectedIndex}"
|
StyleClass="box-value"
|
||||||
StyleClass="box-value" />
|
HorizontalOptions="End" />
|
||||||
</StackLayout>
|
</StackLayout>
|
||||||
<Label
|
<Label
|
||||||
StyleClass="box-footer-label"
|
Text="{u:I18n AutofillAlwaysDescription}"
|
||||||
Text="{u:I18n ThemeDescription}"
|
StyleClass="box-footer-label" />
|
||||||
x:Name="_themeDescriptionLabel" />
|
</StackLayout>
|
||||||
|
<StackLayout StyleClass="box">
|
||||||
|
<StackLayout StyleClass="box-row, box-row-switch">
|
||||||
|
<Label
|
||||||
|
Text="{u:I18n AutofillPersistNotification}"
|
||||||
|
StyleClass="box-label, box-label-regular"
|
||||||
|
HorizontalOptions="StartAndExpand" />
|
||||||
|
<Switch
|
||||||
|
IsToggled="{Binding AutofillPersistNotification}"
|
||||||
|
StyleClass="box-value"
|
||||||
|
HorizontalOptions="End" />
|
||||||
|
</StackLayout>
|
||||||
|
<Label
|
||||||
|
Text="{u:I18n AutofillPersistNotificationDescription}"
|
||||||
|
StyleClass="box-footer-label" />
|
||||||
|
</StackLayout>
|
||||||
|
<StackLayout StyleClass="box">
|
||||||
|
<StackLayout StyleClass="box-row, box-row-switch">
|
||||||
|
<Label
|
||||||
|
Text="{u:I18n AutofillPasswordField}"
|
||||||
|
StyleClass="box-label, box-label-regular"
|
||||||
|
HorizontalOptions="StartAndExpand" />
|
||||||
|
<Switch
|
||||||
|
IsToggled="{Binding AutofillPasswordField}"
|
||||||
|
StyleClass="box-value"
|
||||||
|
HorizontalOptions="End" />
|
||||||
|
</StackLayout>
|
||||||
|
<Label
|
||||||
|
Text="{u:I18n AutofillPasswordFieldDescription}"
|
||||||
|
StyleClass="box-footer-label" />
|
||||||
</StackLayout>
|
</StackLayout>
|
||||||
</StackLayout>
|
</StackLayout>
|
||||||
</ScrollView>
|
</ScrollView>
|
||||||
|
|
|
@ -20,12 +20,17 @@ namespace Bit.App.Pages
|
||||||
private readonly IStateService _stateService;
|
private readonly IStateService _stateService;
|
||||||
private readonly IMessagingService _messagingService;
|
private readonly IMessagingService _messagingService;
|
||||||
|
|
||||||
|
|
||||||
|
private bool _autofillAlwaysScan;
|
||||||
|
private bool _autofillPersistNotification;
|
||||||
|
private bool _autofillPasswordField;
|
||||||
private bool _disableFavicon;
|
private bool _disableFavicon;
|
||||||
private bool _disableAutoTotpCopy;
|
private bool _disableAutoTotpCopy;
|
||||||
private int _clearClipboardSelectedIndex;
|
private int _clearClipboardSelectedIndex;
|
||||||
private int _themeSelectedIndex;
|
private int _themeSelectedIndex;
|
||||||
private int _uriMatchSelectedIndex;
|
private int _uriMatchSelectedIndex;
|
||||||
private bool _inited;
|
private bool _inited;
|
||||||
|
private bool _updatingAutofill;
|
||||||
|
|
||||||
public OptionsPageViewModel()
|
public OptionsPageViewModel()
|
||||||
{
|
{
|
||||||
|
@ -129,10 +134,51 @@ namespace Bit.App.Pages
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public bool AutofillAlwaysScan
|
||||||
|
{
|
||||||
|
get => _autofillAlwaysScan;
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if(SetProperty(ref _autofillAlwaysScan, value))
|
||||||
|
{
|
||||||
|
var task = UpdateAutofillAsync(false, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool AutofillPersistNotification
|
||||||
|
{
|
||||||
|
get => _autofillPersistNotification;
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if(SetProperty(ref _autofillPersistNotification, value))
|
||||||
|
{
|
||||||
|
var task = UpdateAutofillAsync(value, false);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public bool AutofillPasswordField
|
||||||
|
{
|
||||||
|
get => _autofillPasswordField;
|
||||||
|
set
|
||||||
|
{
|
||||||
|
if(SetProperty(ref _autofillPasswordField, value))
|
||||||
|
{
|
||||||
|
var task = UpdateAutofillAsync(false, value);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public async Task InitAsync()
|
public async Task InitAsync()
|
||||||
{
|
{
|
||||||
|
AutofillPersistNotification = (await _storageService.GetAsync<bool?>(
|
||||||
|
Constants.AccessibilityAutofillPersistNotificationKey)).GetValueOrDefault();
|
||||||
|
AutofillPasswordField = (await _storageService.GetAsync<bool?>(
|
||||||
|
Constants.AccessibilityAutofillPasswordFieldKey)).GetValueOrDefault();
|
||||||
|
AutofillAlwaysScan = !AutofillPersistNotification && !AutofillPasswordField;
|
||||||
DisableAutoTotpCopy = !(await _totpService.IsAutoCopyEnabledAsync());
|
DisableAutoTotpCopy = !(await _totpService.IsAutoCopyEnabledAsync());
|
||||||
DisableFavicon = await _storageService.GetAsync<bool>(Constants.DisableFaviconKey);
|
DisableFavicon = (await _storageService.GetAsync<bool?>(Constants.DisableFaviconKey)).GetValueOrDefault();
|
||||||
var theme = await _storageService.GetAsync<string>(Constants.ThemeKey);
|
var theme = await _storageService.GetAsync<string>(Constants.ThemeKey);
|
||||||
ThemeSelectedIndex = ThemeOptions.FindIndex(k => k.Key == theme);
|
ThemeSelectedIndex = ThemeOptions.FindIndex(k => k.Key == theme);
|
||||||
var defaultUriMatch = await _storageService.GetAsync<int?>(Constants.DefaultUriMatch);
|
var defaultUriMatch = await _storageService.GetAsync<int?>(Constants.DefaultUriMatch);
|
||||||
|
@ -143,6 +189,35 @@ namespace Bit.App.Pages
|
||||||
_inited = true;
|
_inited = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private async Task UpdateAutofillAsync(bool persistNotification, bool passwordField)
|
||||||
|
{
|
||||||
|
if(_inited && !_updatingAutofill)
|
||||||
|
{
|
||||||
|
_updatingAutofill = true;
|
||||||
|
if(persistNotification)
|
||||||
|
{
|
||||||
|
AutofillAlwaysScan = false;
|
||||||
|
AutofillPasswordField = false;
|
||||||
|
}
|
||||||
|
else if(passwordField)
|
||||||
|
{
|
||||||
|
AutofillAlwaysScan = false;
|
||||||
|
AutofillPersistNotification = false;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
AutofillAlwaysScan = true;
|
||||||
|
AutofillPersistNotification = false;
|
||||||
|
AutofillPasswordField = false;
|
||||||
|
}
|
||||||
|
await _storageService.SaveAsync(Constants.AccessibilityAutofillPersistNotificationKey,
|
||||||
|
AutofillPersistNotification);
|
||||||
|
await _storageService.SaveAsync(Constants.AccessibilityAutofillPasswordFieldKey,
|
||||||
|
AutofillPasswordField);
|
||||||
|
_updatingAutofill = false;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
private async Task UpdateAutoTotpCopyAsync()
|
private async Task UpdateAutoTotpCopyAsync()
|
||||||
{
|
{
|
||||||
if(_inited)
|
if(_inited)
|
||||||
|
|
Loading…
Reference in a new issue