mirror of
https://github.com/NativeScript/NativeScript.git
synced 2025-08-15 11:01:21 +08:00
190 lines
8.0 KiB
TypeScript
190 lines
8.0 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,
|
|
minWidthProperty, minHeightProperty,
|
|
CssProperty
|
|
} 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 ensureNativeTypes() {
|
|
if (!widgetFlexboxLayout) {
|
|
widgetFlexboxLayout = org.nativescript.widgets.FlexboxLayout;
|
|
widgetLayoutParams = widgetFlexboxLayout.LayoutParams;
|
|
}
|
|
}
|
|
|
|
function makeNativeSetter<T>(setter: (lp: org.nativescript.widgets.FlexboxLayout.LayoutParams, value: T) => void) {
|
|
return function (this: View, value: T) {
|
|
ensureNativeTypes();
|
|
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();
|
|
ensureNativeTypes();
|
|
}
|
|
|
|
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);
|
|
|
|
// NOTE: If minWidth/Height is not set, the next code will clear the default native values for minWidth/Height.
|
|
// Flex box will not respect the button default min width. Keeping this behavior for back-compatibility.
|
|
this._setChildMinWidthNative(child, child.minWidth);
|
|
this._setChildMinHeightNative(child, child.minHeight);
|
|
|
|
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, value: Length): void {
|
|
// Check needed to maintain back-compat after https://github.com/NativeScript/NativeScript/pull/7804
|
|
if (!child._ignoreFlexMinWidthHeightReset) {
|
|
child._setMinWidthNative(0);
|
|
}
|
|
|
|
const nativeView = child.nativeViewProtected;
|
|
const lp = nativeView.getLayoutParams();
|
|
if (lp instanceof widgetLayoutParams) {
|
|
lp.minWidth = Length.toDevicePixels(value, 0);
|
|
nativeView.setLayoutParams(lp);
|
|
}
|
|
}
|
|
|
|
public _setChildMinHeightNative(child: View, value: Length): void {
|
|
// Check needed to maintain back-compat after https://github.com/NativeScript/NativeScript/pull/7804
|
|
if (!child._ignoreFlexMinWidthHeightReset) {
|
|
child._setMinHeightNative(0);
|
|
}
|
|
|
|
const nativeView = child.nativeViewProtected;
|
|
const lp = nativeView.getLayoutParams();
|
|
if (lp instanceof widgetLayoutParams) {
|
|
lp.minHeight = Length.toDevicePixels(value, 0);
|
|
nativeView.setLayoutParams(lp);
|
|
}
|
|
}
|
|
}
|