mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 19:26:42 +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
170 lines
7.2 KiB
TypeScript
170 lines
7.2 KiB
TypeScript
import {
|
|
FlexDirection, FlexWrap, JustifyContent, AlignItems, AlignContent,
|
|
FlexboxLayoutBase, View,
|
|
Length,
|
|
orderProperty, Order,
|
|
flexGrowProperty, FlexGrow,
|
|
flexShrinkProperty, FlexShrink,
|
|
flexWrapBeforeProperty, FlexWrapBefore,
|
|
alignSelfProperty, AlignSelf,
|
|
flexDirectionProperty, flexWrapProperty, justifyContentProperty, alignItemsProperty, alignContentProperty
|
|
} from "./flexbox-layout-common";
|
|
|
|
export * from "./flexbox-layout-common";
|
|
|
|
let widgetFlexboxLayout: typeof org.nativescript.widgets.FlexboxLayout;
|
|
let widgetLayoutParams: typeof org.nativescript.widgets.FlexboxLayout.LayoutParams;
|
|
|
|
function makeNativeSetter<T>(setter: (lp: org.nativescript.widgets.FlexboxLayout.LayoutParams, value: T) => void) {
|
|
return function (this: View, value: T) {
|
|
const nativeView: android.view.View = this.nativeViewProtected;
|
|
const lp = nativeView.getLayoutParams() || new widgetLayoutParams();
|
|
if (lp instanceof widgetLayoutParams) {
|
|
setter(lp, value);
|
|
nativeView.setLayoutParams(lp);
|
|
}
|
|
};
|
|
}
|
|
|
|
View.prototype[orderProperty.setNative] = makeNativeSetter<Order>((lp, value) => lp.order = value);
|
|
View.prototype[flexGrowProperty.setNative] = makeNativeSetter<FlexGrow>((lp, value) => lp.flexGrow = value);
|
|
View.prototype[flexShrinkProperty.setNative] = makeNativeSetter<FlexShrink>((lp, value) => lp.flexShrink = value);
|
|
View.prototype[flexWrapBeforeProperty.setNative] = makeNativeSetter<FlexWrapBefore>((lp, value) => lp.wrapBefore = value);
|
|
View.prototype[alignSelfProperty.setNative] = makeNativeSetter<AlignSelf>((lp, value) => lp.alignSelf = alignSelfMap[value]);
|
|
|
|
const flexDirectionMap = {
|
|
[FlexDirection.ROW]: 0, //FlexboxLayoutWidget.FLEX_DIRECTION_ROW,
|
|
[FlexDirection.ROW_REVERSE]: 1, //FlexboxLayoutWidget.FLEX_DIRECTION_ROW_REVERSE,
|
|
[FlexDirection.COLUMN]: 2, //FlexboxLayoutWidget.FLEX_DIRECTION_COLUMN,
|
|
[FlexDirection.COLUMN_REVERSE]: 3 //FlexboxLayoutWidget.FLEX_DIRECTION_COLUMN_REVERSE
|
|
};
|
|
|
|
const flexWrapMap = {
|
|
[FlexWrap.NOWRAP]: 0, //FlexboxLayoutWidget.FLEX_WRAP_NOWRAP,
|
|
[FlexWrap.WRAP]: 1, //FlexboxLayoutWidget.FLEX_WRAP_WRAP,
|
|
[FlexWrap.WRAP_REVERSE]: 2 //FlexboxLayoutWidget.FLEX_WRAP_WRAP_REVERSE
|
|
};
|
|
|
|
const justifyContentMap = {
|
|
[JustifyContent.FLEX_START]: 0, //FlexboxLayoutWidget.JUSTIFY_CONTENT_FLEX_START,
|
|
[JustifyContent.FLEX_END]: 1, //FlexboxLayoutWidget.JUSTIFY_CONTENT_FLEX_END,
|
|
[JustifyContent.CENTER]: 2, //FlexboxLayoutWidget.JUSTIFY_CONTENT_CENTER,
|
|
[JustifyContent.SPACE_BETWEEN]: 3, //FlexboxLayoutWidget.JUSTIFY_CONTENT_SPACE_BETWEEN
|
|
[JustifyContent.SPACE_AROUND]: 4 //FlexboxLayoutWidget.JUSTIFY_CONTENT_SPACE_AROUND,
|
|
};
|
|
|
|
const alignItemsMap = {
|
|
[AlignItems.FLEX_START]: 0, //FlexboxLayoutWidget.ALIGN_ITEMS_FLEX_START,
|
|
[AlignItems.FLEX_END]: 1, //FlexboxLayoutWidget.ALIGN_ITEMS_FLEX_END,
|
|
[AlignItems.CENTER]: 2, //FlexboxLayoutWidget.ALIGN_ITEMS_CENTER,
|
|
[AlignItems.BASELINE]: 3, //FlexboxLayoutWidget.ALIGN_ITEMS_BASELINE,
|
|
[AlignItems.STRETCH]: 4 //FlexboxLayoutWidget.ALIGN_ITEMS_STRETCH
|
|
};
|
|
|
|
const alignContentMap = {
|
|
[AlignContent.FLEX_START]: 0, //FlexboxLayoutWidget.ALIGN_CONTENT_FLEX_START,
|
|
[AlignContent.FLEX_END]: 1, //FlexboxLayoutWidget.ALIGN_CONTENT_FLEX_END,
|
|
[AlignContent.CENTER]: 2, //FlexboxLayoutWidget.ALIGN_CONTENT_CENTER,
|
|
[AlignContent.SPACE_BETWEEN]: 3, //FlexboxLayoutWidget.ALIGN_CONTENT_SPACE_BETWEEN,
|
|
[AlignContent.SPACE_AROUND]: 4, //FlexboxLayoutWidget.ALIGN_CONTENT_SPACE_AROUND,
|
|
[AlignContent.STRETCH]: 5 //FlexboxLayoutWidget.ALIGN_CONTENT_STRETCH
|
|
};
|
|
|
|
const alignSelfMap = {
|
|
[AlignSelf.AUTO]: -1, //FlexboxLayoutWidget.LayoutParams.ALIGN_SELF_AUTO,
|
|
[AlignSelf.FLEX_START]: 0, //FlexboxLayoutWidget.LayoutParams.ALIGN_SELF_FLEX_START,
|
|
[AlignSelf.FLEX_END]: 1, //FlexboxLayoutWidget.LayoutParams.ALIGN_SELF_FLEX_END,
|
|
[AlignSelf.CENTER]: 2, //FlexboxLayoutWidget.LayoutParams.ALIGN_SELF_CENTER,
|
|
[AlignSelf.BASELINE]: 3, //FlexboxLayoutWidget.LayoutParams.ALIGN_SELF_BASELINE,
|
|
[AlignSelf.STRETCH]: 4 //FlexboxLayoutWidget.LayoutParams.ALIGN_SELF_STRETCH
|
|
};
|
|
|
|
export class FlexboxLayout extends FlexboxLayoutBase {
|
|
nativeViewProtected: org.nativescript.widgets.FlexboxLayout;
|
|
|
|
constructor() {
|
|
super();
|
|
if (!widgetFlexboxLayout) {
|
|
widgetFlexboxLayout = org.nativescript.widgets.FlexboxLayout;
|
|
widgetLayoutParams = widgetFlexboxLayout.LayoutParams;
|
|
}
|
|
}
|
|
|
|
public createNativeView() {
|
|
return new widgetFlexboxLayout(this._context);
|
|
}
|
|
|
|
public resetNativeView(): void {
|
|
super.resetNativeView();
|
|
(<any>this.nativeViewProtected).invalidateOrdersCache();
|
|
}
|
|
|
|
[flexDirectionProperty.getDefault](): FlexDirection {
|
|
return flexDirectionProperty.defaultValue;
|
|
}
|
|
[flexDirectionProperty.setNative](flexDirection: FlexDirection) {
|
|
this.nativeViewProtected.setFlexDirection(flexDirectionMap[flexDirection]);
|
|
}
|
|
|
|
[flexWrapProperty.getDefault](): FlexWrap {
|
|
return flexWrapProperty.defaultValue;
|
|
}
|
|
[flexWrapProperty.setNative](flexWrap: FlexWrap) {
|
|
this.nativeViewProtected.setFlexWrap(flexWrapMap[flexWrap]);
|
|
}
|
|
|
|
[justifyContentProperty.getDefault](): JustifyContent {
|
|
return justifyContentProperty.defaultValue;
|
|
}
|
|
[justifyContentProperty.setNative](justifyContent: JustifyContent) {
|
|
this.nativeViewProtected.setJustifyContent(justifyContentMap[justifyContent]);
|
|
}
|
|
|
|
[alignItemsProperty.getDefault](): AlignItems {
|
|
return alignItemsProperty.defaultValue;
|
|
}
|
|
[alignItemsProperty.setNative](alignItems: AlignItems) {
|
|
this.nativeViewProtected.setAlignItems(alignItemsMap[alignItems]);
|
|
}
|
|
|
|
[alignContentProperty.getDefault](): AlignContent {
|
|
return alignContentProperty.defaultValue;
|
|
}
|
|
[alignContentProperty.setNative](alignContent: AlignContent) {
|
|
this.nativeViewProtected.setAlignContent(alignContentMap[alignContent]);
|
|
}
|
|
|
|
public _updateNativeLayoutParams(child: View): void {
|
|
super._updateNativeLayoutParams(child);
|
|
|
|
const lp = <org.nativescript.widgets.FlexboxLayout.LayoutParams>child.nativeViewProtected.getLayoutParams();
|
|
const style = child.style;
|
|
lp.order = style.order;
|
|
lp.flexGrow = style.flexGrow;
|
|
lp.flexShrink = style.flexShrink;
|
|
lp.wrapBefore = style.flexWrapBefore;
|
|
lp.alignSelf = alignSelfMap[style.alignSelf];
|
|
child.nativeViewProtected.setLayoutParams(lp);
|
|
}
|
|
|
|
public _setChildMinWidthNative(child: View): void {
|
|
child._setMinWidthNative(0);
|
|
const nativeView = child.nativeViewProtected;
|
|
const lp = nativeView.getLayoutParams();
|
|
if (lp instanceof widgetLayoutParams) {
|
|
lp.minWidth = Length.toDevicePixels(child.style.minWidth, 0);
|
|
nativeView.setLayoutParams(lp);
|
|
}
|
|
}
|
|
|
|
public _setChildMinHeightNative(child: View): void {
|
|
child._setMinHeightNative(0);
|
|
const nativeView = child.nativeViewProtected;
|
|
const lp = nativeView.getLayoutParams();
|
|
if (lp instanceof widgetLayoutParams) {
|
|
lp.minHeight = Length.toDevicePixels(child.style.minHeight, 0);
|
|
nativeView.setLayoutParams(lp);
|
|
}
|
|
}
|
|
}
|