mirror of
https://github.com/material-components/material-components-ios.git
synced 2026-02-20 08:27:32 +08:00
This PR graduates ContainerScheme to ready. This includes updating the podspecs, podfile, all the import statements related to ContainerScheme, updating .kokoro rewrite rules, and finally the readme to not have ContainerScheme regarded to as being in beta. Ran locally kokoro with -b bazel successfully. Resolves #6732
131 lines
4.6 KiB
Swift
131 lines
4.6 KiB
Swift
// 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 Foundation
|
|
import UIKit
|
|
|
|
import MaterialComponents.MaterialButtons
|
|
import MaterialComponents.MaterialContainerScheme
|
|
import MaterialComponentsBeta.MaterialButtons_Theming
|
|
|
|
class ButtonsSimpleExampleSwiftViewController: UIViewController {
|
|
|
|
let floatingButtonPlusDimension = CGFloat(24)
|
|
let kMinimumAccessibleButtonSize = CGSize(width: 64, height: 48)
|
|
|
|
var containerScheme = MDCContainerScheme()
|
|
|
|
override func viewDidLoad() {
|
|
super.viewDidLoad()
|
|
|
|
view.backgroundColor = UIColor(white: 0.9, alpha: 1.0)
|
|
//let titleColor = UIColor.white
|
|
let backgroundColor = UIColor(white: 0.1, alpha: 1.0)
|
|
|
|
let containedButton = MDCButton()
|
|
containedButton.applyContainedTheme(withScheme: containerScheme)
|
|
containedButton.setTitle("Tap Me Too", for: UIControl.State())
|
|
containedButton.sizeToFit()
|
|
let containedButtonVerticalInset =
|
|
min(0, -(kMinimumAccessibleButtonSize.height - containedButton.bounds.height) / 2);
|
|
let containedButtonHorizontalInset =
|
|
min(0, -(kMinimumAccessibleButtonSize.width - containedButton.bounds.width) / 2);
|
|
containedButton.hitAreaInsets =
|
|
UIEdgeInsets(top: containedButtonVerticalInset, left: containedButtonHorizontalInset,
|
|
bottom: containedButtonVerticalInset, right: containedButtonHorizontalInset)
|
|
containedButton.translatesAutoresizingMaskIntoConstraints = false
|
|
containedButton.addTarget(self, action: #selector(tap), for: .touchUpInside)
|
|
view.addSubview(containedButton)
|
|
|
|
let textButton = MDCButton()
|
|
textButton.applyTextTheme(withScheme: MDCContainerScheme())
|
|
textButton.setTitle("Touch me", for: UIControl.State())
|
|
textButton.sizeToFit()
|
|
let textButtonVerticalInset =
|
|
min(0, -(kMinimumAccessibleButtonSize.height - textButton.bounds.height) / 2);
|
|
let textButtonHorizontalInset =
|
|
min(0, -(kMinimumAccessibleButtonSize.width - textButton.bounds.width) / 2);
|
|
textButton.hitAreaInsets =
|
|
UIEdgeInsets(top: textButtonVerticalInset, left: textButtonHorizontalInset,
|
|
bottom: textButtonVerticalInset, right: textButtonHorizontalInset)
|
|
textButton.translatesAutoresizingMaskIntoConstraints = false
|
|
textButton.addTarget(self, action: #selector(tap), for: .touchUpInside)
|
|
view.addSubview(textButton)
|
|
|
|
let floatingButton = MDCFloatingButton()
|
|
floatingButton.backgroundColor = backgroundColor
|
|
floatingButton.sizeToFit()
|
|
floatingButton.translatesAutoresizingMaskIntoConstraints = false
|
|
floatingButton.addTarget(self, action: #selector(tap), for: .touchUpInside)
|
|
|
|
let plusShapeLayer = ButtonsTypicalUseSupplemental.createPlusShapeLayer(floatingButton)
|
|
floatingButton.layer.addSublayer(plusShapeLayer)
|
|
floatingButton.accessibilityLabel = "Create"
|
|
|
|
view.addSubview(floatingButton)
|
|
|
|
let views = [
|
|
"contained": containedButton,
|
|
"text": textButton,
|
|
"floating": floatingButton
|
|
]
|
|
|
|
centerView(view: textButton, onView: self.view)
|
|
|
|
view.addConstraints(
|
|
NSLayoutConstraint.constraints(withVisualFormat: "V:[contained]-40-[text]-40-[floating]",
|
|
options: .alignAllCenterX,
|
|
metrics: nil,
|
|
views: views))
|
|
}
|
|
|
|
// MARK: Private
|
|
|
|
private func centerView(view: UIView, onView: UIView) {
|
|
onView.addConstraint(NSLayoutConstraint(
|
|
item: view,
|
|
attribute: .centerX,
|
|
relatedBy: .equal,
|
|
toItem: onView,
|
|
attribute: .centerX,
|
|
multiplier: 1.0,
|
|
constant: 0.0))
|
|
|
|
onView.addConstraint(NSLayoutConstraint(
|
|
item: view,
|
|
attribute: .centerY,
|
|
relatedBy: .equal,
|
|
toItem: onView,
|
|
attribute: .centerY,
|
|
multiplier: 1.0,
|
|
constant: -20.0))
|
|
}
|
|
|
|
@objc func tap(_ sender: Any) {
|
|
print("\(type(of: sender)) was tapped.")
|
|
}
|
|
|
|
}
|
|
|
|
extension ButtonsSimpleExampleSwiftViewController {
|
|
|
|
@objc class func catalogMetadata() -> [String: Any] {
|
|
return [
|
|
"breadcrumbs": ["Buttons", "Buttons (Swift)"],
|
|
"primaryDemo": false,
|
|
"presentable": false,
|
|
]
|
|
}
|
|
}
|