| /** | 
|  * Tencent is pleased to support the open source community by making QMUI_iOS available. | 
|  * Copyright (C) 2016-2021 THL A29 Limited, a Tencent company. All rights reserved. | 
|  * Licensed under the MIT License (the "License"); you may not use this file except in compliance with the License. You may obtain a copy of the License at | 
|  * http://opensource.org/licenses/MIT | 
|  * Unless required by applicable law or agreed to in writing, software distributed under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the License for the specific language governing permissions and limitations under the License. | 
|  */ | 
|   | 
| // | 
| //  QMUITextField.h | 
| //  qmui | 
| // | 
| //  Created by QMUI Team on 16-11-03 | 
| // | 
|   | 
| #import <UIKit/UIKit.h> | 
|   | 
| @class QMUITextField; | 
|   | 
| @protocol QMUITextFieldDelegate <UITextFieldDelegate> | 
|   | 
| @optional | 
|   | 
| /** | 
|  由于 maximumTextLength 的实现方式导致业务无法再重写自己的 shouldChangeCharacters,否则会丢失 maximumTextLength 的功能。所以这里提供一个额外的 delegate,在 QMUI 内部逻辑返回 YES 的时候会再询问一次这个 delegate,从而给业务提供一个机会去限制自己的输入内容。如果 QMUI 内部逻辑本身就返回 NO(例如超过了 maximumTextLength 的长度),则不会触发这个方法。 | 
|  当输入被这个方法拦截时,由于拦截逻辑是业务自己写的,业务能轻松获取到这个拦截的时机,所以此时不会调用 textField:didPreventTextChangeInRange:replacementString:。如果有类似 tips 之类的操作,可以直接在 return NO 之前处理。 | 
|  */ | 
| - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string originalValue:(BOOL)originalValue; | 
|   | 
| /** | 
|  *  配合 `maximumTextLength` 属性使用,在输入文字超过限制时被调用。 | 
|  *  @warning 在 UIControlEventEditingChanged 里也会触发文字长度拦截,由于此时 textField 的文字已经改变完,所以无法得知发生改变的文本位置及改变的文本内容,所以此时 range 和 replacementString 这两个参数的值也会比较特殊,具体请看参数讲解。 | 
|  * | 
|  *  @param textField 触发的 textField | 
|  *  @param range 要变化的文字的位置,如果在 UIControlEventEditingChanged 里,这里的 range 也即文字变化后的 range,所以可能比最大长度要大。 | 
|  *  @param replacementString 要变化的文字,如果在 UIControlEventEditingChanged 里,这里永远传入 nil。 | 
|  */ | 
| - (void)textField:(QMUITextField *)textField didPreventTextChangeInRange:(NSRange)range replacementString:(NSString *)replacementString; | 
|   | 
| @end | 
|   | 
| /** | 
|  *  支持的特性包括: | 
|  * | 
|  *  1. 自定义 placeholderColor。 | 
|  *  2. 自定义 UITextField 的文字 padding。 | 
|  *  3. 支持限制输入的文字的长度。 | 
|  *  4. 修复 iOS 10 之后 UITextField 输入中文超过文本框宽度后再删除,文字往下掉的 bug。 | 
|  */ | 
| @interface QMUITextField : UITextField | 
|   | 
| @property(nonatomic, weak) id<QMUITextFieldDelegate> delegate; | 
|   | 
| /** | 
|  *  修改 placeholder 的颜色,默认是 UIColorPlaceholder。 | 
|  */ | 
| @property(nonatomic, strong) IBInspectable UIColor *placeholderColor; | 
|   | 
| /** | 
|  *  文字在输入框内的 padding。如果出现 clearButton,则 textInsets.right 会控制 clearButton 的右边距 | 
|  * | 
|  *  默认为 TextFieldTextInsets | 
|  */ | 
| @property(nonatomic, assign) UIEdgeInsets textInsets; | 
|   | 
| /** | 
|  clearButton 在默认位置上的偏移 | 
|  */ | 
| @property(nonatomic, assign) UIOffset clearButtonPositionAdjustment UI_APPEARANCE_SELECTOR; | 
|   | 
| /** | 
|  *  当通过 `setText:`、`setAttributedText:`等方式修改文字时,是否应该自动触发 UIControlEventEditingChanged 事件及 UITextFieldTextDidChangeNotification 通知。 | 
|  * | 
|  *  默认为YES(注意系统的 UITextField 对这种行为默认是 NO) | 
|  */ | 
| @property(nonatomic, assign) IBInspectable BOOL shouldResponseToProgrammaticallyTextChanges; | 
|   | 
| /** | 
|  *  显示允许输入的最大文字长度,默认为 NSUIntegerMax,也即不限制长度。 | 
|  */ | 
| @property(nonatomic, assign) IBInspectable NSUInteger maximumTextLength; | 
|   | 
| /** | 
|  *  在使用 maximumTextLength 功能的时候,是否应该把文字长度按照 [NSString (QMUI) qmui_lengthWhenCountingNonASCIICharacterAsTwo] 的方法来计算。 | 
|  *  默认为 NO。 | 
|  */ | 
| @property(nonatomic, assign) IBInspectable BOOL shouldCountingNonASCIICharacterAsTwo; | 
|   | 
| /** | 
|  *  控制输入框是否要出现“粘贴”menu | 
|  *  @param sender 触发这次询问事件的来源 | 
|  *  @param superReturnValue [super canPerformAction:withSender:] 的返回值,当你不需要控制这个 block 的返回值时,可以返回 superReturnValue | 
|  *  @return 控制是否要出现“粘贴”menu,YES 表示出现,NO 表示不出现。当你想要返回系统默认的结果时,请返回参数 superReturnValue | 
|  */ | 
| @property(nonatomic, copy) BOOL (^canPerformPasteActionBlock)(id sender, BOOL superReturnValue); | 
|   | 
| /** | 
|  *  当输入框的“粘贴”事件被触发时,可通过这个 block 去接管事件的响应。 | 
|  *  @param sender “粘贴”事件触发的来源,例如可能是一个 UIMenuController | 
|  *  @return 返回值用于控制是否要调用系统默认的 paste: 实现,YES 表示执行完 block 后继续调用系统默认实现,NO 表示执行完 block 后就结束了,不调用 super。 | 
|  */ | 
| @property(nonatomic, copy) BOOL (^pasteBlock)(id sender); | 
|   | 
| @end |