chromium/ios/chrome/browser/ntp/ui_bundled/feed_header_view_controller.h

// Copyright 2021 The Chromium Authors
// Use of this source code is governed by a BSD-style license that can be
// found in the LICENSE file.

#ifndef IOS_CHROME_BROWSER_NTP_UI_BUNDLED_FEED_HEADER_VIEW_CONTROLLER_H_
#define IOS_CHROME_BROWSER_NTP_UI_BUNDLED_FEED_HEADER_VIEW_CONTROLLER_H_

#import <UIKit/UIKit.h>

#import "ios/chrome/browser/discover_feed/model/feed_constants.h"

@protocol FeedControlDelegate;
@protocol FeedMenuCommands;
@class FeedMetricsRecorder;
@protocol NewTabPageDelegate;

@interface FeedHeaderViewController : UIViewController

// Button for opening top-level feed management menu.
@property(nonatomic, readonly, strong) UIButton* managementButton;

// Delegate for controlling the presented feed.
@property(nonatomic, weak) id<FeedControlDelegate> feedControlDelegate;

// Delegate to communicate back to the New Tab Page coordinator.
@property(nonatomic, weak) id<NewTabPageDelegate> NTPDelegate;

// The currently selected sorting for the Following feed.
@property(nonatomic, assign) FollowingFeedSortType followingFeedSortType;

// Feed metrics recorder.
@property(nonatomic, weak) FeedMetricsRecorder* feedMetricsRecorder;

// Object that can open the feed menu.
@property(nonatomic, weak) id<FeedMenuCommands> feedMenuHandler;

// Initializes header with the Following segment dot visibility as
// `followingDotVisible`.
- (instancetype)initWithFollowingDotVisible:(BOOL)followingDotVisible
    NS_DESIGNATED_INITIALIZER;

- (instancetype)init NS_UNAVAILABLE;
- (instancetype)initWithNibName:(NSString*)nibNameOrNil
                         bundle:(NSBundle*)nibBundleOrNil NS_UNAVAILABLE;
- (instancetype)initWithCoder:(NSCoder*)aDecoder NS_UNAVAILABLE;

// Toggles the feed header's background blur. Animates the transition if
// `animated` is YES.
- (void)toggleBackgroundBlur:(BOOL)blurred animated:(BOOL)animated;

// Returns the height of the feed header.
- (CGFloat)feedHeaderHeight;

// Returns the height of the custom search engine view. Returns 0 if it is not
// visible.
- (CGFloat)customSearchEngineViewHeight;

// Updates the unseen content dot in the Following segment. Will only show the
// dot if there is unseen content and if the user is not currently on the
// Following feed.
- (void)updateFollowingDotForUnseenContent:(BOOL)hasUnseenContent;

// Updates the header view and re-applies constraints in response to the default
// search engine changing.
- (void)updateForDefaultSearchEngineChanged;

// Updates the header for when the user turns the feed off from the header menu.
- (void)updateForFeedVisibilityChanged;

// Updates the header for when the Following Feed visibility has changed.
- (void)updateForFollowingFeedVisibilityChanged;

// Updates the segmented control and sort button for the current feed type.
- (void)updateForSelectedFeed;

@end

#endif  // IOS_CHROME_BROWSER_NTP_UI_BUNDLED_FEED_HEADER_VIEW_CONTROLLER_H_