blob: f972aa4d0724a410f51be8f25e3ddf826582d0d4 [file] [log] [blame]
// Copyright 2017-present the Material Components for iOS authors. All Rights Reserved.
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
#import "MaterialIcons+ic_arrow_back.h"
#import "MaterialNavigationBar.h"
#import "MaterialTextFields.h"
#import "MaterialNavigationBar+ColorThemer.h"
#import <MDFInternationalization/MDFInternationalization.h>
@interface NavigationBarLayoutExample : UIViewController <UITextFieldDelegate>
@property(nonatomic, strong) MDCNavigationBar *navigationBar;
@property(nonatomic, strong) MDCTextInputControllerLegacyDefault *leadingItemController;
@property(nonatomic, strong) MDCTextField *leadingItemField;
@property(nonatomic, strong) MDCTextInputControllerLegacyDefault *trailingItemController;
@property(nonatomic, strong) MDCTextField *trailingItemField;
@property(nonatomic, strong) MDCTextInputControllerLegacyDefault *titleController;
@property(nonatomic, strong) MDCTextField *titleField;
@property(nonatomic, weak) UIBarButtonItem *trailingBarButtonItem;
@property(nonatomic, weak) UIBarButtonItem *leadingBarButtonItem;
@property(nonatomic, strong) MDCSemanticColorScheme *colorScheme;
@end
@implementation NavigationBarLayoutExample
- (id)init {
self = [super init];
if (self) {
self.colorScheme =
[[MDCSemanticColorScheme alloc] initWithDefaults:MDCColorSchemeDefaultsMaterial201804];
}
return self;
}
- (void)viewDidLoad {
[super viewDidLoad];
self.title = @"Title";
self.view.backgroundColor = UIColor.whiteColor;
self.navigationBar = [[MDCNavigationBar alloc] initWithFrame:CGRectZero];
self.navigationBar.translatesAutoresizingMaskIntoConstraints = NO;
[self.navigationBar observeNavigationItem:self.navigationItem];
[self.view addSubview:self.navigationBar];
[MDCNavigationBarColorThemer applySemanticColorScheme:self.colorScheme
toNavigationBar:self.navigationBar];
UIBarButtonItem *leadingButtonItem =
[[UIBarButtonItem alloc] initWithTitle:@"L"
style:UIBarButtonItemStylePlain
target:nil
action:nil];
UIBarButtonItem *trailingButtonItem =
[[UIBarButtonItem alloc] initWithTitle:@"T"
style:UIBarButtonItemStylePlain
target:nil
action:nil];
self.leadingBarButtonItem = leadingButtonItem;
self.trailingBarButtonItem = trailingButtonItem;
self.navigationItem.hidesBackButton = NO;
self.navigationItem.leftBarButtonItems = @[ leadingButtonItem ];
self.navigationItem.rightBarButtonItem = trailingButtonItem;
self.leadingItemField = [[MDCTextField alloc] initWithFrame:CGRectZero];
self.leadingItemField.translatesAutoresizingMaskIntoConstraints = NO;
self.leadingItemField.delegate = self;
self.leadingItemField.text = @"L";
self.leadingItemController =
[[MDCTextInputControllerLegacyDefault alloc] initWithTextInput:self.leadingItemField];
self.trailingItemField = [[MDCTextField alloc] initWithFrame:CGRectZero];
self.trailingItemField.translatesAutoresizingMaskIntoConstraints = NO;
self.trailingItemField.delegate = self;
self.trailingItemField.text = @"T";
self.trailingItemController =
[[MDCTextInputControllerLegacyDefault alloc] initWithTextInput:self.trailingItemField];
self.titleField = [[MDCTextField alloc] initWithFrame:CGRectZero];
self.titleField.translatesAutoresizingMaskIntoConstraints = NO;
self.titleField.delegate = self;
self.titleField.text = self.title;
self.titleController =
[[MDCTextInputControllerLegacyDefault alloc] initWithTextInput:self.titleField];
[self.view addSubview:self.leadingItemField];
[self.view addSubview:self.trailingItemField];
[self.view addSubview:self.titleField];
if (@available(iOS 11.0, *)) {
[self.view.safeAreaLayoutGuide.topAnchor constraintEqualToAnchor:self.navigationBar.topAnchor].active = YES;
} else {
[NSLayoutConstraint constraintWithItem:self.topLayoutGuide
attribute:NSLayoutAttributeBottom
relatedBy:NSLayoutRelationEqual
toItem:self.navigationBar
attribute:NSLayoutAttributeTop
multiplier:1.0
constant:0].active = YES;
}
[NSLayoutConstraint constraintWithItem:self.navigationBar
attribute:NSLayoutAttributeBottom
relatedBy:NSLayoutRelationEqual
toItem:self.leadingItemField
attribute:NSLayoutAttributeTop
multiplier:1.0
constant:0].active = YES;
[NSLayoutConstraint constraintWithItem:self.leadingItemField
attribute:NSLayoutAttributeBottom
relatedBy:NSLayoutRelationEqual
toItem:self.titleField
attribute:NSLayoutAttributeTop
multiplier:1.0
constant:0].active = YES;
[NSLayoutConstraint constraintWithItem:self.titleField
attribute:NSLayoutAttributeBottom
relatedBy:NSLayoutRelationEqual
toItem:self.trailingItemField
attribute:NSLayoutAttributeTop
multiplier:1.0
constant:0].active = YES;
NSDictionary *viewsBindings = NSDictionaryOfVariableBindings(_navigationBar, _leadingItemField,
_titleField, _trailingItemField);
[NSLayoutConstraint
activateConstraints:[NSLayoutConstraint constraintsWithVisualFormat:@"H:|[_navigationBar]|"
options:0
metrics:nil
views:viewsBindings]];
[NSLayoutConstraint
activateConstraints:[NSLayoutConstraint
constraintsWithVisualFormat:@"H:|-16-[_leadingItemField]-16-|"
options:0
metrics:nil
views:viewsBindings]];
[NSLayoutConstraint
activateConstraints:[NSLayoutConstraint
constraintsWithVisualFormat:@"H:|-16-[_titleField]-16-|"
options:0
metrics:nil
views:viewsBindings]];
[NSLayoutConstraint
activateConstraints:[NSLayoutConstraint
constraintsWithVisualFormat:@"H:|-16-[_trailingItemField]-16-|"
options:0
metrics:nil
views:viewsBindings]];
}
- (BOOL)prefersStatusBarHidden {
return YES;
}
- (void)viewWillAppear:(BOOL)animated {
[super viewWillAppear:animated];
[self.navigationController setNavigationBarHidden:YES animated:animated];
}
- (void)didTapBackButton {
[self.navigationController popViewControllerAnimated:YES];
}
#pragma mark - <UITextFieldDelegate>
- (BOOL)textField:(UITextField *)textField
shouldChangeCharactersInRange:(NSRange)range
replacementString:(NSString *)string {
NSString *finishedString =
[textField.text stringByReplacingCharactersInRange:range withString:string];
// MDCNavigationBar doesn't handle BarButtonItems with no image and zero-length strings
if (finishedString.length == 0) {
finishedString = @" ";
}
if (textField == self.leadingItemField) {
NSMutableArray<UIBarButtonItem *> *leadingItems =
[self.navigationItem.leftBarButtonItems mutableCopy];
[leadingItems removeLastObject];
[leadingItems addObject:[[UIBarButtonItem alloc] initWithTitle:finishedString
style:UIBarButtonItemStylePlain
target:nil
action:nil]];
self.navigationItem.leftBarButtonItems = leadingItems;
} else if (textField == self.trailingItemField) {
// We need to allocate and reassign because MDCNavigationBar does not adjust its layout
// when the existing items change their title
self.navigationItem.rightBarButtonItem =
[[UIBarButtonItem alloc] initWithTitle:finishedString
style:UIBarButtonItemStylePlain
target:nil
action:nil];
} else if (textField == self.titleField) {
self.title = finishedString;
}
return YES;
}
@end
@implementation NavigationBarLayoutExample (CatalogByConvention)
+ (NSDictionary *)catalogMetadata {
return @{
@"breadcrumbs": @[ @"Navigation Bar", @"Navigation Bar Item Layout" ],
@"primaryDemo": @NO,
@"presentable": @NO,
};
}
- (BOOL)catalogShouldHideNavigation {
return YES;
}
@end