react-native-paper
Version:
Material design for React Native
211 lines (188 loc) • 7.07 kB
JavaScript
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.default = void 0;
var React = _interopRequireWildcard(require("react"));
var _reactNative = require("react-native");
var _color = _interopRequireDefault(require("color"));
var _IconButton = _interopRequireDefault(require("./IconButton"));
var _Surface = _interopRequireDefault(require("./Surface"));
var _theming = require("../core/theming");
var _MaterialCommunityIcon = _interopRequireDefault(require("./MaterialCommunityIcon"));
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
function _getRequireWildcardCache(nodeInterop) { if (typeof WeakMap !== "function") return null; var cacheBabelInterop = new WeakMap(); var cacheNodeInterop = new WeakMap(); return (_getRequireWildcardCache = function (nodeInterop) { return nodeInterop ? cacheNodeInterop : cacheBabelInterop; })(nodeInterop); }
function _interopRequireWildcard(obj, nodeInterop) { if (!nodeInterop && obj && obj.__esModule) { return obj; } if (obj === null || typeof obj !== "object" && typeof obj !== "function") { return { default: obj }; } var cache = _getRequireWildcardCache(nodeInterop); if (cache && cache.has(obj)) { return cache.get(obj); } var newObj = {}; var hasPropertyDescriptor = Object.defineProperty && Object.getOwnPropertyDescriptor; for (var key in obj) { if (key !== "default" && Object.prototype.hasOwnProperty.call(obj, key)) { var desc = hasPropertyDescriptor ? Object.getOwnPropertyDescriptor(obj, key) : null; if (desc && (desc.get || desc.set)) { Object.defineProperty(newObj, key, desc); } else { newObj[key] = obj[key]; } } } newObj.default = obj; if (cache) { cache.set(obj, newObj); } return newObj; }
function _extends() { _extends = Object.assign || 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); }
/**
* Searchbar is a simple input box where users can type search queries.
*
* <div class="screenshots">
* <img class="medium" src="screenshots/searchbar.png" />
* </div>
*
* ## Usage
* ```js
* import * as React from 'react';
* import { Searchbar } from 'react-native-paper';
*
* const MyComponent = () => {
* const [searchQuery, setSearchQuery] = React.useState('');
*
* const onChangeSearch = query => setSearchQuery(query);
*
* return (
* <Searchbar
* placeholder="Search"
* onChangeText={onChangeSearch}
* value={searchQuery}
* />
* );
* };
*
* export default MyComponent;
* ```
*/
const Searchbar = /*#__PURE__*/React.forwardRef((_ref, ref) => {
let {
clearAccessibilityLabel = 'clear',
clearIcon,
icon,
iconColor: customIconColor,
inputStyle,
onIconPress,
placeholder,
searchAccessibilityLabel = 'search',
style,
theme,
value,
...rest
} = _ref;
const root = React.useRef(null);
React.useImperativeHandle(ref, () => {
const input = root.current;
if (input) {
return {
focus: () => input.focus(),
clear: () => input.clear(),
setNativeProps: args => input.setNativeProps(args),
isFocused: () => input.isFocused(),
blur: () => input.blur()
};
}
const noop = () => {
throw new Error('TextInput is not available');
};
return {
focus: noop,
clear: noop,
setNativeProps: noop,
isFocused: noop,
blur: noop
};
});
const handleClearPress = () => {
var _root$current, _rest$onChangeText;
(_root$current = root.current) === null || _root$current === void 0 ? void 0 : _root$current.clear();
(_rest$onChangeText = rest.onChangeText) === null || _rest$onChangeText === void 0 ? void 0 : _rest$onChangeText.call(rest, '');
};
const {
colors,
roundness,
dark,
fonts
} = theme;
const textColor = colors.text;
const font = fonts.regular;
const iconColor = customIconColor || (dark ? textColor : (0, _color.default)(textColor).alpha(0.54).rgb().string());
const rippleColor = (0, _color.default)(textColor).alpha(0.32).rgb().string();
return /*#__PURE__*/React.createElement(_Surface.default, {
style: [{
borderRadius: roundness,
elevation: 4
}, styles.container, style]
}, /*#__PURE__*/React.createElement(_IconButton.default // @ts-expect-error We keep old a11y props for backwards compat with old RN versions
, {
accessibilityTraits: "button",
accessibilityComponentType: "button",
accessibilityRole: "button",
borderless: true,
rippleColor: rippleColor,
onPress: onIconPress,
color: iconColor,
icon: icon || (_ref2 => {
let {
size,
color
} = _ref2;
return /*#__PURE__*/React.createElement(_MaterialCommunityIcon.default, {
name: "magnify",
color: color,
size: size,
direction: _reactNative.I18nManager.isRTL ? 'rtl' : 'ltr'
});
}),
accessibilityLabel: searchAccessibilityLabel
}), /*#__PURE__*/React.createElement(_reactNative.TextInput, _extends({
style: [styles.input, {
color: textColor,
...font,
..._reactNative.Platform.select({
web: {
outline: 'none'
}
})
}, inputStyle],
placeholder: placeholder || '',
placeholderTextColor: colors.placeholder,
selectionColor: colors.primary,
underlineColorAndroid: "transparent",
returnKeyType: "search",
keyboardAppearance: dark ? 'dark' : 'light' // @ts-expect-error We keep old a11y props for backwards compat with old RN versions
,
accessibilityTraits: "search",
accessibilityRole: "search",
ref: root,
value: value
}, rest)), /*#__PURE__*/React.createElement(_IconButton.default, {
borderless: true,
disabled: !value,
accessibilityLabel: clearAccessibilityLabel,
color: value ? iconColor : 'rgba(255, 255, 255, 0)',
rippleColor: rippleColor,
onPress: handleClearPress,
icon: clearIcon || (_ref3 => {
let {
size,
color
} = _ref3;
return /*#__PURE__*/React.createElement(_MaterialCommunityIcon.default, {
name: "close",
color: color,
size: size,
direction: _reactNative.I18nManager.isRTL ? 'rtl' : 'ltr'
});
}) // @ts-expect-error We keep old a11y props for backwards compat with old RN versions
,
accessibilityTraits: "button",
accessibilityComponentType: "button",
accessibilityRole: "button"
}));
});
const styles = _reactNative.StyleSheet.create({
container: {
flexDirection: 'row',
alignItems: 'center'
},
input: {
flex: 1,
fontSize: 18,
paddingLeft: 8,
alignSelf: 'stretch',
textAlign: _reactNative.I18nManager.isRTL ? 'right' : 'left',
minWidth: 0
}
});
var _default = (0, _theming.withTheme)(Searchbar);
exports.default = _default;
//# sourceMappingURL=Searchbar.js.map