From 218c25ac927eb0316a087feda3d22e4ff911a693 Mon Sep 17 00:00:00 2001 From: dragon Date: Mon, 26 Jun 2023 00:02:33 +0545 Subject: [PATCH] fix: Not visible when text is too long --- .../SearchTextField/MainViewController.swift | 3 ++ SearchTextField/Classes/SearchTextField.swift | 51 ++++++++++++++++++- 2 files changed, 53 insertions(+), 1 deletion(-) diff --git a/Example/SearchTextField/MainViewController.swift b/Example/SearchTextField/MainViewController.swift index d5b54b0..f385bdf 100644 --- a/Example/SearchTextField/MainViewController.swift +++ b/Example/SearchTextField/MainViewController.swift @@ -41,6 +41,9 @@ class MainViewController: UITableViewController { // Start visible even without user's interaction as soon as created - Default: false countryTextField.startVisibleWithoutInteraction = true + // Enable multiline cells - Default: false + // countryTextField.enableMultiline = true + // Set data source let countries = localCountries() countryTextField.filterStrings(countries) diff --git a/SearchTextField/Classes/SearchTextField.swift b/SearchTextField/Classes/SearchTextField.swift index 9cf8f55..1e359c6 100755 --- a/SearchTextField/Classes/SearchTextField.swift +++ b/SearchTextField/Classes/SearchTextField.swift @@ -28,6 +28,9 @@ open class SearchTextField: UITextField { /// How long to wait before deciding typing has stopped open var typingStoppedDelay = 0.8 + /// Enable multiline of each row text + open var enableMultiline = false + /// Set your custom visual theme, or just choose between pre-defined SearchTextFieldTheme.lightTheme() and SearchTextFieldTheme.darkTheme() themes open var theme = SearchTextFieldTheme.lightTheme() { didSet { @@ -550,6 +553,15 @@ open class SearchTextField: UITextField { } } } + + + // MARK: - Height for label + + fileprivate func getHeight(forText: String,forWidth: CGFloat ) -> CGFloat { + let tempLabel = UILabel.init() + tempLabel.text = forText + return tempLabel.textHeight(withWidth: forWidth) + } } extension SearchTextField: UITableViewDelegate, UITableViewDataSource { @@ -575,6 +587,7 @@ extension SearchTextField: UITableViewDelegate, UITableViewDataSource { cell!.layoutMargins = UIEdgeInsets.zero cell!.preservesSuperviewLayoutMargins = false cell!.textLabel?.font = theme.font + cell!.textLabel?.numberOfLines = enableMultiline ? 0 : 1 cell!.detailTextLabel?.font = UIFont(name: theme.font.fontName, size: theme.font.pointSize * fontConversionRate) cell!.textLabel?.textColor = theme.fontColor cell!.detailTextLabel?.textColor = theme.subtitleFontColor @@ -592,7 +605,7 @@ extension SearchTextField: UITableViewDelegate, UITableViewDataSource { } public func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat { - return theme.cellHeight + return getHeight(forText: filteredResults[(indexPath as NSIndexPath).row].title, forWidth: tableView.frame.width) > theme.cellHeight && enableMultiline ? UITableView.automaticDimension : theme.cellHeight } public func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) { @@ -678,3 +691,39 @@ enum Direction { case down case up } + + +//////////////////////////////////////////////////////////////////////// +// Extension for UILable height calculation + +extension UILabel { + func textHeight(withWidth width: CGFloat) -> CGFloat { + guard let text = text else { + return 0 + } + return text.height(withWidth: width, font: font) + } + + func attributedTextHeight(withWidth width: CGFloat) -> CGFloat { + guard let attributedText = attributedText else { + return 0 + } + return attributedText.height(withWidth: width) + } +} + +extension String { + func height(withWidth width: CGFloat, font: UIFont) -> CGFloat { + let maxSize = CGSize(width: width, height: CGFloat.greatestFiniteMagnitude) + let actualSize = self.boundingRect(with: maxSize, options: [.usesLineFragmentOrigin], attributes: [.font : font], context: nil) + return actualSize.height + } +} + +extension NSAttributedString { + func height(withWidth width: CGFloat) -> CGFloat { + let maxSize = CGSize(width: width, height: CGFloat.greatestFiniteMagnitude) + let actualSize = boundingRect(with: maxSize, options: [.usesLineFragmentOrigin], context: nil) + return actualSize.height + } +}