blob: b9737b08e1c56411fda016cec9fdab685e1bf066 [file] [log] [blame]
// Copyright 2021-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 Foundation
import MaterialComponents.MaterialBottomSheet
import MaterialComponents.MaterialButtons
import MaterialComponents.MaterialButtons_Theming
import MaterialComponents.MaterialContainerScheme
class BottomSheetKeyboardBehaviorExample: UIViewController {
@objc var containerScheme = MDCContainerScheme()
var pushBottomSheetUpWhenKeyboardShows = true
override func viewDidLoad() {
super.viewDidLoad()
view.backgroundColor = containerScheme.colorScheme.backgroundColor
let presentButton = MDCButton()
presentButton.setTitle("Show bottom sheet", for: .normal)
presentButton.applyContainedTheme(withScheme: containerScheme)
presentButton.addTarget(
self,
action: #selector(didTapPresentButton),
for: .touchUpInside)
presentButton.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(presentButton)
let toggleBehaviorButton = MDCButton()
toggleBehaviorButton.setTitle("Toggle keyboard behavior", for: .normal)
toggleBehaviorButton.applyContainedTheme(withScheme: containerScheme)
toggleBehaviorButton.addTarget(
self,
action: #selector(didTapToggleBehaviorButton),
for: .touchUpInside)
toggleBehaviorButton.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(toggleBehaviorButton)
NSLayoutConstraint.activate([
presentButton.centerXAnchor.constraint(equalTo: self.view.centerXAnchor),
presentButton.centerYAnchor.constraint(equalTo: self.view.centerYAnchor),
toggleBehaviorButton.centerXAnchor.constraint(equalTo: presentButton.centerXAnchor),
toggleBehaviorButton.bottomAnchor.constraint(equalTo: presentButton.topAnchor, constant: -20),
])
}
@objc func didTapPresentButton(_ sender: MDCFloatingButton) {
let textFieldContent = BottomSheetWithUITextField()
let bottomSheet = MDCBottomSheetController(contentViewController: textFieldContent)
bottomSheet.ignoreKeyboardHeight = !pushBottomSheetUpWhenKeyboardShows
present(bottomSheet, animated: true)
}
@objc func didTapToggleBehaviorButton(_ sender: MDCFloatingButton) {
pushBottomSheetUpWhenKeyboardShows = !pushBottomSheetUpWhenKeyboardShows
}
}
class BottomSheetWithUITextField: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
view.backgroundColor = .white
let textField = UITextField()
textField.borderStyle = .roundedRect
textField.placeholder = "Type here"
textField.translatesAutoresizingMaskIntoConstraints = false
view.addSubview(textField)
NSLayoutConstraint.activate([
textField.widthAnchor.constraint(equalToConstant: 200),
textField.heightAnchor.constraint(equalToConstant: 40),
textField.centerXAnchor.constraint(equalTo: self.view.centerXAnchor),
textField.centerYAnchor.constraint(equalTo: self.view.centerYAnchor),
])
}
}
// MARK: Catalog by convention
extension BottomSheetKeyboardBehaviorExample {
@objc class func catalogMetadata() -> [String: Any] {
return [
"breadcrumbs": ["Bottom Sheet", "Keyboard behavior"],
"primaryDemo": false,
"presentable": true,
]
}
}