mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 11:01:21 +08:00

* chore: move tns-core-modules to nativescript-core * chore: preparing compat generate script * chore: add missing definitions * chore: no need for http-request to be private * chore: packages chore * test: generate tests for tns-core-modules * chore: add anroid module for consistency * chore: add .npmignore * chore: added privateModulesWhitelist * chore(webpack): added bundle-entry-points * chore: scripts * chore: tests changed to use @ns/core * test: add scoped-packages test project * test: fix types * test: update test project * chore: build scripts * chore: update build script * chore: npm scripts cleanup * chore: make the compat pgk work with old wp config * test: generate diff friendly tests * chore: create barrel exports * chore: move files after rebase * chore: typedoc config * chore: compat mode * chore: review of barrels * chore: remove tns-core-modules import after rebase * chore: dev workflow setup * chore: update developer-workflow * docs: experiment with API extractor * chore: api-extractor and barrel exports * chore: api-extractor configs * chore: generate d.ts rollup with api-extractor * refactor: move methods inside Frame * chore: fic tests to use Frame static methods * refactor: create Builder class * refactor: use Builder class in tests * refactor: include Style in ui barrel * chore: separate compat build script * chore: fix tslint errors * chore: update NATIVESCRIPT_CORE_ARGS * chore: fix compat pack * chore: fix ui-test-app build with linked modules * chore: Application, ApplicationSettings, Connectivity and Http * chore: export Trace, Profiling and Utils * refactor: Static create methods for ImageSource * chore: fix deprecated usages of ImageSource * chore: move Span and FormattedString to ui * chore: add events-args and ImageSource to index files * chore: check for CLI >= 6.2 when building for IOS * chore: update travis build * chore: copy Pod file to compat package * chore: update error msg ui-tests-app * refactor: Apply suggestions from code review Co-Authored-By: Martin Yankov <m.i.yankov@gmail.com> * chore: typings and refs * chore: add missing d.ts files for public API * chore: adress code review FB * chore: update api-report * chore: dev-workflow for other apps * chore: api update * chore: update api-report
139 lines
4.6 KiB
TypeScript
139 lines
4.6 KiB
TypeScript
import { SegmentedBar as SegmentedBarDefinition, SegmentedBarItem as SegmentedBarItemDefinition, SelectedIndexChangedEventData } from ".";
|
|
import {
|
|
ViewBase, View, AddChildFromBuilder, AddArrayFromBuilder,
|
|
Property, CoercibleProperty, InheritedCssProperty, Color, Style, EventData, CSSType
|
|
} from "../core/view";
|
|
|
|
export * from "../core/view";
|
|
|
|
export module knownCollections {
|
|
export const items = "items";
|
|
}
|
|
|
|
@CSSType("SegmentedBarItem")
|
|
export abstract class SegmentedBarItemBase extends ViewBase implements SegmentedBarItemDefinition {
|
|
private _title: string = "";
|
|
|
|
get title(): string {
|
|
return this._title;
|
|
}
|
|
set title(value: string) {
|
|
let strValue = (value !== null && value !== undefined) ? value.toString() : "";
|
|
if (this._title !== strValue) {
|
|
this._title = strValue;
|
|
this._update();
|
|
}
|
|
}
|
|
|
|
public abstract _update();
|
|
}
|
|
|
|
@CSSType("SegmentedBar")
|
|
export abstract class SegmentedBarBase extends View implements SegmentedBarDefinition, AddChildFromBuilder, AddArrayFromBuilder {
|
|
public static selectedIndexChangedEvent = "selectedIndexChanged";
|
|
|
|
public selectedIndex: number;
|
|
public items: Array<SegmentedBarItemDefinition>;
|
|
|
|
public get selectedBackgroundColor(): Color {
|
|
return this.style.selectedBackgroundColor;
|
|
}
|
|
public set selectedBackgroundColor(value: Color) {
|
|
this.style.selectedBackgroundColor = value;
|
|
}
|
|
|
|
public _addArrayFromBuilder(name: string, value: Array<any>): void {
|
|
if (name === "items") {
|
|
this.items = value;
|
|
}
|
|
}
|
|
|
|
public _addChildFromBuilder(name: string, value: any): void {
|
|
if (name === "SegmentedBarItem") {
|
|
const item = <SegmentedBarItemBase>value;
|
|
let items = this.items;
|
|
if (!items) {
|
|
items = new Array<SegmentedBarItemBase>();
|
|
items.push(item);
|
|
this.items = items;
|
|
} else {
|
|
items.push(item);
|
|
this._addView(item);
|
|
}
|
|
|
|
if (this.nativeViewProtected) {
|
|
this[itemsProperty.setNative](items);
|
|
}
|
|
}
|
|
}
|
|
|
|
public onItemsChanged(oldItems: SegmentedBarItemDefinition[], newItems: SegmentedBarItemDefinition[]): void {
|
|
if (oldItems) {
|
|
for (let i = 0, count = oldItems.length; i < count; i++) {
|
|
this._removeView(oldItems[i]);
|
|
}
|
|
}
|
|
|
|
if (newItems) {
|
|
for (let i = 0, count = newItems.length; i < count; i++) {
|
|
this._addView(newItems[i]);
|
|
}
|
|
}
|
|
}
|
|
|
|
// TODO: Make _addView to keep its children so this method is not needed!
|
|
public eachChild(callback: (child: ViewBase) => boolean): void {
|
|
const items = this.items;
|
|
if (items) {
|
|
items.forEach((item, i) => {
|
|
callback(item);
|
|
});
|
|
}
|
|
}
|
|
}
|
|
|
|
export interface SegmentedBarBase {
|
|
on(eventNames: string, callback: (data: EventData) => void, thisArg?: any);
|
|
on(event: "selectedIndexChanged", callback: (args: SelectedIndexChangedEventData) => void, thisArg?: any);
|
|
}
|
|
|
|
SegmentedBarBase.prototype.recycleNativeView = "auto";
|
|
|
|
/**
|
|
* Gets or sets the selected index dependency property of the SegmentedBar.
|
|
*/
|
|
export const selectedIndexProperty = new CoercibleProperty<SegmentedBarBase, number>({
|
|
name: "selectedIndex", defaultValue: -1,
|
|
valueChanged: (target, oldValue, newValue) => {
|
|
target.notify(<SelectedIndexChangedEventData>{ eventName: SegmentedBarBase.selectedIndexChangedEvent, object: target, oldIndex: oldValue, newIndex: newValue });
|
|
},
|
|
coerceValue: (target, value) => {
|
|
let items = target.items;
|
|
if (items) {
|
|
let max = items.length - 1;
|
|
if (value < 0) {
|
|
value = 0;
|
|
}
|
|
if (value > max) {
|
|
value = max;
|
|
}
|
|
} else {
|
|
value = -1;
|
|
}
|
|
|
|
return value;
|
|
},
|
|
valueConverter: (v) => parseInt(v)
|
|
});
|
|
selectedIndexProperty.register(SegmentedBarBase);
|
|
|
|
export const itemsProperty = new Property<SegmentedBarBase, SegmentedBarItemDefinition[]>({
|
|
name: "items", valueChanged: (target, oldValue, newValue) => {
|
|
target.onItemsChanged(oldValue, newValue);
|
|
}
|
|
});
|
|
itemsProperty.register(SegmentedBarBase);
|
|
|
|
export const selectedBackgroundColorProperty = new InheritedCssProperty<Style, Color>({ name: "selectedBackgroundColor", cssName: "selected-background-color", equalityComparer: Color.equals, valueConverter: (v) => new Color(v) });
|
|
selectedBackgroundColorProperty.register(Style);
|