mirror of
https://github.com/Swiftgram/Telegram-iOS.git
synced 2025-12-23 06:35:51 +00:00
Filter consecutive newlines
This commit is contained in:
@@ -182,6 +182,7 @@ public final class ChatTextInputPanelComponent: Component {
|
||||
let insets: UIEdgeInsets
|
||||
let maxHeight: CGFloat
|
||||
let maxLength: Int?
|
||||
let allowConsecutiveNewlines: Bool
|
||||
let sendAction: (() -> Void)?
|
||||
let sendContextAction: ((UIView, ContextGesture) -> Void)?
|
||||
|
||||
@@ -206,6 +207,7 @@ public final class ChatTextInputPanelComponent: Component {
|
||||
insets: UIEdgeInsets,
|
||||
maxHeight: CGFloat,
|
||||
maxLength: Int?,
|
||||
allowConsecutiveNewlines: Bool,
|
||||
sendAction: (() -> Void)?,
|
||||
sendContextAction: ((UIView, ContextGesture) -> Void)?
|
||||
) {
|
||||
@@ -229,6 +231,7 @@ public final class ChatTextInputPanelComponent: Component {
|
||||
self.insets = insets
|
||||
self.maxHeight = maxHeight
|
||||
self.maxLength = maxLength
|
||||
self.allowConsecutiveNewlines = allowConsecutiveNewlines
|
||||
self.sendAction = sendAction
|
||||
self.sendContextAction = sendContextAction
|
||||
}
|
||||
@@ -294,6 +297,9 @@ public final class ChatTextInputPanelComponent: Component {
|
||||
if lhs.maxLength != rhs.maxLength {
|
||||
return false
|
||||
}
|
||||
if lhs.allowConsecutiveNewlines != rhs.allowConsecutiveNewlines {
|
||||
return false
|
||||
}
|
||||
if (lhs.sendAction == nil) != (rhs.sendAction == nil) {
|
||||
return false
|
||||
}
|
||||
@@ -1013,6 +1019,8 @@ public final class ChatTextInputPanelComponent: Component {
|
||||
}
|
||||
}
|
||||
|
||||
panelNode.allowConsecutiveNewlines = component.allowConsecutiveNewlines
|
||||
|
||||
if let resetInputState = component.externalState.resetInputState {
|
||||
component.externalState.resetInputState = nil
|
||||
let _ = resetInputState
|
||||
|
||||
@@ -407,6 +407,7 @@ public class ChatTextInputPanelNode: ChatInputPanelNode, ASEditableTextNodeDeleg
|
||||
public var customSendIsDisabled: Bool = false
|
||||
public var customInputTextMaxLength: Int?
|
||||
public var customSwitchToKeyboard: (() -> Void)?
|
||||
public var allowConsecutiveNewlines = true
|
||||
|
||||
private var starReactionButton: ComponentView<Empty>?
|
||||
private var liveMicrophoneButton: ComponentView<Empty>?
|
||||
@@ -4953,7 +4954,6 @@ public class ChatTextInputPanelNode: ChatInputPanelNode, ASEditableTextNodeDeleg
|
||||
}
|
||||
}
|
||||
|
||||
if cleanText != text {
|
||||
let string = NSMutableAttributedString(attributedString: editableTextNode.attributedText ?? NSAttributedString())
|
||||
var textColor: UIColor = .black
|
||||
var accentTextColor: UIColor = .blue
|
||||
@@ -4970,6 +4970,24 @@ public class ChatTextInputPanelNode: ChatInputPanelNode, ASEditableTextNodeDeleg
|
||||
return ChatInputTextCollapsedQuoteAttachmentImpl(text: text, attributes: attributes)
|
||||
})
|
||||
string.replaceCharacters(in: range, with: cleanReplacementString)
|
||||
|
||||
var resetText = false
|
||||
if cleanText != text {
|
||||
resetText = true
|
||||
}
|
||||
|
||||
if !self.allowConsecutiveNewlines {
|
||||
while string.string.range(of: "\n\n") != nil {
|
||||
if let range = string.string.range(of: "\n\n") {
|
||||
let rawRange = NSRange(range, in: string.string)
|
||||
let firstNewline = string.attributedSubstring(from: NSRange(location: rawRange.location, length: 1))
|
||||
string.replaceCharacters(in: rawRange, with: firstNewline)
|
||||
resetText = true
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
if resetText {
|
||||
self.textInputNode?.attributedText = string
|
||||
self.textInputNode?.selectedRange = NSMakeRange(range.lowerBound + cleanReplacementString.length, 0)
|
||||
self.updateTextNodeText(animated: true)
|
||||
|
||||
@@ -1125,6 +1125,7 @@ public final class MessageInputPanelComponent: Component {
|
||||
insets: UIEdgeInsets(top: 0.0, left: 0.0, bottom: component.bottomInset, right: 0.0),
|
||||
maxHeight: availableSize.height,
|
||||
maxLength: component.maxLength,
|
||||
allowConsecutiveNewlines: false,
|
||||
sendAction: { [weak self] in
|
||||
guard let self, let component = self.component else {
|
||||
return
|
||||
|
||||
Reference in New Issue
Block a user