// Copyright 2016-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 #import "MaterialFlexibleHeader.h" @class FlexibleHeaderTypicalUseInstructionsView; @interface FlexibleHeaderTypicalUseViewController : UIViewController @property(nonatomic) MDCFlexibleHeaderViewController *fhvc; @property(nonatomic, strong) IBOutlet UIView *exampleView; @property(nonatomic, strong) UIScrollView *scrollView; @property(nonatomic, strong) IBOutlet UIImageView *imageView; @end @implementation FlexibleHeaderTypicalUseViewController - (instancetype)init { self = [super init]; if (self) { [self commonMDCFlexibleHeaderViewControllerInit]; } return self; } - (instancetype)initWithNibName:(NSString *)nibNameOrNil bundle:(NSBundle *)nibBundleOrNil { self = [super initWithNibName:nibNameOrNil bundle:nibBundleOrNil]; if (self) { [self commonMDCFlexibleHeaderViewControllerInit]; } return self; } - (instancetype)initWithCoder:(NSCoder *)aDecoder { self = [super initWithCoder:aDecoder]; if (self) { [self commonMDCFlexibleHeaderViewControllerInit]; } return self; } - (void)commonMDCFlexibleHeaderViewControllerInit { _fhvc = [[MDCFlexibleHeaderViewController alloc] initWithNibName:nil bundle:nil]; // Behavioral flags. _fhvc.topLayoutGuideAdjustmentEnabled = YES; _fhvc.inferTopSafeAreaInsetFromViewController = YES; _fhvc.headerView.minMaxHeightIncludesSafeArea = NO; [self addChildViewController:_fhvc]; } - (void)viewDidLoad { [super viewDidLoad]; self.scrollView = [[UIScrollView alloc] initWithFrame:self.view.bounds]; self.scrollView.autoresizingMask = UIViewAutoresizingFlexibleWidth | UIViewAutoresizingFlexibleHeight; [self.view addSubview:self.scrollView]; // If a tableView was being used instead of a scrollView, you would set the trackingScrollView // to be that tableView and either set the MDCFlexibleHeaderViewController to be the // UITableViewDelegate or forward the UIScrollViewDelegate methods to // MDCFlexibleHeaderViewController from the UITableViewDelegate. self.scrollView.delegate = self.fhvc; self.fhvc.headerView.trackingScrollView = self.scrollView; self.fhvc.view.frame = self.view.bounds; [self.view addSubview:self.fhvc.view]; [self.fhvc didMoveToParentViewController:self]; [self setupExampleViews]; } - (UIStatusBarStyle)preferredStatusBarStyle { return UIStatusBarStyleLightContent; } - (void)viewWillAppear:(BOOL)animated { [super viewWillAppear:animated]; [self.navigationController setNavigationBarHidden:YES animated:animated]; } // This method must be implemented for MDCFlexibleHeaderViewController's // MDCFlexibleHeaderView to properly support MDCFlexibleHeaderShiftBehavior should you choose // to customize it. - (UIViewController *)childViewControllerForStatusBarHidden { return self.fhvc; } #pragma mark - Supplemental - (void)setupExampleViews { NSBundle *bundle = [NSBundle bundleForClass:[FlexibleHeaderTypicalUseViewController class]]; [bundle loadNibNamed:@"FlexibleHeaderTypicalUseInstructionsView" owner:self options:nil]; self.imageView.image = [self.imageView.image imageWithRenderingMode:UIImageRenderingModeAlwaysTemplate]; [self.scrollView addSubview:self.exampleView]; self.view.backgroundColor = [UIColor whiteColor]; } - (void)viewDidLayoutSubviews { [super viewDidLayoutSubviews]; self.exampleView.frame = self.view.bounds; self.scrollView.contentSize = self.view.bounds.size; } @end @implementation FlexibleHeaderTypicalUseViewController (CatalogByConvention) + (NSDictionary *)catalogMetadata { return @{ @"breadcrumbs" : @[ @"Flexible Header", @"Flexible Header" ], @"description" : @"The Flexible Header is a container view whose height and vertical offset " @"react to UIScrollViewDelegate events.", @"primaryDemo" : @NO, @"presentable" : @NO, @"skip_snapshots" : @YES, // Crashing with "Could not load NIB in bundle: 'NSBundle <...> // (loaded)' with name 'FlexibleHeaderTypicalUseInstructionsView'" }; } - (BOOL)catalogShouldHideNavigation { return YES; } @end