diff --git a/.swiftlint.yml b/.swiftlint.yml index f78e62541..117242117 100644 --- a/.swiftlint.yml +++ b/.swiftlint.yml @@ -26,7 +26,7 @@ disabled_rules: - type_body_length - line_length - type_name - + - vertical_parameter_alignment custom_rules: empty_line_after_guard_statement: included: ".*\\.swift" diff --git a/ownCloud/Bookmarks/BookmarkViewController.swift b/ownCloud/Bookmarks/BookmarkViewController.swift index 26497f3f2..e2a7e02c5 100644 --- a/ownCloud/Bookmarks/BookmarkViewController.swift +++ b/ownCloud/Bookmarks/BookmarkViewController.swift @@ -74,7 +74,7 @@ class BookmarkViewController: StaticTableViewController { if let textField = sender as? UITextField { self?.bookmark?.name = (textField.text?.count == 0) ? nil : textField.text } - }, placeholder: "Name".localized, identifier: "row-name-name") + }, placeholder: "Name".localized, identifier: "row-name-name", accessibilityLabel: "Server name".localized) nameSection = StaticTableViewSection(headerTitle: "Name".localized, footerTitle: nil, identifier: "section-name", rows: [ nameRow! ]) @@ -116,7 +116,7 @@ class BookmarkViewController: StaticTableViewController { self?.nameRow?.textField?.attributedPlaceholder = NSAttributedString(string: placeholderString, attributes: [.foregroundColor : Theme.shared.activeCollection.tableRowColors.secondaryLabelColor]) } - }, placeholder: "https://", keyboardType: .URL, autocorrectionType: .no, identifier: "row-url-url") + }, placeholder: "https://", keyboardType: .URL, autocorrectionType: .no, identifier: "row-url-url", accessibilityLabel: "Sever url".localized) certificateRow = StaticTableViewRow(rowWithAction: { [weak self] (_, _) in if let certificate = self?.bookmark?.certificate { @@ -136,14 +136,14 @@ class BookmarkViewController: StaticTableViewController { self?.bookmark?.authenticationData = nil self?.composeSectionsAndRows(animated: true) } - }, placeholder: "Username".localized, autocorrectionType: .no, identifier: "row-credentials-username") + }, placeholder: "Username".localized, autocorrectionType: .no, identifier: "row-credentials-username", accessibilityLabel: "Server Username".localized) passwordRow = StaticTableViewRow(secureTextFieldWithAction: { [weak self] (_, sender) in if (sender as? UITextField) != nil, self?.bookmark?.authenticationData != nil { self?.bookmark?.authenticationData = nil self?.composeSectionsAndRows(animated: true) } - }, placeholder: "Password".localized, autocorrectionType: .no, identifier: "row-credentials-password") + }, placeholder: "Password".localized, autocorrectionType: .no, identifier: "row-credentials-password", accessibilityLabel: "Server Password".localized) addPasswordManagerButton() diff --git a/ownCloud/Client/Actions/NamingViewController.swift b/ownCloud/Client/Actions/NamingViewController.swift index 2b963c6ec..386c6f735 100644 --- a/ownCloud/Client/Actions/NamingViewController.swift +++ b/ownCloud/Client/Actions/NamingViewController.swift @@ -174,6 +174,7 @@ class NamingViewController: UIViewController { nameTextField.addTarget(self, action: #selector(textfieldDidChange(_:)), for: .editingChanged) nameTextField.enablesReturnKeyAutomatically = true nameTextField.autocorrectionType = .no + nameTextField.accessibilityLabel = "Folder name".localized // Name container view nameContainer.translatesAutoresizingMaskIntoConstraints = false diff --git a/ownCloud/Client/ClientItemCell.swift b/ownCloud/Client/ClientItemCell.swift index 91dc9b1ff..b474f1691 100644 --- a/ownCloud/Client/ClientItemCell.swift +++ b/ownCloud/Client/ClientItemCell.swift @@ -54,8 +54,11 @@ class ClientItemCell: ThemeTableViewCell { iconView.contentMode = .scaleAspectFit moreButton.translatesAutoresizingMaskIntoConstraints = false - titleLabel.font = UIFont.systemFont(ofSize: 17, weight: UIFont.Weight.semibold) - detailLabel.font = UIFont.systemFont(ofSize: 14) + titleLabel.font = UIFont.preferredFont(forTextStyle: .headline) + titleLabel.adjustsFontForContentSizeCategory = true + + detailLabel.font = UIFont.preferredFont(forTextStyle: .footnote) + detailLabel.adjustsFontForContentSizeCategory = true detailLabel.textColor = UIColor.gray @@ -69,7 +72,8 @@ class ClientItemCell: ThemeTableViewCell { iconView.rightAnchor.constraint(equalTo: detailLabel.leftAnchor, constant: -15).isActive = true moreButton.setAttributedTitle(NSAttributedString(string: "● ● ●", attributes: - [NSAttributedString.Key.font: UIFont.systemFont(ofSize: 10)]), for: .normal) + [NSAttributedString.Key.font: UIFont.preferredFont(forTextStyle: .caption2)]), for: .normal) + moreButton.titleLabel?.adjustsFontForContentSizeCategory = true moreButton.contentMode = .scaleToFill @@ -168,6 +172,7 @@ class ClientItemCell: ThemeTableViewCell { self.iconView.alpha = item.isPlaceholder ? 0.5 : 1.0 self.moreButton.isHidden = item.isPlaceholder ? true : false + self.moreButton.accessibilityLabel = item.name! + " " + "Actions".localized } // MARK: - Themeing diff --git a/ownCloud/Client/ClientQueryViewController.swift b/ownCloud/Client/ClientQueryViewController.swift index 40250ccf1..d2615cbbb 100644 --- a/ownCloud/Client/ClientQueryViewController.swift +++ b/ownCloud/Client/ClientQueryViewController.swift @@ -147,6 +147,7 @@ class ClientQueryViewController: UITableViewController, Themeable { self.tableView.dragInteractionEnabled = true let actionsBarButton: UIBarButtonItem = UIBarButtonItem(barButtonSystemItem: .add, target: self, action: #selector(uploadsBarButtonPressed)) + actionsBarButton.accessibilityLabel = "Upload files".localized self.navigationItem.rightBarButtonItem = actionsBarButton } diff --git a/ownCloud/Client/SortBar.swift b/ownCloud/Client/SortBar.swift index 3cb118534..10bb3413e 100644 --- a/ownCloud/Client/SortBar.swift +++ b/ownCloud/Client/SortBar.swift @@ -32,6 +32,9 @@ class SortBar: UIView, Themeable { weak var delegate: SortBarDelegate? + // MARK: - Constants + let sideButtonsSize: CGSize = CGSize(width: 30.0, height: 30.0) + // MARK: - Instance variables. var stackView: UIStackView @@ -50,6 +53,7 @@ class SortBar: UIView, Themeable { let title = NSString(format: "Sorted by %@ ▼".localized as NSString, sortMethod.localizedName()) as String sortButton.setTitle(title, for: .normal) + sortButton.accessibilityLabel = NSString(format: "Sorted by %@".localized as NSString, sortMethod.localizedName()) as String sortSegmentedControl.selectedSegmentIndex = SortMethod.all.index(of: sortMethod)! @@ -72,9 +76,10 @@ class SortBar: UIView, Themeable { sortButton = ThemeButton() sortButton.accessibilityIdentifier = "sort-bar.sortButton" - leftButtonImage = Theme.shared.image(for: "folder-create", size: CGSize(width: 30.0, height: 30.0))!.withRenderingMode(.alwaysTemplate) + leftButtonImage = Theme.shared.image(for: "folder-create", size: sideButtonsSize)!.withRenderingMode(.alwaysTemplate) + leftButton.accessibilityLabel = "Create Folder".localized - rightButtonImage = Theme.shared.image(for: "folder-create", size: CGSize(width: 30.0, height: 30.0))!.withRenderingMode(.alwaysTemplate) + rightButtonImage = Theme.shared.image(for: "folder-create", size: sideButtonsSize)!.withRenderingMode(.alwaysTemplate) self.sortMethod = sortMethod diff --git a/ownCloud/Resources/en.lproj/Localizable.strings b/ownCloud/Resources/en.lproj/Localizable.strings index 002c34915..10819405c 100644 --- a/ownCloud/Resources/en.lproj/Localizable.strings +++ b/ownCloud/Resources/en.lproj/Localizable.strings @@ -43,6 +43,10 @@ "Missing hostname" = "Missing hostname"; "The entered URL does not include a hostname." = "The entered URL does not include a hostname."; +"Add server" = "Add server"; +"Sever name" = "Sever name"; +"Server Password" = "Server Password"; +"Server Username" = "Server Username"; /* Client */ "Browse" = "Browse"; @@ -60,6 +64,7 @@ "Everything up-to-date." = "Everything up-to-date."; "Please wait…" = "Please wait…"; "Sorted by %@ ▼" = "Sorted by %@ ▼"; +"Sorted by %@" = "Sorted by %@"; "Sort by" = "Sort by"; "name (A-Z)" = "name (A-Z)"; @@ -86,6 +91,7 @@ "This permission is needed to upload photos and videos from your photo library." = "This permission is needed to upload photos and videos from your photo library."; "Not now" = "Not now"; "Upload file" = "Upload file"; +"Upload files" = "Upload files"; /* Server List*/ "Cancel" = "Cancel"; @@ -189,6 +195,7 @@ "Forbidden Characters" = "Forbidden Characters"; "File name cannot contain / or \\" = "File name cannot contain / or \\"; "New Folder" = "New Folder"; +"Folder name" = "Folder name"; "Rename" =" Rename"; "Create folder" =" Create folder"; "Duplicate" = "Duplicate"; @@ -198,6 +205,7 @@ "Copy here" = "Copy here"; "Cannot connect to " = "Cannot connect to "; " couldn't download this file" = " couldn't download this file"; +"Actions" = "Actions"; /* Directory Picker Messages */ "Move here" = "Move here"; diff --git a/ownCloud/Server List/ServerListBookmarkCell.swift b/ownCloud/Server List/ServerListBookmarkCell.swift index cd8bc4807..21500bdea 100644 --- a/ownCloud/Server List/ServerListBookmarkCell.swift +++ b/ownCloud/Server List/ServerListBookmarkCell.swift @@ -40,8 +40,11 @@ class ServerListBookmarkCell : ThemeTableViewCell { iconView.translatesAutoresizingMaskIntoConstraints = false iconView.contentMode = .scaleAspectFit - titleLabel.font = UIFont.systemFont(ofSize: 17, weight: UIFont.Weight.semibold) - detailLabel.font = UIFont.systemFont(ofSize: 14) + titleLabel.font = UIFont.preferredFont(forTextStyle: .headline) + titleLabel.adjustsFontForContentSizeCategory = true + + detailLabel.font = UIFont.preferredFont(forTextStyle: .subheadline) + detailLabel.adjustsFontForContentSizeCategory = true detailLabel.textColor = UIColor.gray diff --git a/ownCloud/Server List/ServerListTableViewController.swift b/ownCloud/Server List/ServerListTableViewController.swift index 95225c59e..7b1fdbe21 100644 --- a/ownCloud/Server List/ServerListTableViewController.swift +++ b/ownCloud/Server List/ServerListTableViewController.swift @@ -72,7 +72,9 @@ class ServerListTableViewController: UITableViewController, Themeable { self.tableView.estimatedRowHeight = 80 self.tableView.allowsSelectionDuringEditing = true - self.navigationItem.rightBarButtonItem = UIBarButtonItem(barButtonSystemItem: UIBarButtonItem.SystemItem.add, target: self, action: #selector(addBookmark)) + let addServerBarButtonItem = UIBarButtonItem(barButtonSystemItem: UIBarButtonItem.SystemItem.add, target: self, action: #selector(addBookmark)) + addServerBarButtonItem.accessibilityLabel = "Add Server".localized + self.navigationItem.rightBarButtonItem = addServerBarButtonItem welcomeOverlayView.translatesAutoresizingMaskIntoConstraints = false diff --git a/ownCloud/Theming/NSObject+ThemeApplication.swift b/ownCloud/Theming/NSObject+ThemeApplication.swift index 5a3c0b287..0532d7a38 100644 --- a/ownCloud/Theming/NSObject+ThemeApplication.swift +++ b/ownCloud/Theming/NSObject+ThemeApplication.swift @@ -154,7 +154,8 @@ extension NSObject { case .bigMessage: label.font = UIFont.systemFont(ofSize: 17) - default: break + default: + break } switch itemState { diff --git a/ownCloud/Theming/UI/ThemeButton.swift b/ownCloud/Theming/UI/ThemeButton.swift index dd92b83e0..9bba19174 100644 --- a/ownCloud/Theming/UI/ThemeButton.swift +++ b/ownCloud/Theming/UI/ThemeButton.swift @@ -86,7 +86,8 @@ class ThemeButton : UIButton { private func styleButton() { self.layer.cornerRadius = 5 - self.titleLabel!.font = UIFont.systemFont(ofSize: 16, weight: UIFont.Weight.semibold) + self.titleLabel!.font = UIFont.preferredFont(forTextStyle: .headline) + self.titleLabel!.adjustsFontForContentSizeCategory = true } override init(frame: CGRect) { diff --git a/ownCloud/UI Elements/StaticTableViewRow.swift b/ownCloud/UI Elements/StaticTableViewRow.swift index 0f298d6ae..2edf03747 100644 --- a/ownCloud/UI Elements/StaticTableViewRow.swift +++ b/ownCloud/UI Elements/StaticTableViewRow.swift @@ -7,14 +7,14 @@ // /* - * Copyright (C) 2018, ownCloud GmbH. - * - * This code is covered by the GNU Public License Version 3. - * - * For distribution utilizing Apple mechanisms please see https://owncloud.org/contribute/iOS-license-exception/ - * You should have received a copy of this license along with this program. If not, see . - * - */ +* Copyright (C) 2018, ownCloud GmbH. +* +* This code is covered by the GNU Public License Version 3. +* +* For distribution utilizing Apple mechanisms please see https://owncloud.org/contribute/iOS-license-exception/ +* You should have received a copy of this license along with this program. If not, see . +* +*/ import UIKit @@ -151,7 +151,10 @@ class StaticTableViewRow : NSObject, UITextFieldDelegate { // MARK: - Text Field public var textField : UITextField? - convenience init(textFieldWithAction action: StaticTableViewRowAction?, placeholder placeholderString: String = "", value textValue: String = "", secureTextEntry : Bool = false, keyboardType: UIKeyboardType = UIKeyboardType.default, autocorrectionType: UITextAutocorrectionType = UITextAutocorrectionType.default, autocapitalizationType: UITextAutocapitalizationType = UITextAutocapitalizationType.none, enablesReturnKeyAutomatically: Bool = true, returnKeyType : UIReturnKeyType = UIReturnKeyType.default, identifier : String? = nil) { + convenience init(textFieldWithAction action: StaticTableViewRowAction?, placeholder placeholderString: String = "", value textValue: String = "", + secureTextEntry : Bool = false, keyboardType: UIKeyboardType = UIKeyboardType.default, autocorrectionType: UITextAutocorrectionType = UITextAutocorrectionType.default, + autocapitalizationType: UITextAutocapitalizationType = UITextAutocapitalizationType.none, enablesReturnKeyAutomatically: Bool = true, + returnKeyType : UIReturnKeyType = UIReturnKeyType.default, identifier : String? = nil, accessibilityLabel: String? = nil) { self.init() @@ -203,17 +206,23 @@ class StaticTableViewRow : NSObject, UITextFieldDelegate { cellTextField.textColor = (self?.enabled == true) ? themeCollection.tableRowColors.labelColor : themeCollection.tableRowColors.secondaryLabelColor cellTextField.attributedPlaceholder = NSAttributedString(string: placeholderString, attributes: [.foregroundColor : themeCollection.tableRowColors.secondaryLabelColor]) }) + + cellTextField.accessibilityLabel = accessibilityLabel } - convenience init(secureTextFieldWithAction action: StaticTableViewRowAction?, placeholder placeholderString: String = "", value textValue: String = "", keyboardType: UIKeyboardType = UIKeyboardType.default, autocorrectionType: UITextAutocorrectionType = UITextAutocorrectionType.default, autocapitalizationType: UITextAutocapitalizationType = UITextAutocapitalizationType.none, enablesReturnKeyAutomatically: Bool = true, returnKeyType : UIReturnKeyType = UIReturnKeyType.default, identifier : String? = nil) { + convenience init(secureTextFieldWithAction action: StaticTableViewRowAction?, placeholder placeholderString: String = "", value textValue: String = "", + keyboardType: UIKeyboardType = UIKeyboardType.default, autocorrectionType: UITextAutocorrectionType = UITextAutocorrectionType.default, + autocapitalizationType: UITextAutocapitalizationType = UITextAutocapitalizationType.none, enablesReturnKeyAutomatically: Bool = true, + returnKeyType : UIReturnKeyType = UIReturnKeyType.default, identifier : String? = nil, accessibilityLabel: String? = nil) { self.init(textFieldWithAction: action, - placeholder: placeholderString, - value: textValue, secureTextEntry: true, - keyboardType: keyboardType, - autocorrectionType: autocorrectionType, - autocapitalizationType: autocapitalizationType, - enablesReturnKeyAutomatically: enablesReturnKeyAutomatically, - returnKeyType: returnKeyType, identifier : identifier) + placeholder: placeholderString, + value: textValue, secureTextEntry: true, + keyboardType: keyboardType, + autocorrectionType: autocorrectionType, + autocapitalizationType: autocapitalizationType, + enablesReturnKeyAutomatically: enablesReturnKeyAutomatically, + returnKeyType: returnKeyType, identifier : identifier, + accessibilityLabel: accessibilityLabel) } @objc func textFieldContentChanged(_ sender: UITextField) { @@ -303,28 +312,28 @@ class StaticTableViewRow : NSObject, UITextFieldDelegate { var textColor, selectedTextColor, backgroundColor, selectedBackgroundColor : UIColor? switch style { - case .plain: - textColor = themeCollection.tintColor - backgroundColor = themeCollection.tableRowColors.backgroundColor + case .plain: + textColor = themeCollection.tintColor + backgroundColor = themeCollection.tableRowColors.backgroundColor - case .plainNonOpaque: - textColor = themeCollection.tableRowColors.tintColor - backgroundColor = themeCollection.tableRowColors.backgroundColor + case .plainNonOpaque: + textColor = themeCollection.tableRowColors.tintColor + backgroundColor = themeCollection.tableRowColors.backgroundColor - case .proceed: - textColor = themeCollection.neutralColors.normal.foreground - backgroundColor = themeCollection.neutralColors.normal.background - selectedBackgroundColor = themeCollection.neutralColors.highlighted.background + case .proceed: + textColor = themeCollection.neutralColors.normal.foreground + backgroundColor = themeCollection.neutralColors.normal.background + selectedBackgroundColor = themeCollection.neutralColors.highlighted.background - case .destructive: - textColor = UIColor.red - backgroundColor = themeCollection.tableRowColors.backgroundColor + case .destructive: + textColor = UIColor.red + backgroundColor = themeCollection.tableRowColors.backgroundColor - case let .custom(customTextColor, customSelectedTextColor, customBackgroundColor, customSelectedBackgroundColor): - textColor = customTextColor - selectedTextColor = customSelectedTextColor - backgroundColor = customBackgroundColor - selectedBackgroundColor = customSelectedBackgroundColor + case let .custom(customTextColor, customSelectedTextColor, customBackgroundColor, customSelectedBackgroundColor): + textColor = customTextColor + selectedTextColor = customSelectedTextColor + backgroundColor = customBackgroundColor + selectedBackgroundColor = customSelectedBackgroundColor } @@ -347,7 +356,7 @@ class StaticTableViewRow : NSObject, UITextFieldDelegate { self?.cell?.selectedBackgroundView? = selectedBackgroundView } - }, applyImmediately: true) + }, applyImmediately: true) self.action = action } diff --git a/ownCloud/Viewer/DisplayViewController.swift b/ownCloud/Viewer/DisplayViewController.swift index 74e32f8fd..0dccdada4 100644 --- a/ownCloud/Viewer/DisplayViewController.swift +++ b/ownCloud/Viewer/DisplayViewController.swift @@ -41,6 +41,10 @@ protocol DisplayViewEditingDelegate: class { class DisplayViewController: UIViewController { private let iconImageSize: CGSize = CGSize(width: 200.0, height: 200.0) + private let bottomMarginToYAxis: CGFloat = -60.0 + private let verticalSpacing: CGFloat = 10.0 + private let lateralSpacing: CGFloat = 10 + private let progressViewVerticalSpacing: CGFloat = 20.0 // MARK: - Configuration weak var item: OCItem! @@ -55,6 +59,7 @@ class DisplayViewController: UIViewController { OnMainThread { self.iconImageView.isHidden = true } + hideItemMetadataUIElements() renderSpecificView() } } @@ -79,9 +84,9 @@ class DisplayViewController: UIViewController { // MARK: - Views private var iconImageView: UIImageView! private var progressView : UIProgressView? - private var cancelButton : UIButton? + private var cancelButton : ThemeButton? private var metadataInfoLabel: UILabel? - private var showPreviewButton: UIButton? + private var showPreviewButton: ThemeButton? private var noNetworkLabel : UILabel? // MARK: - Delegate @@ -118,6 +123,8 @@ class DisplayViewController: UIViewController { metadataInfoLabel?.isHidden = false metadataInfoLabel?.text = item.sizeLocalized + " - " + item.lastModifiedLocalized metadataInfoLabel?.textAlignment = .center + metadataInfoLabel?.adjustsFontForContentSizeCategory = true + metadataInfoLabel?.font = UIFont.preferredFont(forTextStyle: .headline) view.addSubview(metadataInfoLabel!) @@ -129,7 +136,7 @@ class DisplayViewController: UIViewController { view.addSubview(progressView!) - cancelButton = ThemeButton(type: .system) + cancelButton = ThemeButton(type: .custom) cancelButton?.translatesAutoresizingMaskIntoConstraints = false cancelButton?.setTitle("Cancel".localized, for: .normal) cancelButton?.isHidden = (downloadProgress != nil) @@ -137,7 +144,7 @@ class DisplayViewController: UIViewController { view.addSubview(cancelButton!) - showPreviewButton = ThemeButton(type: .system) + showPreviewButton = ThemeButton(type: .custom) showPreviewButton?.translatesAutoresizingMaskIntoConstraints = false showPreviewButton?.setTitle("Open file".localized, for: .normal) showPreviewButton?.isHidden = true @@ -147,32 +154,35 @@ class DisplayViewController: UIViewController { noNetworkLabel = UILabel() noNetworkLabel?.translatesAutoresizingMaskIntoConstraints = false noNetworkLabel?.isHidden = true + noNetworkLabel?.adjustsFontForContentSizeCategory = true noNetworkLabel?.text = "There is no network".localized noNetworkLabel?.textAlignment = .center + noNetworkLabel?.font = UIFont.preferredFont(forTextStyle: .headline) view.addSubview(noNetworkLabel!) NSLayoutConstraint.activate([ iconImageView.centerXAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerXAnchor), - iconImageView.centerYAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerYAnchor, constant: -60), + iconImageView.centerYAnchor.constraint(equalTo: view.safeAreaLayoutGuide.centerYAnchor, constant: bottomMarginToYAxis), iconImageView.heightAnchor.constraint(equalToConstant: iconImageSize.height), iconImageView.widthAnchor.constraint(equalTo: iconImageView.heightAnchor), metadataInfoLabel!.centerXAnchor.constraint(equalTo: iconImageView.centerXAnchor), - metadataInfoLabel!.topAnchor.constraint(equalTo: iconImageView!.bottomAnchor, constant: 10), - metadataInfoLabel!.widthAnchor.constraint(equalTo: iconImageView.widthAnchor), + metadataInfoLabel!.topAnchor.constraint(equalTo: iconImageView!.bottomAnchor, constant: verticalSpacing), + metadataInfoLabel!.leftAnchor.constraint(equalTo: view.safeAreaLayoutGuide.leftAnchor, constant: lateralSpacing), + metadataInfoLabel!.rightAnchor.constraint(equalTo: view.safeAreaLayoutGuide.rightAnchor, constant: -lateralSpacing), progressView!.centerXAnchor.constraint(equalTo: iconImageView.centerXAnchor), progressView!.widthAnchor.constraint(equalTo: iconImageView.widthAnchor), - progressView!.topAnchor.constraint(equalTo: metadataInfoLabel!.bottomAnchor, constant: 20), + progressView!.topAnchor.constraint(equalTo: metadataInfoLabel!.bottomAnchor, constant: progressViewVerticalSpacing), cancelButton!.centerXAnchor.constraint(equalTo: iconImageView.centerXAnchor), - cancelButton!.topAnchor.constraint(equalTo: progressView!.bottomAnchor, constant: 10), + cancelButton!.topAnchor.constraint(equalTo: progressView!.bottomAnchor, constant: verticalSpacing), showPreviewButton!.centerXAnchor.constraint(equalTo: iconImageView.centerXAnchor), - showPreviewButton!.topAnchor.constraint(equalTo: progressView!.bottomAnchor, constant: 10), + showPreviewButton!.topAnchor.constraint(equalTo: progressView!.bottomAnchor, constant: verticalSpacing), noNetworkLabel!.centerXAnchor.constraint(equalTo: metadataInfoLabel!.centerXAnchor), - noNetworkLabel!.topAnchor.constraint(equalTo: metadataInfoLabel!.bottomAnchor, constant: 10), + noNetworkLabel!.topAnchor.constraint(equalTo: metadataInfoLabel!.bottomAnchor, constant: verticalSpacing), noNetworkLabel!.widthAnchor.constraint(equalTo: iconImageView.widthAnchor) ]) } @@ -213,7 +223,9 @@ class DisplayViewController: UIViewController { } parent.navigationItem.title = item.name - parent.navigationItem.rightBarButtonItem = UIBarButtonItem(title: "•••", style: .plain, target: self, action: #selector(optionsBarButtonPressed)) + let actionsBarButtonItem = UIBarButtonItem(title: "•••", style: .plain, target: self, action: #selector(optionsBarButtonPressed)) + actionsBarButtonItem.accessibilityLabel = item.name! + " " + "Actions".localized + parent.navigationItem.rightBarButtonItem = actionsBarButtonItem } // MARK: - Download actions @@ -246,6 +258,15 @@ class DisplayViewController: UIViewController { // This function is intended to be overwritten by the subclases to implement a custom view based on the source property.s } + func hideItemMetadataUIElements() { + iconImageView.isHidden = true + progressView?.isHidden = true + cancelButton?.isHidden = true + metadataInfoLabel?.isHidden = true + showPreviewButton?.isHidden = true + noNetworkLabel?.isHidden = true + } + // MARK: - KVO observing // swiftlint:disable block_based_kvo override func observeValue(forKeyPath keyPath: String?, of object: Any?, change: [NSKeyValueChangeKey : Any]?, context: UnsafeMutableRawPointer?) {