@wavemaker/app-rn-runtime 11.4.3-patch.1 → 11.4.3-patch.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/components/advanced/carousel/carousel.component.js +4 -12
- package/components/advanced/carousel/carousel.component.js.map +1 -1
- package/components/advanced/login/login.component.js +2 -3
- package/components/advanced/login/login.component.js.map +1 -1
- package/components/advanced/network-info-toaster/network-info-toaster.component.js +16 -17
- package/components/advanced/network-info-toaster/network-info-toaster.component.js.map +1 -1
- package/components/advanced/webview/webview.component.js +0 -1
- package/components/advanced/webview/webview.component.js.map +1 -1
- package/components/basic/anchor/anchor.component.js +5 -7
- package/components/basic/anchor/anchor.component.js.map +1 -1
- package/components/basic/animatedview.component.js +50 -0
- package/components/basic/animatedview.component.js.map +1 -1
- package/components/basic/audio/audio.component.js +0 -5
- package/components/basic/audio/audio.component.js.map +1 -1
- package/components/basic/button/button.component.js +6 -7
- package/components/basic/button/button.component.js.map +1 -1
- package/components/basic/button/button.styles.js +4 -14
- package/components/basic/button/button.styles.js.map +1 -1
- package/components/basic/buttongroup/buttongroup.styles.js +1 -2
- package/components/basic/buttongroup/buttongroup.styles.js.map +1 -1
- package/components/basic/icon/icon.component.js +8 -7
- package/components/basic/icon/icon.component.js.map +1 -1
- package/components/basic/icon/icon.props.js +1 -0
- package/components/basic/icon/icon.props.js.map +1 -1
- package/components/basic/label/label.component.js +3 -60
- package/components/basic/label/label.component.js.map +1 -1
- package/components/basic/label/label.styles.js +1 -2
- package/components/basic/label/label.styles.js.map +1 -1
- package/components/basic/message/message.component.js +3 -6
- package/components/basic/message/message.component.js.map +1 -1
- package/components/basic/picture/picture.component.js +5 -7
- package/components/basic/picture/picture.component.js.map +1 -1
- package/components/basic/progress-bar/progress-bar.component.js +2 -4
- package/components/basic/progress-bar/progress-bar.component.js.map +1 -1
- package/components/basic/progress-bar/progress-bar.styles.js +1 -1
- package/components/basic/progress-bar/progress-bar.styles.js.map +1 -1
- package/components/basic/progress-circle/progress-circle.component.js +2 -3
- package/components/basic/progress-circle/progress-circle.component.js.map +1 -1
- package/components/basic/search/search.component.js +5 -9
- package/components/basic/search/search.component.js.map +1 -1
- package/components/basic/search/search.styles.js +10 -11
- package/components/basic/search/search.styles.js.map +1 -1
- package/components/basic/spinner/spinner.component.js +2 -6
- package/components/basic/spinner/spinner.component.js.map +1 -1
- package/components/basic/spinner/spinner.styles.js +2 -3
- package/components/basic/spinner/spinner.styles.js.map +1 -1
- package/components/basic/video/video.component.js +1 -2
- package/components/basic/video/video.component.js.map +1 -1
- package/components/chart/pie-chart/pie-chart.component.js +26 -2
- package/components/chart/pie-chart/pie-chart.component.js.map +1 -1
- package/components/chart/pie-chart/pie-chart.props.js +1 -0
- package/components/chart/pie-chart/pie-chart.props.js.map +1 -1
- package/components/container/accordion/accordion.component.js +13 -16
- package/components/container/accordion/accordion.component.js.map +1 -1
- package/components/container/accordion/accordionpane/accordionpane.component.js +22 -3
- package/components/container/accordion/accordionpane/accordionpane.component.js.map +1 -1
- package/components/container/container.component.js +2 -3
- package/components/container/container.component.js.map +1 -1
- package/components/container/panel/panel.component.js +66 -43
- package/components/container/panel/panel.component.js.map +1 -1
- package/components/container/panel/panel.styles.js +2 -9
- package/components/container/panel/panel.styles.js.map +1 -1
- package/components/container/tabs/tabheader/tabheader.component.js +5 -7
- package/components/container/tabs/tabheader/tabheader.component.js.map +1 -1
- package/components/container/tabs/tabheader/tabheader.styles.js +5 -9
- package/components/container/tabs/tabheader/tabheader.styles.js.map +1 -1
- package/components/container/tabs/tabs.component.js +0 -1
- package/components/container/tabs/tabs.component.js.map +1 -1
- package/components/container/tile/tile.component.js +2 -3
- package/components/container/tile/tile.component.js.map +1 -1
- package/components/container/wizard/wizard.component.js +2 -7
- package/components/container/wizard/wizard.component.js.map +1 -1
- package/components/container/wizard/wizard.styles.js +4 -15
- package/components/container/wizard/wizard.styles.js.map +1 -1
- package/components/data/card/card.component.js +2 -3
- package/components/data/card/card.component.js.map +1 -1
- package/components/data/form/form-action/form-action.component.js +0 -1
- package/components/data/form/form-action/form-action.component.js.map +1 -1
- package/components/data/form/form-field/form-field.component.js +2 -3
- package/components/data/form/form-field/form-field.component.js.map +1 -1
- package/components/data/form/form.component.js +0 -3
- package/components/data/form/form.component.js.map +1 -1
- package/components/data/list/list-template/list-template.styles.js +1 -5
- package/components/data/list/list-template/list-template.styles.js.map +1 -1
- package/components/data/list/list.component.js +2 -8
- package/components/data/list/list.component.js.map +1 -1
- package/components/data/list/list.styles.js +5 -12
- package/components/data/list/list.styles.js.map +1 -1
- package/components/device/barcodescanner/barcodescanner.component.js +0 -1
- package/components/device/barcodescanner/barcodescanner.component.js.map +1 -1
- package/components/device/barcodescanner/barcodescanner.styles.js +1 -2
- package/components/device/barcodescanner/barcodescanner.styles.js.map +1 -1
- package/components/device/camera/camera.component.js +0 -1
- package/components/device/camera/camera.component.js.map +1 -1
- package/components/device/camera/camera.styles.js +1 -2
- package/components/device/camera/camera.styles.js.map +1 -1
- package/components/dialogs/alertdialog/alertdialog.component.js +1 -4
- package/components/dialogs/alertdialog/alertdialog.component.js.map +1 -1
- package/components/dialogs/alertdialog/alertdialog.styles.js +3 -9
- package/components/dialogs/alertdialog/alertdialog.styles.js.map +1 -1
- package/components/dialogs/confirmdialog/confirmdialog.component.js +2 -6
- package/components/dialogs/confirmdialog/confirmdialog.component.js.map +1 -1
- package/components/dialogs/confirmdialog/confirmdialog.styles.js +10 -10
- package/components/dialogs/confirmdialog/confirmdialog.styles.js.map +1 -1
- package/components/dialogs/dialog/dialog.component.js +0 -2
- package/components/dialogs/dialog/dialog.component.js.map +1 -1
- package/components/dialogs/dialog/dialog.styles.js +8 -17
- package/components/dialogs/dialog/dialog.styles.js.map +1 -1
- package/components/input/calendar/calendar.component.js +0 -4
- package/components/input/calendar/calendar.component.js.map +1 -1
- package/components/input/calendar/calendar.styles.js +11 -22
- package/components/input/calendar/calendar.styles.js.map +1 -1
- package/components/input/calendar/views/month-view.js +0 -4
- package/components/input/calendar/views/month-view.js.map +1 -1
- package/components/input/checkbox/checkbox.component.js +6 -6
- package/components/input/checkbox/checkbox.component.js.map +1 -1
- package/components/input/checkboxset/checkboxset.component.js +4 -5
- package/components/input/checkboxset/checkboxset.component.js.map +1 -1
- package/components/input/chips/chips.component.js +4 -8
- package/components/input/chips/chips.component.js.map +1 -1
- package/components/input/chips/chips.styles.js +12 -20
- package/components/input/chips/chips.styles.js.map +1 -1
- package/components/input/currency/currency.component.js +1 -1
- package/components/input/currency/currency.component.js.map +1 -1
- package/components/input/currency/currency.styles.js +4 -12
- package/components/input/currency/currency.styles.js.map +1 -1
- package/components/input/epoch/base-datetime.component.js +4 -6
- package/components/input/epoch/base-datetime.component.js.map +1 -1
- package/components/input/fileupload/fileupload.component.js +0 -1
- package/components/input/fileupload/fileupload.component.js.map +1 -1
- package/components/input/number/number.component.js +1 -1
- package/components/input/number/number.component.js.map +1 -1
- package/components/input/number/number.styles.js +2 -6
- package/components/input/number/number.styles.js.map +1 -1
- package/components/input/radioset/radioset.component.js +2 -3
- package/components/input/radioset/radioset.component.js.map +1 -1
- package/components/input/rating/rating.component.js +0 -2
- package/components/input/rating/rating.component.js.map +1 -1
- package/components/input/select/select.component.js +14 -16
- package/components/input/select/select.component.js.map +1 -1
- package/components/input/select/select.styles.js +5 -4
- package/components/input/select/select.styles.js.map +1 -1
- package/components/input/slider/slider.component.js +23 -94
- package/components/input/slider/slider.component.js.map +1 -1
- package/components/input/slider/slider.styles.js +2 -27
- package/components/input/slider/slider.styles.js.map +1 -1
- package/components/input/switch/switch.component.js +4 -6
- package/components/input/switch/switch.component.js.map +1 -1
- package/components/input/switch/switch.styles.js +3 -5
- package/components/input/switch/switch.styles.js.map +1 -1
- package/components/input/text/text.component.js +1 -1
- package/components/input/text/text.component.js.map +1 -1
- package/components/input/text/text.styles.js +1 -5
- package/components/input/text/text.styles.js.map +1 -1
- package/components/input/textarea/textarea.component.js +1 -1
- package/components/input/textarea/textarea.component.js.map +1 -1
- package/components/input/toggle/toggle.component.js +2 -3
- package/components/input/toggle/toggle.component.js.map +1 -1
- package/components/input/toggle/toggle.styles.js +9 -21
- package/components/input/toggle/toggle.styles.js.map +1 -1
- package/components/navigation/appnavbar/appnavbar.component.js +2 -7
- package/components/navigation/appnavbar/appnavbar.component.js.map +1 -1
- package/components/navigation/appnavbar/appnavbar.styles.js +1 -1
- package/components/navigation/appnavbar/appnavbar.styles.js.map +1 -1
- package/components/navigation/menu/menu.component.js +3 -5
- package/components/navigation/menu/menu.component.js.map +1 -1
- package/components/navigation/menu/menu.styles.js +6 -10
- package/components/navigation/menu/menu.styles.js.map +1 -1
- package/components/navigation/navbar/navbar.component.js +4 -7
- package/components/navigation/navbar/navbar.component.js.map +1 -1
- package/components/navigation/navitem/navitem.component.js +0 -4
- package/components/navigation/navitem/navitem.component.js.map +1 -1
- package/components/navigation/navitem/navitem.styles.js +10 -14
- package/components/navigation/navitem/navitem.styles.js.map +1 -1
- package/components/navigation/popover/popover.component.js +4 -7
- package/components/navigation/popover/popover.component.js.map +1 -1
- package/components/navigation/popover/popover.styles.js +2 -8
- package/components/navigation/popover/popover.styles.js.map +1 -1
- package/components/page/left-panel/left-panel.styles.js +1 -6
- package/components/page/left-panel/left-panel.styles.js.map +1 -1
- package/components/page/tabbar/tabbar.component.js +6 -7
- package/components/page/tabbar/tabbar.component.js.map +1 -1
- package/core/base.component.js +37 -80
- package/core/base.component.js.map +1 -1
- package/core/formatters.js +2 -9
- package/core/formatters.js.map +1 -1
- package/core/tappable.component.js +5 -15
- package/core/tappable.component.js.map +1 -1
- package/package.json +2 -3
- package/runtime/App.js +8 -18
- package/runtime/App.js.map +1 -1
- package/runtime/base-fragment.component.js +3 -13
- package/runtime/base-fragment.component.js.map +1 -1
- package/runtime/services/device/camera-service.js +9 -26
- package/runtime/services/device/camera-service.js.map +1 -1
- package/runtime/services/device/scan-service.js +2 -16
- package/runtime/services/device/scan-service.js.map +1 -1
- package/styles/theme.variables.js +3 -14
- package/styles/theme.variables.js.map +1 -1
- package/components/container/panel/collapsible-pane.component.js +0 -26
- package/components/container/panel/collapsible-pane.component.js.map +0 -1
- package/core/change.queue.js +0 -26
- package/core/change.queue.js.map +0 -1
- package/core/testid.provider.js +0 -5
- package/core/testid.provider.js.map +0 -1
- package/styles/fdfd.css +0 -56
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["BASE_THEME","defineStyles","DEFAULT_CLASS","registerStyle","themeVariables","addStyle","defaultStyles","root","
|
|
1
|
+
{"version":3,"names":["BASE_THEME","defineStyles","DEFAULT_CLASS","registerStyle","themeVariables","addStyle","defaultStyles","root","padding","borderWidth","borderStyle","borderColor","inputBorderColor","backgroundColor","inputBackgroundColor","borderRadius","text","fontSize","textAlign","invalid","borderBottomColor","inputInvalidBorderColor","placeholderText","color","inputPlaceholderColor","skeleton","inputDisabledBgColor"],"sources":["number.styles.ts"],"sourcesContent":["import BASE_THEME, { AllStyle } from '@wavemaker/app-rn-runtime/styles/theme';\nimport { BaseStyles, defineStyles } from '@wavemaker/app-rn-runtime/core/base.component';\nimport { WmSkeletonStyles } from '../../basic/skeleton/skeleton.styles';\n\nexport type WmNumberStyles = BaseStyles & {\n invalid: AllStyle;\n placeholderText: AllStyle;\n skeleton: WmSkeletonStyles;\n};\n\nexport const DEFAULT_CLASS = 'app-number';\nBASE_THEME.registerStyle((themeVariables, addStyle) => {\n const defaultStyles: WmNumberStyles = defineStyles<WmNumberStyles>({\n root: {\n padding: 12,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: themeVariables.inputBorderColor,\n backgroundColor: themeVariables.inputBackgroundColor,\n borderRadius: 6\n },\n text: {\n fontSize: 16,\n textAlign: 'left'\n },\n invalid: {\n borderBottomColor: themeVariables.inputInvalidBorderColor\n },\n placeholderText: {\n color: themeVariables.inputPlaceholderColor\n },\n skeleton: {} as WmSkeletonStyles\n });\n\n addStyle(DEFAULT_CLASS, '', defaultStyles);\n addStyle(DEFAULT_CLASS + '-disabled', '', {\n root : {\n backgroundColor: themeVariables.inputDisabledBgColor\n }\n });\n addStyle(DEFAULT_CLASS + '-rtl', '', {\n root : {\n textAlign: 'right'\n }\n });\n});\n\n"],"mappings":"AAAA,OAAOA,UAAU,MAAoB,wCAAwC;AAC7E,SAAqBC,YAAY,QAAQ,+CAA+C;AASxF,OAAO,MAAMC,aAAa,GAAG,YAAY;AACzCF,UAAU,CAACG,aAAa,CAAC,CAACC,cAAc,EAAEC,QAAQ,KAAK;EACrD,MAAMC,aAA6B,GAAGL,YAAY,CAAiB;IAC/DM,IAAI,EAAE;MACJC,OAAO,EAAE,EAAE;MACXC,WAAW,EAAE,CAAC;MACdC,WAAW,EAAE,OAAO;MACpBC,WAAW,EAAEP,cAAc,CAACQ,gBAAgB;MAC5CC,eAAe,EAAET,cAAc,CAACU,oBAAoB;MACpDC,YAAY,EAAE;IAChB,CAAC;IACDC,IAAI,EAAE;MACJC,QAAQ,EAAE,EAAE;MACZC,SAAS,EAAE;IACb,CAAC;IACDC,OAAO,EAAE;MACPC,iBAAiB,EAAEhB,cAAc,CAACiB;IACpC,CAAC;IACDC,eAAe,EAAE;MACfC,KAAK,EAAEnB,cAAc,CAACoB;IACxB,CAAC;IACDC,QAAQ,EAAE,CAAC;EACf,CAAC,CAAC;EAEFpB,QAAQ,CAACH,aAAa,EAAE,EAAE,EAAEI,aAAa,CAAC;EAC1CD,QAAQ,CAACH,aAAa,GAAG,WAAW,EAAE,EAAE,EAAE;IACtCK,IAAI,EAAG;MACLM,eAAe,EAAET,cAAc,CAACsB;IAClC;EACJ,CAAC,CAAC;EACFrB,QAAQ,CAACH,aAAa,GAAG,MAAM,EAAE,EAAE,EAAE;IACjCK,IAAI,EAAG;MACLW,SAAS,EAAE;IACb;EACJ,CAAC,CAAC;AACJ,CAAC,CAAC"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
2
1
|
import React from 'react';
|
|
3
2
|
import { View, Text } from 'react-native';
|
|
4
3
|
import { RadioButton } from 'react-native-paper';
|
|
@@ -21,12 +20,12 @@ export default class WmRadioset extends BaseDatasetComponent {
|
|
|
21
20
|
width: colWidth
|
|
22
21
|
}],
|
|
23
22
|
key: item.key
|
|
24
|
-
}, /*#__PURE__*/React.createElement(RadioButton.Android,
|
|
23
|
+
}, /*#__PURE__*/React.createElement(RadioButton.Android, {
|
|
25
24
|
value: this.state.props.datafield === 'All Fields' ? this.getItemKey(item.datafield) : item.datafield,
|
|
26
25
|
color: this.styles.root.color,
|
|
27
26
|
uncheckedColor: this.styles.root.color,
|
|
28
27
|
disabled: this.state.props.readonly || this.state.props.disabled
|
|
29
|
-
})
|
|
28
|
+
}), /*#__PURE__*/React.createElement(Text, {
|
|
30
29
|
style: this.styles.radioLabel
|
|
31
30
|
}, displayText));
|
|
32
31
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","View","Text","RadioButton","WmRadiosetProps","DEFAULT_CLASS","BaseDatasetComponent","BaseDatasetState","WmRadiosetState","WmRadioset","constructor","props","onPress","value","invokeEventCallback","proxy","onValueChange","renderChild","item","index","colWidth","displayText","displayexp","displayfield","createElement","style","styles","radioHead","width","key","Android","
|
|
1
|
+
{"version":3,"names":["React","View","Text","RadioButton","WmRadiosetProps","DEFAULT_CLASS","BaseDatasetComponent","BaseDatasetState","WmRadiosetState","WmRadioset","constructor","props","onPress","value","invokeEventCallback","proxy","onValueChange","renderChild","item","index","colWidth","displayText","displayexp","displayfield","createElement","style","styles","radioHead","width","key","Android","state","datafield","getItemKey","color","root","uncheckedColor","disabled","readonly","radioLabel","renderGroupby","groupedData","length","map","groupObj","groupHeaderTitle","renderRadioButtons","data","items","noOfColumns","itemsperrow","xs","Math","round","Group","bind","datavalue","group","renderWidget","dataItems","groupby"],"sources":["radioset.component.tsx"],"sourcesContent":["import React from 'react';\nimport { View, Text, DimensionValue } from 'react-native';\nimport { RadioButton } from 'react-native-paper';\n\nimport WmRadiosetProps from './radioset.props';\nimport { DEFAULT_CLASS, WmRadiosetStyles } from './radioset.styles';\nimport {\n BaseDatasetComponent,\n BaseDatasetState\n} from '@wavemaker/app-rn-runtime/components/input/basedataset/basedataset.component';\nimport WmSkeleton, { createSkeleton } from '../../basic/skeleton/skeleton.component';\n\nexport class WmRadiosetState extends BaseDatasetState<WmRadiosetProps> {\n}\n\nexport default class WmRadioset extends BaseDatasetComponent<WmRadiosetProps, WmRadiosetState, WmRadiosetStyles> {\n\n constructor(props: WmRadiosetProps) {\n super(props, DEFAULT_CLASS, new WmRadiosetProps());\n }\n\n onPress(value: any) {\n this.invokeEventCallback('onTap', [null, this.proxy]);\n this.onValueChange(value);\n }\n\n renderChild(item: any, index: any, colWidth: DimensionValue) {\n const displayText = item.displayexp || item.displayfield;\n return (\n <View style={[this.styles.radioHead, {width: colWidth}]} key={item.key}>\n <RadioButton.Android\n value={this.state.props.datafield === 'All Fields' ? this.getItemKey(item.datafield) : item.datafield}\n color={this.styles.root.color as string}\n uncheckedColor={this.styles.root.color as string}\n disabled={this.state.props.readonly || this.state.props.disabled}\n />\n <Text style={this.styles.radioLabel}>{displayText}</Text>\n </View>)\n }\n\n renderGroupby() {\n const groupedData = this.state.groupedData;\n return (\n <View>\n {groupedData && groupedData.length\n ? groupedData.map((groupObj: any, index: any) => {\n return(\n <View key={groupObj.key}>\n <Text style={this.styles.groupHeaderTitle}>{groupObj.key}</Text>\n {this.renderRadioButtons(groupObj.data)}\n </View>)\n })\n : null}\n </View>\n );\n }\n\n renderRadioButtons(items: any) {\n const props = this.state.props;\n const noOfColumns = props.itemsperrow.xs || 1;\n const colWidth = Math.round(100/ noOfColumns) + '%' as DimensionValue;\n return(<RadioButton.Group onValueChange={this.onPress.bind(this)} value={this.state.props.datafield === 'All Fields'? this.getItemKey(props.datavalue) : props.datavalue}>\n <View style={this.styles.group}>\n {items && items.length ?\n items.map((item: any, index: any) => this.renderChild(item, index, colWidth)): null}\n </View>\n </RadioButton.Group>)\n }\n\n renderWidget(props: WmRadiosetProps) {\n const items = this.state.dataItems;\n return (\n <View style={this.styles.root}>\n {props.groupby && this.renderGroupby()}\n {!props.groupby && this.renderRadioButtons(items)}\n </View>\n );\n }\n}\n"],"mappings":"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"}
|
|
@@ -119,7 +119,6 @@ export default class WmRating extends BaseComponent {
|
|
|
119
119
|
return /*#__PURE__*/React.createElement(View, {
|
|
120
120
|
style: this.styles.root
|
|
121
121
|
}, this._background, arr.map((v, i) => this.state.selectedIndex > -1 && i <= this.state.selectedIndex ? /*#__PURE__*/React.createElement(WmIcon, {
|
|
122
|
-
id: this.getTestId('star' + i),
|
|
123
122
|
key: i,
|
|
124
123
|
iconclass: "wi wi-star",
|
|
125
124
|
iconsize: props.iconsize,
|
|
@@ -128,7 +127,6 @@ export default class WmRating extends BaseComponent {
|
|
|
128
127
|
this.changeValue(i);
|
|
129
128
|
}
|
|
130
129
|
}) : null), arr.map((v, i) => this.state.selectedIndex === -1 || i > this.state.selectedIndex ? /*#__PURE__*/React.createElement(WmIcon, {
|
|
131
|
-
id: this.getTestId('star' + i),
|
|
132
130
|
key: i,
|
|
133
131
|
iconclass: "wi wi-star-border",
|
|
134
132
|
iconsize: props.iconsize,
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","View","Text","BaseComponent","BaseComponentState","WmIcon","WmRatingProps","DEFAULT_CLASS","cloneDeep","isArray","isNumber","isString","WmRatingState","constructor","arguments","_defineProperty","WmRating","props","caption","state","prepareItems","items","dataset","maxvalue","Array","from","keys","map","v","split","Object","i","key","value","selectedIndex","datavalue","undefined","findIndex","item","k","datafield","showcaptions","selectedItem","getDisplayExpression","displayfield","updateState","onPropertyChange","name","$new","$old","isDefault","onFieldChange","bind","disabled","changeValue","oldValue","readonly","invokeEventCallback","proxy","renderWidget","maxValue","arr","selectedIconStyles","styles","selectedIcon","iconcolor","text","color","createElement","style","root","_background","id","getTestId","iconclass","iconsize","onTap","icon"],"sources":["rating.component.tsx"],"sourcesContent":["import React from 'react';\nimport { View, Text } from 'react-native';\nimport { BaseComponent, BaseComponentState } from '@wavemaker/app-rn-runtime/core/base.component';\nimport WmIcon from '@wavemaker/app-rn-runtime/components/basic/icon/icon.component';\n\nimport WmRatingProps from './rating.props';\nimport { DEFAULT_CLASS, WmRatingStyles } from './rating.styles';\nimport { cloneDeep, isArray, isEmpty, isNumber, isString } from 'lodash-es';\n\nexport class WmRatingState extends BaseComponentState<WmRatingProps> {\n items: any[] = null as any;\n caption: any = null as any;\n selectedIndex = -1;\n isDefault = false;\n}\n\nexport default class WmRating extends BaseComponent<WmRatingProps, WmRatingState, WmRatingStyles> {\n\n constructor(props: WmRatingProps) {\n super(props, DEFAULT_CLASS, new WmRatingProps());\n }\n\n get caption() {\n return this.state.caption;\n }\n\n prepareItems(props: WmRatingProps) {\n let items: any[] = [];\n if (!props.dataset && props.maxvalue) {\n items = Array.from(Array(+props.maxvalue).keys());\n items = items.map(v => v + 1);\n } else if (isString(props.dataset)) {\n items = props.dataset.split(',');\n } else {\n items = props.dataset as any[] || [];\n }\n if (isArray(items) && items[0] !== Object(items[0])) {\n items = items.map((v, i) => ({\n key: i + 1,\n value: v\n }));\n }\n let selectedIndex = -1;\n if (props.datavalue !== undefined && props.datavalue !== null) {\n selectedIndex = items.findIndex((item: any, k) => item[props.datafield as string] == props.datavalue);\n if (selectedIndex === -1 && isNumber(props.datavalue)) {\n selectedIndex = props.datavalue;\n }\n }\n let caption: any = '';\n if (selectedIndex > -1 && props.showcaptions) {\n const selectedItem = items[selectedIndex];\n if (selectedItem) {\n if (props.getDisplayExpression) {\n caption = props.getDisplayExpression(selectedItem);\n } else {\n caption = selectedItem[props.displayfield as string];\n }\n } else {\n caption = selectedIndex + 1;\n }\n }\n this.updateState({\n items: items,\n selectedIndex: selectedIndex,\n caption: caption\n } as WmRatingState);\n }\n\n onPropertyChange(name: string, $new: any, $old: any) {\n switch(name) {\n case 'dataset' :\n case 'datafield' :\n case 'displayfield' :\n case 'maxvalue':\n case 'datavalue' :\n this.prepareItems(this.state.props);\n if (name === 'datavalue') {\n const isDefault = this.state.isDefault;\n if (isDefault) {\n this.updateState({ isDefault: false } as WmRatingState, this.props.onFieldChange && this.props.onFieldChange.bind(this, 'datavalue', $new, $old, isDefault));\n } else {\n this.props.onFieldChange && this.props.onFieldChange('datavalue', $new, $old, isDefault);\n }\n }\n break;\n case 'readonly' :\n this.updateState({\n props: {\n disabled: $new\n }\n } as WmRatingState);\n break;\n }\n }\n\n changeValue(i: number) {\n const props = this.state.props;\n const oldValue = props.datavalue;\n if (!props.readonly) {\n let value = this.state.items[i] ? this.state.items[i][props.datafield || '']: i;\n this.updateState({\n props: {\n datavalue: value\n }\n } as WmRatingState, () => {\n !this.props.onFieldChange && value !== oldValue && this.invokeEventCallback('onChange', [undefined, this.proxy, value, oldValue]);\n });\n }\n }\n\n renderWidget(props: WmRatingProps) {\n const maxValue = props.maxvalue ? +props.maxvalue : 5;\n const arr = Array.from(Array(maxValue).keys());\n\n let selectedIconStyles = this.styles.selectedIcon;\n if (props.iconcolor) {\n selectedIconStyles = cloneDeep(this.styles.selectedIcon);\n selectedIconStyles.text.color = props.iconcolor;\n }\n return (\n <View style={this.styles.root}>\n {this._background}\n {arr.map((v, i) => (\n (this.state.selectedIndex > -1 && i <= this.state.selectedIndex) ? <WmIcon\n id={this.getTestId('star' + i)}\n key={i}\n iconclass=\"wi wi-star\"\n iconsize={props.iconsize}\n styles={selectedIconStyles}\n onTap={() => { this.changeValue(i)}}\n ></WmIcon> : null\n ))}\n {arr.map((v, i) => (\n (this.state.selectedIndex === -1 || i > this.state.selectedIndex) ? <WmIcon\n id={this.getTestId('star' + i)}\n key={i}\n iconclass=\"wi wi-star-border\"\n iconsize={props.iconsize}\n styles={this.styles.icon}\n onTap={() => { this.changeValue(i)}}\n ></WmIcon> : null\n ))}\n { !!props.showcaptions ? (<Text style={this.styles.text}>{this.state.caption}</Text>) : null }\n </View>);\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["React","View","Text","BaseComponent","BaseComponentState","WmIcon","WmRatingProps","DEFAULT_CLASS","cloneDeep","isArray","isNumber","isString","WmRatingState","constructor","arguments","_defineProperty","WmRating","props","caption","state","prepareItems","items","dataset","maxvalue","Array","from","keys","map","v","split","Object","i","key","value","selectedIndex","datavalue","undefined","findIndex","item","k","datafield","showcaptions","selectedItem","getDisplayExpression","displayfield","updateState","onPropertyChange","name","$new","$old","isDefault","onFieldChange","bind","disabled","changeValue","oldValue","readonly","invokeEventCallback","proxy","renderWidget","maxValue","arr","selectedIconStyles","styles","selectedIcon","iconcolor","text","color","createElement","style","root","_background","iconclass","iconsize","onTap","icon"],"sources":["rating.component.tsx"],"sourcesContent":["import React from 'react';\nimport { View, Text } from 'react-native';\nimport { BaseComponent, BaseComponentState } from '@wavemaker/app-rn-runtime/core/base.component';\nimport WmIcon from '@wavemaker/app-rn-runtime/components/basic/icon/icon.component';\n\nimport WmRatingProps from './rating.props';\nimport { DEFAULT_CLASS, WmRatingStyles } from './rating.styles';\nimport { cloneDeep, isArray, isEmpty, isNumber, isString } from 'lodash-es';\n\nexport class WmRatingState extends BaseComponentState<WmRatingProps> {\n items: any[] = null as any;\n caption: any = null as any;\n selectedIndex = -1;\n isDefault = false;\n}\n\nexport default class WmRating extends BaseComponent<WmRatingProps, WmRatingState, WmRatingStyles> {\n\n constructor(props: WmRatingProps) {\n super(props, DEFAULT_CLASS, new WmRatingProps());\n }\n\n get caption() {\n return this.state.caption;\n }\n\n prepareItems(props: WmRatingProps) {\n let items: any[] = [];\n if (!props.dataset && props.maxvalue) {\n items = Array.from(Array(+props.maxvalue).keys());\n items = items.map(v => v + 1);\n } else if (isString(props.dataset)) {\n items = props.dataset.split(',');\n } else {\n items = props.dataset as any[] || [];\n }\n if (isArray(items) && items[0] !== Object(items[0])) {\n items = items.map((v, i) => ({\n key: i + 1,\n value: v\n }));\n }\n let selectedIndex = -1;\n if (props.datavalue !== undefined && props.datavalue !== null) {\n selectedIndex = items.findIndex((item: any, k) => item[props.datafield as string] == props.datavalue);\n if (selectedIndex === -1 && isNumber(props.datavalue)) {\n selectedIndex = props.datavalue;\n }\n }\n let caption: any = '';\n if (selectedIndex > -1 && props.showcaptions) {\n const selectedItem = items[selectedIndex];\n if (selectedItem) {\n if (props.getDisplayExpression) {\n caption = props.getDisplayExpression(selectedItem);\n } else {\n caption = selectedItem[props.displayfield as string];\n }\n } else {\n caption = selectedIndex + 1;\n }\n }\n this.updateState({\n items: items,\n selectedIndex: selectedIndex,\n caption: caption\n } as WmRatingState);\n }\n\n onPropertyChange(name: string, $new: any, $old: any) {\n switch(name) {\n case 'dataset' :\n case 'datafield' :\n case 'displayfield' :\n case 'maxvalue':\n case 'datavalue' :\n this.prepareItems(this.state.props);\n if (name === 'datavalue') {\n const isDefault = this.state.isDefault;\n if (isDefault) {\n this.updateState({ isDefault: false } as WmRatingState, this.props.onFieldChange && this.props.onFieldChange.bind(this, 'datavalue', $new, $old, isDefault));\n } else {\n this.props.onFieldChange && this.props.onFieldChange('datavalue', $new, $old, isDefault);\n }\n }\n break;\n case 'readonly' :\n this.updateState({\n props: {\n disabled: $new\n }\n } as WmRatingState);\n break;\n }\n }\n\n changeValue(i: number) {\n const props = this.state.props;\n const oldValue = props.datavalue;\n if (!props.readonly) {\n let value = this.state.items[i] ? this.state.items[i][props.datafield || '']: i;\n this.updateState({\n props: {\n datavalue: value\n }\n } as WmRatingState, () => {\n !this.props.onFieldChange && value !== oldValue && this.invokeEventCallback('onChange', [undefined, this.proxy, value, oldValue]);\n });\n }\n }\n\n renderWidget(props: WmRatingProps) {\n const maxValue = props.maxvalue ? +props.maxvalue : 5;\n const arr = Array.from(Array(maxValue).keys());\n\n let selectedIconStyles = this.styles.selectedIcon;\n if (props.iconcolor) {\n selectedIconStyles = cloneDeep(this.styles.selectedIcon);\n selectedIconStyles.text.color = props.iconcolor;\n }\n return (\n <View style={this.styles.root}>\n {this._background}\n {arr.map((v, i) => (\n (this.state.selectedIndex > -1 && i <= this.state.selectedIndex) ? <WmIcon\n key={i}\n iconclass=\"wi wi-star\"\n iconsize={props.iconsize}\n styles={selectedIconStyles}\n onTap={() => { this.changeValue(i)}}\n ></WmIcon> : null\n ))}\n {arr.map((v, i) => (\n (this.state.selectedIndex === -1 || i > this.state.selectedIndex) ? <WmIcon\n key={i}\n iconclass=\"wi wi-star-border\"\n iconsize={props.iconsize}\n styles={this.styles.icon}\n onTap={() => { this.changeValue(i)}}\n ></WmIcon> : null\n ))}\n { !!props.showcaptions ? (<Text style={this.styles.text}>{this.state.caption}</Text>) : null }\n </View>);\n }\n}\n"],"mappings":"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"}
|
|
@@ -1,4 +1,3 @@
|
|
|
1
|
-
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
2
1
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
3
2
|
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
4
3
|
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
@@ -100,16 +99,15 @@ export default class WmSelect extends BaseDatasetComponent {
|
|
|
100
99
|
this.view = ref;
|
|
101
100
|
},
|
|
102
101
|
onLayout: () => {}
|
|
103
|
-
}, /*#__PURE__*/React.createElement(Text,
|
|
102
|
+
}, /*#__PURE__*/React.createElement(Text, {
|
|
104
103
|
style: [this.styles.text, this.state.props.displayValue ? {} : {
|
|
105
104
|
color: this.styles.placeholderText.color
|
|
106
105
|
}],
|
|
107
106
|
ref: ref => {
|
|
108
107
|
this.widgetRef = ref;
|
|
109
|
-
}
|
|
110
|
-
}, this.getTestPropsForInput(), {
|
|
108
|
+
},
|
|
111
109
|
onPress: this.onPress.bind(this)
|
|
112
|
-
}
|
|
110
|
+
}, this.state.props.displayValue || props.placeholder || ' '), /*#__PURE__*/React.createElement(WmButton, {
|
|
113
111
|
styles: this.styles.arrowButton,
|
|
114
112
|
iconclass: 'wi wi-keyboard-arrow-down',
|
|
115
113
|
onTap: this.onPress.bind(this)
|
|
@@ -125,21 +123,21 @@ export default class WmSelect extends BaseDatasetComponent {
|
|
|
125
123
|
this.onChange(isPlaceholder ? '' : this.state.props.datafield === 'All Fields' ? item.dataObject : item.datafield);
|
|
126
124
|
this.hide();
|
|
127
125
|
}
|
|
128
|
-
renderSelectItem(item,
|
|
129
|
-
|
|
126
|
+
renderSelectItem(item, isPlaceholder, isLast) {
|
|
127
|
+
let selected = this.isSelected(item);
|
|
128
|
+
return /*#__PURE__*/React.createElement(Tappable, {
|
|
130
129
|
onTap: this.onItemSelect.bind(this, item, isPlaceholder)
|
|
131
|
-
}
|
|
132
|
-
style: [this.styles.selectItem, isLast ? this.styles.lastSelectItem : null]
|
|
133
|
-
}, /*#__PURE__*/React.createElement(Text,
|
|
130
|
+
}, /*#__PURE__*/React.createElement(View, {
|
|
131
|
+
style: [this.styles.selectItem, isLast ? this.styles.lastSelectItem : null, selected ? this.styles.selectedItem : null]
|
|
132
|
+
}, /*#__PURE__*/React.createElement(Text, {
|
|
134
133
|
style: [this.styles.selectItemText, {
|
|
135
|
-
color: isPlaceholder ? this.styles.placeholderText.color : this.styles.selectItemText.color
|
|
134
|
+
color: isPlaceholder ? this.styles.placeholderText.color : selected ? this.styles.selectedItemText.color : this.styles.selectItemText.color
|
|
136
135
|
}]
|
|
137
|
-
}
|
|
138
|
-
id: this.getTestId('checkicon' + index),
|
|
136
|
+
}, isPlaceholder ? this.state.props.placeholder : item.displayexp || item.displayfield), /*#__PURE__*/React.createElement(WmIcon, {
|
|
139
137
|
iconclass: "wi wi-check",
|
|
140
138
|
styles: this.theme.mergeStyle(this.styles.checkIcon, {
|
|
141
139
|
root: {
|
|
142
|
-
opacity: !isPlaceholder &&
|
|
140
|
+
opacity: !isPlaceholder && selected ? 1 : 0
|
|
143
141
|
}
|
|
144
142
|
})
|
|
145
143
|
})));
|
|
@@ -174,9 +172,9 @@ export default class WmSelect extends BaseDatasetComponent {
|
|
|
174
172
|
}, props.placeholder ? /*#__PURE__*/React.createElement(View, {
|
|
175
173
|
key: props.name + '_placeholder',
|
|
176
174
|
style: this.styles.placeholderText
|
|
177
|
-
}, this.renderSelectItem({},
|
|
175
|
+
}, this.renderSelectItem({}, true, false)) : null, items && items.map((item, index) => /*#__PURE__*/React.createElement(View, {
|
|
178
176
|
key: item.key
|
|
179
|
-
}, this.renderSelectItem(item,
|
|
177
|
+
}, this.renderSelectItem(item, false, index === items.length - 1)))), this.styles, modalService));
|
|
180
178
|
return null;
|
|
181
179
|
}) : null);
|
|
182
180
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","ScrollView","Text","View","find","isEmpty","WmSelectProps","DEFAULT_CLASS","BaseDatasetComponent","BaseDatasetState","WmIcon","ModalConsumer","WmButton","Tappable","ThemeVariables","WmSelectState","constructor","arguments","_defineProperty","WmSelect","props","updateState","isOpened","onPress","event","state","disabled","showPopover","invokeEventCallback","proxy","onPropertyChange","name","$new","$old","isNaN","displayValue","placeholder","prepareModalOptions","content","styles","modalService","o","modalOptions","modalStyle","modal","contentStyle","modalContent","isModal","centered","onClose","hide","isDefaultValue","validate","triggerValidation","setState","hideModal","focus","_this$widgetRef","widgetRef","renderSelect","createElement","style","root","isValid","invalid","backgroundColor","disabledText","ref","view","onLayout","_extends","text","color","placeholderText","getTestPropsForInput","bind","arrowButton","iconclass","onTap","isSelected","item","val","datafield","dataObject","datavalue","onItemSelect","isPlaceholder","onChange","renderSelectItem","index","isLast","getTestPropsForAction","selectItem","lastSelectItem","getTestPropsForLabel","selectItemText","displayexp","displayfield","id","getTestId","theme","mergeStyle","checkIcon","opacity","updateDefaultQueryModel","dataItems","length","selectedItem","selected","componentDidMount","onDataItemsUpdate","renderWidget","items","showModal","width","maxHeight","INSTANCE","maxModalHeight","contentContainerStyle","dropDownContent","key","map"],"sources":["select.component.tsx"],"sourcesContent":["import React from 'react';\nimport { ScrollView, Text, View } from 'react-native';\nimport { find, isEmpty } from 'lodash';\n\nimport WmSelectProps from './select.props';\nimport { DEFAULT_CLASS, WmSelectStyles } from './select.styles';\nimport {\n BaseDatasetComponent,\n BaseDatasetState\n} from '@wavemaker/app-rn-runtime/components/input/basedataset/basedataset.component';\nimport WmIcon from '@wavemaker/app-rn-runtime/components/basic/icon/icon.component';\nimport { ModalConsumer, ModalOptions, ModalService } from '@wavemaker/app-rn-runtime/core/modal.service';\nimport WmButton from '@wavemaker/app-rn-runtime/components/basic/button/button.component';\nimport { Tappable } from '@wavemaker/app-rn-runtime/core/tappable.component';\nimport ThemeVariables from '@wavemaker/app-rn-runtime/styles/theme.variables';\n\nexport class WmSelectState extends BaseDatasetState<WmSelectProps> {\n modalOptions = {} as ModalOptions;\n isOpened: boolean = false;\n selectedValue: any = '';\n}\n\nexport default class WmSelect extends BaseDatasetComponent<WmSelectProps, WmSelectState, WmSelectStyles> {\n constructor(props: WmSelectProps) {\n super(props, DEFAULT_CLASS, new WmSelectProps(), new WmSelectState());\n }\n view: View = null as any;\n public widgetRef: Text | null = null;\n private isDefaultValue: boolean = true;\n\n onPress(event: any) {\n if (this.state.props.disabled) {\n return;\n }\n if (!this.state.isOpened) {\n this.showPopover();\n }\n this.invokeEventCallback('onFocus', [event, this.proxy]);\n }\n\n onPropertyChange(name: string, $new: any, $old: any): void {\n super.onPropertyChange(name, $new, $old);\n switch(name) {\n case 'datavalue':\n if (isNaN($new) && isEmpty($new)) {\n this.updateState({\n props: {\n displayValue: this.state.props.placeholder || ''\n }\n } as WmSelectState);\n }\n }\n }\n\n prepareModalOptions(content: React.ReactNode, styles: WmSelectStyles, modalService: ModalService) {\n const o = this.state.modalOptions;\n o.modalStyle = styles.modal;\n o.contentStyle = {...styles.modalContent};\n o.content = content;\n o.isModal = true;\n o.centered = true;\n o.onClose = () => {\n this.hide = () => {};\n if (this.isDefaultValue && this.state.props.displayValue === '') {\n this.validate(this.state.props.displayValue);\n this.props.triggerValidation && this.props.triggerValidation();\n }\n this.invokeEventCallback('onBlur', [{}, this.proxy]);\n this.setState({ isOpened: false, modalOptions: {} as ModalOptions } as WmSelectState);\n };\n this.hide = () => modalService.hideModal(this.state.modalOptions);\n return o;\n }\n\n public showPopover = () => {\n this.updateState({ isOpened: true } as WmSelectState);\n };\n\n public hide = () => {};\n\n focus() {\n this?.widgetRef?.focus();\n }\n\n renderSelect() {\n const props = this.state.props;\n return (\n /*\n * onLayout function is required.\n * https://github.com/naoufal/react-native-accordion/pull/19/files\n */\n <View\n style={[this.styles.root, this.state.isValid ? {} : this.styles.invalid, { backgroundColor: props.disabled ? this.styles.disabledText.backgroundColor : this.styles.root.backgroundColor}]}\n ref={(ref) => {\n this.view = ref as View;\n }}\n onLayout={() => {}}>\n <Text\n style={[this.styles.text,\n this.state.props.displayValue ? {} : {color: this.styles.placeholderText.color}]}\n ref={(ref) => {\n this.widgetRef = ref;\n }}\n {...this.getTestPropsForInput()}\n onPress={this.onPress.bind(this)}>\n {this.state.props.displayValue || props.placeholder || ' '}\n </Text>\n <WmButton\n styles={this.styles.arrowButton}\n iconclass={'wi wi-keyboard-arrow-down'}\n onTap={this.onPress.bind(this)}\n />\n </View>\n );\n }\n\n isSelected(item: any) {\n const val = this.state.props.datafield === 'All Fields' ? item.dataObject : item.datafield;\n return this.state.props.datavalue === val;\n }\n\n onItemSelect(item: any, isPlaceholder?: boolean) {\n this.isDefaultValue = false;\n this.onChange(isPlaceholder ? '' : this.state.props.datafield === 'All Fields' ? item.dataObject : item.datafield);\n this.hide();\n }\n\n renderSelectItem(item: any, index: number, isPlaceholder: boolean, isLast: boolean) {\n return (\n <Tappable {...this.getTestPropsForAction(index + '')} onTap={this.onItemSelect.bind(this, item, isPlaceholder)}>\n <View style={[this.styles.selectItem, isLast ? this.styles.lastSelectItem : null ]}>\n <Text {...this.getTestPropsForLabel(index + '')} style={[this.styles.selectItemText, {color: isPlaceholder ? this.styles.placeholderText.color : this.styles.selectItemText.color}]}>\n {isPlaceholder ? this.state.props.placeholder : (item.displayexp || item.displayfield)}\n </Text>\n <WmIcon id={this.getTestId('checkicon' + index)} iconclass='wi wi-check' styles={this.theme.mergeStyle(this.styles.checkIcon, {\n root: {\n opacity: !isPlaceholder && this.isSelected(item) ? 1 : 0\n }\n })}></WmIcon>\n </View>\n </Tappable>\n );\n }\n\n updateDefaultQueryModel() {\n if (this.state.dataItems && this.state.dataItems.length && this.isDefaultValue) {\n const selectedItem = find(this.state.dataItems, (item) => item.selected);\n selectedItem && this.updateState({\n props: {\n displayValue: selectedItem.displayexp || selectedItem.displayfield || ''\n }\n } as WmSelectState);\n }\n }\n\n componentDidMount() {\n super.componentDidMount();\n this.updateDefaultQueryModel();\n }\n\n onDataItemsUpdate() {\n super.onDataItemsUpdate();\n this.updateDefaultQueryModel();\n }\n\n renderWidget(props: WmSelectProps) {\n return (\n <View>\n {this.renderSelect()}\n {this.state.isOpened ? (\n <ModalConsumer>\n {(modalService: ModalService) => {\n const items = this.state.dataItems;\n modalService.showModal(\n this.prepareModalOptions(\n <ScrollView style={{width: '100%', maxHeight: ThemeVariables.INSTANCE.maxModalHeight}} contentContainerStyle={this.styles.dropDownContent}>\n {props.placeholder ?\n <View key={props.name + '_placeholder'} style={this.styles.placeholderText}>\n {this.renderSelectItem({}, 0, true, false)}\n </View>\n : null}\n {items && items.map((item: any, index: number) => (\n <View key={item.key}>\n {this.renderSelectItem(item, index, false, index === items.length - 1)}\n </View>\n ))}\n </ScrollView>,\n this.styles,\n modalService\n )\n );\n return null;\n }}\n </ModalConsumer>\n ) : null}\n </View>\n );\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["React","ScrollView","Text","View","find","isEmpty","WmSelectProps","DEFAULT_CLASS","BaseDatasetComponent","BaseDatasetState","WmIcon","ModalConsumer","WmButton","Tappable","ThemeVariables","WmSelectState","constructor","arguments","_defineProperty","WmSelect","props","updateState","isOpened","onPress","event","state","disabled","showPopover","invokeEventCallback","proxy","onPropertyChange","name","$new","$old","isNaN","displayValue","placeholder","prepareModalOptions","content","styles","modalService","o","modalOptions","modalStyle","modal","contentStyle","modalContent","isModal","centered","onClose","hide","isDefaultValue","validate","triggerValidation","setState","hideModal","focus","_this$widgetRef","widgetRef","renderSelect","createElement","style","root","isValid","invalid","backgroundColor","disabledText","ref","view","onLayout","text","color","placeholderText","bind","arrowButton","iconclass","onTap","isSelected","item","val","datafield","dataObject","datavalue","onItemSelect","isPlaceholder","onChange","renderSelectItem","isLast","selected","selectItem","lastSelectItem","selectedItem","selectItemText","selectedItemText","displayexp","displayfield","theme","mergeStyle","checkIcon","opacity","updateDefaultQueryModel","dataItems","length","componentDidMount","onDataItemsUpdate","renderWidget","items","showModal","width","maxHeight","INSTANCE","maxModalHeight","contentContainerStyle","dropDownContent","key","map","index"],"sources":["select.component.tsx"],"sourcesContent":["import React from 'react';\nimport { ScrollView, Text, View } from 'react-native';\nimport { find, isEmpty } from 'lodash';\n\nimport WmSelectProps from './select.props';\nimport { DEFAULT_CLASS, WmSelectStyles } from './select.styles';\nimport {\n BaseDatasetComponent,\n BaseDatasetState\n} from '@wavemaker/app-rn-runtime/components/input/basedataset/basedataset.component';\nimport WmIcon from '@wavemaker/app-rn-runtime/components/basic/icon/icon.component';\nimport { ModalConsumer, ModalOptions, ModalService } from '@wavemaker/app-rn-runtime/core/modal.service';\nimport WmButton from '@wavemaker/app-rn-runtime/components/basic/button/button.component';\nimport { Tappable } from '@wavemaker/app-rn-runtime/core/tappable.component';\nimport ThemeVariables from '@wavemaker/app-rn-runtime/styles/theme.variables';\n\nexport class WmSelectState extends BaseDatasetState<WmSelectProps> {\n modalOptions = {} as ModalOptions;\n isOpened: boolean = false;\n selectedValue: any = '';\n}\n\nexport default class WmSelect extends BaseDatasetComponent<WmSelectProps, WmSelectState, WmSelectStyles> {\n constructor(props: WmSelectProps) {\n super(props, DEFAULT_CLASS, new WmSelectProps(), new WmSelectState());\n }\n view: View = null as any;\n public widgetRef: Text | null = null;\n private isDefaultValue: boolean = true;\n\n onPress(event: any) {\n if (this.state.props.disabled) {\n return;\n }\n if (!this.state.isOpened) {\n this.showPopover();\n }\n this.invokeEventCallback('onFocus', [event, this.proxy]);\n }\n\n onPropertyChange(name: string, $new: any, $old: any): void {\n super.onPropertyChange(name, $new, $old);\n switch(name) {\n case 'datavalue':\n if (isNaN($new) && isEmpty($new)) {\n this.updateState({\n props: {\n displayValue: this.state.props.placeholder || ''\n }\n } as WmSelectState);\n }\n }\n }\n\n prepareModalOptions(content: React.ReactNode, styles: WmSelectStyles, modalService: ModalService) {\n const o = this.state.modalOptions;\n o.modalStyle = styles.modal;\n o.contentStyle = {...styles.modalContent};\n o.content = content;\n o.isModal = true;\n o.centered = true;\n o.onClose = () => {\n this.hide = () => {};\n if (this.isDefaultValue && this.state.props.displayValue === '') {\n this.validate(this.state.props.displayValue);\n this.props.triggerValidation && this.props.triggerValidation();\n }\n this.invokeEventCallback('onBlur', [{}, this.proxy]);\n this.setState({ isOpened: false, modalOptions: {} as ModalOptions } as WmSelectState);\n };\n this.hide = () => modalService.hideModal(this.state.modalOptions);\n return o;\n }\n\n public showPopover = () => {\n this.updateState({ isOpened: true } as WmSelectState);\n };\n\n public hide = () => {};\n\n focus() {\n this?.widgetRef?.focus();\n }\n\n renderSelect() {\n const props = this.state.props;\n return (\n /*\n * onLayout function is required.\n * https://github.com/naoufal/react-native-accordion/pull/19/files\n */\n <View\n style={[this.styles.root, this.state.isValid ? {} : this.styles.invalid, { backgroundColor: props.disabled ? this.styles.disabledText.backgroundColor : this.styles.root.backgroundColor}]}\n ref={(ref) => {\n this.view = ref as View;\n }}\n onLayout={() => {}}>\n <Text\n style={[this.styles.text,\n this.state.props.displayValue ? {} : {color: this.styles.placeholderText.color}]}\n ref={(ref) => {\n this.widgetRef = ref;\n }}\n onPress={this.onPress.bind(this)}>\n {this.state.props.displayValue || props.placeholder || ' '}\n </Text>\n <WmButton\n styles={this.styles.arrowButton}\n iconclass={'wi wi-keyboard-arrow-down'}\n onTap={this.onPress.bind(this)}\n />\n </View>\n );\n }\n\n isSelected(item: any) {\n const val = this.state.props.datafield === 'All Fields' ? item.dataObject : item.datafield;\n return this.state.props.datavalue === val;\n }\n\n onItemSelect(item: any, isPlaceholder?: boolean) {\n this.isDefaultValue = false;\n this.onChange(isPlaceholder ? '' : this.state.props.datafield === 'All Fields' ? item.dataObject : item.datafield);\n this.hide();\n }\n\n renderSelectItem(item: any, isPlaceholder: boolean, isLast: boolean) {\n let selected = this.isSelected(item);\n return (\n <Tappable onTap={this.onItemSelect.bind(this, item, isPlaceholder)}>\n <View style={[this.styles.selectItem, isLast ? this.styles.lastSelectItem : null, selected ? this.styles.selectedItem : null ]}>\n <Text style={[this.styles.selectItemText, {color: isPlaceholder ? this.styles.placeholderText.color : selected ? this.styles.selectedItemText.color : this.styles.selectItemText.color}]}>\n {isPlaceholder ? this.state.props.placeholder : (item.displayexp || item.displayfield)}\n </Text>\n <WmIcon iconclass='wi wi-check' styles={this.theme.mergeStyle(this.styles.checkIcon, {\n root: {\n opacity: !isPlaceholder && selected ? 1 : 0\n }\n })}></WmIcon>\n </View>\n </Tappable>\n );\n }\n\n updateDefaultQueryModel() {\n if (this.state.dataItems && this.state.dataItems.length && this.isDefaultValue) {\n const selectedItem = find(this.state.dataItems, (item) => item.selected);\n selectedItem && this.updateState({\n props: {\n displayValue: selectedItem.displayexp || selectedItem.displayfield || ''\n }\n } as WmSelectState);\n }\n }\n\n componentDidMount() {\n super.componentDidMount();\n this.updateDefaultQueryModel();\n }\n\n onDataItemsUpdate() {\n super.onDataItemsUpdate();\n this.updateDefaultQueryModel();\n }\n\n renderWidget(props: WmSelectProps) {\n return (\n <View>\n {this.renderSelect()}\n {this.state.isOpened ? (\n <ModalConsumer>\n {(modalService: ModalService) => {\n const items = this.state.dataItems;\n modalService.showModal(\n this.prepareModalOptions(\n <ScrollView style={{width: '100%', maxHeight: ThemeVariables.INSTANCE.maxModalHeight}} contentContainerStyle={this.styles.dropDownContent}>\n {props.placeholder ?\n <View key={props.name + '_placeholder'} style={this.styles.placeholderText}>\n {this.renderSelectItem({}, true, false)}\n </View>\n : null}\n {items && items.map((item: any, index: number) => (\n <View key={item.key}>\n {this.renderSelectItem(item, false, index === items.length - 1)}\n </View>\n ))}\n </ScrollView>,\n this.styles,\n modalService\n )\n );\n return null;\n }}\n </ModalConsumer>\n ) : null}\n </View>\n );\n }\n}\n"],"mappings":"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"}
|
|
@@ -25,7 +25,7 @@ BASE_THEME.registerStyle((themeVariables, addStyle) => {
|
|
|
25
25
|
color: themeVariables.inputTextColor
|
|
26
26
|
},
|
|
27
27
|
checkIcon: {
|
|
28
|
-
|
|
28
|
+
text: {
|
|
29
29
|
fontSize: 24,
|
|
30
30
|
color: themeVariables.primaryColor
|
|
31
31
|
}
|
|
@@ -38,12 +38,12 @@ BASE_THEME.registerStyle((themeVariables, addStyle) => {
|
|
|
38
38
|
height: '100%'
|
|
39
39
|
},
|
|
40
40
|
modalContent: {
|
|
41
|
-
backgroundColor: themeVariables.
|
|
41
|
+
backgroundColor: themeVariables.selectDropdownBackgroundColor,
|
|
42
42
|
borderRadius: 6,
|
|
43
43
|
position: 'absolute',
|
|
44
44
|
borderWidth: 1,
|
|
45
45
|
borderStyle: 'solid',
|
|
46
|
-
borderColor: themeVariables.
|
|
46
|
+
borderColor: themeVariables.selectBorderColor,
|
|
47
47
|
width: '90%'
|
|
48
48
|
},
|
|
49
49
|
selectItem: {
|
|
@@ -65,6 +65,8 @@ BASE_THEME.registerStyle((themeVariables, addStyle) => {
|
|
|
65
65
|
color: themeVariables.selectItemTextColor,
|
|
66
66
|
flex: 1
|
|
67
67
|
},
|
|
68
|
+
selectedItem: {},
|
|
69
|
+
selectedItemText: {},
|
|
68
70
|
placeholderText: {
|
|
69
71
|
color: themeVariables.inputPlaceholderColor
|
|
70
72
|
},
|
|
@@ -72,7 +74,6 @@ BASE_THEME.registerStyle((themeVariables, addStyle) => {
|
|
|
72
74
|
arrowButton: {
|
|
73
75
|
root: {
|
|
74
76
|
padding: 0,
|
|
75
|
-
minHeight: 0,
|
|
76
77
|
alignItems: 'center',
|
|
77
78
|
alignSelf: 'center',
|
|
78
79
|
justifyContent: 'center',
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["BASE_THEME","defineStyles","Platform","DEFAULT_CLASS","registerStyle","themeVariables","addStyle","defaultStyles","root","flexDirection","padding","borderWidth","borderStyle","borderColor","inputBorderColor","backgroundColor","inputBackgroundColor","borderRadius","minWidth","alignItems","invalid","borderBottomColor","inputInvalidBorderColor","text","fontSize","fontFamily","baseFont","flex","color","inputTextColor","checkIcon","
|
|
1
|
+
{"version":3,"names":["BASE_THEME","defineStyles","Platform","DEFAULT_CLASS","registerStyle","themeVariables","addStyle","defaultStyles","root","flexDirection","padding","borderWidth","borderStyle","borderColor","inputBorderColor","backgroundColor","inputBackgroundColor","borderRadius","minWidth","alignItems","invalid","borderBottomColor","inputInvalidBorderColor","text","fontSize","fontFamily","baseFont","flex","color","inputTextColor","checkIcon","primaryColor","disabledText","inputDisabledBgColor","modal","height","modalContent","selectDropdownBackgroundColor","position","selectBorderColor","width","selectItem","paddingHorizontal","paddingVertical","borderBottomWidth","borderBottomStyle","selecttemBorderColor","lastSelectItem","selectItemText","selectItemTextColor","selectedItem","selectedItemText","placeholderText","inputPlaceholderColor","dropDownContent","arrowButton","alignSelf","justifyContent","OS","textAlign"],"sources":["select.styles.ts"],"sourcesContent":["import BASE_THEME, {AllStyle} from '@wavemaker/app-rn-runtime/styles/theme';\nimport { BaseStyles, defineStyles } from '@wavemaker/app-rn-runtime/core/base.component';\nimport { WmButtonStyles } from '@wavemaker/app-rn-runtime/components/basic/button/button.styles';\nimport { Platform } from 'react-native';\nimport { WmIconStyles } from '@wavemaker/app-rn-runtime/components/basic/icon/icon.styles';\n\nexport type WmSelectStyles = BaseStyles & {\n arrowButton: WmButtonStyles;\n modal: AllStyle;\n modalContent: AllStyle;\n checkIcon: WmIconStyles;\n selectItem: AllStyle;\n lastSelectItem: AllStyle,\n selectItemText: AllStyle;\n selectedItem: AllStyle;\n selectedItemText: AllStyle;\n dropDownContent: AllStyle;\n disabledText: AllStyle;\n placeholderText: AllStyle;\n invalid: AllStyle;\n};\n\nexport const DEFAULT_CLASS = 'app-select';\nBASE_THEME.registerStyle((themeVariables, addStyle) => {\n const defaultStyles: WmSelectStyles = defineStyles({\n root: {\n flexDirection: 'row',\n padding: 12,\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: themeVariables.inputBorderColor,\n backgroundColor: themeVariables.inputBackgroundColor,\n borderRadius: 6,\n minWidth: 160,\n alignItems: 'center'\n },\n invalid: {\n borderBottomColor: themeVariables.inputInvalidBorderColor\n },\n text: {\n fontSize: 16,\n fontFamily: themeVariables.baseFont,\n flex: 1,\n color: themeVariables.inputTextColor\n },\n checkIcon: {\n text: {\n fontSize: 24,\n color: themeVariables.primaryColor\n }\n } as WmIconStyles,\n disabledText: {\n backgroundColor : themeVariables.inputDisabledBgColor\n },\n modal: {\n backgroundColor: 'rgba(0, 0, 0, 0.3)',\n height: '100%'\n },\n modalContent: {\n backgroundColor: themeVariables.selectDropdownBackgroundColor,\n borderRadius: 6,\n position: 'absolute',\n borderWidth: 1,\n borderStyle: 'solid',\n borderColor: themeVariables.selectBorderColor,\n width: '90%'\n },\n selectItem: {\n width: '100%',\n paddingHorizontal: 16,\n paddingVertical: 8,\n borderBottomWidth: 1,\n borderBottomStyle: 'solid',\n borderBottomColor: themeVariables.selecttemBorderColor,\n flexDirection: 'row',\n alignItems: 'center'\n },\n lastSelectItem: {\n borderBottomWidth: 0\n },\n selectItemText: {\n fontSize: 16,\n fontFamily: themeVariables.baseFont,\n color: themeVariables.selectItemTextColor,\n flex: 1\n },\n selectedItem: {},\n selectedItemText:{},\n placeholderText: {\n color: themeVariables.inputPlaceholderColor\n },\n dropDownContent: {},\n arrowButton: {\n root: {\n padding: 0,\n alignItems: 'center',\n alignSelf: 'center',\n justifyContent: 'center',\n backgroundColor: 'transparent'\n }\n } as WmButtonStyles,\n });\n\n addStyle(DEFAULT_CLASS, '', defaultStyles);\n addStyle(DEFAULT_CLASS + '-disabled', '', {\n root : {\n backgroundColor: themeVariables.inputDisabledBgColor\n }\n });\n addStyle(DEFAULT_CLASS + '-rtl', '', Platform.OS==\"web\"?{\n text:{\n textAlign:'right',\n }\n }:{\n text:{\n textAlign:'left',\n }\n });\n});\n"],"mappings":"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"}
|
|
@@ -1,28 +1,18 @@
|
|
|
1
|
-
function _extends() { _extends = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends.apply(this, arguments); }
|
|
2
1
|
function _defineProperty(obj, key, value) { key = _toPropertyKey(key); if (key in obj) { Object.defineProperty(obj, key, { value: value, enumerable: true, configurable: true, writable: true }); } else { obj[key] = value; } return obj; }
|
|
3
2
|
function _toPropertyKey(arg) { var key = _toPrimitive(arg, "string"); return typeof key === "symbol" ? key : String(key); }
|
|
4
3
|
function _toPrimitive(input, hint) { if (typeof input !== "object" || input === null) return input; var prim = input[Symbol.toPrimitive]; if (prim !== undefined) { var res = prim.call(input, hint || "default"); if (typeof res !== "object") return res; throw new TypeError("@@toPrimitive must return a primitive value."); } return (hint === "string" ? String : Number)(input); }
|
|
5
4
|
import React from 'react';
|
|
6
|
-
import { View, Text,
|
|
5
|
+
import { View, Text, Platform } from 'react-native';
|
|
7
6
|
import { debounce, isNumber, isNil } from 'lodash';
|
|
8
|
-
import
|
|
7
|
+
import Slider from '@react-native-community/slider';
|
|
9
8
|
import { BaseComponent, BaseComponentState } from '@wavemaker/app-rn-runtime/core/base.component';
|
|
10
9
|
import WmSliderProps from './slider.props';
|
|
11
10
|
import { DEFAULT_CLASS } from './slider.styles';
|
|
12
|
-
|
|
13
|
-
export class WmSliderState extends BaseComponentState {
|
|
14
|
-
constructor() {
|
|
15
|
-
super(...arguments);
|
|
16
|
-
_defineProperty(this, "track", void 0);
|
|
17
|
-
}
|
|
18
|
-
}
|
|
11
|
+
export class WmSliderState extends BaseComponentState {}
|
|
19
12
|
export default class WmSlider extends BaseComponent {
|
|
20
13
|
constructor(props) {
|
|
21
14
|
super(props, DEFAULT_CLASS, new WmSliderProps());
|
|
22
15
|
_defineProperty(this, "valueBeforeSlide", 0);
|
|
23
|
-
_defineProperty(this, "position", new Animated.Value(0));
|
|
24
|
-
_defineProperty(this, "trackGesture", Gesture.Pan());
|
|
25
|
-
_defineProperty(this, "knobGesture", Gesture.Pan());
|
|
26
16
|
_defineProperty(this, "onChange", debounce(value => {
|
|
27
17
|
if (this.state.props.datavalue !== value) {
|
|
28
18
|
this.updateState({
|
|
@@ -33,42 +23,8 @@ export default class WmSlider extends BaseComponent {
|
|
|
33
23
|
this.props.onFieldChange && this.props.onFieldChange('datavalue', value, this.state.props.datavalue);
|
|
34
24
|
}
|
|
35
25
|
}, 200));
|
|
36
|
-
_defineProperty(this, "
|
|
37
|
-
|
|
38
|
-
this.updateState({
|
|
39
|
-
track: {
|
|
40
|
-
top: isWebPreviewMode() ? layout.top : layout.y,
|
|
41
|
-
left: isWebPreviewMode() ? layout.left : layout.x,
|
|
42
|
-
width: layout.width,
|
|
43
|
-
height: layout.height
|
|
44
|
-
}
|
|
45
|
-
}, () => this.computePosition(this.state.props.datavalue));
|
|
46
|
-
});
|
|
47
|
-
this.configureGesture(this.trackGesture);
|
|
48
|
-
this.configureGesture(this.knobGesture);
|
|
49
|
-
}
|
|
50
|
-
getValueFromGesture(positionX) {
|
|
51
|
-
if (this.state.track) {
|
|
52
|
-
const factor = (positionX - this.state.track.left) / this.state.track.width;
|
|
53
|
-
const props = this.state.props;
|
|
54
|
-
const step = props.step || (props.maxvalue - props.minvalue) / 100;
|
|
55
|
-
let value = Math.round((factor * props.maxvalue + props.minvalue) / step) * step;
|
|
56
|
-
return Math.max(Math.min(props.maxvalue, value), props.minvalue);
|
|
57
|
-
}
|
|
58
|
-
return 0;
|
|
59
|
-
}
|
|
60
|
-
configureGesture(gesture) {
|
|
61
|
-
gesture.maxPointers(1).minDistance(0).onChange(e => {
|
|
62
|
-
const value = this.getValueFromGesture(e.absoluteX);
|
|
63
|
-
this.computePosition(value);
|
|
64
|
-
this.forceUpdate();
|
|
65
|
-
}).onEnd(e => {
|
|
66
|
-
if (this.state.track) {
|
|
67
|
-
const value = this.getValueFromGesture(e.absoluteX);
|
|
68
|
-
this.onChange(value);
|
|
69
|
-
this.forceUpdate();
|
|
70
|
-
}
|
|
71
|
-
});
|
|
26
|
+
_defineProperty(this, "onBeforeSlide", () => this.valueBeforeSlide = this.props.datavalue);
|
|
27
|
+
_defineProperty(this, "onAfterSlide", () => this.valueBeforeSlide = 0);
|
|
72
28
|
}
|
|
73
29
|
getDataValue() {
|
|
74
30
|
if (isNil(this.props.datavalue)) {
|
|
@@ -85,19 +41,9 @@ export default class WmSlider extends BaseComponent {
|
|
|
85
41
|
case 'maxvalue':
|
|
86
42
|
case 'minvalue':
|
|
87
43
|
this.setProp('datavalue', this.getDataValue() || 0);
|
|
88
|
-
this.computePosition(this.state.props.datavalue);
|
|
89
44
|
}
|
|
90
45
|
}
|
|
91
|
-
computePosition(datavalue) {
|
|
92
|
-
var _this$state$track, _this$position;
|
|
93
|
-
const props = this.state.props;
|
|
94
|
-
const width = ((_this$state$track = this.state.track) === null || _this$state$track === void 0 ? void 0 : _this$state$track.width) || 0;
|
|
95
|
-
const value = (datavalue - props.minvalue) / props.maxvalue * width;
|
|
96
|
-
(_this$position = this.position) === null || _this$position === void 0 ? void 0 : _this$position.setValue(isNaN(value) ? 0 : value);
|
|
97
|
-
}
|
|
98
46
|
renderWidget(props) {
|
|
99
|
-
var _this$state$track2;
|
|
100
|
-
const width = ((_this$state$track2 = this.state.track) === null || _this$state$track2 === void 0 ? void 0 : _this$state$track2.width) || 0;
|
|
101
47
|
return /*#__PURE__*/React.createElement(View, {
|
|
102
48
|
style: this.styles.root
|
|
103
49
|
}, this._background, /*#__PURE__*/React.createElement(View, {
|
|
@@ -105,44 +51,27 @@ export default class WmSlider extends BaseComponent {
|
|
|
105
51
|
flexDirection: 'row',
|
|
106
52
|
justifyContent: 'space-between'
|
|
107
53
|
}
|
|
108
|
-
}, /*#__PURE__*/React.createElement(Text,
|
|
54
|
+
}, /*#__PURE__*/React.createElement(Text, {
|
|
109
55
|
style: [this.styles.text, this.styles.minimumValue]
|
|
110
|
-
}
|
|
56
|
+
}, props.minvalue), /*#__PURE__*/React.createElement(Text, {
|
|
111
57
|
style: [this.styles.text, this.styles.value]
|
|
112
|
-
}
|
|
58
|
+
}, props.datavalue), /*#__PURE__*/React.createElement(Text, {
|
|
113
59
|
style: [this.styles.text, this.styles.maximumValue]
|
|
114
|
-
}
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
}]
|
|
130
|
-
}), /*#__PURE__*/React.createElement(Animated.View, {
|
|
131
|
-
style: [this.styles.maximumTrack, {
|
|
132
|
-
width: width,
|
|
133
|
-
transform: [{
|
|
134
|
-
translateX: this.position
|
|
135
|
-
}]
|
|
136
|
-
}]
|
|
137
|
-
}))), /*#__PURE__*/React.createElement(GestureDetector, {
|
|
138
|
-
gesture: this.knobGesture
|
|
139
|
-
}, /*#__PURE__*/React.createElement(Animated.View, {
|
|
140
|
-
style: [this.styles.thumb, {
|
|
141
|
-
transform: [{
|
|
142
|
-
translateX: this.position
|
|
143
|
-
}]
|
|
144
|
-
}]
|
|
145
|
-
})));
|
|
60
|
+
}, props.maxvalue)), /*#__PURE__*/React.createElement(Slider, {
|
|
61
|
+
style: props.readonly || props.disabled ? this.styles.disabled : {},
|
|
62
|
+
step: props.step,
|
|
63
|
+
value: this.valueBeforeSlide || props.datavalue || 0,
|
|
64
|
+
disabled: props.readonly,
|
|
65
|
+
minimumValue: props.minvalue,
|
|
66
|
+
inverted: this.isRTL && (Platform.OS == "android" || Platform.OS == "web"),
|
|
67
|
+
maximumValue: props.maxvalue,
|
|
68
|
+
onValueChange: this.onChange,
|
|
69
|
+
thumbTintColor: this.styles.thumb.backgroundColor,
|
|
70
|
+
onTouchStart: this.onBeforeSlide,
|
|
71
|
+
onTouchEnd: this.onAfterSlide,
|
|
72
|
+
minimumTrackTintColor: this.styles.minimumTrack.backgroundColor,
|
|
73
|
+
maximumTrackTintColor: this.styles.maximumTrack.backgroundColor
|
|
74
|
+
}));
|
|
146
75
|
}
|
|
147
76
|
}
|
|
148
77
|
//# sourceMappingURL=slider.component.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["React","View","Text","TouchableOpacity","Animated","debounce","isNumber","isNil","Gesture","GestureDetector","BaseComponent","BaseComponentState","WmSliderProps","DEFAULT_CLASS","isWebPreviewMode","WmSliderState","constructor","arguments","_defineProperty","WmSlider","props","Value","Pan","value","state","datavalue","updateState","onFieldChange","e","layout","nativeEvent","track","top","y","left","x","width","height","computePosition","configureGesture","trackGesture","knobGesture","getValueFromGesture","positionX","factor","step","maxvalue","minvalue","Math","round","max","min","gesture","maxPointers","minDistance","onChange","absoluteX","forceUpdate","onEnd","getDataValue","onPropertyChange","name","$new","$old","invokeEventCallback","setProp","_this$state$track","_this$position","position","setValue","isNaN","renderWidget","_this$state$track2","createElement","style","styles","root","_background","flexDirection","justifyContent","_extends","getTestProps","text","minimumValue","maximumValue","activeOpacity","onLayout","onLayoutChange","minimumTrack","transform","translateX","interpolate","inputRange","outputRange","maximumTrack","thumb"],"sources":["slider.component.tsx"],"sourcesContent":["import React from 'react';\nimport { View, Text, LayoutChangeEvent, TouchableOpacity, Animated, Easing } from 'react-native';\nimport { debounce, isNumber, isNil } from 'lodash';\nimport { Gesture, GestureDetector, PanGesture } from 'react-native-gesture-handler';\nimport { BaseComponent, BaseComponentState } from '@wavemaker/app-rn-runtime/core/base.component';\n\nimport WmSliderProps from './slider.props';\nimport { DEFAULT_CLASS, WmSliderStyles } from './slider.styles';\nimport { isWebPreviewMode } from '@wavemaker/app-rn-runtime/core/utils';\n\nexport class WmSliderState extends BaseComponentState<WmSliderProps> {\n track?: {\n top: number,\n left: number,\n width: number,\n height: number\n };\n}\n\nexport default class WmSlider extends BaseComponent<WmSliderProps, WmSliderState, WmSliderStyles> {\n valueBeforeSlide: number = 0;\n private position = new Animated.Value(0);\n private trackGesture = Gesture.Pan();\n private knobGesture = Gesture.Pan();\n\n constructor(props: WmSliderProps) {\n super(props, DEFAULT_CLASS, new WmSliderProps());\n this.configureGesture(this.trackGesture);\n this.configureGesture(this.knobGesture);\n }\n\n getValueFromGesture(positionX: number) {\n if (this.state.track) {\n const factor = (positionX - this.state.track.left) / this.state.track.width;\n const props = this.state.props;\n const step = props.step || (props.maxvalue - props.minvalue) / 100;\n let value = Math.round((factor * props.maxvalue + props.minvalue) / step) * step;\n return Math.max(Math.min(props.maxvalue, value), props.minvalue);\n }\n return 0;\n };\n\n configureGesture(gesture: PanGesture) {\n gesture\n .maxPointers(1)\n .minDistance(0)\n .onChange(e => {\n const value = this.getValueFromGesture(e.absoluteX);\n this.computePosition(value);\n this.forceUpdate();\n })\n .onEnd(e => {\n if (this.state.track) {\n const value = this.getValueFromGesture(e.absoluteX);\n this.onChange(value);\n this.forceUpdate();\n }\n })\n }\n\n getDataValue() {\n if (isNil(this.props.datavalue)) {\n return this.state.props.minvalue + (this.state.props.maxvalue - this.state.props.minvalue)/2;\n }\n return Math.min(Math.max(this.props.datavalue, this.state.props.minvalue), this.state.props.maxvalue);\n }\n\n onPropertyChange(name: string, $new: any, $old: any) {\n switch(name) {\n case 'datavalue':\n if (isNumber($new) && isNumber($old)) {\n this.invokeEventCallback('onChange', [null, this, $new, $old]);\n }\n case 'maxvalue':\n case 'minvalue': \n this.setProp('datavalue', this.getDataValue() || 0)\n this.computePosition(this.state.props.datavalue);\n }\n }\n\n onChange = debounce((value: number) => {\n if (this.state.props.datavalue !== value) {\n this.updateState({\n props : {\n datavalue: value\n }\n } as WmSliderState);\n this.props.onFieldChange &&\n this.props.onFieldChange(\n 'datavalue',\n value,\n this.state.props.datavalue\n );\n }\n }, 200);\n\n computePosition(datavalue: number) {\n const props = this.state.props;\n const width = this.state.track?.width || 0;\n const value = ((datavalue - props.minvalue) / props.maxvalue) * (width);\n this.position?.setValue(isNaN(value) ? 0 : value);\n }\n\n onLayoutChange = (e: LayoutChangeEvent) => {\n const layout = e.nativeEvent.layout;\n this.updateState({\n track: {\n top: isWebPreviewMode() ? (layout as any).top : layout.y,\n left: isWebPreviewMode() ? (layout as any).left : layout.x,\n width: layout.width,\n height: layout.height\n }\n } as WmSliderState, () => this.computePosition(this.state.props.datavalue));\n }\n\n renderWidget(props: WmSliderProps) {\n const width = this.state.track?.width || 0;\n return (\n <View style={this.styles.root}>\n {this._background}\n <View style={{flexDirection:'row', justifyContent:'space-between'}}>\n <Text {...this.getTestProps('min')} style={[this.styles.text, this.styles.minimumValue]}>{props.minvalue}</Text>\n <Text {...this.getTestProps('value')} style={[this.styles.text, this.styles.value]}>{props.datavalue}</Text>\n <Text {...this.getTestProps('max')} style={[this.styles.text, this.styles.maximumValue]}>{props.maxvalue}</Text>\n </View>\n <GestureDetector gesture={this.trackGesture}>\n <TouchableOpacity\n activeOpacity={1} \n style={this.styles.track}\n onLayout={this.onLayoutChange}\n {...this.getTestProps()}>\n <Animated.View style={[this.styles.minimumTrack, {\n width: width,\n transform: [{\n translateX: this.position.interpolate({\n inputRange: [0, width],\n outputRange: [-width, 0]\n })\n }]\n }]}></Animated.View>\n <Animated.View style={[this.styles.maximumTrack, {\n width: width,\n transform: [{\n translateX: this.position\n }]\n }]}></Animated.View>\n </TouchableOpacity>\n </GestureDetector>\n <GestureDetector gesture={this.knobGesture}>\n <Animated.View style={[this.styles.thumb, {\n transform: [{\n translateX: this.position\n }]\n }]}></Animated.View>\n </GestureDetector>\n </View>);\n }\n}\n"],"mappings":"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"}
|
|
1
|
+
{"version":3,"names":["React","View","Text","Platform","debounce","isNumber","isNil","Slider","BaseComponent","BaseComponentState","WmSliderProps","DEFAULT_CLASS","WmSliderState","WmSlider","constructor","props","_defineProperty","value","state","datavalue","updateState","onFieldChange","valueBeforeSlide","getDataValue","minvalue","maxvalue","Math","min","max","onPropertyChange","name","$new","$old","invokeEventCallback","setProp","renderWidget","createElement","style","styles","root","_background","flexDirection","justifyContent","text","minimumValue","maximumValue","readonly","disabled","step","inverted","isRTL","OS","onValueChange","onChange","thumbTintColor","thumb","backgroundColor","onTouchStart","onBeforeSlide","onTouchEnd","onAfterSlide","minimumTrackTintColor","minimumTrack","maximumTrackTintColor","maximumTrack"],"sources":["slider.component.tsx"],"sourcesContent":["import React from 'react';\nimport {View, Text, Platform } from 'react-native';\nimport { debounce, isNumber, isNil } from 'lodash';\nimport Slider from '@react-native-community/slider';\nimport { BaseComponent, BaseComponentState } from '@wavemaker/app-rn-runtime/core/base.component';\n\nimport WmSliderProps from './slider.props';\nimport { DEFAULT_CLASS, WmSliderStyles } from './slider.styles';\n\nexport class WmSliderState extends BaseComponentState<WmSliderProps> {}\n\nexport default class WmSlider extends BaseComponent<WmSliderProps, WmSliderState, WmSliderStyles> {\n valueBeforeSlide: number = 0;\n\n constructor(props: WmSliderProps) {\n super(props, DEFAULT_CLASS, new WmSliderProps());\n }\n\n getDataValue() {\n if (isNil(this.props.datavalue)) {\n return this.state.props.minvalue + (this.state.props.maxvalue - this.state.props.minvalue)/2;\n }\n return Math.min(Math.max(this.props.datavalue, this.state.props.minvalue), this.state.props.maxvalue);\n }\n\n onPropertyChange(name: string, $new: any, $old: any) {\n switch(name) {\n case 'datavalue':\n if (isNumber($new) && isNumber($old)) {\n this.invokeEventCallback('onChange', [null, this, $new, $old]);\n }\n case 'maxvalue':\n case 'minvalue': \n this.setProp('datavalue', this.getDataValue() || 0)\n }\n }\n\n onChange = debounce((value: number) => {\n if (this.state.props.datavalue !== value) {\n this.updateState({\n props : {\n datavalue: value\n }\n } as WmSliderState);\n this.props.onFieldChange &&\n this.props.onFieldChange(\n 'datavalue',\n value,\n this.state.props.datavalue\n );\n }\n }, 200);\n\n onBeforeSlide = () => this.valueBeforeSlide = this.props.datavalue;\n\n onAfterSlide = () => this.valueBeforeSlide = 0;\n\n renderWidget(props: WmSliderProps) {\n return (\n <View style={this.styles.root}>\n {this._background}\n <View style={{flexDirection:'row', justifyContent:'space-between'}}>\n <Text style={[this.styles.text, this.styles.minimumValue]}>{props.minvalue}</Text>\n <Text style={[this.styles.text, this.styles.value]}>{props.datavalue}</Text>\n <Text style={[this.styles.text, this.styles.maximumValue]}>{props.maxvalue}</Text>\n </View>\n <Slider\n style={props.readonly || props.disabled ? this.styles.disabled : {}}\n step={props.step}\n value={this.valueBeforeSlide || props.datavalue || 0}\n disabled={props.readonly}\n minimumValue={props.minvalue}\n inverted={this.isRTL && (Platform.OS==\"android\"||Platform.OS==\"web\")}\n maximumValue={props.maxvalue}\n onValueChange={this.onChange}\n thumbTintColor={this.styles.thumb.backgroundColor as string}\n onTouchStart={this.onBeforeSlide}\n onTouchEnd={this.onAfterSlide}\n minimumTrackTintColor={this.styles.minimumTrack.backgroundColor as string}\n maximumTrackTintColor={this.styles.maximumTrack.backgroundColor as string}\n />\n </View>);\n }\n}\n"],"mappings":"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"}
|