mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-14 18:12:09 +08:00
154 lines
5.0 KiB
TypeScript
154 lines
5.0 KiB
TypeScript
import { Font } from '../styling/font';
|
|
import { SegmentedBarItemBase, SegmentedBarBase, selectedIndexProperty, itemsProperty, selectedBackgroundColorProperty } from './segmented-bar-common';
|
|
import { colorProperty, fontInternalProperty } from '../styling/style-properties';
|
|
import { Color } from '../../color';
|
|
import { Trace } from '../../trace';
|
|
import { SDK_VERSION } from '../../utils';
|
|
export * from './segmented-bar-common';
|
|
|
|
export class SegmentedBarItem extends SegmentedBarItemBase {
|
|
public _update() {
|
|
const parent = <SegmentedBar>this.parent;
|
|
if (parent?.ios) {
|
|
const tabIndex = parent.items.indexOf(this);
|
|
let title = this.title;
|
|
title = title === null || title === undefined ? '' : title;
|
|
parent.ios.setTitleForSegmentAtIndex(title, tabIndex);
|
|
}
|
|
}
|
|
}
|
|
|
|
export class SegmentedBar extends SegmentedBarBase {
|
|
nativeViewProtected: UISegmentedControl;
|
|
private _selectionHandler: NSObject;
|
|
|
|
createNativeView() {
|
|
return UISegmentedControl.new();
|
|
}
|
|
|
|
initNativeView() {
|
|
super.initNativeView();
|
|
this._selectionHandler = SelectionHandlerImpl.initWithOwner(new WeakRef(this));
|
|
this.nativeViewProtected.addTargetActionForControlEvents(this._selectionHandler, 'selected', UIControlEvents.ValueChanged);
|
|
}
|
|
|
|
disposeNativeView() {
|
|
this._selectionHandler = null;
|
|
super.disposeNativeView();
|
|
}
|
|
|
|
// @ts-ignore
|
|
get ios(): UISegmentedControl {
|
|
return this.nativeViewProtected;
|
|
}
|
|
|
|
[selectedIndexProperty.getDefault](): number {
|
|
return -1;
|
|
}
|
|
[selectedIndexProperty.setNative](value: number) {
|
|
this.ios.selectedSegmentIndex = value;
|
|
}
|
|
|
|
[itemsProperty.getDefault](): SegmentedBarItem[] {
|
|
return null;
|
|
}
|
|
[itemsProperty.setNative](value: SegmentedBarItem[]) {
|
|
const segmentedControl = this.ios;
|
|
segmentedControl.removeAllSegments();
|
|
const newItems = value;
|
|
|
|
if (newItems && newItems.length) {
|
|
newItems.forEach((item, index, arr) => {
|
|
let title = item.title;
|
|
title = title === null || title === undefined ? '' : title;
|
|
segmentedControl.insertSegmentWithTitleAtIndexAnimated(title, index, false);
|
|
});
|
|
}
|
|
|
|
selectedIndexProperty.coerce(this);
|
|
}
|
|
|
|
[selectedBackgroundColorProperty.getDefault](): UIColor {
|
|
return SDK_VERSION < 13 ? this.ios.tintColor : this.ios.selectedSegmentTintColor;
|
|
}
|
|
[selectedBackgroundColorProperty.setNative](value: UIColor | Color) {
|
|
const color = value instanceof Color ? value.ios : value;
|
|
if (SDK_VERSION < 13) {
|
|
this.ios.tintColor = color;
|
|
} else {
|
|
this.ios.selectedSegmentTintColor = color;
|
|
}
|
|
}
|
|
|
|
[colorProperty.getDefault](): UIColor {
|
|
return null;
|
|
}
|
|
[colorProperty.setNative](value: Color | UIColor) {
|
|
const color = value instanceof Color ? value.ios : value;
|
|
const bar = this.ios;
|
|
const currentAttrs = bar.titleTextAttributesForState(UIControlState.Normal);
|
|
const attrs = currentAttrs ? currentAttrs.mutableCopy() : NSMutableDictionary.new();
|
|
attrs.setValueForKey(color, NSForegroundColorAttributeName);
|
|
bar.setTitleTextAttributesForState(attrs, UIControlState.Normal);
|
|
// Set the selected text color
|
|
this.setSelectedTextColor(bar);
|
|
}
|
|
|
|
[fontInternalProperty.getDefault](): Font {
|
|
return null;
|
|
}
|
|
[fontInternalProperty.setNative](value: Font) {
|
|
const font: UIFont = value ? value.getUIFont(UIFont.systemFontOfSize(UIFont.labelFontSize)) : null;
|
|
const bar = this.ios;
|
|
const currentAttrs = bar.titleTextAttributesForState(UIControlState.Normal);
|
|
const attrs = currentAttrs ? currentAttrs.mutableCopy() : NSMutableDictionary.new();
|
|
attrs.setValueForKey(font, NSFontAttributeName);
|
|
bar.setTitleTextAttributesForState(attrs, UIControlState.Normal);
|
|
}
|
|
setSelectedTextColor(bar: UISegmentedControl) {
|
|
try {
|
|
const selectedTextColor = this.getColorForIOS(this?.selectedTextColor ?? this?.color ?? '#000000');
|
|
if (!selectedTextColor) {
|
|
Trace.write(`unable te set selectedTextColor`, Trace.categories.Error);
|
|
}
|
|
const selectedText = bar.titleTextAttributesForState(UIControlState.Selected);
|
|
const attrsSelected = selectedText ? selectedText.mutableCopy() : NSMutableDictionary.new();
|
|
attrsSelected.setValueForKey(selectedTextColor, NSForegroundColorAttributeName);
|
|
bar.setTitleTextAttributesForState(attrsSelected, UIControlState.Selected);
|
|
} catch (e) {
|
|
console.error(`SegmentedBar:`, e);
|
|
}
|
|
}
|
|
private getColorForIOS(color: string | Color): UIColor {
|
|
if (typeof color === 'string') {
|
|
return new Color(color).ios;
|
|
} else if (color instanceof Color) {
|
|
return color.ios;
|
|
}
|
|
}
|
|
}
|
|
|
|
@NativeClass
|
|
class SelectionHandlerImpl extends NSObject {
|
|
private _owner: WeakRef<SegmentedBar>;
|
|
|
|
public static initWithOwner(owner: WeakRef<SegmentedBar>): SelectionHandlerImpl {
|
|
const handler = <SelectionHandlerImpl>SelectionHandlerImpl.new();
|
|
handler._owner = owner;
|
|
|
|
return handler;
|
|
}
|
|
|
|
public selected(sender: UISegmentedControl) {
|
|
const owner = this._owner?.deref();
|
|
if (owner) {
|
|
owner.selectedIndex = sender.selectedSegmentIndex;
|
|
owner.setSelectedTextColor(sender);
|
|
}
|
|
}
|
|
|
|
public static ObjCExposedMethods = {
|
|
selected: { returns: interop.types.void, params: [UISegmentedControl] },
|
|
};
|
|
}
|