| Index: ios/chrome/browser/ui/collection_view/cells/collection_view_detail_item.mm
|
| diff --git a/ios/chrome/browser/ui/collection_view/cells/collection_view_detail_item.mm b/ios/chrome/browser/ui/collection_view/cells/collection_view_detail_item.mm
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..906b89219f74c0f80cd4b5de0302462a731fae8e
|
| --- /dev/null
|
| +++ b/ios/chrome/browser/ui/collection_view/cells/collection_view_detail_item.mm
|
| @@ -0,0 +1,169 @@
|
| +// Copyright 2016 The Chromium Authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#import "ios/chrome/browser/ui/collection_view/cells/collection_view_detail_item.h"
|
| +
|
| +#include <algorithm>
|
| +
|
| +#import "ios/third_party/material_components_ios/src/components/Palettes/src/MaterialPalettes.h"
|
| +#import "ios/third_party/material_roboto_font_loader_ios/src/src/MaterialRobotoFontLoader.h"
|
| +
|
| +#if !defined(__has_feature) || !__has_feature(objc_arc)
|
| +#error "This file requires ARC support."
|
| +#endif
|
| +
|
| +namespace {
|
| +
|
| +// Padding used on the leading and trailing edges of the cell and between the
|
| +// two labels.
|
| +const CGFloat kHorizontalPadding = 16;
|
| +
|
| +// Minimum proportion of the available width to guarantee to the main and detail
|
| +// labels.
|
| +const CGFloat kMinTextWidthRatio = 0.75f;
|
| +const CGFloat kMinDetailTextWidthRatio = 0.25f;
|
| +}
|
| +
|
| +@implementation CollectionViewDetailItem
|
| +
|
| +@synthesize accessoryType = _accessoryType;
|
| +@synthesize text = _text;
|
| +@synthesize detailText = _detailText;
|
| +
|
| +- (instancetype)initWithType:(NSInteger)type {
|
| + self = [super initWithType:type];
|
| + if (self) {
|
| + self.cellClass = [CollectionViewDetailCell class];
|
| + }
|
| + return self;
|
| +}
|
| +
|
| +#pragma mark CollectionViewItem
|
| +
|
| +- (void)configureCell:(CollectionViewDetailCell*)cell {
|
| + [super configureCell:cell];
|
| + cell.accessoryType = self.accessoryType;
|
| + cell.textLabel.text = self.text;
|
| + cell.detailTextLabel.text = self.detailText;
|
| +}
|
| +
|
| +@end
|
| +
|
| +@implementation CollectionViewDetailCell {
|
| + NSLayoutConstraint* _textLabelWidthConstraint;
|
| + NSLayoutConstraint* _detailTextLabelWidthConstraint;
|
| +}
|
| +
|
| +@synthesize textLabel = _textLabel;
|
| +@synthesize detailTextLabel = _detailTextLabel;
|
| +
|
| +- (instancetype)initWithFrame:(CGRect)frame {
|
| + self = [super initWithFrame:frame];
|
| + if (self) {
|
| + self.isAccessibilityElement = YES;
|
| + UIView* contentView = self.contentView;
|
| +
|
| + _textLabel = [[UILabel alloc] init];
|
| + _textLabel.translatesAutoresizingMaskIntoConstraints = NO;
|
| + _textLabel.backgroundColor = [UIColor clearColor];
|
| + [contentView addSubview:_textLabel];
|
| +
|
| + _textLabel.font =
|
| + [[MDFRobotoFontLoader sharedInstance] mediumFontOfSize:14];
|
| + _textLabel.textColor = [[MDCPalette greyPalette] tint900];
|
| +
|
| + _detailTextLabel = [[UILabel alloc] init];
|
| + _detailTextLabel.translatesAutoresizingMaskIntoConstraints = NO;
|
| + _detailTextLabel.backgroundColor = [UIColor clearColor];
|
| + [contentView addSubview:_detailTextLabel];
|
| +
|
| + _detailTextLabel.font =
|
| + [[MDFRobotoFontLoader sharedInstance] regularFontOfSize:14];
|
| + _detailTextLabel.textColor = [[MDCPalette greyPalette] tint500];
|
| +
|
| + // Set up the width constraints. They are activated here and updated in
|
| + // layoutSubviews.
|
| + _textLabelWidthConstraint =
|
| + [_textLabel.widthAnchor constraintEqualToConstant:0];
|
| + _detailTextLabelWidthConstraint =
|
| + [_detailTextLabel.widthAnchor constraintEqualToConstant:0];
|
| +
|
| + [NSLayoutConstraint activateConstraints:@[
|
| + // Fix the leading and trailing edges of the text labels.
|
| + [_textLabel.leadingAnchor
|
| + constraintEqualToAnchor:contentView.leadingAnchor
|
| + constant:kHorizontalPadding],
|
| + [_detailTextLabel.trailingAnchor
|
| + constraintEqualToAnchor:contentView.trailingAnchor
|
| + constant:-kHorizontalPadding],
|
| +
|
| + // Center the text label vertically and align the baselines of the two
|
| + // text labels.
|
| + [_textLabel.centerYAnchor
|
| + constraintEqualToAnchor:contentView.centerYAnchor],
|
| + [_detailTextLabel.firstBaselineAnchor
|
| + constraintEqualToAnchor:_textLabel.firstBaselineAnchor],
|
| +
|
| + _textLabelWidthConstraint,
|
| + _detailTextLabelWidthConstraint,
|
| + ]];
|
| + }
|
| + return self;
|
| +}
|
| +
|
| +// Updates the layout constraints of the text labels and then calls the
|
| +// superclass's implementation of layoutSubviews which can then take account of
|
| +// the new constraints.
|
| +- (void)layoutSubviews {
|
| + [super layoutSubviews];
|
| +
|
| + // Size the labels in order to determine how much width they want.
|
| + [self.textLabel sizeToFit];
|
| + [self.detailTextLabel sizeToFit];
|
| +
|
| + // Update the width constraints.
|
| + _textLabelWidthConstraint.constant = self.textLabelTargetWidth;
|
| + _detailTextLabelWidthConstraint.constant = self.detailTextLabelTargetWidth;
|
| +
|
| + // Now invoke the layout.
|
| + [super layoutSubviews];
|
| +}
|
| +
|
| +- (CGFloat)textLabelTargetWidth {
|
| + CGFloat availableWidth =
|
| + self.contentView.bounds.size.width - (3 * kHorizontalPadding);
|
| + CGFloat textLabelWidth = self.textLabel.frame.size.width;
|
| + CGFloat detailTextLabelWidth = self.detailTextLabel.frame.size.width;
|
| +
|
| + if (textLabelWidth + detailTextLabelWidth <= availableWidth)
|
| + return textLabelWidth;
|
| +
|
| + return std::max(
|
| + availableWidth - detailTextLabelWidth,
|
| + std::min(availableWidth * kMinTextWidthRatio, textLabelWidth));
|
| +}
|
| +
|
| +- (CGFloat)detailTextLabelTargetWidth {
|
| + CGFloat availableWidth =
|
| + self.contentView.bounds.size.width - (3 * kHorizontalPadding);
|
| + CGFloat textLabelWidth = self.textLabel.frame.size.width;
|
| + CGFloat detailTextLabelWidth = self.detailTextLabel.frame.size.width;
|
| +
|
| + if (textLabelWidth + detailTextLabelWidth <= availableWidth)
|
| + return detailTextLabelWidth;
|
| +
|
| + return std::max(availableWidth - textLabelWidth,
|
| + std::min(availableWidth * kMinDetailTextWidthRatio,
|
| + detailTextLabelWidth));
|
| +}
|
| +
|
| +- (NSString*)accessibilityLabel {
|
| + return self.textLabel.text;
|
| +}
|
| +
|
| +- (NSString*)accessibilityValue {
|
| + return self.detailTextLabel.text;
|
| +}
|
| +
|
| +@end
|
|
|