linphone-iphone/Classes/Utils/HPGrowingTextView/HPTextViewInternal.m
2015-11-17 14:59:50 +01:00

105 lines
3.1 KiB
Objective-C
Executable file

//
// HPTextViewInternal.m
//
// Created by Hans Pinckaers on 29-06-10.
//
// MIT License
//
// Copyright (c) 2011 Hans Pinckaers
//
// Permission is hereby granted, free of charge, to any person obtaining a copy
// of this software and associated documentation files (the "Software"), to deal
// in the Software without restriction, including without limitation the rights
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
// copies of the Software, and to permit persons to whom the Software is
// furnished to do so, subject to the following conditions:
//
// The above copyright notice and this permission notice shall be included in
// all copies or substantial portions of the Software.
//
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
// THE SOFTWARE.
#import "HPTextViewInternal.h"
@implementation HPTextViewInternal
@synthesize placeholder;
@synthesize placeholderColor;
@synthesize displayPlaceHolder;
- (void)setText:(NSString *)text {
BOOL originalValue = self.scrollEnabled;
// If one of GrowingTextView's superviews is a scrollView, and self.scrollEnabled == NO,
// setting the text programatically will cause UIKit to search upwards until it finds a scrollView with
// scrollEnabled==yes
// then scroll it erratically. Setting scrollEnabled temporarily to YES prevents this.
[self setScrollEnabled:YES];
[super setText:text];
[self setScrollEnabled:originalValue];
}
- (void)setScrollable:(BOOL)isScrollable {
[super setScrollEnabled:isScrollable];
}
- (void)setContentOffset:(CGPoint)s {
if (self.tracking || self.decelerating) {
// initiated by user...
UIEdgeInsets insets = self.contentInset;
insets.bottom = 0;
insets.top = 0;
self.contentInset = insets;
} else {
float bottomOffset = (self.contentSize.height - self.frame.size.height + self.contentInset.bottom);
if (s.y < bottomOffset && self.scrollEnabled) {
UIEdgeInsets insets = self.contentInset;
insets.bottom = 8;
insets.top = 0;
self.contentInset = insets;
}
}
[super setContentOffset:s];
}
- (void)setContentInset:(UIEdgeInsets)s {
UIEdgeInsets insets = s;
if (s.bottom > 8)
insets.bottom = 0;
insets.top = 0;
[super setContentInset:insets];
}
- (void)setContentSize:(CGSize)contentSize {
// is this an iOS5 bug? Need testing!
if (self.contentSize.height > contentSize.height) {
UIEdgeInsets insets = self.contentInset;
insets.bottom = 0;
insets.top = 0;
self.contentInset = insets;
}
[super setContentSize:contentSize];
}
- (void)drawRect:(CGRect)rect {
[super drawRect:rect];
if (displayPlaceHolder && placeholder && placeholderColor) {
[placeholderColor set];
[placeholder drawInRect:CGRectMake(8.0f, 8.0f, self.frame.size.width - 16.0f, self.frame.size.height - 16.0f)
withFont:self.font];
}
}
@end