Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(105)

Unified Diff: ios/chrome/browser/ui/settings/sync_encryption_passphrase_collection_view_controller.h

Issue 2587023002: Upstream Chrome on iOS source code [8/11]. (Closed)
Patch Set: Created 4 years ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
Index: ios/chrome/browser/ui/settings/sync_encryption_passphrase_collection_view_controller.h
diff --git a/ios/chrome/browser/ui/settings/sync_encryption_passphrase_collection_view_controller.h b/ios/chrome/browser/ui/settings/sync_encryption_passphrase_collection_view_controller.h
new file mode 100644
index 0000000000000000000000000000000000000000..63bf506cc106c3eb70e776e78bbcf420f3320b59
--- /dev/null
+++ b/ios/chrome/browser/ui/settings/sync_encryption_passphrase_collection_view_controller.h
@@ -0,0 +1,91 @@
+// Copyright 2015 The Chromium Authors. All rights reserved.
+// Use of this source code is governed by a BSD-style license that can be
+// found in the LICENSE file.
+
+#ifndef IOS_CHROME_BROWSER_UI_SETTINGS_SYNC_ENCRYPTION_PASSPHRASE_COLLECTION_VIEW_CONTROLLER_H_
+#define IOS_CHROME_BROWSER_UI_SETTINGS_SYNC_ENCRYPTION_PASSPHRASE_COLLECTION_VIEW_CONTROLLER_H_
+
+#import <UIKit/UIKit.h>
+
+#import "ios/chrome/browser/sync/sync_observer_bridge.h"
+#import "ios/chrome/browser/ui/collection_view/collection_view_model.h"
+#import "ios/chrome/browser/ui/settings/settings_root_collection_view_controller.h"
+
+namespace ios {
+class ChromeBrowserState;
+} // namespace ios
+
+namespace ios_internal {
+namespace sync_encryption_passphrase {
+typedef NS_ENUM(NSInteger, SectionIdentifier) {
+ SectionIdentifierPassphrase = kSectionIdentifierEnumZero,
+ SectionIdentifierFooter,
+};
+typedef NS_ENUM(NSInteger, ItemType) {
+ ItemTypeMessage = kItemTypeEnumZero,
+ ItemTypeEnterPassphrase,
+ ItemTypeConfirmPassphrase,
+ ItemTypeError,
+ ItemTypeFooter,
+};
+} // namespace sync_encryption_passphrase
+} // namespace ios_internal
+
+// Controller to allow user to specify encryption passphrase for Sync.
+@interface SyncEncryptionPassphraseCollectionViewController
+ : SettingsRootCollectionViewController<SyncObserverModelBridge>
+
+@property(nonatomic, readonly) UITextField* passphrase;
+@property(nonatomic, copy) NSString* headerMessage;
+@property(nonatomic, copy) NSString* footerMessage;
+@property(nonatomic, copy) NSString* processingMessage;
+@property(nonatomic, copy) NSString* syncErrorMessage;
+
+// |browserState| must not be nil.
+- (instancetype)initWithBrowserState:(ios::ChromeBrowserState*)browserState
+ NS_DESIGNATED_INITIALIZER;
+- (instancetype)initWithStyle:(CollectionViewControllerStyle)style
+ NS_UNAVAILABLE;
+
+@end
+
+@interface SyncEncryptionPassphraseCollectionViewController (
+ Subclassing)<UITextFieldDelegate>
+
+// Whether this controller is for encryption or decryption. Returns |YES|, if
+// the used for the user to enter an existing passphrase that is not yet
+// available on the device. Returns |NO| if the user is setting a new
+// passphrase.
+- (BOOL)forDecryption;
+
+// User has pressed the Sign In button.
+- (void)signInPressed;
+
+// Clears all fields after displaying an error.
+- (void)clearFieldsOnError:(NSString*)errorMessage;
+
+// Whether the text field(s) is(are) filled.
+- (BOOL)areAllFieldsFilled;
+
+// Registers listening to the events of |textField|.
+- (void)registerTextField:(UITextField*)textField;
+
+// Unregisters listening to the events of |textField|.
+- (void)unregisterTextField:(UITextField*)textField;
+
+// Called after a touch event entering a |UITextField|.
+- (void)textFieldDidBeginEditing:(id)sender;
+
+// Called after a touch event changing a |UITextField|.
+- (void)textFieldDidChange:(id)sender;
+
+// Called after a touch event leaving a |UITextField| by clicking "return" key.
+- (void)textFieldDidEndEditing:(id)sender;
+
+// Stops observing the sync service. This is required during the shutdown phase
+// to avoid observing sync events for a browser state that is being killed.
+- (void)stopObserving;
+
+@end
+
+#endif // IOS_CHROME_BROWSER_UI_SETTINGS_SYNC_ENCRYPTION_PASSPHRASE_COLLECTION_VIEW_CONTROLLER_H_

Powered by Google App Engine
This is Rietveld 408576698