IOS-92: Enlarge post action buttons at larger text sizes (#927)

This commit is contained in:
Jed Fox 2023-03-20 03:39:11 -04:00 committed by GitHub
parent 2f458b7810
commit 414df3154a
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
3 changed files with 81 additions and 88 deletions

View File

@ -135,11 +135,6 @@ extension DataSourceFacade {
provider: provider, provider: provider,
status: status status: status
) )
case .bookmark:
try await DataSourceFacade.responseToStatusBookmarkAction(
provider: provider,
status: status
)
case .share: case .share:
try await DataSourceFacade.responseToStatusShareAction( try await DataSourceFacade.responseToStatusShareAction(
provider: provider, provider: provider,

View File

@ -558,7 +558,6 @@ extension StatusView.Style {
// action toolbar // action toolbar
statusView.actionToolbarAdaptiveMarginContainerView.contentView = statusView.actionToolbarContainer statusView.actionToolbarAdaptiveMarginContainerView.contentView = statusView.actionToolbarContainer
statusView.actionToolbarAdaptiveMarginContainerView.margin = StatusView.containerLayoutMargin statusView.actionToolbarAdaptiveMarginContainerView.margin = StatusView.containerLayoutMargin
statusView.actionToolbarContainer.configure(for: .inline)
statusView.containerStackView.addArrangedSubview(statusView.actionToolbarAdaptiveMarginContainerView) statusView.containerStackView.addArrangedSubview(statusView.actionToolbarAdaptiveMarginContainerView)
// filterHintLabel // filterHintLabel

View File

@ -35,7 +35,11 @@ public final class ActionToolbarContainer: UIView {
public weak var delegate: ActionToolbarContainerDelegate? public weak var delegate: ActionToolbarContainerDelegate?
private let container = UIStackView() private let container = UIStackView()
private var style: Style? private let firstContainer = UIStackView()
private let secondContainer = UIStackView()
private var isAccessibilityCategory: Bool?
private var shareButtonWidthConstraint: NSLayoutConstraint?
public override init(frame: CGRect) { public override init(frame: CGRect) {
super.init(frame: frame) super.init(frame: frame)
@ -65,27 +69,19 @@ extension ActionToolbarContainer {
reblogButton.addTarget(self, action: #selector(ActionToolbarContainer.buttonDidPressed(_:)), for: .touchUpInside) reblogButton.addTarget(self, action: #selector(ActionToolbarContainer.buttonDidPressed(_:)), for: .touchUpInside)
favoriteButton.addTarget(self, action: #selector(ActionToolbarContainer.buttonDidPressed(_:)), for: .touchUpInside) favoriteButton.addTarget(self, action: #selector(ActionToolbarContainer.buttonDidPressed(_:)), for: .touchUpInside)
shareButton.addTarget(self, action: #selector(ActionToolbarContainer.buttonDidPressed(_:)), for: .touchUpInside) shareButton.addTarget(self, action: #selector(ActionToolbarContainer.buttonDidPressed(_:)), for: .touchUpInside)
}
public func configure(for style: Style) {
guard needsConfigure(for: style) else {
return
}
self.style = style
container.arrangedSubviews.forEach { subview in
container.removeArrangedSubview(subview)
subview.removeFromSuperview()
}
let buttons = [replyButton, reblogButton, favoriteButton, shareButton] let buttons = [replyButton, reblogButton, favoriteButton, shareButton]
buttons.forEach { button in buttons.forEach { button in
button.tintColor = Asset.Colors.Button.actionToolbar.color button.tintColor = Asset.Colors.Button.actionToolbar.color
button.titleLabel?.font = .monospacedDigitSystemFont(ofSize: 12, weight: .regular) button.titleLabel?.font = UIFontMetrics(forTextStyle: .caption1)
.scaledFont(for: .monospacedDigitSystemFont(ofSize: 12, weight: .regular))
button.titleLabel?.adjustsFontForContentSizeCategory = true
button.setTitle("", for: .normal) button.setTitle("", for: .normal)
button.setTitleColor(.secondaryLabel, for: .normal) button.setTitleColor(.secondaryLabel, for: .normal)
button.expandEdgeInsets = UIEdgeInsets(top: -10, left: -10, bottom: -10, right: -10) button.expandEdgeInsets = UIEdgeInsets(top: -10, left: -10, bottom: -10, right: -10)
button.setInsets(forContentPadding: .zero, imageTitlePadding: style.buttonTitleImagePadding) button.setInsets(forContentPadding: .zero, imageTitlePadding: 4)
button.adjustsImageSizeForAccessibilityContentSizeCategory = true
button.setContentCompressionResistancePriority(.defaultHigh + 100, for: .horizontal)
} }
// add more expand for menu button // add more expand for menu button
shareButton.expandEdgeInsets = UIEdgeInsets(top: -10, left: -20, bottom: -10, right: -20) shareButton.expandEdgeInsets = UIEdgeInsets(top: -10, left: -20, bottom: -10, right: -20)
@ -95,8 +91,6 @@ extension ActionToolbarContainer {
favoriteButton.accessibilityLabel = L10n.Common.Controls.Status.Actions.favorite // needs update to follow state favoriteButton.accessibilityLabel = L10n.Common.Controls.Status.Actions.favorite // needs update to follow state
shareButton.accessibilityLabel = L10n.Common.Controls.Actions.share shareButton.accessibilityLabel = L10n.Common.Controls.Actions.share
switch style {
case .inline:
buttons.forEach { button in buttons.forEach { button in
button.contentHorizontalAlignment = .leading button.contentHorizontalAlignment = .leading
} }
@ -112,10 +106,22 @@ extension ActionToolbarContainer {
reblogButton.translatesAutoresizingMaskIntoConstraints = false reblogButton.translatesAutoresizingMaskIntoConstraints = false
favoriteButton.translatesAutoresizingMaskIntoConstraints = false favoriteButton.translatesAutoresizingMaskIntoConstraints = false
shareButton.translatesAutoresizingMaskIntoConstraints = false shareButton.translatesAutoresizingMaskIntoConstraints = false
container.addArrangedSubview(replyButton)
container.addArrangedSubview(reblogButton) firstContainer.translatesAutoresizingMaskIntoConstraints = false
container.addArrangedSubview(favoriteButton) firstContainer.axis = .horizontal
container.addArrangedSubview(shareButton) firstContainer.distribution = .equalSpacing
secondContainer.translatesAutoresizingMaskIntoConstraints = false
secondContainer.axis = .horizontal
secondContainer.distribution = .equalSpacing
shareButton.setContentHuggingPriority(.defaultHigh, for: .horizontal)
shareButton.setContentCompressionResistancePriority(.defaultHigh, for: .horizontal)
shareButtonWidthConstraint = replyButton.widthAnchor.constraint(equalTo: shareButton.widthAnchor)
traitCollectionDidChange(nil)
NSLayoutConstraint.activate([ NSLayoutConstraint.activate([
replyButton.heightAnchor.constraint(equalToConstant: 36).priority(.defaultHigh), replyButton.heightAnchor.constraint(equalToConstant: 36).priority(.defaultHigh),
replyButton.heightAnchor.constraint(equalTo: reblogButton.heightAnchor).priority(.defaultHigh), replyButton.heightAnchor.constraint(equalTo: reblogButton.heightAnchor).priority(.defaultHigh),
@ -124,32 +130,40 @@ extension ActionToolbarContainer {
replyButton.widthAnchor.constraint(equalTo: reblogButton.widthAnchor).priority(.defaultHigh), replyButton.widthAnchor.constraint(equalTo: reblogButton.widthAnchor).priority(.defaultHigh),
replyButton.widthAnchor.constraint(equalTo: favoriteButton.widthAnchor).priority(.defaultHigh), replyButton.widthAnchor.constraint(equalTo: favoriteButton.widthAnchor).priority(.defaultHigh),
]) ])
shareButton.setContentHuggingPriority(.defaultHigh, for: .horizontal)
shareButton.setContentCompressionResistancePriority(.defaultHigh, for: .horizontal)
case .plain:
buttons.forEach { button in
button.contentHorizontalAlignment = .center
} }
replyButton.setImage(ActionToolbarContainer.replyImage, for: .normal)
reblogButton.setImage(ActionToolbarContainer.reblogImage, for: .normal)
favoriteButton.setImage(ActionToolbarContainer.starImage, for: .normal)
public override func traitCollectionDidChange(_ previousTraitCollection: UITraitCollection?) {
super.traitCollectionDidChange(previousTraitCollection)
let isAccessibilityCategory = traitCollection.preferredContentSizeCategory.isAccessibilityCategory
guard isAccessibilityCategory != self.isAccessibilityCategory else { return }
self.isAccessibilityCategory = isAccessibilityCategory
if isAccessibilityCategory {
container.axis = .vertical
container.spacing = 12
firstContainer.addArrangedSubview(replyButton)
firstContainer.addArrangedSubview(reblogButton)
container.addArrangedSubview(firstContainer)
secondContainer.addArrangedSubview(favoriteButton)
secondContainer.addArrangedSubview(shareButton)
container.addArrangedSubview(secondContainer)
} else {
container.axis = .horizontal container.axis = .horizontal
container.spacing = 8 container.spacing = 0
container.distribution = .fillEqually
container.addArrangedSubview(replyButton) container.addArrangedSubview(replyButton)
container.addArrangedSubview(reblogButton) container.addArrangedSubview(reblogButton)
container.addArrangedSubview(favoriteButton) container.addArrangedSubview(favoriteButton)
} container.addArrangedSubview(shareButton)
}
private func needsConfigure(for style: Style) -> Bool { firstContainer.removeFromSuperview()
guard let oldStyle = self.style else { return true } secondContainer.removeFromSuperview()
return oldStyle != style }
shareButtonWidthConstraint!.isActive = isAccessibilityCategory
} }
} }
extension ActionToolbarContainer { extension ActionToolbarContainer {
@ -158,22 +172,9 @@ extension ActionToolbarContainer {
case reply case reply
case reblog case reblog
case like case like
case bookmark
case share case share
} }
public enum Style {
case inline
case plain
var buttonTitleImagePadding: CGFloat {
switch self {
case .inline: return 4.0
case .plain: return 0
}
}
}
private func isReblogButtonHighlightStateDidChange(to isHighlight: Bool) { private func isReblogButtonHighlightStateDidChange(to isHighlight: Bool) {
let tintColor = isHighlight ? Asset.Colors.successGreen.color : Asset.Colors.Button.actionToolbar.color let tintColor = isHighlight ? Asset.Colors.successGreen.color : Asset.Colors.Button.actionToolbar.color
reblogButton.tintColor = tintColor reblogButton.tintColor = tintColor
@ -302,9 +303,7 @@ struct ActionToolbarContainer_Previews: PreviewProvider {
static var previews: some View { static var previews: some View {
Group { Group {
UIViewPreview(width: 300) { UIViewPreview(width: 300) {
let toolbar = ActionToolbarContainer() ActionToolbarContainer()
toolbar.configure(for: .inline)
return toolbar
} }
.previewLayout(.fixed(width: 300, height: 44)) .previewLayout(.fixed(width: 300, height: 44))
.previewDisplayName("Inline") .previewDisplayName("Inline")